verben-ng-ui 0.7.2 → 0.7.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -315,7 +315,9 @@ export class DropDownComponent {
315
315
  item.isLoading = true;
316
316
  var result = await item.loadMore(item.loadTimes);
317
317
  item.isLoading = false;
318
- item.loadTimes.increaseLoadTime();
318
+ if (result.length > 0) {
319
+ item.loadTimes.increaseLoadTime();
320
+ }
319
321
  item.items = this.convertToExpandable(result);
320
322
  if (this.filter) {
321
323
  item.copy = cloneDeep(item.items);
@@ -358,7 +360,9 @@ export class DropDownComponent {
358
360
  ? await item.search(searchContext, item.loadTimes)
359
361
  : await item.loadMore(item.loadTimes);
360
362
  item.isLoading = false;
361
- item.loadTimes.increaseLoadTime();
363
+ if (result.length > 0) {
364
+ item.loadTimes.increaseLoadTime();
365
+ }
362
366
  const converted = this.convertToExpandable(result);
363
367
  for (let res of converted) {
364
368
  item.items.push(res);
@@ -392,7 +396,9 @@ export class DropDownComponent {
392
396
  if (this.group) {
393
397
  result = this.convertToExpandable(result);
394
398
  }
395
- this.loadTimes.increaseLoadTime();
399
+ if (result.length > 0) {
400
+ this.loadTimes.increaseLoadTime();
401
+ }
396
402
  for (let item of result) {
397
403
  this.options.push(item);
398
404
  }
@@ -565,7 +571,8 @@ export class DropDownComponent {
565
571
  : isEqual(this.getValue(option), obj);
566
572
  if (equalityCheck) {
567
573
  this.selectedOption = this.getValue(option);
568
- this.selectedOptionLabel = this.getOptionLabel(option);
574
+ this.selectedOptionLabel = this.asyncLabel
575
+ ? await this.asyncLabel(option) : this.getOptionLabel(option);
569
576
  break;
570
577
  }
571
578
  }
@@ -596,7 +603,8 @@ export class DropDownComponent {
596
603
  : isEqual(this.getValue(option), object);
597
604
  if (equalityCheck) {
598
605
  this.selectedOptions.push(this.getValue(option));
599
- this.selectedOptionLabels.push(this.getOptionLabel(option));
606
+ this.selectedOptionLabels.push(this.asyncLabel
607
+ ? await this.asyncLabel(object) : this.getOptionLabel(option));
600
608
  break;
601
609
  }
602
610
  }
@@ -773,4 +781,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
773
781
  type: HostListener,
774
782
  args: ['document:click', ['$event']]
775
783
  }] } });
776
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-down.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/drop-down/drop-down.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/drop-down/drop-down.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  Self,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { DropdownMenuItem } from './DropdownMenuItem';\nimport { DropdownLoadEvent } from './DropdownLoadEvent';\nimport { TemplateDirective } from '../TemplateDirective.directive';\nimport { DropdownChangeEvent } from './DropdownChangeEvent';\nimport { DropDownItemComponent } from './drop-down-item/drop-down-item.component';\nimport { isEqual, cloneDeep } from 'lodash';\nimport { debounceTime, Subject } from 'rxjs';\nimport { SharedModule } from '../shared.module';\nimport { SvgModule } from '../svg/svg.module';\nimport { TooltipModule } from '../tooltip/tooltip.module';\n\nexport interface DropdownMenuItemWrapper extends DropdownMenuItem {\n  expanded: boolean;\n  items?: DropdownMenuItemWrapper[];\n  isLoading: boolean;\n  copy: DropdownMenuItemWrapper[];\n  loadTimes?: DropdownLoadEvent;\n  loadTimesCopy?: DropdownLoadEvent;\n}\n\n@Component({\n  selector: 'verben-drop-down',\n  standalone: true,\n  imports: [\n    CommonModule,\n    DropDownItemComponent,\n    SharedModule,\n    FormsModule,\n    SvgModule,\n    TooltipModule,\n  ],\n  templateUrl: './drop-down.component.html',\n  styleUrl: './drop-down.component.css',\n})\nexport class DropDownComponent\n  implements ControlValueAccessor, OnInit, AfterContentInit\n{\n  // INTERNAL\n  private _options: any[] = []; // Internal variable for options\n\n  // INPUTS\n  @Input()\n  set options(value: any[]) {\n    if (this.group) {\n      if (this.isDropdownMenuItemWrapperArray(value)) {\n        this._options = value;\n      } else {\n        this._options = this.convertToExpandable(value); // Set the internal options variable\n      }\n    } else {\n      this._options = value;\n    }\n  }\n\n  get options(): any[] {\n    return this._options; // Return the internal options variable\n  }\n\n  @Input() width: string = '12rem';\n  @Input() showHorizontalLine: boolean = true;\n  @Input() horizontalLineColor: string = 'rgba(255, 230, 129, 1)';\n  @Input() optionLabel?: string;\n  @Input() optionSubLabel?: string;\n  @Input() optionValue?: string;\n  @Input() placeholder?: string;\n  @Input() invalidMessage?: string;\n  @Input() errorPosition: string = '';\n  @Input() loadMoreCaption: string = 'See more';\n  @Input() display: 'default' | 'chip' = 'chip';\n  @Input() showClear: boolean = false;\n  @Input() lazyLoad: boolean = false;\n  @Input() selectKey: string | null = null;\n  @Input() styleClass: string = '';\n  @Input() group: boolean = false;\n  @Input() multiselect: boolean = false;\n  @Input() filter: boolean = false;\n  @Input() avoidDuplication: boolean = false;\n  @Input() filterBy?: string;\n  @Input() debounceTime: number = 500;\n  @Input() minChar: number = 0;\n  @Input() disabled: boolean = false;\n  @Input() required: boolean = false;\n  @Input() load?: (context: DropdownLoadEvent) => Promise<any[]>;\n  @Input() asyncLabel?: (context: any) => Promise<string | null>;\n  @Input() search?: (data: any, context: DropdownLoadEvent) => Promise<any[]>;\n\n  // OUTPUTS\n  @Output() optionsChange: EventEmitter<any[]> = new EventEmitter();\n  @Output() onChange: EventEmitter<DropdownChangeEvent> = new EventEmitter();\n  @Output() onClick: EventEmitter<Event> = new EventEmitter();\n  @Output() onClear: EventEmitter<Event> = new EventEmitter();\n\n  onItemChange: (value: any) => void = () => {};\n  onTouched: () => void = () => {};\n  isInvalid: boolean = false;\n\n  //TEMPLATING\n  @ViewChild('dropdownContainer', { static: true })\n  dropdownContainer!: ElementRef;\n  @ViewChild('dropdownExpansion', { static: false })\n  dropdownExpansion!: ElementRef;\n  @ContentChildren(TemplateDirective) templates!: QueryList<TemplateDirective>;\n\n  @HostBinding('class.focused') isFocused = false;\n  isInputFocused = false;\n\n  selectedItemTemplate: TemplateRef<any> | null = null;\n  itemTemplate: TemplateRef<any> | null = null; // Allow null for custom item template\n  groupTemplate: TemplateRef<any> | null = null;\n\n  //VARIABLES\n  isExpanded: boolean = false;\n  loadTimes: DropdownLoadEvent = new DropdownLoadEvent();\n  initialIncrement: boolean = false;\n  selectedOption: any;\n  selectedOptions: any[] = [];\n  selectedOptionLabel: any;\n  selectedOptionLabels: any[] = [];\n  isLoading: boolean = false;\n  optionsCopy: any[] = [];\n  loadTimesCopy: DropdownLoadEvent = new DropdownLoadEvent();\n  selectedContexts: any[] = [];\n  searchHistory: string[] = [];\n  searchTerm$ = new Subject<string>();\n  searchContext: string = '';\n  allowSelectAll: boolean = false;\n  selectedAll: boolean = false;\n\n  constructor(@Optional() @Self() private ngControl: NgControl) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this; // Assign this component as the value accessor\n      this.ngControl?.statusChanges?.subscribe((status) => {\n        this.isInvalid = this.ngControl.touched\n          ? status === 'INVALID' && this.ngControl.touched\n          : false;\n      });\n    }\n  }\n  ngOnInit(): void {\n    if (this.multiselect) {\n      if (!this.lazyLoad) {\n        if (!this.group) {\n          this.allowSelectAll = true;\n        } else {\n          let isAllowed = true;\n          for (let item of this.options) {\n            if (item.lazyLoad) {\n              isAllowed = false;\n              break;\n            }\n          }\n          this.allowSelectAll = isAllowed;\n        }\n      }\n    }\n    if (this.filter) {\n      this.optionsCopy = cloneDeep(this._options);\n      this.searchTerm$\n        .pipe(debounceTime(this.debounceTime)) // Adjust debounce time here (in ms)\n        .subscribe(async (searchTerm) => {\n          if (searchTerm.length < this.minChar) {\n            return;\n          }\n          if (this.selectedContexts.length > 0) {\n            const item = this.selectedContexts[\n              this.selectedContexts.length - 1\n            ] as DropdownMenuItemWrapper;\n            if (item.search && item.loadTimes) {\n              item.loadTimes.reset();\n              item.isLoading = true;\n              const result = await item.search(searchTerm, item.loadTimes);\n              item.isLoading = false;\n              if (this.searchContext.length > 0) {\n                item.loadTimes.increaseLoadTime();\n                item.items = this.convertToExpandable(result);\n                this.group\n                  ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n                  : this.optionsChange.emit(this.options);\n              }\n            }\n          } else {\n            if (this.search && this.loadTimes) {\n              this.isLoading = true;\n              this.loadTimes.reset();\n              const result = await this.search(searchTerm, this.loadTimes);\n              this.isLoading = false;\n              if (this.searchContext.length > 0) {\n                this.options = this.convertToExpandable(result);\n                this.group\n                  ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n                  : this.optionsChange.emit(this.options);\n              }\n            }\n          }\n        });\n    }\n  }\n  ngAfterContentInit(): void {\n    this.templates.forEach((templateDirective) => {\n      if (templateDirective.vTemplate === 'selected') {\n        this.selectedItemTemplate = templateDirective.template;\n      }\n      if (templateDirective.vTemplate === 'item') {\n        this.itemTemplate = templateDirective.template;\n      }\n      if (templateDirective.vTemplate === 'group') {\n        this.groupTemplate = templateDirective.template;\n      }\n    });\n  }\n\n  @HostListener('focus') onFocus() {\n    this.isFocused = true;\n  }\n\n  @HostListener('blur') onBlur() {\n    this.isFocused = false;\n  }\n\n  onSearchFocus() {\n    this.isInputFocused = true;\n  }\n\n  onSearchBlur() {\n    this.isInputFocused = false;\n  }\n\n  onInputFocus() {\n    this.isInputFocused = true;\n  }\n\n  onInputBlur() {\n    this.isInputFocused = false;\n  }\n\n  onSearch(event: any) {\n    if (this.disabled) {\n      return;\n    }\n    const searchTerm = event.target.value;\n    if (this.selectedContexts.length > 0) {\n      const item = this.selectedContexts[\n        this.selectedContexts.length - 1\n      ] as DropdownMenuItemWrapper;\n      if (searchTerm.trim().length == 0) {\n        item.items = cloneDeep(item.copy);\n        item.loadTimes = cloneDeep(item.loadTimesCopy);\n        this.group\n          ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n          : this.optionsChange.emit(this.options);\n        return;\n      }\n      if (item.lazyLoad) {\n        this.searchTerm$.next(searchTerm);\n      } else {\n        if (item.filterBy) {\n          if (!item.items) {\n            return;\n          }\n          item.items = item.items.filter(\n            (x) =>\n              typeof x.value[item.filterBy!] == 'string' &&\n              new RegExp(searchTerm, 'i').test(x.value[item.filterBy!])\n          );\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        } else {\n          if (!item.items) {\n            return;\n          }\n          item.items = item.copy.filter(\n            (x) =>\n              typeof x.value == 'string' &&\n              new RegExp(searchTerm, 'i').test(x.value)\n          );\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        }\n      }\n    } else {\n      if (searchTerm.trim().length == 0) {\n        this.options = cloneDeep(this.optionsCopy);\n        this.loadTimes = cloneDeep(this.loadTimesCopy);\n        this.group\n          ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n          : this.optionsChange.emit(this.options);\n        return;\n      }\n      if (this.lazyLoad) {\n        this.searchTerm$.next(searchTerm);\n      } else {\n        if (this.filterBy) {\n          this.options = this.optionsCopy.filter(\n            (x) =>\n              typeof x[this.filterBy!] == 'string' &&\n              new RegExp(searchTerm, 'i').test(x[this.filterBy!])\n          );\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        } else {\n          this.options = this.optionsCopy.filter(\n            (x) => typeof x == 'string' && new RegExp(searchTerm, 'i').test(x)\n          );\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        }\n      }\n    }\n  }\n\n  onDropdownClick(event: Event) {\n    if (this.disabled) {\n      return;\n    }\n    this.toggleDropdown();\n    this.onClick.emit(event);\n  }\n\n  toggleDropdown() {\n    this.isExpanded = !this.isExpanded;\n  }\n\n  hasSibling(siblings: DropdownMenuItemWrapper[]): number | null {\n    for (let i = 0; i < siblings.length; i++) {\n      const index = this.selectedContexts.indexOf(siblings[i]);\n      if (index > -1) {\n        return index;\n      }\n    }\n    return null;\n  }\n\n  async expandMenu(\n    item: DropdownMenuItemWrapper,\n    siblings: DropdownMenuItemWrapper[]\n  ) {\n    if (item.items) {\n      if (this.filter) {\n        for (let it of siblings.filter((x) => x !== item)) {\n          if (it.expanded) {\n            it.expanded = false;\n            it.loadTimes && it.loadTimes.reset();\n          }\n        }\n      }\n      item.expanded = !item.expanded;\n      if (item.expanded) {\n        if (this.filter) {\n          const siblingCheck = this.hasSibling(siblings);\n          if (this.selectedContexts.length > 0 && siblingCheck !== null) {\n            const contextsLength = this.selectedContexts.length;\n            this.selectedContexts.splice(\n              siblingCheck,\n              contextsLength - siblingCheck\n            );\n          }\n          this.selectedContexts.push(item);\n          if (siblingCheck == null) {\n            this.searchHistory.push(this.searchContext);\n          }\n          this.searchContext = '';\n        }\n        if (item.lazyLoad && item.loadMore && item.loadTimes) {\n          item.isLoading = true;\n          var result = await item.loadMore(item.loadTimes);\n          item.isLoading = false;\n          item.loadTimes.increaseLoadTime();\n          item.items = this.convertToExpandable(result);\n          if (this.filter) {\n            item.copy = cloneDeep(item.items);\n            item.loadTimesCopy = cloneDeep(item.loadTimes);\n          }\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        }\n      } else {\n        if (this.filter) {\n          const index = this.selectedContexts.indexOf(item);\n          const contextsLength = this.selectedContexts.length;\n          if (index > -1) {\n            this.selectedContexts.splice(index, contextsLength - index);\n          }\n        }\n        if (item.loadTimes) {\n          item.loadTimes.reset();\n          if (this.filter) {\n            item.loadTimesCopy = cloneDeep(item.loadTimes);\n          }\n        }\n        if (this.filter) {\n          if (this.searchHistory.length > 0) {\n            this.searchContext =\n              this.searchHistory[this.searchHistory.length - 1];\n            this.searchHistory.splice(this.searchHistory.length - 1, 1);\n          }\n        }\n      }\n    }\n  }\n\n  async loadMoreMenuItems(item: DropdownMenuItemWrapper) {\n    if (item.loadMore && item.loadTimes && item.items) {\n      const searchContext = this.searchContext.trim();\n      item.isLoading = true;\n      var result =\n        searchContext.length > 0 && item.search\n          ? await item.search(searchContext, item.loadTimes)\n          : await item.loadMore(item.loadTimes);\n      item.isLoading = false;\n      item.loadTimes.increaseLoadTime();\n      const converted = this.convertToExpandable(result);\n      for (let res of converted) {\n        item.items.push(res);\n      }\n      if (this.filter) {\n        if (searchContext.length == 0 || !item.search) {\n          item.copy = cloneDeep(item.items);\n          item.loadTimesCopy = cloneDeep(item.loadTimes);\n        }\n      }\n      this.group\n        ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n        : this.optionsChange.emit(this.options);\n    }\n  }\n\n  async loadMore() {\n    if (this.load) {\n      if (this.options.length > 0 && !this.initialIncrement) {\n        this.loadTimes.increaseLoadTime();\n        if (this.filter) {\n          this.loadTimesCopy = cloneDeep(this.loadTimes);\n        }\n        this.initialIncrement = true;\n      }\n      const searchContext = this.searchContext.trim();\n      this.isLoading = true;\n      var result =\n        searchContext.length > 0 && this.search\n          ? await this.search(searchContext, this.loadTimes)\n          : await this.load(this.loadTimes);\n      this.isLoading = false;\n      if (this.group) {\n        result = this.convertToExpandable(result);\n      }\n      this.loadTimes.increaseLoadTime();\n      for (let item of result) {\n        this.options.push(item);\n      }\n      if (this.filter) {\n        if (searchContext.length == 0 || !this.search) {\n          this.optionsCopy = cloneDeep(this.options);\n          this.loadTimesCopy = cloneDeep(this.loadTimes);\n        }\n      }\n      this.group\n        ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n        : this.optionsChange.emit(this.options);\n    }\n  }\n\n  convertToExpandable(items: DropdownMenuItem[]): DropdownMenuItemWrapper[] {\n    const wrapper: DropdownMenuItemWrapper[] = [];\n    for (let item of items) {\n      const convertedItem: DropdownMenuItemWrapper = {\n        ...item,\n        isLoading: false,\n        expanded: false,\n        loadTimes: item.items ? new DropdownLoadEvent() : undefined,\n        loadTimesCopy: item.items ? new DropdownLoadEvent() : undefined,\n        items: item.items ? this.convertToExpandable(item.items) : undefined,\n        copy: item.items ? cloneDeep(this.convertToExpandable(item.items)) : [],\n      };\n      wrapper.push(convertedItem);\n    }\n    return wrapper;\n  }\n\n  onSelectAll(event: Event) {\n    if (this.selectedAll) {\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      this.onItemChange([]);\n      this.onTouched();\n      this.onChange.emit({ originalEvent: event, value: [] });\n      if (this.required) {\n        this.isInvalid = true;\n      }\n      return;\n    }\n    if (!this.group) {\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      for (let option of this.options) {\n        const index = this.checkMultiselectValue(option);\n        if (index == null) {\n          this.selectedOptions.push(this.getValue(option));\n          this.selectedOptionLabels.push(this.getOptionLabel(option));\n        }\n      }\n    } else {\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      for (let option of this.options) {\n        for (let item of option.items) {\n          const index = this.checkMultiselectValue(item);\n          if (index == null) {\n            this.selectedOptions.push(this.getValue(item));\n            this.selectedOptionLabels.push(this.getOptionLabel(item));\n          }\n        }\n      }\n    }\n    this.onItemChange(this.selectedOptions);\n    this.onTouched();\n    this.onChange.emit({ originalEvent: event, value: this.selectedOptions });\n  }\n\n  clearSelection(event: Event) {\n    if (!this.multiselect) {\n      this.selectedOption = null;\n      this.selectedOptionLabel = null;\n      this.onItemChange(null);\n      this.onTouched();\n      this.onChange.emit({ originalEvent: event, value: null });\n    } else {\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      this.onItemChange([]);\n      this.onTouched();\n      this.onChange.emit({ originalEvent: event, value: [] });\n    }\n    if (this.required) {\n      this.isInvalid = true;\n    }\n    this.selectedAll = false;\n    this.onClear.emit(event);\n  }\n\n  onSelect(value: any, event: Event) {\n    if (!this.multiselect) {\n      this.selectedOption = this.getValue(value);\n      this.selectedOptionLabel = this.getOptionLabel(value);\n      this.onItemChange(this.getValue(value));\n      this.onTouched();\n      this.onChange.emit({ originalEvent: event, value: this.getValue(value) });\n      this.toggleDropdown();\n    } else {\n      const exists = this.checkMultiselectValue(value);\n      if (exists == null) {\n        const newSelectedOptions = [\n          ...this.selectedOptions,\n          this.getValue(value),\n        ];\n        const newSelectedOptionLabels = [\n          ...this.selectedOptionLabels,\n          this.getOptionLabel(value),\n        ];\n        this.selectedOptions = newSelectedOptions;\n        this.selectedOptionLabels = newSelectedOptionLabels;\n        this.onItemChange(this.selectedOptions);\n        this.onTouched();\n        this.onChange.emit({\n          originalEvent: event,\n          value: this.selectedOptions,\n        });\n      } else {\n        this.selectedAll = false;\n        const newSelectedOptions = [...this.selectedOptions];\n        newSelectedOptions.splice(exists, 1);\n        const newSelectedOptionLabels = [...this.selectedOptionLabels];\n        newSelectedOptionLabels.splice(exists, 1);\n        this.selectedOptions = newSelectedOptions;\n        this.selectedOptionLabels = newSelectedOptionLabels;\n        this.onItemChange(this.selectedOptions);\n        this.onTouched();\n        this.onChange.emit({\n          originalEvent: event,\n          value: this.selectedOptions,\n        });\n      }\n    }\n  }\n\n  onMultiselectItemClosed(index: number, event: Event) {\n    const newSelectedOptions = [...this.selectedOptions];\n    newSelectedOptions.splice(index, 1);\n    const newSelectedOptionLabels = [...this.selectedOptionLabels];\n    newSelectedOptionLabels.splice(index, 1);\n    this.selectedOptions = newSelectedOptions;\n    this.selectedOptionLabels = newSelectedOptionLabels;\n    this.onItemChange(this.selectedOptions);\n    this.onTouched();\n    this.onChange.emit({ originalEvent: event, value: this.selectedOptions });\n  }\n\n  checkMultiselectValue(value: any): number | null {\n    for (let i = 0; i < this.selectedOptions.length; i++) {\n      if (isEqual(this.selectedOptions[i], this.getValue(value))) {\n        return i;\n      }\n    }\n    return null;\n  }\n\n  async writeValue(obj: any): Promise<void> {\n    if (!this.multiselect) {\n      if (obj == null || obj == undefined) {\n        this.selectedOption = obj;\n        this.selectedOptionLabel = obj;\n        return;\n      }\n      this.selectedOption = null;\n      this.selectedOptionLabel = null;\n      if (!this.group && !this.lazyLoad) {\n        for (let option of this.options) {\n          const equalityCheck = this.selectKey\n            ? isEqual(\n                this.getValue(option)[this.selectKey],\n                (obj && obj[this.selectKey]) || null\n              )\n            : isEqual(this.getValue(option), obj);\n          if (equalityCheck) {\n            this.selectedOption = this.getValue(option);\n            this.selectedOptionLabel = this.getOptionLabel(option);\n            break;\n          }\n        }\n        this.onTouched();\n        this.onChange.emit({ value: this.selectedOption });\n        return;\n      }\n      this.selectedOption = obj;\n      this.selectedOptionLabel = this.asyncLabel\n        ? await this.asyncLabel(obj)\n        : this.getOptionLabel(obj);\n      this.onTouched();\n      this.onChange.emit({ value: this.selectedOption });\n    } else {\n      if (!Array.isArray(obj)) {\n        this.selectedOptions = [];\n        this.selectedOptionLabels = [];\n        return;\n      }\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      if (!this.group && !this.lazyLoad) {\n        for (let option of this.options) {\n          for (let object of obj) {\n            const equalityCheck = this.selectKey\n              ? isEqual(\n                  this.getValue(option)[this.selectKey],\n                  object[this.selectKey]\n                )\n              : isEqual(this.getValue(option), object);\n            if (equalityCheck) {\n              this.selectedOptions.push(this.getValue(option));\n              this.selectedOptionLabels.push(this.getOptionLabel(option));\n              break;\n            }\n          }\n        }\n        this.onTouched();\n        this.onChange.emit({ value: this.selectedOptions });\n        return;\n      }\n      this.selectedOptions = obj;\n      for (let object of obj) {\n        this.selectedOptionLabels.push(\n          this.asyncLabel\n            ? await this.asyncLabel(object)\n            : this.getOptionLabel(object)\n        );\n      }\n      this.onTouched();\n      this.onChange.emit({ value: this.selectedOptions });\n    }\n  }\n\n  getOptionFromValue(value: any): any {\n    if (!this.optionValue) {\n      return this.group ? value.value : value;\n    }\n    const index = this.group\n      ? this.options.findIndex(\n          (x) =>\n            x.value[this.optionValue!] && x.value[this.optionValue!] == value\n        )\n      : this.options.findIndex(\n          (x) => x[this.optionValue!] && x[this.optionValue!] == value\n        );\n    if (index < 0) {\n      return this.group ? value.value : value;\n    }\n    return this.options[index];\n  }\n\n  registerOnChange(fn: any): void {\n    this.onItemChange = fn;\n  }\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  getValue(item: any): any {\n    if (!this.optionValue) {\n      return this.group ? item.value : item;\n    }\n    return this.group ? item.value[this.optionValue] : item[this.optionValue];\n  }\n  getOptionLabel(item: any): any {\n    if (this.group) {\n      return item.label;\n    }\n    if (!this.optionLabel) {\n      return item;\n    }\n    return typeof item === 'string' ? item : item[this.optionLabel];\n  }\n\n  private isDropdownMenuItemWrapperArray(value: any[]): boolean {\n    return (\n      Array.isArray(value) &&\n      value.every((item) => this.isDropdownMenuItemWrapper(item))\n    );\n  }\n\n  // Type guard function to check if an object is of type DropdownMenuItem\n  private isDropdownMenuItemWrapper(item: any): boolean {\n    return 'expanded' in item;\n  }\n\n  @HostListener('document:click', ['$event'])\n  onClickOutside(event: Event) {\n    if (!this.isExpanded) {\n      return;\n    }\n    if (\n      !this.dropdownContainer.nativeElement.contains(event.target) &&\n      this.isExpanded &&\n      this.dropdownExpansion &&\n      !this.dropdownExpansion.nativeElement.contains(event.target)\n    ) {\n      this.isExpanded = false;\n    }\n  }\n}\n","<div #dropdownContainer [ngClass]=\"styleClass\" [style.width]=\"width\" class=\"drop-down\">\n  <div\n    [ngClass]=\"{'right-error': errorPosition == 'right', 'left-error': errorPosition == 'left', 'top-error': errorPosition == 'top'}\"\n    class=\"drop-down-input-wrapper\">\n    <div (click)=\"onDropdownClick($event)\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\" [class.focused]=\"isFocused\"\n      [ngClass]=\"{'ng-invalid': isInvalid, 'disabled': disabled}\" (focus)=\"onFocus()\" (blur)=\"onBlur()\" tabindex=\"0\"\n      class=\"drop-down-input verben-input flex\">\n      <div class=\"drop-down-main-content\">\n        <ng-container\n          *ngIf=\"(selectedItemTemplate && selectedOption) || (selectedItemTemplate && selectedOptions.length > 0); else defaultItem\">\n          <div *ngIf=\"!multiselect\">\n            <ng-container\n              *ngTemplateOutlet=\"selectedItemTemplate; context: { $implicit: selectedOption }\"></ng-container>\n          </div>\n          <div *ngIf=\"multiselect\">\n            <ng-container\n              *ngTemplateOutlet=\"selectedItemTemplate; context: { $implicit: selectedOptions }\"></ng-container>\n          </div>\n        </ng-container>\n\n        <ng-template #defaultItem>\n          <div *ngIf=\"!multiselect\" class=\"default-item flex\">\n            <div class=\"dropdown-label place-holder\" *ngIf=\"!this.selectedOption\">{{placeholder}}</div>\n            <div *ngIf=\"this.selectedOption\" class=\"item-label dropdown-label\">\n              {{this.selectedOptionLabel}}</div>\n          </div>\n          <div *ngIf=\"multiselect\" class=\"default-item multi-select flex\">\n            <div class=\"dropdown-label place-holder\" *ngIf=\"this.selectedOptions.length == 0\">{{placeholder}}</div>\n            <verben-tooltip customClass=\"custom-tooltip-width\" border=\"1px solid #334155\" backgroundColor=\"white\"\n              [tooltipContent]=\"multiselectTooltip\">\n              <div *ngIf=\"this.selectedOptions.length > 0\" class=\"item-label dropdown-label\">\n                <div *ngIf=\"display == 'chip'\" class=\"multiselect-items-container-two chip\">\n                  <span *ngFor=\"let item of selectedOptionLabels; index as i\"\n                    class=\"multiselect-item-chip multi-select flex\">\n                    <span>{{item}}</span>\n                    <verben-svg (click)=\"onMultiselectItemClosed(i, $event); $event.stopPropagation();\"\n                      icon=\"close-circle-full\" [width]=\"15\" [height]=\"15\"></verben-svg>\n                    <!-- <svg (click)=\"onMultiselectItemClosed(i, $event); $event.stopPropagation();\" width=\"10\" height=\"10\"\n                      viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path\n                        d=\"M5.00065 9.33333C7.30184 9.33333 9.16732 7.46785 9.16732 5.16667C9.16732 2.86548 7.30184 1 5.00065 1C2.69946 1 0.833984 2.86548 0.833984 5.16667C0.833984 7.46785 2.69946 9.33333 5.00065 9.33333Z\"\n                        stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M6.25 3.91797L3.75 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M3.75 3.91797L6.25 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg> -->\n                  </span>\n                </div>\n                <div *ngIf=\"display != 'chip'\" class=\"multiselect-items-container-two normal\">\n                  <span *ngFor=\"let item of selectedOptionLabels; index as i\" class=\"multiselect-item\">\n                    {{i !== selectedOptionLabels.length - 1? item + ', ':item}}\n                  </span>\n                </div>\n              </div>\n            </verben-tooltip>\n            <ng-template #multiselectTooltip>\n              <div class=\"multi-select-full-view\">\n                <div *ngIf=\"this.selectedOptions.length > 0\" class=\"item-label dropdown-label\">\n                  <div *ngIf=\"display == 'chip'\" class=\"multiselect-items-container-two-tooltip chip\">\n                    <span *ngFor=\"let item of selectedOptionLabels; index as i\"\n                      class=\"multiselect-item-chip multi-select flex\">\n                      <span>{{item}}</span>\n                      <verben-svg (click)=\"onMultiselectItemClosed(i, $event); $event.stopPropagation();\"\n                        icon=\"close-circle-full\" [width]=\"15\" [height]=\"15\"></verben-svg>\n                      <!-- <svg (click)=\"onMultiselectItemClosed(i, $event); $event.stopPropagation();\" width=\"10\" height=\"10\"\n                        viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                        <path\n                          d=\"M5.00065 9.33333C7.30184 9.33333 9.16732 7.46785 9.16732 5.16667C9.16732 2.86548 7.30184 1 5.00065 1C2.69946 1 0.833984 2.86548 0.833984 5.16667C0.833984 7.46785 2.69946 9.33333 5.00065 9.33333Z\"\n                          stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                        <path d=\"M6.25 3.91797L3.75 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\"\n                          stroke-linejoin=\"round\" />\n                        <path d=\"M3.75 3.91797L6.25 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\"\n                          stroke-linejoin=\"round\" />\n                      </svg> -->\n                    </span>\n                  </div>\n                  <div *ngIf=\"display != 'chip'\" class=\"multiselect-items-container-two-tooltip-normal\">\n                    <span *ngFor=\"let item of selectedOptionLabels; index as i\" class=\"multiselect-item\">\n                      {{i !== selectedOptionLabels.length - 1? item + ', ':item}}\n                    </span>\n                  </div>\n                </div>\n              </div>\n            </ng-template>\n          </div>\n        </ng-template>\n      </div>\n      <span\n        *ngIf=\"(showClear && this.selectedOption && !multiselect) || (showClear && this.selectedOptions.length > 0 && multiselect)\"\n        (click)=\"this.clearSelection($event); $event.stopPropagation()\"\n        class=\"drop-down-icon-item drop-down-clear-button\">\n        <verben-svg icon=\"close-no-circle\" stroke=\"#94a3b8\" [width]=\"13\" [height]=\"13\"></verben-svg>\n        <!-- <svg width=\"9\" height=\"9\" viewBox=\"0 0 9 9\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M0.84375 0.84375L8.15625 8.15625\" stroke=\"currentColor\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M0.84375 8.15625L8.15625 0.84375\" stroke=\"currentColor\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg> -->\n      </span>\n      <span class=\"drop-down-icon-item drop-down-expand-button\">\n        <verben-svg icon=\"chevron-down\" fill=\"#94a3b8\" [width]=\"15\" [height]=\"8\"></verben-svg>\n        <!-- <svg width=\"12\" height=\"7\" viewBox=\"0 0 12 7\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M6.00507 4.88027C6.20205 4.62775 6.30683 4.4622 6.44095 4.32704C7.74334 3.01731 9.05202 1.71387 10.3576 0.406242C10.5713 0.192495 10.7882 0.00913367 11.1193 0.0101814C11.4692 0.0112292 11.7228 0.15792 11.8884 0.456537C12.057 0.760394 12.0309 1.06111 11.8349 1.34296C11.7658 1.4425 11.6767 1.52737 11.5908 1.61433C9.98873 3.21639 8.37305 4.80483 6.793 6.42784C6.29111 6.94335 5.68759 6.92344 5.21399 6.43832C3.63184 4.8174 2.01826 3.22687 0.414109 1.62691C0.116539 1.32934 -0.116067 1.0192 0.0620561 0.565507C0.271612 0.031139 0.883519 -0.167941 1.35502 0.157919C1.49647 0.255363 1.61592 0.387385 1.73955 0.509975C3.02204 1.79036 4.30452 3.07075 5.58386 4.35533C5.70645 4.47792 5.80284 4.62671 6.00611 4.88132L6.00507 4.88027Z\"\n            fill=\"currentColor\" />\n        </svg> -->\n      </span>\n    </div>\n    <div *ngIf=\"this.isInvalid && this.invalidMessage\" class=\"verben-error-message error-message\">{{invalidMessage}}\n    </div>\n  </div>\n  <ng-template cdkConnectedOverlay [cdkConnectedOverlayWidth]=\"dropdownContainer.offsetWidth\"\n    [cdkConnectedOverlayLockPosition]=\"false\" [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayPositions]=\"[\n    {\n      originX: 'start',\n      originY: 'bottom',\n      overlayX: 'start',\n      overlayY: 'top'\n    },\n    {\n      originX: 'start',\n      originY: 'top',\n      overlayX: 'start',\n      overlayY: 'bottom'\n    }\n  ]\" [cdkConnectedOverlayOpen]=\"isExpanded\" (detach)=\"isExpanded = false\">\n    <div #dropdownExpansion class=\"drop-down-menu-item-wrapper\">\n      <div *ngIf=\"multiselect && this.selectedOptions.length > 0\">\n        <div *ngIf=\"display == 'chip'\" class=\"multiselect-items-container chip flex\">\n          <span *ngFor=\"let item of selectedOptionLabels; index as i\" class=\"multiselect-item-chip flex\">\n            <span>{{item}}</span>\n            <verben-svg (click)=\"onMultiselectItemClosed(i, $event)\" icon=\"close-circle-full\" [width]=\"15\"\n              [height]=\"15\"></verben-svg>\n            <!-- <svg (click)=\"onMultiselectItemClosed(i, $event)\" width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                d=\"M5.00065 9.33333C7.30184 9.33333 9.16732 7.46785 9.16732 5.16667C9.16732 2.86548 7.30184 1 5.00065 1C2.69946 1 0.833984 2.86548 0.833984 5.16667C0.833984 7.46785 2.69946 9.33333 5.00065 9.33333Z\"\n                stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n              <path d=\"M6.25 3.91797L3.75 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n              <path d=\"M3.75 3.91797L6.25 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            </svg> -->\n          </span>\n        </div>\n        <div *ngIf=\"display != 'chip'\" class=\"multiselect-items-container normal\">\n          <span *ngFor=\"let item of selectedOptionLabels; index as i\" class=\"multiselect-item\">\n            {{i !== selectedOptionLabels.length - 1? item + ', ':item}}\n          </span>\n        </div>\n      </div>\n      <div *ngIf=\"allowSelectAll || filter\" class=\"actions-section flex\">\n        <input *ngIf=\"allowSelectAll\" (click)=\"onSelectAll($event)\" type=\"checkbox\" [(ngModel)]=\"selectedAll\"\n          class=\"custom-checkbox\" />\n        <span class=\"select-all-caption\" *ngIf=\"allowSelectAll && !filter\">Select All</span>\n        <div *ngIf=\"filter\" [ngClass]=\"{'focused': isInputFocused}\" tabindex=\"0\" (focus)=\"onSearchFocus()\"\n          (blur)=\"onSearchBlur()\" class=\"search-section flex\">\n          <span class=\"search-icon flex\">\n            <verben-svg icon=\"search\" stroke=\"#64748b\" [width]=\"15\" [height]=\"15\"></verben-svg>\n            <!-- <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n              <circle cx=\"9\" cy=\"9\" r=\"8\" stroke=\"currentColor\" stroke-width=\"2\" fill=\"none\"></circle>\n              <line x1=\"14\" y1=\"14\" x2=\"19\" y2=\"19\" stroke=\"currentColor\" stroke-width=\"2\"></line>\n            </svg> -->\n          </span>\n          <span *ngIf=\"this.selectedContexts[this.selectedContexts.length - 1]\" class=\"search-context\">\n            {{this.getOptionLabel(this.selectedContexts[this.selectedContexts.length - 1])}}\n          </span>\n          <div class=\"search-input-container\">\n            <input (input)=\"onSearch($event)\" [(ngModel)]=\"searchContext\" (focus)=\"onInputFocus()\"\n              (blur)=\"onInputBlur()\" placeholder=\"Search...\" class=\"search-input\" />\n          </div>\n        </div>\n      </div>\n      <div *ngIf=\"showHorizontalLine\" class=\"colored-underline-section\">\n        <hr [style.background-color]=\"horizontalLineColor\" class=\"colored-underline\" />\n      </div>\n      <div class=\"drop-down-menu-item\">\n        <drop-down-item [itemTemplate]=\"itemTemplate\" [groupTemplate]=\"groupTemplate\" [activeItem]=\"selectedOption\"\n          [activeItems]=\"selectedOptions\" [multiselect]=\"multiselect\" [optionValue]=\"optionValue\"\n          [optionLabel]=\"optionLabel\" [optionSubLabel]=\"optionSubLabel\" [selectKey]=\"selectKey\"\n          [loadMoreCaption]=\"loadMoreCaption\" [options]=\"options\" [group]=\"group\" [onExpand]=\"expandMenu.bind(this)\"\n          [onLoadMore]=\"loadMoreMenuItems.bind(this)\" [onSelect]=\"onSelect.bind(this)\"></drop-down-item>\n        <div *ngIf=\"lazyLoad\">\n          <div class=\"see-more-container flex justify-end\">\n            <span class=\"see-more-caption\" (click)=\"loadMore()\">{{loadMoreCaption}}</span>\n          </div>\n        </div>\n        <div *ngIf=\"isLoading\" class=\"loading-overlay\">\n          <div class=\"loader\"></div>\n        </div>\n      </div>\n    </div>\n  </ng-template>\n</div>\n"]}
784
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-down.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/drop-down/drop-down.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/drop-down/drop-down.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  Self,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { DropdownMenuItem } from './DropdownMenuItem';\nimport { DropdownLoadEvent } from './DropdownLoadEvent';\nimport { TemplateDirective } from '../TemplateDirective.directive';\nimport { DropdownChangeEvent } from './DropdownChangeEvent';\nimport { DropDownItemComponent } from './drop-down-item/drop-down-item.component';\nimport { isEqual, cloneDeep } from 'lodash';\nimport { debounceTime, Subject } from 'rxjs';\nimport { SharedModule } from '../shared.module';\nimport { SvgModule } from '../svg/svg.module';\nimport { TooltipModule } from '../tooltip/tooltip.module';\n\nexport interface DropdownMenuItemWrapper extends DropdownMenuItem {\n  expanded: boolean;\n  items?: DropdownMenuItemWrapper[];\n  isLoading: boolean;\n  copy: DropdownMenuItemWrapper[];\n  loadTimes?: DropdownLoadEvent;\n  loadTimesCopy?: DropdownLoadEvent;\n}\n\n@Component({\n  selector: 'verben-drop-down',\n  standalone: true,\n  imports: [\n    CommonModule,\n    DropDownItemComponent,\n    SharedModule,\n    FormsModule,\n    SvgModule,\n    TooltipModule,\n  ],\n  templateUrl: './drop-down.component.html',\n  styleUrl: './drop-down.component.css',\n})\nexport class DropDownComponent\n  implements ControlValueAccessor, OnInit, AfterContentInit\n{\n  // INTERNAL\n  private _options: any[] = []; // Internal variable for options\n\n  // INPUTS\n  @Input()\n  set options(value: any[]) {\n    if (this.group) {\n      if (this.isDropdownMenuItemWrapperArray(value)) {\n        this._options = value;\n      } else {\n        this._options = this.convertToExpandable(value); // Set the internal options variable\n      }\n    } else {\n      this._options = value;\n    }\n  }\n\n  get options(): any[] {\n    return this._options; // Return the internal options variable\n  }\n\n  @Input() width: string = '12rem';\n  @Input() showHorizontalLine: boolean = true;\n  @Input() horizontalLineColor: string = 'rgba(255, 230, 129, 1)';\n  @Input() optionLabel?: string;\n  @Input() optionSubLabel?: string;\n  @Input() optionValue?: string;\n  @Input() placeholder?: string;\n  @Input() invalidMessage?: string;\n  @Input() errorPosition: string = '';\n  @Input() loadMoreCaption: string = 'See more';\n  @Input() display: 'default' | 'chip' = 'chip';\n  @Input() showClear: boolean = false;\n  @Input() lazyLoad: boolean = false;\n  @Input() selectKey: string | null = null;\n  @Input() styleClass: string = '';\n  @Input() group: boolean = false;\n  @Input() multiselect: boolean = false;\n  @Input() filter: boolean = false;\n  @Input() avoidDuplication: boolean = false;\n  @Input() filterBy?: string;\n  @Input() debounceTime: number = 500;\n  @Input() minChar: number = 0;\n  @Input() disabled: boolean = false;\n  @Input() required: boolean = false;\n  @Input() load?: (context: DropdownLoadEvent) => Promise<any[]>;\n  @Input() asyncLabel?: (context: any) => Promise<string | null>;\n  @Input() search?: (data: any, context: DropdownLoadEvent) => Promise<any[]>;\n\n  // OUTPUTS\n  @Output() optionsChange: EventEmitter<any[]> = new EventEmitter();\n  @Output() onChange: EventEmitter<DropdownChangeEvent> = new EventEmitter();\n  @Output() onClick: EventEmitter<Event> = new EventEmitter();\n  @Output() onClear: EventEmitter<Event> = new EventEmitter();\n\n  onItemChange: (value: any) => void = () => {};\n  onTouched: () => void = () => {};\n  isInvalid: boolean = false;\n\n  //TEMPLATING\n  @ViewChild('dropdownContainer', { static: true })\n  dropdownContainer!: ElementRef;\n  @ViewChild('dropdownExpansion', { static: false })\n  dropdownExpansion!: ElementRef;\n  @ContentChildren(TemplateDirective) templates!: QueryList<TemplateDirective>;\n\n  @HostBinding('class.focused') isFocused = false;\n  isInputFocused = false;\n\n  selectedItemTemplate: TemplateRef<any> | null = null;\n  itemTemplate: TemplateRef<any> | null = null; // Allow null for custom item template\n  groupTemplate: TemplateRef<any> | null = null;\n\n  //VARIABLES\n  isExpanded: boolean = false;\n  loadTimes: DropdownLoadEvent = new DropdownLoadEvent();\n  initialIncrement: boolean = false;\n  selectedOption: any;\n  selectedOptions: any[] = [];\n  selectedOptionLabel: any;\n  selectedOptionLabels: any[] = [];\n  isLoading: boolean = false;\n  optionsCopy: any[] = [];\n  loadTimesCopy: DropdownLoadEvent = new DropdownLoadEvent();\n  selectedContexts: any[] = [];\n  searchHistory: string[] = [];\n  searchTerm$ = new Subject<string>();\n  searchContext: string = '';\n  allowSelectAll: boolean = false;\n  selectedAll: boolean = false;\n\n  constructor(@Optional() @Self() private ngControl: NgControl) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this; // Assign this component as the value accessor\n      this.ngControl?.statusChanges?.subscribe((status) => {\n        this.isInvalid = this.ngControl.touched\n          ? status === 'INVALID' && this.ngControl.touched\n          : false;\n      });\n    }\n  }\n  ngOnInit(): void {\n    if (this.multiselect) {\n      if (!this.lazyLoad) {\n        if (!this.group) {\n          this.allowSelectAll = true;\n        } else {\n          let isAllowed = true;\n          for (let item of this.options) {\n            if (item.lazyLoad) {\n              isAllowed = false;\n              break;\n            }\n          }\n          this.allowSelectAll = isAllowed;\n        }\n      }\n    }\n    if (this.filter) {\n      this.optionsCopy = cloneDeep(this._options);\n      this.searchTerm$\n        .pipe(debounceTime(this.debounceTime)) // Adjust debounce time here (in ms)\n        .subscribe(async (searchTerm) => {\n          if (searchTerm.length < this.minChar) {\n            return;\n          }\n          if (this.selectedContexts.length > 0) {\n            const item = this.selectedContexts[\n              this.selectedContexts.length - 1\n            ] as DropdownMenuItemWrapper;\n            if (item.search && item.loadTimes) {\n              item.loadTimes.reset();\n              item.isLoading = true;\n              const result = await item.search(searchTerm, item.loadTimes);\n              item.isLoading = false;\n              if (this.searchContext.length > 0) {\n                item.loadTimes.increaseLoadTime();\n                item.items = this.convertToExpandable(result);\n                this.group\n                  ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n                  : this.optionsChange.emit(this.options);\n              }\n            }\n          } else {\n            if (this.search && this.loadTimes) {\n              this.isLoading = true;\n              this.loadTimes.reset();\n              const result = await this.search(searchTerm, this.loadTimes);\n              this.isLoading = false;\n              if (this.searchContext.length > 0) {\n                this.options = this.convertToExpandable(result);\n                this.group\n                  ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n                  : this.optionsChange.emit(this.options);\n              }\n            }\n          }\n        });\n    }\n  }\n  ngAfterContentInit(): void {\n    this.templates.forEach((templateDirective) => {\n      if (templateDirective.vTemplate === 'selected') {\n        this.selectedItemTemplate = templateDirective.template;\n      }\n      if (templateDirective.vTemplate === 'item') {\n        this.itemTemplate = templateDirective.template;\n      }\n      if (templateDirective.vTemplate === 'group') {\n        this.groupTemplate = templateDirective.template;\n      }\n    });\n  }\n\n  @HostListener('focus') onFocus() {\n    this.isFocused = true;\n  }\n\n  @HostListener('blur') onBlur() {\n    this.isFocused = false;\n  }\n\n  onSearchFocus() {\n    this.isInputFocused = true;\n  }\n\n  onSearchBlur() {\n    this.isInputFocused = false;\n  }\n\n  onInputFocus() {\n    this.isInputFocused = true;\n  }\n\n  onInputBlur() {\n    this.isInputFocused = false;\n  }\n\n  onSearch(event: any) {\n    if (this.disabled) {\n      return;\n    }\n    const searchTerm = event.target.value;\n    if (this.selectedContexts.length > 0) {\n      const item = this.selectedContexts[\n        this.selectedContexts.length - 1\n      ] as DropdownMenuItemWrapper;\n      if (searchTerm.trim().length == 0) {\n        item.items = cloneDeep(item.copy);\n        item.loadTimes = cloneDeep(item.loadTimesCopy);\n        this.group\n          ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n          : this.optionsChange.emit(this.options);\n        return;\n      }\n      if (item.lazyLoad) {\n        this.searchTerm$.next(searchTerm);\n      } else {\n        if (item.filterBy) {\n          if (!item.items) {\n            return;\n          }\n          item.items = item.items.filter(\n            (x) =>\n              typeof x.value[item.filterBy!] == 'string' &&\n              new RegExp(searchTerm, 'i').test(x.value[item.filterBy!])\n          );\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        } else {\n          if (!item.items) {\n            return;\n          }\n          item.items = item.copy.filter(\n            (x) =>\n              typeof x.value == 'string' &&\n              new RegExp(searchTerm, 'i').test(x.value)\n          );\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        }\n      }\n    } else {\n      if (searchTerm.trim().length == 0) {\n        this.options = cloneDeep(this.optionsCopy);\n        this.loadTimes = cloneDeep(this.loadTimesCopy);\n        this.group\n          ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n          : this.optionsChange.emit(this.options);\n        return;\n      }\n      if (this.lazyLoad) {\n        this.searchTerm$.next(searchTerm);\n      } else {\n        if (this.filterBy) {\n          this.options = this.optionsCopy.filter(\n            (x) =>\n              typeof x[this.filterBy!] == 'string' &&\n              new RegExp(searchTerm, 'i').test(x[this.filterBy!])\n          );\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        } else {\n          this.options = this.optionsCopy.filter(\n            (x) => typeof x == 'string' && new RegExp(searchTerm, 'i').test(x)\n          );\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        }\n      }\n    }\n  }\n\n  onDropdownClick(event: Event) {\n    if (this.disabled) {\n      return;\n    }\n    this.toggleDropdown();\n    this.onClick.emit(event);\n  }\n\n  toggleDropdown() {\n    this.isExpanded = !this.isExpanded;\n  }\n\n  hasSibling(siblings: DropdownMenuItemWrapper[]): number | null {\n    for (let i = 0; i < siblings.length; i++) {\n      const index = this.selectedContexts.indexOf(siblings[i]);\n      if (index > -1) {\n        return index;\n      }\n    }\n    return null;\n  }\n\n  async expandMenu(\n    item: DropdownMenuItemWrapper,\n    siblings: DropdownMenuItemWrapper[]\n  ) {\n    if (item.items) {\n      if (this.filter) {\n        for (let it of siblings.filter((x) => x !== item)) {\n          if (it.expanded) {\n            it.expanded = false;\n            it.loadTimes && it.loadTimes.reset();\n          }\n        }\n      }\n      item.expanded = !item.expanded;\n      if (item.expanded) {\n        if (this.filter) {\n          const siblingCheck = this.hasSibling(siblings);\n          if (this.selectedContexts.length > 0 && siblingCheck !== null) {\n            const contextsLength = this.selectedContexts.length;\n            this.selectedContexts.splice(\n              siblingCheck,\n              contextsLength - siblingCheck\n            );\n          }\n          this.selectedContexts.push(item);\n          if (siblingCheck == null) {\n            this.searchHistory.push(this.searchContext);\n          }\n          this.searchContext = '';\n        }\n        if (item.lazyLoad && item.loadMore && item.loadTimes) {\n          item.isLoading = true;\n          var result = await item.loadMore(item.loadTimes);\n          item.isLoading = false;\n          if(result.length > 0){\n            item.loadTimes.increaseLoadTime();\n          }\n          item.items = this.convertToExpandable(result);\n          if (this.filter) {\n            item.copy = cloneDeep(item.items);\n            item.loadTimesCopy = cloneDeep(item.loadTimes);\n          }\n          this.group\n            ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n            : this.optionsChange.emit(this.options);\n        }\n      } else {\n        if (this.filter) {\n          const index = this.selectedContexts.indexOf(item);\n          const contextsLength = this.selectedContexts.length;\n          if (index > -1) {\n            this.selectedContexts.splice(index, contextsLength - index);\n          }\n        }\n        if (item.loadTimes) {\n          item.loadTimes.reset();\n          if (this.filter) {\n            item.loadTimesCopy = cloneDeep(item.loadTimes);\n          }\n        }\n        if (this.filter) {\n          if (this.searchHistory.length > 0) {\n            this.searchContext =\n              this.searchHistory[this.searchHistory.length - 1];\n            this.searchHistory.splice(this.searchHistory.length - 1, 1);\n          }\n        }\n      }\n    }\n  }\n\n  async loadMoreMenuItems(item: DropdownMenuItemWrapper) {\n    if (item.loadMore && item.loadTimes && item.items) {\n      const searchContext = this.searchContext.trim();\n      item.isLoading = true;\n      var result =\n        searchContext.length > 0 && item.search\n          ? await item.search(searchContext, item.loadTimes)\n          : await item.loadMore(item.loadTimes);\n      item.isLoading = false;\n      if(result.length > 0){\n        item.loadTimes.increaseLoadTime();\n      }\n      const converted = this.convertToExpandable(result);\n      for (let res of converted) {\n        item.items.push(res);\n      }\n      if (this.filter) {\n        if (searchContext.length == 0 || !item.search) {\n          item.copy = cloneDeep(item.items);\n          item.loadTimesCopy = cloneDeep(item.loadTimes);\n        }\n      }\n      this.group\n        ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n        : this.optionsChange.emit(this.options);\n    }\n  }\n\n  async loadMore() {\n    if (this.load) {\n      if (this.options.length > 0 && !this.initialIncrement) {\n        this.loadTimes.increaseLoadTime();\n        if (this.filter) {\n          this.loadTimesCopy = cloneDeep(this.loadTimes);\n        }\n        this.initialIncrement = true;\n      }\n      const searchContext = this.searchContext.trim();\n      this.isLoading = true;\n      var result =\n        searchContext.length > 0 && this.search\n          ? await this.search(searchContext, this.loadTimes)\n          : await this.load(this.loadTimes);\n      this.isLoading = false;\n      if (this.group) {\n        result = this.convertToExpandable(result);\n      }\n      if(result.length > 0){\n        this.loadTimes.increaseLoadTime();\n      }\n      for (let item of result) {\n        this.options.push(item);\n      }\n      if (this.filter) {\n        if (searchContext.length == 0 || !this.search) {\n          this.optionsCopy = cloneDeep(this.options);\n          this.loadTimesCopy = cloneDeep(this.loadTimes);\n        }\n      }\n      this.group\n        ? this.optionsChange.emit(this.options as DropdownMenuItem[])\n        : this.optionsChange.emit(this.options);\n    }\n  }\n\n  convertToExpandable(items: DropdownMenuItem[]): DropdownMenuItemWrapper[] {\n    const wrapper: DropdownMenuItemWrapper[] = [];\n    for (let item of items) {\n      const convertedItem: DropdownMenuItemWrapper = {\n        ...item,\n        isLoading: false,\n        expanded: false,\n        loadTimes: item.items ? new DropdownLoadEvent() : undefined,\n        loadTimesCopy: item.items ? new DropdownLoadEvent() : undefined,\n        items: item.items ? this.convertToExpandable(item.items) : undefined,\n        copy: item.items ? cloneDeep(this.convertToExpandable(item.items)) : [],\n      };\n      wrapper.push(convertedItem);\n    }\n    return wrapper;\n  }\n\n  onSelectAll(event: Event) {\n    if (this.selectedAll) {\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      this.onItemChange([]);\n      this.onTouched();\n      this.onChange.emit({ originalEvent: event, value: [] });\n      if (this.required) {\n        this.isInvalid = true;\n      }\n      return;\n    }\n    if (!this.group) {\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      for (let option of this.options) {\n        const index = this.checkMultiselectValue(option);\n        if (index == null) {\n          this.selectedOptions.push(this.getValue(option));\n          this.selectedOptionLabels.push(this.getOptionLabel(option));\n        }\n      }\n    } else {\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      for (let option of this.options) {\n        for (let item of option.items) {\n          const index = this.checkMultiselectValue(item);\n          if (index == null) {\n            this.selectedOptions.push(this.getValue(item));\n            this.selectedOptionLabels.push(this.getOptionLabel(item));\n          }\n        }\n      }\n    }\n    this.onItemChange(this.selectedOptions);\n    this.onTouched();\n    this.onChange.emit({ originalEvent: event, value: this.selectedOptions });\n  }\n\n  clearSelection(event: Event) {\n    if (!this.multiselect) {\n      this.selectedOption = null;\n      this.selectedOptionLabel = null;\n      this.onItemChange(null);\n      this.onTouched();\n      this.onChange.emit({ originalEvent: event, value: null });\n    } else {\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      this.onItemChange([]);\n      this.onTouched();\n      this.onChange.emit({ originalEvent: event, value: [] });\n    }\n    if (this.required) {\n      this.isInvalid = true;\n    }\n    this.selectedAll = false;\n    this.onClear.emit(event);\n  }\n\n  onSelect(value: any, event: Event) {\n    if (!this.multiselect) {\n      this.selectedOption = this.getValue(value);\n      this.selectedOptionLabel = this.getOptionLabel(value);\n      this.onItemChange(this.getValue(value));\n      this.onTouched();\n      this.onChange.emit({ originalEvent: event, value: this.getValue(value) });\n      this.toggleDropdown();\n    } else {\n      const exists = this.checkMultiselectValue(value);\n      if (exists == null) {\n        const newSelectedOptions = [\n          ...this.selectedOptions,\n          this.getValue(value),\n        ];\n        const newSelectedOptionLabels = [\n          ...this.selectedOptionLabels,\n          this.getOptionLabel(value),\n        ];\n        this.selectedOptions = newSelectedOptions;\n        this.selectedOptionLabels = newSelectedOptionLabels;\n        this.onItemChange(this.selectedOptions);\n        this.onTouched();\n        this.onChange.emit({\n          originalEvent: event,\n          value: this.selectedOptions,\n        });\n      } else {\n        this.selectedAll = false;\n        const newSelectedOptions = [...this.selectedOptions];\n        newSelectedOptions.splice(exists, 1);\n        const newSelectedOptionLabels = [...this.selectedOptionLabels];\n        newSelectedOptionLabels.splice(exists, 1);\n        this.selectedOptions = newSelectedOptions;\n        this.selectedOptionLabels = newSelectedOptionLabels;\n        this.onItemChange(this.selectedOptions);\n        this.onTouched();\n        this.onChange.emit({\n          originalEvent: event,\n          value: this.selectedOptions,\n        });\n      }\n    }\n  }\n\n  onMultiselectItemClosed(index: number, event: Event) {\n    const newSelectedOptions = [...this.selectedOptions];\n    newSelectedOptions.splice(index, 1);\n    const newSelectedOptionLabels = [...this.selectedOptionLabels];\n    newSelectedOptionLabels.splice(index, 1);\n    this.selectedOptions = newSelectedOptions;\n    this.selectedOptionLabels = newSelectedOptionLabels;\n    this.onItemChange(this.selectedOptions);\n    this.onTouched();\n    this.onChange.emit({ originalEvent: event, value: this.selectedOptions });\n  }\n\n  checkMultiselectValue(value: any): number | null {\n    for (let i = 0; i < this.selectedOptions.length; i++) {\n      if (isEqual(this.selectedOptions[i], this.getValue(value))) {\n        return i;\n      }\n    }\n    return null;\n  }\n\n  async writeValue(obj: any): Promise<void> {\n    if (!this.multiselect) {\n      if (obj == null || obj == undefined) {\n        this.selectedOption = obj;\n        this.selectedOptionLabel = obj;\n        return;\n      }\n      this.selectedOption = null;\n      this.selectedOptionLabel = null;\n      if (!this.group && !this.lazyLoad) {\n        for (let option of this.options) {\n          const equalityCheck = this.selectKey\n            ? isEqual(\n                this.getValue(option)[this.selectKey],\n                (obj && obj[this.selectKey]) || null\n              )\n            : isEqual(this.getValue(option), obj);\n          if (equalityCheck) {\n            this.selectedOption = this.getValue(option);\n            this.selectedOptionLabel = this.asyncLabel\n            ? await this.asyncLabel(option) : this.getOptionLabel(option);\n            break;\n          }\n        }\n        this.onTouched();\n        this.onChange.emit({ value: this.selectedOption });\n        return;\n      }\n      this.selectedOption = obj;\n      this.selectedOptionLabel = this.asyncLabel\n        ? await this.asyncLabel(obj)\n        : this.getOptionLabel(obj);\n      this.onTouched();\n      this.onChange.emit({ value: this.selectedOption });\n    } else {\n      if (!Array.isArray(obj)) {\n        this.selectedOptions = [];\n        this.selectedOptionLabels = [];\n        return;\n      }\n      this.selectedOptions = [];\n      this.selectedOptionLabels = [];\n      if (!this.group && !this.lazyLoad) {\n        for (let option of this.options) {\n          for (let object of obj) {\n            const equalityCheck = this.selectKey\n              ? isEqual(\n                  this.getValue(option)[this.selectKey],\n                  object[this.selectKey]\n                )\n              : isEqual(this.getValue(option), object);\n            if (equalityCheck) {\n              this.selectedOptions.push(this.getValue(option));\n              this.selectedOptionLabels.push(this.asyncLabel\n                ? await this.asyncLabel(object) :this.getOptionLabel(option));\n              break;\n            }\n          }\n        }\n        this.onTouched();\n        this.onChange.emit({ value: this.selectedOptions });\n        return;\n      }\n      this.selectedOptions = obj;\n      for (let object of obj) {\n        this.selectedOptionLabels.push(\n          this.asyncLabel\n            ? await this.asyncLabel(object)\n            : this.getOptionLabel(object)\n        );\n      }\n      this.onTouched();\n      this.onChange.emit({ value: this.selectedOptions });\n    }\n  }\n\n  getOptionFromValue(value: any): any {\n    if (!this.optionValue) {\n      return this.group ? value.value : value;\n    }\n    const index = this.group\n      ? this.options.findIndex(\n          (x) =>\n            x.value[this.optionValue!] && x.value[this.optionValue!] == value\n        )\n      : this.options.findIndex(\n          (x) => x[this.optionValue!] && x[this.optionValue!] == value\n        );\n    if (index < 0) {\n      return this.group ? value.value : value;\n    }\n    return this.options[index];\n  }\n\n  registerOnChange(fn: any): void {\n    this.onItemChange = fn;\n  }\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  getValue(item: any): any {\n    if (!this.optionValue) {\n      return this.group ? item.value : item;\n    }\n    return this.group ? item.value[this.optionValue] : item[this.optionValue];\n  }\n  getOptionLabel(item: any): any {\n    if (this.group) {\n      return item.label;\n    }\n    if (!this.optionLabel) {\n      return item;\n    }\n    return typeof item === 'string' ? item : item[this.optionLabel];\n  }\n\n  private isDropdownMenuItemWrapperArray(value: any[]): boolean {\n    return (\n      Array.isArray(value) &&\n      value.every((item) => this.isDropdownMenuItemWrapper(item))\n    );\n  }\n\n  // Type guard function to check if an object is of type DropdownMenuItem\n  private isDropdownMenuItemWrapper(item: any): boolean {\n    return 'expanded' in item;\n  }\n\n  @HostListener('document:click', ['$event'])\n  onClickOutside(event: Event) {\n    if (!this.isExpanded) {\n      return;\n    }\n    if (\n      !this.dropdownContainer.nativeElement.contains(event.target) &&\n      this.isExpanded &&\n      this.dropdownExpansion &&\n      !this.dropdownExpansion.nativeElement.contains(event.target)\n    ) {\n      this.isExpanded = false;\n    }\n  }\n}\n","<div #dropdownContainer [ngClass]=\"styleClass\" [style.width]=\"width\" class=\"drop-down\">\n  <div\n    [ngClass]=\"{'right-error': errorPosition == 'right', 'left-error': errorPosition == 'left', 'top-error': errorPosition == 'top'}\"\n    class=\"drop-down-input-wrapper\">\n    <div (click)=\"onDropdownClick($event)\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\" [class.focused]=\"isFocused\"\n      [ngClass]=\"{'ng-invalid': isInvalid, 'disabled': disabled}\" (focus)=\"onFocus()\" (blur)=\"onBlur()\" tabindex=\"0\"\n      class=\"drop-down-input verben-input flex\">\n      <div class=\"drop-down-main-content\">\n        <ng-container\n          *ngIf=\"(selectedItemTemplate && selectedOption) || (selectedItemTemplate && selectedOptions.length > 0); else defaultItem\">\n          <div *ngIf=\"!multiselect\">\n            <ng-container\n              *ngTemplateOutlet=\"selectedItemTemplate; context: { $implicit: selectedOption }\"></ng-container>\n          </div>\n          <div *ngIf=\"multiselect\">\n            <ng-container\n              *ngTemplateOutlet=\"selectedItemTemplate; context: { $implicit: selectedOptions }\"></ng-container>\n          </div>\n        </ng-container>\n\n        <ng-template #defaultItem>\n          <div *ngIf=\"!multiselect\" class=\"default-item flex\">\n            <div class=\"dropdown-label place-holder\" *ngIf=\"!this.selectedOption\">{{placeholder}}</div>\n            <div *ngIf=\"this.selectedOption\" class=\"item-label dropdown-label\">\n              {{this.selectedOptionLabel}}</div>\n          </div>\n          <div *ngIf=\"multiselect\" class=\"default-item multi-select flex\">\n            <div class=\"dropdown-label place-holder\" *ngIf=\"this.selectedOptions.length == 0\">{{placeholder}}</div>\n            <verben-tooltip customClass=\"custom-tooltip-width\" border=\"1px solid #334155\" backgroundColor=\"white\"\n              [tooltipContent]=\"multiselectTooltip\">\n              <div *ngIf=\"this.selectedOptions.length > 0\" class=\"item-label dropdown-label\">\n                <div *ngIf=\"display == 'chip'\" class=\"multiselect-items-container-two chip\">\n                  <span *ngFor=\"let item of selectedOptionLabels; index as i\"\n                    class=\"multiselect-item-chip multi-select flex\">\n                    <span>{{item}}</span>\n                    <verben-svg (click)=\"onMultiselectItemClosed(i, $event); $event.stopPropagation();\"\n                      icon=\"close-circle-full\" [width]=\"15\" [height]=\"15\"></verben-svg>\n                    <!-- <svg (click)=\"onMultiselectItemClosed(i, $event); $event.stopPropagation();\" width=\"10\" height=\"10\"\n                      viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path\n                        d=\"M5.00065 9.33333C7.30184 9.33333 9.16732 7.46785 9.16732 5.16667C9.16732 2.86548 7.30184 1 5.00065 1C2.69946 1 0.833984 2.86548 0.833984 5.16667C0.833984 7.46785 2.69946 9.33333 5.00065 9.33333Z\"\n                        stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M6.25 3.91797L3.75 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M3.75 3.91797L6.25 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg> -->\n                  </span>\n                </div>\n                <div *ngIf=\"display != 'chip'\" class=\"multiselect-items-container-two normal\">\n                  <span *ngFor=\"let item of selectedOptionLabels; index as i\" class=\"multiselect-item\">\n                    {{i !== selectedOptionLabels.length - 1? item + ', ':item}}\n                  </span>\n                </div>\n              </div>\n            </verben-tooltip>\n            <ng-template #multiselectTooltip>\n              <div class=\"multi-select-full-view\">\n                <div *ngIf=\"this.selectedOptions.length > 0\" class=\"item-label dropdown-label\">\n                  <div *ngIf=\"display == 'chip'\" class=\"multiselect-items-container-two-tooltip chip\">\n                    <span *ngFor=\"let item of selectedOptionLabels; index as i\"\n                      class=\"multiselect-item-chip multi-select flex\">\n                      <span>{{item}}</span>\n                      <verben-svg (click)=\"onMultiselectItemClosed(i, $event); $event.stopPropagation();\"\n                        icon=\"close-circle-full\" [width]=\"15\" [height]=\"15\"></verben-svg>\n                      <!-- <svg (click)=\"onMultiselectItemClosed(i, $event); $event.stopPropagation();\" width=\"10\" height=\"10\"\n                        viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                        <path\n                          d=\"M5.00065 9.33333C7.30184 9.33333 9.16732 7.46785 9.16732 5.16667C9.16732 2.86548 7.30184 1 5.00065 1C2.69946 1 0.833984 2.86548 0.833984 5.16667C0.833984 7.46785 2.69946 9.33333 5.00065 9.33333Z\"\n                          stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                        <path d=\"M6.25 3.91797L3.75 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\"\n                          stroke-linejoin=\"round\" />\n                        <path d=\"M3.75 3.91797L6.25 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\"\n                          stroke-linejoin=\"round\" />\n                      </svg> -->\n                    </span>\n                  </div>\n                  <div *ngIf=\"display != 'chip'\" class=\"multiselect-items-container-two-tooltip-normal\">\n                    <span *ngFor=\"let item of selectedOptionLabels; index as i\" class=\"multiselect-item\">\n                      {{i !== selectedOptionLabels.length - 1? item + ', ':item}}\n                    </span>\n                  </div>\n                </div>\n              </div>\n            </ng-template>\n          </div>\n        </ng-template>\n      </div>\n      <span\n        *ngIf=\"(showClear && this.selectedOption && !multiselect) || (showClear && this.selectedOptions.length > 0 && multiselect)\"\n        (click)=\"this.clearSelection($event); $event.stopPropagation()\"\n        class=\"drop-down-icon-item drop-down-clear-button\">\n        <verben-svg icon=\"close-no-circle\" stroke=\"#94a3b8\" [width]=\"13\" [height]=\"13\"></verben-svg>\n        <!-- <svg width=\"9\" height=\"9\" viewBox=\"0 0 9 9\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M0.84375 0.84375L8.15625 8.15625\" stroke=\"currentColor\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M0.84375 8.15625L8.15625 0.84375\" stroke=\"currentColor\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg> -->\n      </span>\n      <span class=\"drop-down-icon-item drop-down-expand-button\">\n        <verben-svg icon=\"chevron-down\" fill=\"#94a3b8\" [width]=\"15\" [height]=\"8\"></verben-svg>\n        <!-- <svg width=\"12\" height=\"7\" viewBox=\"0 0 12 7\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M6.00507 4.88027C6.20205 4.62775 6.30683 4.4622 6.44095 4.32704C7.74334 3.01731 9.05202 1.71387 10.3576 0.406242C10.5713 0.192495 10.7882 0.00913367 11.1193 0.0101814C11.4692 0.0112292 11.7228 0.15792 11.8884 0.456537C12.057 0.760394 12.0309 1.06111 11.8349 1.34296C11.7658 1.4425 11.6767 1.52737 11.5908 1.61433C9.98873 3.21639 8.37305 4.80483 6.793 6.42784C6.29111 6.94335 5.68759 6.92344 5.21399 6.43832C3.63184 4.8174 2.01826 3.22687 0.414109 1.62691C0.116539 1.32934 -0.116067 1.0192 0.0620561 0.565507C0.271612 0.031139 0.883519 -0.167941 1.35502 0.157919C1.49647 0.255363 1.61592 0.387385 1.73955 0.509975C3.02204 1.79036 4.30452 3.07075 5.58386 4.35533C5.70645 4.47792 5.80284 4.62671 6.00611 4.88132L6.00507 4.88027Z\"\n            fill=\"currentColor\" />\n        </svg> -->\n      </span>\n    </div>\n    <div *ngIf=\"this.isInvalid && this.invalidMessage\" class=\"verben-error-message error-message\">{{invalidMessage}}\n    </div>\n  </div>\n  <ng-template cdkConnectedOverlay [cdkConnectedOverlayWidth]=\"dropdownContainer.offsetWidth\"\n    [cdkConnectedOverlayLockPosition]=\"false\" [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayPositions]=\"[\n    {\n      originX: 'start',\n      originY: 'bottom',\n      overlayX: 'start',\n      overlayY: 'top'\n    },\n    {\n      originX: 'start',\n      originY: 'top',\n      overlayX: 'start',\n      overlayY: 'bottom'\n    }\n  ]\" [cdkConnectedOverlayOpen]=\"isExpanded\" (detach)=\"isExpanded = false\">\n    <div #dropdownExpansion class=\"drop-down-menu-item-wrapper\">\n      <div *ngIf=\"multiselect && this.selectedOptions.length > 0\">\n        <div *ngIf=\"display == 'chip'\" class=\"multiselect-items-container chip flex\">\n          <span *ngFor=\"let item of selectedOptionLabels; index as i\" class=\"multiselect-item-chip flex\">\n            <span>{{item}}</span>\n            <verben-svg (click)=\"onMultiselectItemClosed(i, $event)\" icon=\"close-circle-full\" [width]=\"15\"\n              [height]=\"15\"></verben-svg>\n            <!-- <svg (click)=\"onMultiselectItemClosed(i, $event)\" width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                d=\"M5.00065 9.33333C7.30184 9.33333 9.16732 7.46785 9.16732 5.16667C9.16732 2.86548 7.30184 1 5.00065 1C2.69946 1 0.833984 2.86548 0.833984 5.16667C0.833984 7.46785 2.69946 9.33333 5.00065 9.33333Z\"\n                stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n              <path d=\"M6.25 3.91797L3.75 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n              <path d=\"M3.75 3.91797L6.25 6.41797\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            </svg> -->\n          </span>\n        </div>\n        <div *ngIf=\"display != 'chip'\" class=\"multiselect-items-container normal\">\n          <span *ngFor=\"let item of selectedOptionLabels; index as i\" class=\"multiselect-item\">\n            {{i !== selectedOptionLabels.length - 1? item + ', ':item}}\n          </span>\n        </div>\n      </div>\n      <div *ngIf=\"allowSelectAll || filter\" class=\"actions-section flex\">\n        <input *ngIf=\"allowSelectAll\" (click)=\"onSelectAll($event)\" type=\"checkbox\" [(ngModel)]=\"selectedAll\"\n          class=\"custom-checkbox\" />\n        <span class=\"select-all-caption\" *ngIf=\"allowSelectAll && !filter\">Select All</span>\n        <div *ngIf=\"filter\" [ngClass]=\"{'focused': isInputFocused}\" tabindex=\"0\" (focus)=\"onSearchFocus()\"\n          (blur)=\"onSearchBlur()\" class=\"search-section flex\">\n          <span class=\"search-icon flex\">\n            <verben-svg icon=\"search\" stroke=\"#64748b\" [width]=\"15\" [height]=\"15\"></verben-svg>\n            <!-- <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n              <circle cx=\"9\" cy=\"9\" r=\"8\" stroke=\"currentColor\" stroke-width=\"2\" fill=\"none\"></circle>\n              <line x1=\"14\" y1=\"14\" x2=\"19\" y2=\"19\" stroke=\"currentColor\" stroke-width=\"2\"></line>\n            </svg> -->\n          </span>\n          <span *ngIf=\"this.selectedContexts[this.selectedContexts.length - 1]\" class=\"search-context\">\n            {{this.getOptionLabel(this.selectedContexts[this.selectedContexts.length - 1])}}\n          </span>\n          <div class=\"search-input-container\">\n            <input (input)=\"onSearch($event)\" [(ngModel)]=\"searchContext\" (focus)=\"onInputFocus()\"\n              (blur)=\"onInputBlur()\" placeholder=\"Search...\" class=\"search-input\" />\n          </div>\n        </div>\n      </div>\n      <div *ngIf=\"showHorizontalLine\" class=\"colored-underline-section\">\n        <hr [style.background-color]=\"horizontalLineColor\" class=\"colored-underline\" />\n      </div>\n      <div class=\"drop-down-menu-item\">\n        <drop-down-item [itemTemplate]=\"itemTemplate\" [groupTemplate]=\"groupTemplate\" [activeItem]=\"selectedOption\"\n          [activeItems]=\"selectedOptions\" [multiselect]=\"multiselect\" [optionValue]=\"optionValue\"\n          [optionLabel]=\"optionLabel\" [optionSubLabel]=\"optionSubLabel\" [selectKey]=\"selectKey\"\n          [loadMoreCaption]=\"loadMoreCaption\" [options]=\"options\" [group]=\"group\" [onExpand]=\"expandMenu.bind(this)\"\n          [onLoadMore]=\"loadMoreMenuItems.bind(this)\" [onSelect]=\"onSelect.bind(this)\"></drop-down-item>\n        <div *ngIf=\"lazyLoad\">\n          <div class=\"see-more-container flex justify-end\">\n            <span class=\"see-more-caption\" (click)=\"loadMore()\">{{loadMoreCaption}}</span>\n          </div>\n        </div>\n        <div *ngIf=\"isLoading\" class=\"loading-overlay\">\n          <div class=\"loader\"></div>\n        </div>\n      </div>\n    </div>\n  </ng-template>\n</div>\n"]}
@@ -13,6 +13,7 @@ export class NumberInputComponent {
13
13
  max;
14
14
  step = 1;
15
15
  value = 0;
16
+ label = '';
16
17
  controlButton = false;
17
18
  valueChange = new EventEmitter();
18
19
  onChange = (value) => { };
@@ -76,11 +77,11 @@ export class NumberInputComponent {
76
77
  // Optional: Implement if you want to disable the input field
77
78
  }
78
79
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: NumberInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
79
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.10", type: NumberInputComponent, selector: "verben-number-input", inputs: { min: "min", max: "max", step: "step", value: "value", controlButton: "controlButton" }, outputs: { valueChange: "valueChange" }, providers: [NUMBER_INPUT_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"input-container {{ inputContainerClass }}\">\n <input\n type=\"number\"\n [value]=\"value\"\n (input)=\"onInput($event)\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"step\"\n (blur)=\"validateValue()\"\n class=\"input-field verben-input {{ inputWrapperClass }}\"\n />\n\n </div>\n <p class=\"error-message\" *ngIf=\"errorMessage\">{{ errorMessage }}</p>\n ", styles: ["*{font-family:sans-serif;font-size:.9rem}.w-100{width:100%}.h-100{height:100%}.flex{display:flex}.flex-col{flex-direction:column}.font-bold{font-weight:700}.justify-center{justify-content:center}.justify-end{justify-content:end}.align-items-center{align-items:center}.grid{display:grid}.verben-error-message{font-size:.8rem;color:red}.verben-input{border:1px solid #cbd5e1;outline:none;border-radius:5px;color:#334155;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s,outline-color .2s}.verben-input::placeholder{color:#64748b}.verben-input:hover{border:1px solid #697e97}.verben-input.disabled{opacity:1;background-color:light-dark(rgba(239,239,239,.3),rgba(59,59,59,.3));pointer-events:none;color:#64748b}.verben-input:disabled{opacity:1;background-color:light-dark(rgba(239,239,239,.3),rgba(59,59,59,.3));pointer-events:none;color:#64748b}.verben-input.focused{border-color:#3b82f6;outline:none}.verben-input:focus{border-color:#3b82f6;outline:none}.verben-input.ng-invalid{border-color:red}.verben-button{padding:8px 15px;border-radius:4px;border:none;text-align:center}.verben-button.primary{background-color:#ffe681}.verben-button.secondary{background-color:#d9d9d940}.input-container{width:100%}.verben-input{width:100%;background-color:#f9f9f9;border-radius:5px;color:#333;font-size:14px;padding:8px}.number-input{display:flex;align-items:center;border:1px solid #ccc;border-radius:4px;overflow:hidden;width:max-content}.number-input button{background-color:#f0f0f0;border:none;padding:5px 10px;cursor:pointer;font-size:16px}.number-input input{width:50px;text-align:center;border:none;outline:none;font-size:16px}.number-input button:disabled{opacity:.5;cursor:not-allowed}.error-message{color:red;font-size:12px;margin-top:5px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
80
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.10", type: NumberInputComponent, selector: "verben-number-input", inputs: { min: "min", max: "max", step: "step", value: "value", label: "label", controlButton: "controlButton" }, outputs: { valueChange: "valueChange" }, providers: [NUMBER_INPUT_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"input-container {{ inputContainerClass }}\"\n[ngStyle]=\"{\n 'display': 'flex',\n 'flex-direction': 'column'\n }\"\n>\n <div [ngStyle]=\"{\n 'width': '100%',\n 'display': 'flex',\n 'justify-content':'space-between'\n\n }\">\n <label [for]=\"label\">{{ label }}</label>\n <!-- incase i need it back -->\n <!-- <div *ngIf=\" passwordToggle === true\" [ngStyle]=\"{\n\n 'display': 'flex',\n 'align-item':'center',\n 'gap':'4px',\n 'color':'grey',\n 'cursor':'pointer'\n\n }\"\n (click)=\"toggleIcon()\"\n >\n <verben-svg\n [icon]=\"icon\"\n [width]=\"20\"\n [height]=\"20\"\n color=\"black\"\n ></verben-svg>\n <p>{{ textPass }}</p>\n </div> -->\n </div>\n <input\n type=\"number\"\n [value]=\"value\"\n (input)=\"onInput($event)\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"step\"\n (blur)=\"validateValue()\"\n class=\"input-field verben-input {{ inputWrapperClass }}\"\n />\n\n </div>\n <p class=\"error-message\" *ngIf=\"errorMessage\">{{ errorMessage }}</p>\n ", styles: ["*{font-family:sans-serif;font-size:.9rem}.w-100{width:100%}.h-100{height:100%}.flex{display:flex}.flex-col{flex-direction:column}.font-bold{font-weight:700}.justify-center{justify-content:center}.justify-end{justify-content:end}.align-items-center{align-items:center}.grid{display:grid}.verben-error-message{font-size:.8rem;color:red}.verben-input{border:1px solid #cbd5e1;outline:none;border-radius:5px;color:#334155;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s,outline-color .2s}.verben-input::placeholder{color:#64748b}.verben-input:hover{border:1px solid #697e97}.verben-input.disabled{opacity:1;background-color:light-dark(rgba(239,239,239,.3),rgba(59,59,59,.3));pointer-events:none;color:#64748b}.verben-input:disabled{opacity:1;background-color:light-dark(rgba(239,239,239,.3),rgba(59,59,59,.3));pointer-events:none;color:#64748b}.verben-input.focused{border-color:#3b82f6;outline:none}.verben-input:focus{border-color:#3b82f6;outline:none}.verben-input.ng-invalid{border-color:red}.verben-button{padding:8px 15px;border-radius:4px;border:none;text-align:center}.verben-button.primary{background-color:#ffe681}.verben-button.secondary{background-color:#d9d9d940}.input-container{width:100%}.verben-input{width:100%;background-color:#f9f9f9;border-radius:5px;color:#333;font-size:14px;padding:8px}.number-input{display:flex;align-items:center;border:1px solid #ccc;border-radius:4px;overflow:hidden;width:max-content}.number-input button{background-color:#f0f0f0;border:none;padding:5px 10px;cursor:pointer;font-size:16px}.number-input input{width:50px;text-align:center;border:none;outline:none;font-size:16px}.number-input button:disabled{opacity:.5;cursor:not-allowed}.error-message{color:red;font-size:12px;margin-top:5px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
80
81
  }
81
82
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: NumberInputComponent, decorators: [{
82
83
  type: Component,
83
- args: [{ selector: 'verben-number-input', providers: [NUMBER_INPUT_VALUE_ACCESSOR], template: "<div class=\"input-container {{ inputContainerClass }}\">\n <input\n type=\"number\"\n [value]=\"value\"\n (input)=\"onInput($event)\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"step\"\n (blur)=\"validateValue()\"\n class=\"input-field verben-input {{ inputWrapperClass }}\"\n />\n\n </div>\n <p class=\"error-message\" *ngIf=\"errorMessage\">{{ errorMessage }}</p>\n ", styles: ["*{font-family:sans-serif;font-size:.9rem}.w-100{width:100%}.h-100{height:100%}.flex{display:flex}.flex-col{flex-direction:column}.font-bold{font-weight:700}.justify-center{justify-content:center}.justify-end{justify-content:end}.align-items-center{align-items:center}.grid{display:grid}.verben-error-message{font-size:.8rem;color:red}.verben-input{border:1px solid #cbd5e1;outline:none;border-radius:5px;color:#334155;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s,outline-color .2s}.verben-input::placeholder{color:#64748b}.verben-input:hover{border:1px solid #697e97}.verben-input.disabled{opacity:1;background-color:light-dark(rgba(239,239,239,.3),rgba(59,59,59,.3));pointer-events:none;color:#64748b}.verben-input:disabled{opacity:1;background-color:light-dark(rgba(239,239,239,.3),rgba(59,59,59,.3));pointer-events:none;color:#64748b}.verben-input.focused{border-color:#3b82f6;outline:none}.verben-input:focus{border-color:#3b82f6;outline:none}.verben-input.ng-invalid{border-color:red}.verben-button{padding:8px 15px;border-radius:4px;border:none;text-align:center}.verben-button.primary{background-color:#ffe681}.verben-button.secondary{background-color:#d9d9d940}.input-container{width:100%}.verben-input{width:100%;background-color:#f9f9f9;border-radius:5px;color:#333;font-size:14px;padding:8px}.number-input{display:flex;align-items:center;border:1px solid #ccc;border-radius:4px;overflow:hidden;width:max-content}.number-input button{background-color:#f0f0f0;border:none;padding:5px 10px;cursor:pointer;font-size:16px}.number-input input{width:50px;text-align:center;border:none;outline:none;font-size:16px}.number-input button:disabled{opacity:.5;cursor:not-allowed}.error-message{color:red;font-size:12px;margin-top:5px}\n"] }]
84
+ args: [{ selector: 'verben-number-input', providers: [NUMBER_INPUT_VALUE_ACCESSOR], template: "<div class=\"input-container {{ inputContainerClass }}\"\n[ngStyle]=\"{\n 'display': 'flex',\n 'flex-direction': 'column'\n }\"\n>\n <div [ngStyle]=\"{\n 'width': '100%',\n 'display': 'flex',\n 'justify-content':'space-between'\n\n }\">\n <label [for]=\"label\">{{ label }}</label>\n <!-- incase i need it back -->\n <!-- <div *ngIf=\" passwordToggle === true\" [ngStyle]=\"{\n\n 'display': 'flex',\n 'align-item':'center',\n 'gap':'4px',\n 'color':'grey',\n 'cursor':'pointer'\n\n }\"\n (click)=\"toggleIcon()\"\n >\n <verben-svg\n [icon]=\"icon\"\n [width]=\"20\"\n [height]=\"20\"\n color=\"black\"\n ></verben-svg>\n <p>{{ textPass }}</p>\n </div> -->\n </div>\n <input\n type=\"number\"\n [value]=\"value\"\n (input)=\"onInput($event)\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"step\"\n (blur)=\"validateValue()\"\n class=\"input-field verben-input {{ inputWrapperClass }}\"\n />\n\n </div>\n <p class=\"error-message\" *ngIf=\"errorMessage\">{{ errorMessage }}</p>\n ", styles: ["*{font-family:sans-serif;font-size:.9rem}.w-100{width:100%}.h-100{height:100%}.flex{display:flex}.flex-col{flex-direction:column}.font-bold{font-weight:700}.justify-center{justify-content:center}.justify-end{justify-content:end}.align-items-center{align-items:center}.grid{display:grid}.verben-error-message{font-size:.8rem;color:red}.verben-input{border:1px solid #cbd5e1;outline:none;border-radius:5px;color:#334155;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s,outline-color .2s}.verben-input::placeholder{color:#64748b}.verben-input:hover{border:1px solid #697e97}.verben-input.disabled{opacity:1;background-color:light-dark(rgba(239,239,239,.3),rgba(59,59,59,.3));pointer-events:none;color:#64748b}.verben-input:disabled{opacity:1;background-color:light-dark(rgba(239,239,239,.3),rgba(59,59,59,.3));pointer-events:none;color:#64748b}.verben-input.focused{border-color:#3b82f6;outline:none}.verben-input:focus{border-color:#3b82f6;outline:none}.verben-input.ng-invalid{border-color:red}.verben-button{padding:8px 15px;border-radius:4px;border:none;text-align:center}.verben-button.primary{background-color:#ffe681}.verben-button.secondary{background-color:#d9d9d940}.input-container{width:100%}.verben-input{width:100%;background-color:#f9f9f9;border-radius:5px;color:#333;font-size:14px;padding:8px}.number-input{display:flex;align-items:center;border:1px solid #ccc;border-radius:4px;overflow:hidden;width:max-content}.number-input button{background-color:#f0f0f0;border:none;padding:5px 10px;cursor:pointer;font-size:16px}.number-input input{width:50px;text-align:center;border:none;outline:none;font-size:16px}.number-input button:disabled{opacity:.5;cursor:not-allowed}.error-message{color:red;font-size:12px;margin-top:5px}\n"] }]
84
85
  }], propDecorators: { min: [{
85
86
  type: Input
86
87
  }], max: [{
@@ -89,9 +90,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
89
90
  type: Input
90
91
  }], value: [{
91
92
  type: Input
93
+ }], label: [{
94
+ type: Input
92
95
  }], controlButton: [{
93
96
  type: Input
94
97
  }], valueChange: [{
95
98
  type: Output
96
99
  }] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/number-input/number-input.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/number-input/number-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  forwardRef\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR\n} from '@angular/forms';\n\n// ✅ FIX: Define provider constant outside the component\nconst NUMBER_INPUT_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => NumberInputComponent),\n  multi: true,\n};\n\n@Component({\n  selector: 'verben-number-input',\n  templateUrl: './number-input.component.html',\n  styleUrls: ['./number-input.component.css'],\n  providers: [NUMBER_INPUT_VALUE_ACCESSOR],\n})\nexport class NumberInputComponent implements ControlValueAccessor {\n  @Input() min?: number;\n  @Input() max?: number;\n  @Input() step: number = 1;\n  @Input() value: number = 0;\n  @Input() controlButton: boolean = false;\n\n  @Output() valueChange = new EventEmitter<number>();\n\n  private onChange = (value: number) => {};\n  private onTouched = () => {};\n\n  errorMessage: string = '';\n  inputContainerClass: any;\n  inputWrapperClass: any;\n\n  increase() {\n    if (this.max === undefined || this.value + this.step <= this.max) {\n      this.value += this.step;\n      this.validateValue();\n      this.valueChange.emit(this.value);\n      this.notifyValueChange();\n    }\n  }\n\n  decrease() {\n    if (this.min === undefined || this.value - this.step >= this.min) {\n      this.value -= this.step;\n      this.validateValue();\n      this.valueChange.emit(this.value);\n      this.notifyValueChange();\n    }\n  }\n\n  onInput(event: Event) {\n    const inputValue = (event.target as HTMLInputElement).value;\n    let newValue = Number(inputValue);\n    this.value = newValue;\n    this.validateValue();\n    this.notifyValueChange();\n  }\n\n  validateValue() {\n    if (this.min !== undefined && this.value < this.min) {\n      this.value = this.min;\n      this.errorMessage = `Value must be at least ${this.min}`;\n    } else if (this.max !== undefined && this.value > this.max) {\n      this.value = this.max;\n      this.errorMessage = `Value cannot exceed ${this.max}`;\n    } else {\n      this.errorMessage = '';\n    }\n\n    this.valueChange.emit(this.value);\n  }\n\n  notifyValueChange() {\n    this.onChange(this.value);\n    this.onTouched();\n  }\n\n  // Control Value Accessor methods\n  writeValue(value: number): void {\n    this.value = value ?? 0;\n    this.validateValue();\n  }\n\n  registerOnChange(fn: (value: number) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    // Optional: Implement if you want to disable the input field\n  }\n}\n","<div class=\"input-container {{ inputContainerClass }}\">\n    <input\n      type=\"number\"\n      [value]=\"value\"\n      (input)=\"onInput($event)\"\n      [min]=\"min\"\n      [max]=\"max\"\n      [step]=\"step\"\n      (blur)=\"validateValue()\"\n      class=\"input-field verben-input {{ inputWrapperClass }}\"\n    />\n\n  </div>\n  <p class=\"error-message\" *ngIf=\"errorMessage\">{{ errorMessage }}</p>\n  "]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/number-input/number-input.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/number-input/number-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  forwardRef\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR\n} from '@angular/forms';\n\n// ✅ FIX: Define provider constant outside the component\nconst NUMBER_INPUT_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => NumberInputComponent),\n  multi: true,\n};\n\n@Component({\n  selector: 'verben-number-input',\n  templateUrl: './number-input.component.html',\n  styleUrls: ['./number-input.component.css'],\n  providers: [NUMBER_INPUT_VALUE_ACCESSOR],\n})\nexport class NumberInputComponent implements ControlValueAccessor {\n  @Input() min?: number;\n  @Input() max?: number;\n  @Input() step: number = 1;\n  @Input() value: number = 0;\n  @Input() label?: string = '';\n  @Input() controlButton: boolean = false;\n\n  @Output() valueChange = new EventEmitter<number>();\n\n  private onChange = (value: number) => {};\n  private onTouched = () => {};\n\n  errorMessage: string = '';\n  inputContainerClass: any;\n  inputWrapperClass: any;\n\n  increase() {\n    if (this.max === undefined || this.value + this.step <= this.max) {\n      this.value += this.step;\n      this.validateValue();\n      this.valueChange.emit(this.value);\n      this.notifyValueChange();\n    }\n  }\n\n  decrease() {\n    if (this.min === undefined || this.value - this.step >= this.min) {\n      this.value -= this.step;\n      this.validateValue();\n      this.valueChange.emit(this.value);\n      this.notifyValueChange();\n    }\n  }\n\n  onInput(event: Event) {\n    const inputValue = (event.target as HTMLInputElement).value;\n    let newValue = Number(inputValue);\n    this.value = newValue;\n    this.validateValue();\n    this.notifyValueChange();\n  }\n\n  validateValue() {\n    if (this.min !== undefined && this.value < this.min) {\n      this.value = this.min;\n      this.errorMessage = `Value must be at least ${this.min}`;\n    } else if (this.max !== undefined && this.value > this.max) {\n      this.value = this.max;\n      this.errorMessage = `Value cannot exceed ${this.max}`;\n    } else {\n      this.errorMessage = '';\n    }\n\n    this.valueChange.emit(this.value);\n  }\n\n  notifyValueChange() {\n    this.onChange(this.value);\n    this.onTouched();\n  }\n\n  // Control Value Accessor methods\n  writeValue(value: number): void {\n    this.value = value ?? 0;\n    this.validateValue();\n  }\n\n  registerOnChange(fn: (value: number) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    // Optional: Implement if you want to disable the input field\n  }\n}\n","<div class=\"input-container {{ inputContainerClass }}\"\n[ngStyle]=\"{\n  'display': 'flex',\n  'flex-direction': 'column'\n }\"\n>\n    <div [ngStyle]=\"{\n      'width': '100%',\n      'display': 'flex',\n      'justify-content':'space-between'\n\n    }\">\n      <label [for]=\"label\">{{ label }}</label>\n      <!-- incase i need it back  -->\n      <!-- <div *ngIf=\" passwordToggle === true\" [ngStyle]=\"{\n\n        'display': 'flex',\n        'align-item':'center',\n        'gap':'4px',\n        'color':'grey',\n        'cursor':'pointer'\n\n      }\"\n      (click)=\"toggleIcon()\"\n      >\n        <verben-svg\n        [icon]=\"icon\"\n        [width]=\"20\"\n        [height]=\"20\"\n        color=\"black\"\n      ></verben-svg>\n      <p>{{ textPass }}</p>\n    </div> -->\n    </div>\n    <input\n      type=\"number\"\n      [value]=\"value\"\n      (input)=\"onInput($event)\"\n      [min]=\"min\"\n      [max]=\"max\"\n      [step]=\"step\"\n      (blur)=\"validateValue()\"\n      class=\"input-field verben-input {{ inputWrapperClass }}\"\n    />\n\n  </div>\n  <p class=\"error-message\" *ngIf=\"errorMessage\">{{ errorMessage }}</p>\n  "]}