ca-components 1.4.61 → 1.4.63

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.
@@ -148,6 +148,7 @@ export class CaInputDropdownTestComponent {
148
148
  return this.superControl.control;
149
149
  }
150
150
  writeValue(value) {
151
+ console.log("WRITE VALUE FIRST", value);
151
152
  this.firstWriteValue = value;
152
153
  this.writeValueToFormControl(value);
153
154
  }
@@ -705,4 +706,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
705
706
  type: Output,
706
707
  args: ['searchInputEvent']
707
708
  }] } });
708
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-dropdown-test.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input-dropdown-test/ca-input-dropdown-test.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input-dropdown-test/ca-input-dropdown-test.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Renderer2, ViewEncapsulation } from '@angular/core';\nimport {\n    AfterViewInit,\n    Component,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport {\n    debounceTime,\n    distinctUntilChanged,\n    skip,\n    Subject,\n    takeUntil,\n} from 'rxjs';\n\n// bootstrap\nimport {\n    NgbPopover,\n    NgbPopoverModule,\n    NgbModule,\n} from '@ng-bootstrap/ng-bootstrap';\n\n// animation\nimport { inputDropdownAnimation } from './animations';\n\n// components\nimport { CaInputDropdownLoadBrokerComponent } from './components/ca-input-dropdown-load-broker/ca-input-dropdown-load-broker.component';\nimport { CaInputDropdownLoadDispatchesTtdComponent } from './components/ca-input-dropdown-load-dispatches-ttd/ca-input-dropdown-load-dispatches-ttd.component';\nimport { CaInputDropdownLoadDispatcherComponent } from './components/ca-input-dropdown-load-dispatcher/ca-input-dropdown-load-dispatcher.component';\nimport { CaInputDropdownSvgTemplateComponent } from './components/ca-input-dropdown-svg-template/ca-input-dropdown-svg-template.component';\nimport { CaInputDropdownSvgtextTemplateComponent } from './components/ca-input-dropdown-svgtext-template/ca-input-dropdown-svgtext-template.component';\nimport { CaInputDropdownSvgtextDispatchTemplateComponent } from './components/ca-input-dropdown-svgtext-dispatch-template/ca-input-dropdown-svgtext-dispatch-template.component';\nimport { CaInputDropdownGroupsComponent } from './components/ca-input-dropdown-groups/ca-input-dropdown-groups.component';\nimport { CaInputDropdownMultiselectComponent } from './components/ca-input-dropdown-multiselect/ca-input-dropdown-multiselect.component';\nimport { CaInputDropdownLabelsComponent } from './components/ca-input-dropdown-labels/ca-input-dropdown-labels.component';\nimport { CaInputDropdownLoadBrokerContactComponent } from './components/ca-input-dropdown-load-broker-contact/ca-input-dropdown-load-broker-contact.component';\nimport { CaInputDropdownLoadBrokerShipperComponent } from './components/ca-input-dropdown-load-broker-shipper/ca-input-dropdown-load-broker-shipper.component';\nimport { CaInputDropdownTextCounterComponent } from './components/ca-input-dropdown-text-counter/ca-input-dropdown-text-counter.component';\nimport { CaInputDropdownDoubleTextTemplateComponent } from './components/ca-input-dropdown-double-text-template/ca-input-dropdown-double-text-template.component';\nimport { CaInputDropdownTripleTextTemplateComponent } from './components/ca-input-dropdown-triple-text-template/ca-input-dropdown-triple-text-template.component';\nimport { CaInputDropdownDefaultTemplateComponent } from './components/ca-input-dropdown-default-template/ca-input-dropdown-default-template.component';\nimport { CaInputDropdownFuelFranchiseComponent } from './components/ca-input-dropdown-fuel-franchise/ca-input-dropdown-fuel-franchise.component';\nimport { CaInputDropdownDispatchComponent } from './components/ca-input-dropdown-dispatch/ca-input-dropdown-dispatch.component';\nimport { CaInputDropdownDetailsTemplateComponent } from './components/ca-input-dropdown-details-template/ca-input-dropdown-details-template.component';\nimport { CaInputDropdownPayrollTrucksComponent } from './components/ca-input-dropdown-payroll-trucks/ca-input-dropdown-payroll-trucks.component';\nimport { CaInputDropdownLoadDispatchesTtdComponentItem } from './components/ca-input-dropdown-load-dispatches-ttd/ca-input-dropdown-load-dispatches-ttd-item/ca-input-dropdown-load-dispatches-ttd-item';\nimport { CaInputDropdownLoadBrokerComponentItem } from './components/ca-input-dropdown-load-broker/ca-input-dropdown-load-broker-item/ca-input-dropdown-load-broker-item.component';\nimport { CaInputDropdownLoadBrokerShipperItemComponent } from './components/ca-input-dropdown-load-broker-shipper/ca-input-dropdown-load-broker-shipper-item/ca-input-dropdown-load-broker-shipper-item.component';\nimport { CaInputDropdownLoadDispatcherItemComponent } from './components/ca-input-dropdown-load-dispatcher/ca-input-dropdown-load-dispatcher-item/ca-input-dropdown-load-dispatcher-item.component';\n\n// pipes\nimport { FormControlPipe } from '../ca-input/pipes';\nimport {\n    DropdownCountPipe,\n    InputDropdownGetIconsPipe,\n    InputDropdownMultiselectClassPipe,\n} from './pipes';\nimport { DropdownOptionsPipe } from './pipes/dropdown-options.pipe';\n\n// modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// directives\nimport {\n    ControlValueAccessor,\n    FormControl,\n    FormsModule,\n    NgControl,\n    ReactiveFormsModule,\n} from '@angular/forms';\n\n// models\nimport { CommandsEvent } from '../ca-input/models';\n\n// types\nimport {\n    AbstractControlWithNotFoundType,\n    FormControlWithNotFoundType,\n} from './types';\nimport { SelectDropdownValueType } from './types/select-dropdown-value.type';\n\n// svg routes\nimport { InputDropdownSvgRoutes } from './utils/svg-routes/input-dropdown-svg-routes';\n\n// enums\nimport { DropdownStringEnum, DropdownTemplateTypeEnum } from './enums';\n\n// helpers\nimport { uuidv4 } from '../../utils/helpers';\n\n// classes\nimport { EventInputManager } from '../ca-input/base-classes/ca-input-event-manager';\n\n// components\nimport { InputTestComponent } from '../ca-input-test/input-test.component';\nimport { CaLoadStatusStringComponent } from '../ca-load-status-string/ca-load-status-string.component';\nimport { CaProfileImageComponent } from '../ca-profile-image/ca-profile-image.component';\nimport { CaInputDropdownLoadBrokerContactItemComponent } from './components/ca-input-dropdown-load-broker-contact/ca-input-dropdown-load-broker-contact-item/ca-input-dropdown-load-broker-contact-item.component';\n\n// config\nimport { ICaInput } from '../ca-input-test/config';\n\n// interfaces\nimport { IOptionModel } from './interfaces/input-dropdown-option.interface';\n@Component({\n    selector: 'ca-input-dropdown-test',\n    templateUrl: './ca-input-dropdown-test.component.html',\n    styleUrls: ['./ca-input-dropdown-test.component.scss'],\n    standalone: true,\n    encapsulation: ViewEncapsulation.None,\n    providers: [FormControlPipe],\n    animations: [inputDropdownAnimation('showHideDropdownOptions')],\n    imports: [\n        // Module\n        CommonModule,\n        FormsModule,\n        NgbPopoverModule,\n        ReactiveFormsModule,\n        NgbModule,\n        AngularSvgIconModule,\n        // Component\n        CaProfileImageComponent,\n        CaLoadStatusStringComponent,\n        CaInputDropdownSvgtextTemplateComponent,\n        CaInputDropdownSvgtextDispatchTemplateComponent,\n        CaInputDropdownGroupsComponent,\n        CaInputDropdownMultiselectComponent,\n        CaInputDropdownLabelsComponent,\n        CaInputDropdownLoadBrokerComponent,\n        CaInputDropdownLoadDispatchesTtdComponent,\n        CaInputDropdownLoadDispatcherComponent,\n        CaInputDropdownLoadBrokerContactComponent,\n        CaInputDropdownLoadBrokerShipperComponent,\n        CaInputDropdownTextCounterComponent,\n        CaInputDropdownDoubleTextTemplateComponent,\n        CaInputDropdownTripleTextTemplateComponent,\n        CaInputDropdownDefaultTemplateComponent,\n        CaInputDropdownFuelFranchiseComponent,\n        CaInputDropdownDispatchComponent,\n        CaInputDropdownDetailsTemplateComponent,\n        CaInputDropdownPayrollTrucksComponent,\n        CaInputDropdownSvgTemplateComponent,\n        InputTestComponent,\n        CaInputDropdownLoadDispatchesTtdComponentItem,\n        CaInputDropdownLoadBrokerComponentItem,\n        CaInputDropdownLoadBrokerShipperItemComponent,\n        CaInputDropdownLoadDispatcherItemComponent,\n        CaInputDropdownLoadBrokerContactItemComponent,\n        // Pipes\n        FormControlPipe,\n        DropdownCountPipe,\n        InputDropdownMultiselectClassPipe,\n        DropdownOptionsPipe,\n        InputDropdownGetIconsPipe,\n    ],\n})\nexport class CaInputDropdownTestComponent\n    implements\n        OnInit,\n        AfterViewInit,\n        OnDestroy,\n        ControlValueAccessor,\n        AfterViewInit\n{\n    @ViewChild('input') inputRef!: InputTestComponent;\n    @ViewChild('t2') public popoverRef!: NgbPopover;\n    @ViewChild('dropdownComponentRef', { static: false })\n    dropdownComponentRef: any;\n\n    // Label input - value that will be showed inside input\n    @Input() label!: keyof IOptionModel;\n\n    // optionValue input - key value from object - Emit this if you want to set whole object\n    @Input() optionValue!: string;\n\n    public inputHoveredItem: number = -1;\n    public isDropDownIsOpen: boolean = false;\n\n    // different templates for body rendering\n    public _template!: string;\n    _canAddNew: boolean = false;\n\n    @Input() set template(value: string) {\n        this._template = value;\n    }\n\n    @Input() multiselectTemplate!: string;\n    @Input() inputConfig!: ICaInput;\n    @Input() set canAddNew(value: boolean) {\n        this._canAddNew = value;\n    } // ADD NEW item in options\n\n    public get canAddNew() {\n        return this._canAddNew;\n    }\n\n    @Input() canOpenModal!: boolean; // open modal with ADD NEW button\n\n    // sort-template for different options\n    public _sort!: string;\n    @Input() set sort(value: string) {\n        this._sort = value;\n    }\n\n    public get sort() {\n        return this._sort;\n    }\n\n    // currently active item\n    public _activeItem!: IOptionModel | null;\n    @Input() set activeItem(value: IOptionModel | null) {\n        this._activeItem = value;\n    }\n\n    public get activeItem() {\n        return this._activeItem;\n    }\n\n    @Input() activeItemColor!: IOptionModel | null; // currently active color in dropdown\n    @Input() labelMode!: 'Label' | 'Color';\n\n    // when send SVG, please premmaped object: add 'folder' | 'subfolder'\n    public _options: IOptionModel[] = [];\n    @Input() set options(values: IOptionModel[]) {\n        if (values) this._options = [...values];\n\n        console.log(\"update with optins\", values, this.firstWriteValue);\n        if (this.firstWriteValue) {\n            this.writeValueToFormControl(this.firstWriteValue);\n        }\n    }\n\n    // MultiSelect Selected Items From Backend\n    @Input() set preloadMultiselectItems(values: IOptionModel[]) {\n        if (this.inputConfig.multiselectDropdown) {\n            if (!values) {\n                this.deleteAllMultiSelectItems(this.inputConfig.label);\n                return;\n            }\n\n            if (values?.length) {\n                values.forEach((item) => {\n                    this.onMultiselectSelect(item);\n                });\n            }\n        }\n    }\n\n    @Input() isDetailsPages!: boolean; // only for details pages\n    @Input() isIncorrectValue!: boolean; // applicant review option\n    @Input() isAddressDropdown!: boolean; // only for address dropdown\n\n    @Output() selectedItem: EventEmitter<IOptionModel | null> =\n        new EventEmitter<IOptionModel | null>();\n    @Output() selectedItems: EventEmitter<IOptionModel[] | null> =\n        new EventEmitter<IOptionModel[] | null>();\n    @Output() selectedItemColor: EventEmitter<IOptionModel | null> =\n        new EventEmitter<IOptionModel | null>();\n    @Output() selectedLabelMode: EventEmitter<string> =\n        new EventEmitter<string>();\n    @Output() closeDropdown: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output() saveItem: EventEmitter<{\n        data: IOptionModel | null;\n        action: string;\n    }> = new EventEmitter<{ data: IOptionModel | null; action: string }>();\n    @Output() incorrectEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output() placeholderIconEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output('pagination') paginationEvent: EventEmitter<number> =\n        new EventEmitter<number>();\n    @Output('activeGroup') activeGroupEvent: EventEmitter<IOptionModel> =\n        new EventEmitter<IOptionModel>();\n    @Output('clearInputEvent') clearInputEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n\n    @Output('searchInputEvent') searchInputEvent: EventEmitter<string> =\n        new EventEmitter<string>();\n    // events\n    public searchInputText = new EventInputManager<string>(\n        null,\n        this.searchInputEvent\n    );\n\n    // Copy of Options\n    public originalOptions: IOptionModel[] = [];\n\n    // Pagination\n    public paginationNumber: number = 0;\n\n    // Multiselect dropdown options\n    public multiselectItems: IOptionModel[] = [];\n    public isMultiSelectInputFocus: boolean = false;\n    public multiSelectLabel!: string | undefined;\n    public lastActiveMultiselectItem!: IOptionModel | null;\n\n    // Add mode\n    public isInAddMode: boolean = false;\n\n    // Dropdown navigation with keyboard\n    private dropdownPosition: number = -1;\n\n    // Dropdown Cleartimeout\n    public clearTimeoutDropdown: string | number | NodeJS.Timeout | undefined;\n\n    public hoveringIndex!: number;\n    public inputDropdownSvgRoutes = InputDropdownSvgRoutes;\n    public dropdownTemplateTypeEnum = DropdownTemplateTypeEnum;\n\n    // Destroy\n    private destroy$ = new Subject<void>();\n\n    constructor(\n        @Self() public superControl: NgControl,\n        private cdRef: ChangeDetectorRef,\n        private renderer: Renderer2\n    ) {\n        this.superControl.valueAccessor = this;\n    }\n\n    get getSuperControl() {\n        return this.superControl.control;\n    }\n\n    public inputFormControl: FormControl = new FormControl(null);\n\n    public lastValidOption!: IOptionModel;\n    public firstWriteValue: any;\n    writeValue(value: string | number): void {\n        this.firstWriteValue = value;\n        this.writeValueToFormControl(value);\n    }\n\n    public writeValueToFormControl(value: string | number): void {\n        const findInOptions = this.inputConfig.searchinGroupIndex\n            ? this.getMainGroup()\n            : this._options;\n\n        let findOption = findInOptions.find(\n            (option) => option[this.optionValue as keyof IOptionModel] == value\n        );\n\n        let optionNotFound = false;\n        if (!findOption && value) {\n            findOption = {\n                [this.optionValue]: this.firstWriteValue,\n                [this.label]: this.firstWriteValue,\n            };\n            optionNotFound = true;\n        }\n\n        if (findOption) {\n            this.setDropdownValue({\n                option: findOption,\n                setNotFoundError: optionNotFound,\n            });\n        }\n    }\n\n    public setNotFoundInvalidFlag(value: boolean): void {\n        if (this.getSuperControl)\n            (\n                this.getSuperControl as AbstractControlWithNotFoundType\n            ).notFoundInvalid = value; // Attach dynamic values\n        (this.inputFormControl as FormControlWithNotFoundType).notFoundInvalid =\n            value; // Attach dynamic values\n    }\n\n    public onTouched = () => {};\n    public onChange(_: any): void {}\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    ngOnInit(): void {\n        // Multiselect\n        if (this.inputConfig.multiselectDropdown) {\n            this.multiSelectLabel = this.inputConfig.label;\n        }\n\n        this.inputFormControl.valueChanges\n            .pipe(\n                distinctUntilChanged(),\n                debounceTime(50),\n                skip(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe((searchText) => {\n                if (this.labelMode === 'Color') {\n                    return;\n                }\n\n                this.searchInputText.next('');\n\n                if (this.inputRef.inputElement.nativeElement.value) {\n                    this.searchInputText.next(searchText || '');\n                    this.cdRef.detectChanges();\n                }\n            });\n    }\n\n    ngAfterViewInit() {\n        if (this.inputConfig.autoFocus) {\n            this.clearTimeoutDropdown = setTimeout(() => {\n                this.popoverRef.open();\n            }, 450);\n        }\n    }\n\n    public onScrollDropdown(event: EventTarget | null) {\n        const target = event as HTMLElement;\n\n        if (target.scrollTop + target.offsetHeight === target.scrollHeight) {\n            this.paginationNumber += 1;\n\n            this.paginationEvent.emit(this.paginationNumber);\n        }\n    }\n\n    public onActiveItem(option: IOptionModel, group?: any): void {\n        if (\n            this.canOpenModal &&\n            option?.[this.label]?.toLowerCase() === 'add new'\n        ) {\n            this.selectedItem.emit({\n                id: 7655,\n                name: DropdownStringEnum.ADD_NEW,\n                canOpenModal: true,\n            });\n        } else {\n            this.setDropdownValue({ option });\n        }\n    }\n\n    public onActiveItemGroup(event: { option: IOptionModel; group: any }) {\n        this.onActiveItem(event.option, event.group);\n    }\n\n    public onClearSearch(): void {\n        this._activeItem = null;\n        this.inputHoveredItem = -1;\n\n        this.setControlValue('');\n\n        this.selectedItem.emit(null);\n    }\n\n    public clearDropdownLabel() {\n        this._activeItem = null;\n        this.activeItemColor = null;\n        this.selectedItem.emit(null);\n        this.selectedItemColor.emit(null);\n        this.selectedLabelMode.emit('Label');\n    }\n\n    public commandEvent(event: CommandsEvent) {\n        if (event.action === 'Edit Input') {\n            this.selectedLabelMode.emit('Color');\n        }\n        if (event.action === 'Toggle Dropdown') {\n            this.popoverRef.toggle();\n        }\n        if (event.action === 'confirm' && event.mode === 'new') {\n            this.addNewItem();\n        }\n\n        if (event.action === 'confirm' && event.mode === 'edit') {\n            this.updateItem();\n        }\n\n        if (event.action === 'Placeholder Icon Event') {\n            this.placeholderIconEvent.emit(true);\n        }\n\n        if (event.action === 'cancel') {\n            this.saveItem.emit({\n                data: this._activeItem,\n                action: 'cancel',\n            });\n            this.selectedLabelMode.emit('Label');\n        }\n    }\n\n    public addNewItem(): void {\n        this._activeItem = {\n            id: parseInt(uuidv4()),\n            name: this.getSuperControl!.value,\n        };\n        //this.inputConfig.commands!.active = false;\n        this.inputRef.isVisibleCommands = false;\n        this.inputRef.isFocusInput = false;\n\n        this.saveItem.emit({ data: this._activeItem, action: 'new' });\n\n        if (this.inputConfig.dropdownLabel) {\n            this.selectedLabelMode.emit('Label');\n            this.inputRef.isTouchedInput = true;\n        }\n    }\n\n    public updateItem(): void {\n        if (this.inputConfig.dropdownLabel) {\n            this._activeItem = {\n                ...this._activeItem,\n                name: this.getSuperControl?.value,\n                colorId: this.activeItemColor\n                    ? this.activeItemColor.id\n                    : this._activeItem?.colorId,\n                color: this.activeItemColor\n                    ? this.activeItemColor.name\n                    : this._activeItem?.color,\n                code: this.activeItemColor\n                    ? this.activeItemColor.code\n                    : this._activeItem?.code,\n            };\n\n            this.selectedLabelMode.emit('Label');\n        } else {\n            this._activeItem = {\n                ...this._activeItem,\n                name: this.getSuperControl?.value,\n            };\n        }\n\n        this.saveItem.emit({\n            data: this._activeItem,\n            action: 'edit',\n        });\n    }\n\n    public addNewConfig() {\n        this.inputConfig = {\n            ...this.inputConfig,\n            commands: {\n                active: true,\n                type: 'confirm-cancel',\n                firstCommand: {\n                    popup: {\n                        name: 'Confirm',\n                        backgroundColor: '#3074d3',\n                    },\n                    name: 'confirm',\n                    svg: InputDropdownSvgRoutes.specConfirmSvg,\n                },\n                secondCommand: {\n                    popup: {\n                        name: 'Cancel',\n                        backgroundColor: '#2f2f2f',\n                    },\n                    name: 'cancel',\n                    svg: InputDropdownSvgRoutes.xClearSvg,\n                },\n            },\n            placeholder: '',\n        };\n\n        this.popoverRef?.close();\n\n        this.isInAddMode = true;\n        this.clearTimeoutDropdown = setTimeout(() => {\n            this.isInAddMode = false;\n        }, 200);\n    }\n\n    public onIncorrectInput(event: boolean) {\n        this.incorrectEvent.emit(event);\n    }\n\n    public identity(index: number, item: IOptionModel): number | undefined {\n        return item.id;\n    }\n\n    public toggleNestedList(option: IOptionModel): void {\n        if (option.open) {\n            option.open = false;\n            return;\n        }\n        this._options.filter((item) => (item.open = false));\n\n        option.open = !option.open;\n\n        if (option.open) {\n            this.activeGroupEvent.emit(option);\n        }\n    }\n\n    public onBlurInput(event: boolean) {\n        this.closeDropdown.emit(event);\n    }\n\n    public onClearInputEvent(event: boolean) {\n        this.clearInputEvent.emit(event);\n\n        if (event) {\n            this.popoverRef?.close();\n            // label dropdown\n\n            if (this.inputConfig.dropdownLabel) {\n                this.clearDropdownLabel();\n            }\n            // normal dropdown\n            else {\n                this.onClearSearch();\n            }\n        }\n    }\n\n    public handleHiddenDropdown() {\n        this.isDropDownIsOpen = false;\n        this.inputFormControl.patchValue(this.dropdownValue || '');\n        this.inputRef.inputElement.nativeElement.blur();\n        this.searchInputText.next('');\n        this.inputRef.inputElement.nativeElement.value = '';\n    }\n\n    public handleOpenDropdown() {\n        this.isDropDownIsOpen = true;\n        this.searchInputText.next('');\n        this.inputRef.inputElement.nativeElement.value = '';\n    }\n\n    public showHideDropdown(action: boolean) {\n        if (this.inputConfig.multiselectDropdown) {\n            this.isMultiSelectInputFocus = action;\n        }\n\n        if (this.labelMode !== 'Color') {\n            this.getSuperControl!.setValue(null);\n\n            this.popoverRef?.close();\n        }\n\n        // Details pages\n        if (\n            this.inputConfig.customClass?.includes('details-pages') &&\n            !action\n        ) {\n            this.selectedItem.emit(this._activeItem);\n        }\n    }\n\n    public getMainGroup() {\n        let mainGroup: IOptionModel[] = [];\n        this._options.map((groups) => {\n            mainGroup.push(\n                ...groups[\n                    this.inputConfig.searchinGroupIndex as keyof IOptionModel\n                ]\n            );\n        });\n\n        return mainGroup;\n    }\n\n    public dropDownKeyNavigation({\n        keyCode,\n        data,\n    }: {\n        keyCode: number;\n        data: any;\n    }) {\n        // Navigate down\n        if (keyCode === 40) {\n            this.dropdownNavigation(1);\n        }\n        // Navigate up\n        if (keyCode === 38) {\n            this.dropdownNavigation(-1);\n        }\n\n        // Press 'enter'\n        if (keyCode === 13) {\n            let selectedItem;\n            if (this.inputConfig.searchinGroupIndex) {\n                let mainGroup = this.getMainGroup();\n                selectedItem = mainGroup[this.inputHoveredItem];\n            } else {\n                selectedItem =\n                    this.inputHoveredItem > -1\n                        ? this.dropdownComponentRef.options[\n                              this.inputHoveredItem\n                          ]\n                        : { [this.label]: '' };\n            }\n\n            if (\n                this.canOpenModal &&\n                selectedItem?.[this.label]?.toLowerCase() === 'add new'\n            ) {\n                this.selectedItem.emit({\n                    id: 7655,\n                    name: DropdownStringEnum.ADD_NEW,\n                    canOpenModal: true,\n                });\n            } else {\n                this.setDropdownValue({ option: selectedItem });\n            }\n        }\n\n        if (keyCode === 9) {\n            if (!this.popoverRef.isOpen()) this.popoverRef?.open();\n        }\n    }\n\n    public setDropdownValue({\n        option,\n        optionValue,\n        label,\n        setNotFoundError,\n    }: SelectDropdownValueType) {\n        this.setNotFoundInvalidFlag(setNotFoundError || false);\n        this.lastValidOption = option;\n        this.selectedItem.emit(option);\n        const optValue = optionValue ? optionValue : this.optionValue;\n        const lbel = label ? label : this.label;\n        const controlValue = optValue\n            ? option[optValue as keyof IOptionModel]\n            : option;\n\n        const inputValue = option[lbel as keyof IOptionModel] || controlValue;\n\n        this._activeItem = option;\n        this.setControlValue(controlValue, inputValue);\n        this.popoverRef?.close();\n\n        this.searchInputText.next('');\n    }\n\n    // ----------------------------------  Multiselect Dropdown ----------------------------------\n    public onMultiselectSelect(option: IOptionModel): void {\n        this.isMultiSelectInputFocus = false;\n        //this.inputConfig.label = undefined;\n\n        if (this.multiselectItems.some((item) => item.id === option.id)) {\n            return;\n        }\n\n        this._options = this._options.map((item) => {\n            if (item.id === option.id) {\n                return {\n                    ...item,\n                    active: true,\n                };\n            } else {\n                if (!item.active) {\n                    return {\n                        ...item,\n                        active: false,\n                    };\n                } else {\n                    return {\n                        ...item,\n                        active: true,\n                    };\n                }\n            }\n        });\n\n        this.multiselectItems = this._options.filter((item) => item.active);\n\n        this.selectedItems.emit(this.multiselectItems);\n\n        this._options = this._options.sort(\n            (x, y) => Number(y.active) - Number(x.active)\n        );\n        this.originalOptions = [...this._options];\n\n        this.lastActiveMultiselectItem = this._options\n            .filter((item) => item.active)\n            .slice(-1)[0];\n\n        if (this.inputRef) {\n            this.inputRef.isFocusInput = false;\n            this.inputRef.inputElement.nativeElement.blur();\n        }\n    }\n\n    public removeMultiSelectItem(index: number) {\n        this._options = this.originalOptions.map((item) => {\n            if (item.id === this.multiselectItems[index].id) {\n                return {\n                    ...this.multiselectItems[index],\n                    active: false,\n                };\n            }\n            return item;\n        });\n\n        this._options = this._options.sort(\n            (x, y) => Number(y.active) - Number(x.active)\n        );\n\n        this.originalOptions = this._options;\n        this.multiselectItems.splice(index, 1);\n\n        if (!this.multiselectItems.length) {\n            this.lastActiveMultiselectItem = null;\n        } else {\n            this.lastActiveMultiselectItem = this._options\n                .filter((item) => item.active)\n                .slice(-1)[0];\n        }\n\n        this.selectedItems.emit(\n            this.multiselectItems.map((item) => {\n                return { ...item };\n            })\n        );\n    }\n\n    public deleteAllMultiSelectItems(currentLabel?: string) {\n        this.multiselectItems = [];\n        this._options = this._options.map((item) => {\n            return {\n                ...item,\n                active: false,\n            };\n        });\n        this.originalOptions = this._options;\n        this.selectedItems.emit(null);\n\n        this.lastActiveMultiselectItem = null;\n    }\n\n    public toggleMultiselectDropdown() {\n        if (this.inputConfig.isDisabled) {\n            return;\n        }\n        this.isMultiSelectInputFocus = !this.isMultiSelectInputFocus;\n\n        if (this.isMultiSelectInputFocus) {\n            this.clearTimeoutDropdown = setTimeout(() => {\n                this.popoverRef.open();\n            }, 150);\n        } else {\n            this.inputRef.isFocusInput = false;\n            this.popoverRef?.close();\n        }\n    }\n    // ----------------------------------  End ----------------------------------\n\n    public dropdownValue: string | undefined = '';\n    public setControlValue(value?: string, dropdownInputValue?: string) {\n        this.onChange(value); // Notify Angular form about the change\n        if (value) this.onTouched(); // Mark as touched\n        this.dropdownValue = dropdownInputValue || value;\n        this.inputFormControl.patchValue(dropdownInputValue || value);\n    }\n\n    /**\n     * Navigate through dropdown with keyboard arrows\n     */\n    private dropdownNavigation(step: number) {\n        const nextStep = this.inputHoveredItem + step;\n\n        if (nextStep > this.dropdownComponentRef.dropdownOption.length - 1)\n            this.inputHoveredItem = 0;\n        else if (nextStep < 0)\n            this.inputHoveredItem =\n                this.dropdownComponentRef.dropdownOption.length - 1;\n        else this.inputHoveredItem = nextStep;\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        clearTimeout(this.clearTimeoutDropdown);\n    }\n}\n","<div\n    class=\"application-dropdown\"\n    [ngClass]=\"\n        inputConfig\n            | inputDropdownMultiselectClass\n                : multiselectItems\n                : isMultiSelectInputFocus\n    \"\n>\n    @if (multiselectItems.length) {\n        <p class=\"multiselect-label\">\n            {{ multiSelectLabel }}\n        </p>\n    }\n\n    @if (inputConfig.multiSelectDropdownActive) {\n        <!-- Multiselect arrow -->\n        <svg-icon\n            class=\"multiselect-arrow\"\n            [src]=\"inputDropdownSvgRoutes.inputDropdownArrowSvg\"\n            (click)=\"toggleMultiselectDropdown()\"\n        ></svg-icon>\n    }\n\n    @if (multiselectItems.length && !inputConfig.isDisabled) {\n        <!-- Multiselect clear all -->\n        <div\n            class=\"input-clear multiselect-clear\"\n            mainTooltip=\"Clear All\"\n            ngbTooltip\n            position=\"top\"\n            tooltipBackground=\"#2f2f2f\"\n            (click)=\"deleteAllMultiSelectItems()\"\n        >\n            <svg-icon\n                class=\"input-clear-x\"\n                [src]=\"inputDropdownSvgRoutes.xClearSvg\"\n            ></svg-icon>\n        </div>\n    }\n\n    @if (\n        inputConfig.multiselectDropdown &&\n        multiselectItems.length &&\n        _template === 'multiselect'\n    ) {\n        <!-- Multiselect items -->\n        <div class=\"multiselect-items {{ multiselectTemplate }}\">\n            <ng-container> </ng-container>\n            @for (\n                multiSelect of multiselectItems;\n                track $index;\n                let ind = $index\n            ) {\n                <span class=\"multiselect-item\">\n                    {{ multiSelect?.name }}\n                    <!-- Active - Total Counter -->\n                    @if (\n                        inputConfig.multiSelectItemRange &&\n                        multiSelect?.totalCounter\n                    ) {\n                        <span>\n                            {{ multiSelect?.activeCounter }} of\n                            {{ multiSelect?.totalCounter }}\n                        </span>\n                    }\n\n                    @if (\n                        inputConfig.multiSelectItemRange &&\n                        !multiSelect?.totalCounter\n                    ) {\n                        <span>\n                            {{ multiSelect?.activeCounter }}\n                        </span>\n                    }\n\n                    @if (!inputConfig.isDisabled) {\n                        <!-- Active Counter -->\n                        <div\n                            (click)=\"removeMultiSelectItem(ind)\"\n                            class=\"multiselect-item-clear\"\n                            mainTooltip=\"Clear\"\n                            ngbTooltip\n                            position=\"top\"\n                            tooltipBackground=\"#2f2f2f\"\n                        >\n                            <svg-icon\n                                [src]=\"inputDropdownSvgRoutes.xClearSvg\"\n                            ></svg-icon>\n                        </div>\n                    }\n                </span>\n            }\n        </div>\n    }\n\n    <!-- Dropdown search -->\n\n    @if (!inputConfig.isIconInput) {\n        @if (!searchInputText.value) {\n            <!-- <div\n            (scroll)=\"onScrollDropdown($event.target)\"\n            [ngClass]=\"{\n                scroll: _options | caDropdownCount: _template,\n                'dropdown-options-groups':\n                    _template === 'groups' ||\n                    _template === 'load-broker-contact',\n                'dropdown-options-fuel-franchise':\n                    _template === 'fuel-franchise',\n                'merge-dropdown-body-with-input':\n                    inputConfig.mergeDropdownBodyWithInput,\n                'no-result-container': _options[0]?.name === 'No Results',\n                'svgtext-dispatch-template':\n                    _template == 'svgtext-dispatch-template',\n            }\"\n            class=\"dropdown-options  {{ inputConfig.dropdownWidthClass }}\"\n        > -->\n            <div\n                [class.open]=\"isDropDownIsOpen\"\n                [class.leftIcon]=\"inputConfig.placeholderIcon\"\n                [ngClass]=\"{\n                    scroll: _options | caDropdownCount: _template,\n                    'dropdown-options-groups':\n                        _template === 'groups' ||\n                        _template === 'load-broker-contact',\n                    'dropdown-options-fuel-franchise':\n                        _template === 'fuel-franchise',\n                    'merge-dropdown-body-with-input':\n                        inputConfig.mergeDropdownBodyWithInput,\n                    'svgtext-dispatch-template':\n                        _template == 'svgtext-dispatch-template',\n                }\"\n                class=\"dropdown_value dropdown-options  {{\n                    inputConfig.dropdownWidthClass\n                }}\"\n            >\n                @switch (_template) {\n                    @case (dropdownTemplateTypeEnum.LOAD_DISPATCHES_TTD) {\n                        @if (activeItem) {\n                            <div class=\"dropdown-option dropdown-double-column\">\n                                <app-ca-input-dropdown-load-dispatches-ttd-item\n                                    [showNoResulst]=\"false\"\n                                    [index]=\"0\"\n                                    [searchText]=\"searchInputText.value || ''\"\n                                    [activeItem]=\"activeItem\"\n                                    [option]=\"activeItem!\"\n                                    [label]=\"label\"\n                                >\n                                </app-ca-input-dropdown-load-dispatches-ttd-item>\n                            </div>\n                        }\n                    }\n                    @case (dropdownTemplateTypeEnum.LOAD_BROKER) {\n                        @if (activeItem) {\n                            <app-ca-input-dropdown-load-broker-item\n                                [option]=\"activeItem\"\n                                [searchText]=\"searchInputText.value || ''\"\n                                [isInOption]=\"true\"\n                                [label]=\"label\"\n                            ></app-ca-input-dropdown-load-broker-item>\n                        }\n                    }\n\n                    @case (dropdownTemplateTypeEnum.LOAD_SHIPPER) {\n                        @if (activeItem) {\n                            <app-ca-input-dropdown-load-shipper-item\n                                [activeItem]=\"activeItem\"\n                                [searchText]=\"searchInputText.value || ''\"\n                                [option]=\"activeItem\"\n                                [isInOption]=\"true\"\n                                [label]=\"label\"\n                            ></app-ca-input-dropdown-load-shipper-item>\n                        }\n                    }\n\n                    @case (dropdownTemplateTypeEnum.LOAD_BROKER_CONTACT) {\n                        @if (activeItem) {\n                            <div class=\"load-broker-contact-groups\">\n                                <ca-input-dropdown-load-broker-contact-item\n                                    [activeItem]=\"activeItem\"\n                                    [item]=\"activeItem\"\n                                    [searchText]=\"searchInputText.value || ''\"\n                                    [isInOption]=\"true\"\n                                ></ca-input-dropdown-load-broker-contact-item>\n                            </div>\n                        }\n                    }\n\n                    @case (dropdownTemplateTypeEnum.LOAD_DISPATCHER) {\n                        @if (activeItem) {\n                            <app-ca-input-dropdown-load-dispatcher-item\n                                [option]=\"activeItem\"\n                                [searchText]=\"searchInputText.value || ''\"\n                                [activeItem]=\"activeItem\"\n                                [label]=\"label\"\n                                [dropdownWithImage]=\"\n                                    inputConfig.dropdownImageInput\n                                \"\n                                [isInOption]=\"true\"\n                            >\n                            </app-ca-input-dropdown-load-dispatcher-item>\n                        }\n                    }\n\n                    @default {\n                        <!-- Special Dropdown Selected SVG with or Without Text -->\n                        @if (inputConfig.dropdownImageInput && activeItem) {\n                            <svg-icon\n                                [src]=\"\n                                    inputConfig.dropdownImageInput!\n                                        | inputDropdownGetIcons: activeItem\n                                \"\n                                class=\"dropdown-selected-image {{\n                                    inputConfig.dropdownImageInput?.class\n                                }}\"\n                                [ngClass]=\"{\n                                    'unset-color':\n                                        inputConfig.dropdownImageInput?.class,\n                                }\"\n                                [svgStyle]=\"{\n                                    fill: inputConfig.dropdownImageInput\n                                        ? activeItem?.code\n                                        : '#ffffff',\n                                }\"\n                            >\n                            </svg-icon>\n                        }\n\n                        @if (\n                            inputConfig.dropdownImageInput?.withText ||\n                            !inputConfig.dropdownImageInput\n                        ) {\n                            {{ dropdownValue }}\n                        }\n                    }\n                }\n            </div>\n        }\n\n        <ca-input-test\n            #t2=\"ngbPopover\"\n            [ngbPopover]=\"caInputDropdownPopover\"\n            popoverClass=\"ca-input-dropdown\"\n            [autoClose]=\"'outside'\"\n            [container]=\"'body'\"\n            [placement]=\"\n                _template == 'svgtext-dispatch-template'\n                    ? ['bottom-left', 'top-left']\n                    : ['bottom-left']\n            \"\n            #input\n            [formControl]=\"inputFormControl | formControl\"\n            [parentControl]=\"getSuperControl\"\n            [incorrectValue]=\"isIncorrectValue\"\n            [inputConfig]=\"inputConfig\"\n            [selectedDropdownLabelColor]=\"\n                inputConfig.dropdownLabel\n                    ? activeItem\n                        ? activeItem\n                        : activeItemColor\n                    : null\n            \"\n            [template]=\"_template\"\n            (blurInput)=\"onBlurInput($event)\"\n            (clear)=\"onClearInputEvent($event)\"\n            (commandEvent)=\"commandEvent($event)\"\n            (showHideDropdown)=\"showHideDropdown($event)\"\n            (dropDownKeyNavigation)=\"dropDownKeyNavigation($event)\"\n            (incorrectEvent)=\"onIncorrectInput($event)\"\n            (hidden)=\"handleHiddenDropdown()\"\n            (shown)=\"handleOpenDropdown()\"\n        ></ca-input-test>\n    }\n\n    <!-- Dropdown icon instead of input -->\n    @if (inputConfig.isIconInput) {\n        <div\n            class=\"d-flex justify-content-center align-items-center input-icon-container\"\n            [ngClass]=\"{\n                valid:\n                    inputConfig.isValidIcon &&\n                    !inputConfig.inputIcon?.includes('custom'),\n                active: popoverRef?.isOpen(),\n            }\"\n        >\n            <svg-icon\n                #t2=\"ngbPopover\"\n                [ngbPopover]=\"caInputDropdownPopover\"\n                popoverClass=\"ca-input-dropdown\"\n                [autoClose]=\"'outside'\"\n                [container]=\"'body'\"\n                [placement]=\"['bottom-left']\"\n                class=\"input-icon\"\n                [src]=\"\n                    inputDropdownSvgRoutes.repairPmSvgRoute +\n                    inputConfig.inputIcon\n                \"\n            ></svg-icon>\n        </div>\n    }\n</div>\n<ng-template #caInputDropdownPopover>\n    <!--------------------------- Dropdown options --------------------------->\n    @if (inputConfig?.mergeDropdownBodyWithInput && _options?.length) {\n        <div\n            class=\"dropdown-options-divider {{\n                inputConfig.dropdownWidthClass\n            }}\"\n            [class.dispatch_dropdown]=\"_template == 'svgtext-dispatch-template'\"\n        ></div>\n    }\n\n    @if (\n        (inputConfig?.name != 'Address' &&\n            inputConfig?.name != 'RoutingAddress' &&\n            !inputConfig.isDisabled) ||\n        ((inputConfig?.name == 'Address' ||\n            inputConfig?.name == 'RoutingAddress') &&\n            !inputConfig.isDisabled &&\n            _options?.length)\n    ) {\n        <div\n            (scroll)=\"onScrollDropdown($event.target)\"\n            [ngClass]=\"{\n                scroll: _options | caDropdownCount: _template,\n                'dropdown-options-groups':\n                    _template === 'groups' ||\n                    _template === 'load-broker-contact',\n                'dropdown-options-fuel-franchise':\n                    _template === 'fuel-franchise',\n                'merge-dropdown-body-with-input':\n                    inputConfig.mergeDropdownBodyWithInput,\n                'no-result-container': _options[0]?.name === 'No Results',\n                'svgtext-dispatch-template':\n                    _template == 'svgtext-dispatch-template',\n            }\"\n            class=\"dropdown-options  {{ inputConfig.dropdownWidthClass }}\"\n        >\n            @switch (_template) {\n                <!--------------------------- SVG Template (Render svgs or text if svgs doesn't exist ) --------------------------->\n\n                @case (dropdownTemplateTypeEnum.SVG_TEMPLATE) {\n                    <app-ca-input-dropdown-svg-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [dropdownWithImage]=\"inputConfig.dropdownImageInput\"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-svg-template>\n                    <!-- <ng-container \n                        *ngTemplateOutlet=\"dropdownSvgTemplate\"\n                    ></ng-container> -->\n                }\n\n                <!--------------------------- Svg Text Template (display flex) --------------------------->\n\n                @case (dropdownTemplateTypeEnum.SVGTEXT_TEMPLATE) {\n                    <app-ca-input-dropdown-svgtext-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        [inputConfig]=\"inputConfig\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-svgtext-template>\n\n                    <!-- <ng-container\n                        *ngTemplateOutlet=\"svgTextTemplate\"\n                    ></ng-container> -->\n                }\n\n                <!-------------------------------------------Dispatch dropdown-------------------------------------------->\n\n                @case (dropdownTemplateTypeEnum.SVGTEXT_DISPATCH_TEMPLATE) {\n                    <app-ca-input-dropdown-svgtext-dispatch-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        [inputConfig]=\"inputConfig\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-svgtext-dispatch-template>\n\n                    <!-- <ng-container\n                        *ngTemplateOutlet=\"dispatchTemplate\"\n                    ></ng-container> -->\n                }\n\n                <!--------------------------- Details template (truck, trailer... details-pages)  --------------------------->\n\n                @case (dropdownTemplateTypeEnum.DETAILS_TEMPLATE) {\n                    <app-ca-input-dropdown-details-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        [sort]=\"_sort\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-details-template>\n\n                    <!-- <ng-container\n                        *ngTemplateOutlet=\"detailsTemplate\"\n                    ></ng-container> -->\n                }\n\n                <!--------------------------- Grouping template (can see on contact modal)  --------------------------->\n\n                @case (dropdownTemplateTypeEnum.GROUPS) {\n                    <app-ca-input-dropdown-groups\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-groups>\n                }\n\n                <!--------------------------- Multiselect Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.MULTISELECT) {\n                    <app-ca-input-dropdown-multiselect\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [lastActiveMultiselectItem]=\"lastActiveMultiselectItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onMultiselectSelect)=\"onMultiselectSelect($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-multiselect>\n                }\n                <!--------------------------- Labels Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LABELS) {\n                    <app-ca-input-dropdown-labels\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        [inputConfig]=\"inputConfig\"\n                        [labelMode]=\"labelMode\"\n                        [canAddNew]=\"_canAddNew\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-labels>\n                }\n\n                <!--------------------------- Dispatch Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.DISPATCH) {\n                    <app-ca-input-dropdown-dispatch\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-dispatch>\n                }\n\n                <!--------------------------- Load Dispatcher Template (user avatar + user name) --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_DISPATCHER) {\n                    <app-ca-input-dropdown-load-dispatcher\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                        [inputConfig]=\"inputConfig\"\n                    ></app-ca-input-dropdown-load-dispatcher>\n                }\n\n                <!--------------------------- Load Combine Truck-Trailer-Driver Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_DISPATCHES_TTD) {\n                    <app-ca-input-dropdown-load-dispatches-ttd\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-load-dispatches-ttd>\n                }\n\n                <!--------------------------- Load Broker Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_BROKER) {\n                    <app-ca-input-dropdown-load-broker\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-load-broker>\n                }\n\n                <!--------------------------- Load Broker Contact Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_BROKER_CONTACT) {\n                    <app-ca-input-dropdown-load-broker-contact\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-load-broker-contact>\n                }\n\n                <!--------------------------- Load Shipper Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_SHIPPER) {\n                    <app-ca-input-dropdown-load-shipper\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-load-shipper>\n                }\n\n                <!--------------------------- Template Text - Counter --------------------------->\n\n                @case (dropdownTemplateTypeEnum.TEXT_COUNTER) {\n                    <app-ca-input-dropdown-text-counter\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-text-counter>\n                }\n\n                <!--------------------------- Fuel Franchise Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.FUEL_FRANCHISE) {\n                    <app-ca-input-dropdown-fuel-franchise\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        (toggleNestedList)=\"toggleNestedList($event)\"\n                        (onActiveItemGroup)=\"onActiveItemGroup($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-fuel-franchise>\n                }\n\n                <!-- Double Text Template -->\n\n                @case (dropdownTemplateTypeEnum.DOUBLE_TEXT_TEMPLATE) {\n                    <app-ca-input-dropdown-double-text-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-double-text-template>\n                }\n\n                <!-- Double Column Template -->\n\n                @case (dropdownTemplateTypeEnum.DOUBLE_COLUMN_TEMPLATE) {\n                    <app-ca-input-dropdown-double-text-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-double-text-template>\n                }\n\n                <!-- Triple Column Template -->\n\n                @case (dropdownTemplateTypeEnum.TRIPLE_COLUMN_TEMPLATE) {\n                    <app-ca-input-dropdown-triple-text-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-triple-text-template>\n                }\n\n                <!-- PAYROLL TRUCKS Template -->\n\n                @case (dropdownTemplateTypeEnum.PAYROLL_TRUCKS) {\n                    <app-ca-input-dropdown-payroll-trucks\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-payroll-trucks>\n                }\n\n                <!--------------------------- Default Template - Render Only Text --------------------------->\n                @default {\n                    <app-ca-input-dropdown-default-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [inputConfig]=\"inputConfig\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-default-template>\n                }\n            }\n        </div>\n    }\n</ng-template>\n"]}
709
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-dropdown-test.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input-dropdown-test/ca-input-dropdown-test.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input-dropdown-test/ca-input-dropdown-test.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Renderer2, ViewEncapsulation } from '@angular/core';\nimport {\n    AfterViewInit,\n    Component,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport {\n    debounceTime,\n    distinctUntilChanged,\n    skip,\n    Subject,\n    takeUntil,\n} from 'rxjs';\n\n// bootstrap\nimport {\n    NgbPopover,\n    NgbPopoverModule,\n    NgbModule,\n} from '@ng-bootstrap/ng-bootstrap';\n\n// animation\nimport { inputDropdownAnimation } from './animations';\n\n// components\nimport { CaInputDropdownLoadBrokerComponent } from './components/ca-input-dropdown-load-broker/ca-input-dropdown-load-broker.component';\nimport { CaInputDropdownLoadDispatchesTtdComponent } from './components/ca-input-dropdown-load-dispatches-ttd/ca-input-dropdown-load-dispatches-ttd.component';\nimport { CaInputDropdownLoadDispatcherComponent } from './components/ca-input-dropdown-load-dispatcher/ca-input-dropdown-load-dispatcher.component';\nimport { CaInputDropdownSvgTemplateComponent } from './components/ca-input-dropdown-svg-template/ca-input-dropdown-svg-template.component';\nimport { CaInputDropdownSvgtextTemplateComponent } from './components/ca-input-dropdown-svgtext-template/ca-input-dropdown-svgtext-template.component';\nimport { CaInputDropdownSvgtextDispatchTemplateComponent } from './components/ca-input-dropdown-svgtext-dispatch-template/ca-input-dropdown-svgtext-dispatch-template.component';\nimport { CaInputDropdownGroupsComponent } from './components/ca-input-dropdown-groups/ca-input-dropdown-groups.component';\nimport { CaInputDropdownMultiselectComponent } from './components/ca-input-dropdown-multiselect/ca-input-dropdown-multiselect.component';\nimport { CaInputDropdownLabelsComponent } from './components/ca-input-dropdown-labels/ca-input-dropdown-labels.component';\nimport { CaInputDropdownLoadBrokerContactComponent } from './components/ca-input-dropdown-load-broker-contact/ca-input-dropdown-load-broker-contact.component';\nimport { CaInputDropdownLoadBrokerShipperComponent } from './components/ca-input-dropdown-load-broker-shipper/ca-input-dropdown-load-broker-shipper.component';\nimport { CaInputDropdownTextCounterComponent } from './components/ca-input-dropdown-text-counter/ca-input-dropdown-text-counter.component';\nimport { CaInputDropdownDoubleTextTemplateComponent } from './components/ca-input-dropdown-double-text-template/ca-input-dropdown-double-text-template.component';\nimport { CaInputDropdownTripleTextTemplateComponent } from './components/ca-input-dropdown-triple-text-template/ca-input-dropdown-triple-text-template.component';\nimport { CaInputDropdownDefaultTemplateComponent } from './components/ca-input-dropdown-default-template/ca-input-dropdown-default-template.component';\nimport { CaInputDropdownFuelFranchiseComponent } from './components/ca-input-dropdown-fuel-franchise/ca-input-dropdown-fuel-franchise.component';\nimport { CaInputDropdownDispatchComponent } from './components/ca-input-dropdown-dispatch/ca-input-dropdown-dispatch.component';\nimport { CaInputDropdownDetailsTemplateComponent } from './components/ca-input-dropdown-details-template/ca-input-dropdown-details-template.component';\nimport { CaInputDropdownPayrollTrucksComponent } from './components/ca-input-dropdown-payroll-trucks/ca-input-dropdown-payroll-trucks.component';\nimport { CaInputDropdownLoadDispatchesTtdComponentItem } from './components/ca-input-dropdown-load-dispatches-ttd/ca-input-dropdown-load-dispatches-ttd-item/ca-input-dropdown-load-dispatches-ttd-item';\nimport { CaInputDropdownLoadBrokerComponentItem } from './components/ca-input-dropdown-load-broker/ca-input-dropdown-load-broker-item/ca-input-dropdown-load-broker-item.component';\nimport { CaInputDropdownLoadBrokerShipperItemComponent } from './components/ca-input-dropdown-load-broker-shipper/ca-input-dropdown-load-broker-shipper-item/ca-input-dropdown-load-broker-shipper-item.component';\nimport { CaInputDropdownLoadDispatcherItemComponent } from './components/ca-input-dropdown-load-dispatcher/ca-input-dropdown-load-dispatcher-item/ca-input-dropdown-load-dispatcher-item.component';\n\n// pipes\nimport { FormControlPipe } from '../ca-input/pipes';\nimport {\n    DropdownCountPipe,\n    InputDropdownGetIconsPipe,\n    InputDropdownMultiselectClassPipe,\n} from './pipes';\nimport { DropdownOptionsPipe } from './pipes/dropdown-options.pipe';\n\n// modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// directives\nimport {\n    ControlValueAccessor,\n    FormControl,\n    FormsModule,\n    NgControl,\n    ReactiveFormsModule,\n} from '@angular/forms';\n\n// models\nimport { CommandsEvent } from '../ca-input/models';\n\n// types\nimport {\n    AbstractControlWithNotFoundType,\n    FormControlWithNotFoundType,\n} from './types';\nimport { SelectDropdownValueType } from './types/select-dropdown-value.type';\n\n// svg routes\nimport { InputDropdownSvgRoutes } from './utils/svg-routes/input-dropdown-svg-routes';\n\n// enums\nimport { DropdownStringEnum, DropdownTemplateTypeEnum } from './enums';\n\n// helpers\nimport { uuidv4 } from '../../utils/helpers';\n\n// classes\nimport { EventInputManager } from '../ca-input/base-classes/ca-input-event-manager';\n\n// components\nimport { InputTestComponent } from '../ca-input-test/input-test.component';\nimport { CaLoadStatusStringComponent } from '../ca-load-status-string/ca-load-status-string.component';\nimport { CaProfileImageComponent } from '../ca-profile-image/ca-profile-image.component';\nimport { CaInputDropdownLoadBrokerContactItemComponent } from './components/ca-input-dropdown-load-broker-contact/ca-input-dropdown-load-broker-contact-item/ca-input-dropdown-load-broker-contact-item.component';\n\n// config\nimport { ICaInput } from '../ca-input-test/config';\n\n// interfaces\nimport { IOptionModel } from './interfaces/input-dropdown-option.interface';\n@Component({\n    selector: 'ca-input-dropdown-test',\n    templateUrl: './ca-input-dropdown-test.component.html',\n    styleUrls: ['./ca-input-dropdown-test.component.scss'],\n    standalone: true,\n    encapsulation: ViewEncapsulation.None,\n    providers: [FormControlPipe],\n    animations: [inputDropdownAnimation('showHideDropdownOptions')],\n    imports: [\n        // Module\n        CommonModule,\n        FormsModule,\n        NgbPopoverModule,\n        ReactiveFormsModule,\n        NgbModule,\n        AngularSvgIconModule,\n        // Component\n        CaProfileImageComponent,\n        CaLoadStatusStringComponent,\n        CaInputDropdownSvgtextTemplateComponent,\n        CaInputDropdownSvgtextDispatchTemplateComponent,\n        CaInputDropdownGroupsComponent,\n        CaInputDropdownMultiselectComponent,\n        CaInputDropdownLabelsComponent,\n        CaInputDropdownLoadBrokerComponent,\n        CaInputDropdownLoadDispatchesTtdComponent,\n        CaInputDropdownLoadDispatcherComponent,\n        CaInputDropdownLoadBrokerContactComponent,\n        CaInputDropdownLoadBrokerShipperComponent,\n        CaInputDropdownTextCounterComponent,\n        CaInputDropdownDoubleTextTemplateComponent,\n        CaInputDropdownTripleTextTemplateComponent,\n        CaInputDropdownDefaultTemplateComponent,\n        CaInputDropdownFuelFranchiseComponent,\n        CaInputDropdownDispatchComponent,\n        CaInputDropdownDetailsTemplateComponent,\n        CaInputDropdownPayrollTrucksComponent,\n        CaInputDropdownSvgTemplateComponent,\n        InputTestComponent,\n        CaInputDropdownLoadDispatchesTtdComponentItem,\n        CaInputDropdownLoadBrokerComponentItem,\n        CaInputDropdownLoadBrokerShipperItemComponent,\n        CaInputDropdownLoadDispatcherItemComponent,\n        CaInputDropdownLoadBrokerContactItemComponent,\n        // Pipes\n        FormControlPipe,\n        DropdownCountPipe,\n        InputDropdownMultiselectClassPipe,\n        DropdownOptionsPipe,\n        InputDropdownGetIconsPipe,\n    ],\n})\nexport class CaInputDropdownTestComponent\n    implements\n        OnInit,\n        AfterViewInit,\n        OnDestroy,\n        ControlValueAccessor,\n        AfterViewInit\n{\n    @ViewChild('input') inputRef!: InputTestComponent;\n    @ViewChild('t2') public popoverRef!: NgbPopover;\n    @ViewChild('dropdownComponentRef', { static: false })\n    dropdownComponentRef: any;\n\n    // Label input - value that will be showed inside input\n    @Input() label!: keyof IOptionModel;\n\n    // optionValue input - key value from object - Emit this if you want to set whole object\n    @Input() optionValue!: string;\n\n    public inputHoveredItem: number = -1;\n    public isDropDownIsOpen: boolean = false;\n\n    // different templates for body rendering\n    public _template!: string;\n    _canAddNew: boolean = false;\n\n    @Input() set template(value: string) {\n        this._template = value;\n    }\n\n    @Input() multiselectTemplate!: string;\n    @Input() inputConfig!: ICaInput;\n    @Input() set canAddNew(value: boolean) {\n        this._canAddNew = value;\n    } // ADD NEW item in options\n\n    public get canAddNew() {\n        return this._canAddNew;\n    }\n\n    @Input() canOpenModal!: boolean; // open modal with ADD NEW button\n\n    // sort-template for different options\n    public _sort!: string;\n    @Input() set sort(value: string) {\n        this._sort = value;\n    }\n\n    public get sort() {\n        return this._sort;\n    }\n\n    // currently active item\n    public _activeItem!: IOptionModel | null;\n    @Input() set activeItem(value: IOptionModel | null) {\n        this._activeItem = value;\n    }\n\n    public get activeItem() {\n        return this._activeItem;\n    }\n\n    @Input() activeItemColor!: IOptionModel | null; // currently active color in dropdown\n    @Input() labelMode!: 'Label' | 'Color';\n\n    // when send SVG, please premmaped object: add 'folder' | 'subfolder'\n    public _options: IOptionModel[] = [];\n    @Input() set options(values: IOptionModel[]) {\n        if (values) this._options = [...values];\n\n        console.log(\"update with optins\", values, this.firstWriteValue);\n        if (this.firstWriteValue) {\n            this.writeValueToFormControl(this.firstWriteValue);\n        }\n    }\n\n    // MultiSelect Selected Items From Backend\n    @Input() set preloadMultiselectItems(values: IOptionModel[]) {\n        if (this.inputConfig.multiselectDropdown) {\n            if (!values) {\n                this.deleteAllMultiSelectItems(this.inputConfig.label);\n                return;\n            }\n\n            if (values?.length) {\n                values.forEach((item) => {\n                    this.onMultiselectSelect(item);\n                });\n            }\n        }\n    }\n\n    @Input() isDetailsPages!: boolean; // only for details pages\n    @Input() isIncorrectValue!: boolean; // applicant review option\n    @Input() isAddressDropdown!: boolean; // only for address dropdown\n\n    @Output() selectedItem: EventEmitter<IOptionModel | null> =\n        new EventEmitter<IOptionModel | null>();\n    @Output() selectedItems: EventEmitter<IOptionModel[] | null> =\n        new EventEmitter<IOptionModel[] | null>();\n    @Output() selectedItemColor: EventEmitter<IOptionModel | null> =\n        new EventEmitter<IOptionModel | null>();\n    @Output() selectedLabelMode: EventEmitter<string> =\n        new EventEmitter<string>();\n    @Output() closeDropdown: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output() saveItem: EventEmitter<{\n        data: IOptionModel | null;\n        action: string;\n    }> = new EventEmitter<{ data: IOptionModel | null; action: string }>();\n    @Output() incorrectEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output() placeholderIconEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output('pagination') paginationEvent: EventEmitter<number> =\n        new EventEmitter<number>();\n    @Output('activeGroup') activeGroupEvent: EventEmitter<IOptionModel> =\n        new EventEmitter<IOptionModel>();\n    @Output('clearInputEvent') clearInputEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n\n    @Output('searchInputEvent') searchInputEvent: EventEmitter<string> =\n        new EventEmitter<string>();\n    // events\n    public searchInputText = new EventInputManager<string>(\n        null,\n        this.searchInputEvent\n    );\n\n    // Copy of Options\n    public originalOptions: IOptionModel[] = [];\n\n    // Pagination\n    public paginationNumber: number = 0;\n\n    // Multiselect dropdown options\n    public multiselectItems: IOptionModel[] = [];\n    public isMultiSelectInputFocus: boolean = false;\n    public multiSelectLabel!: string | undefined;\n    public lastActiveMultiselectItem!: IOptionModel | null;\n\n    // Add mode\n    public isInAddMode: boolean = false;\n\n    // Dropdown navigation with keyboard\n    private dropdownPosition: number = -1;\n\n    // Dropdown Cleartimeout\n    public clearTimeoutDropdown: string | number | NodeJS.Timeout | undefined;\n\n    public hoveringIndex!: number;\n    public inputDropdownSvgRoutes = InputDropdownSvgRoutes;\n    public dropdownTemplateTypeEnum = DropdownTemplateTypeEnum;\n\n    // Destroy\n    private destroy$ = new Subject<void>();\n\n    constructor(\n        @Self() public superControl: NgControl,\n        private cdRef: ChangeDetectorRef,\n        private renderer: Renderer2\n    ) {\n        this.superControl.valueAccessor = this;\n    }\n\n    get getSuperControl() {\n        return this.superControl.control;\n    }\n\n    public inputFormControl: FormControl = new FormControl(null);\n\n    public lastValidOption!: IOptionModel;\n    public firstWriteValue: any;\n    writeValue(value: string | number): void {\n        console.log(\"WRITE VALUE FIRST\", value);\n        this.firstWriteValue = value;\n        this.writeValueToFormControl(value);\n    }\n\n    public writeValueToFormControl(value: string | number): void {\n        const findInOptions = this.inputConfig.searchinGroupIndex\n            ? this.getMainGroup()\n            : this._options;\n\n        let findOption = findInOptions.find(\n            (option) => option[this.optionValue as keyof IOptionModel] == value\n        );\n\n        let optionNotFound = false;\n        if (!findOption && value) {\n            findOption = {\n                [this.optionValue]: this.firstWriteValue,\n                [this.label]: this.firstWriteValue,\n            };\n            optionNotFound = true;\n        }\n\n        if (findOption) {\n            this.setDropdownValue({\n                option: findOption,\n                setNotFoundError: optionNotFound,\n            });\n        }\n    }\n\n    public setNotFoundInvalidFlag(value: boolean): void {\n        if (this.getSuperControl)\n            (\n                this.getSuperControl as AbstractControlWithNotFoundType\n            ).notFoundInvalid = value; // Attach dynamic values\n        (this.inputFormControl as FormControlWithNotFoundType).notFoundInvalid =\n            value; // Attach dynamic values\n    }\n\n    public onTouched = () => {};\n    public onChange(_: any): void {}\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    ngOnInit(): void {\n        // Multiselect\n        if (this.inputConfig.multiselectDropdown) {\n            this.multiSelectLabel = this.inputConfig.label;\n        }\n\n        this.inputFormControl.valueChanges\n            .pipe(\n                distinctUntilChanged(),\n                debounceTime(50),\n                skip(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe((searchText) => {\n                if (this.labelMode === 'Color') {\n                    return;\n                }\n\n                this.searchInputText.next('');\n\n                if (this.inputRef.inputElement.nativeElement.value) {\n                    this.searchInputText.next(searchText || '');\n                    this.cdRef.detectChanges();\n                }\n            });\n    }\n\n    ngAfterViewInit() {\n        if (this.inputConfig.autoFocus) {\n            this.clearTimeoutDropdown = setTimeout(() => {\n                this.popoverRef.open();\n            }, 450);\n        }\n    }\n\n    public onScrollDropdown(event: EventTarget | null) {\n        const target = event as HTMLElement;\n\n        if (target.scrollTop + target.offsetHeight === target.scrollHeight) {\n            this.paginationNumber += 1;\n\n            this.paginationEvent.emit(this.paginationNumber);\n        }\n    }\n\n    public onActiveItem(option: IOptionModel, group?: any): void {\n        if (\n            this.canOpenModal &&\n            option?.[this.label]?.toLowerCase() === 'add new'\n        ) {\n            this.selectedItem.emit({\n                id: 7655,\n                name: DropdownStringEnum.ADD_NEW,\n                canOpenModal: true,\n            });\n        } else {\n            this.setDropdownValue({ option });\n        }\n    }\n\n    public onActiveItemGroup(event: { option: IOptionModel; group: any }) {\n        this.onActiveItem(event.option, event.group);\n    }\n\n    public onClearSearch(): void {\n        this._activeItem = null;\n        this.inputHoveredItem = -1;\n\n        this.setControlValue('');\n\n        this.selectedItem.emit(null);\n    }\n\n    public clearDropdownLabel() {\n        this._activeItem = null;\n        this.activeItemColor = null;\n        this.selectedItem.emit(null);\n        this.selectedItemColor.emit(null);\n        this.selectedLabelMode.emit('Label');\n    }\n\n    public commandEvent(event: CommandsEvent) {\n        if (event.action === 'Edit Input') {\n            this.selectedLabelMode.emit('Color');\n        }\n        if (event.action === 'Toggle Dropdown') {\n            this.popoverRef.toggle();\n        }\n        if (event.action === 'confirm' && event.mode === 'new') {\n            this.addNewItem();\n        }\n\n        if (event.action === 'confirm' && event.mode === 'edit') {\n            this.updateItem();\n        }\n\n        if (event.action === 'Placeholder Icon Event') {\n            this.placeholderIconEvent.emit(true);\n        }\n\n        if (event.action === 'cancel') {\n            this.saveItem.emit({\n                data: this._activeItem,\n                action: 'cancel',\n            });\n            this.selectedLabelMode.emit('Label');\n        }\n    }\n\n    public addNewItem(): void {\n        this._activeItem = {\n            id: parseInt(uuidv4()),\n            name: this.getSuperControl!.value,\n        };\n        //this.inputConfig.commands!.active = false;\n        this.inputRef.isVisibleCommands = false;\n        this.inputRef.isFocusInput = false;\n\n        this.saveItem.emit({ data: this._activeItem, action: 'new' });\n\n        if (this.inputConfig.dropdownLabel) {\n            this.selectedLabelMode.emit('Label');\n            this.inputRef.isTouchedInput = true;\n        }\n    }\n\n    public updateItem(): void {\n        if (this.inputConfig.dropdownLabel) {\n            this._activeItem = {\n                ...this._activeItem,\n                name: this.getSuperControl?.value,\n                colorId: this.activeItemColor\n                    ? this.activeItemColor.id\n                    : this._activeItem?.colorId,\n                color: this.activeItemColor\n                    ? this.activeItemColor.name\n                    : this._activeItem?.color,\n                code: this.activeItemColor\n                    ? this.activeItemColor.code\n                    : this._activeItem?.code,\n            };\n\n            this.selectedLabelMode.emit('Label');\n        } else {\n            this._activeItem = {\n                ...this._activeItem,\n                name: this.getSuperControl?.value,\n            };\n        }\n\n        this.saveItem.emit({\n            data: this._activeItem,\n            action: 'edit',\n        });\n    }\n\n    public addNewConfig() {\n        this.inputConfig = {\n            ...this.inputConfig,\n            commands: {\n                active: true,\n                type: 'confirm-cancel',\n                firstCommand: {\n                    popup: {\n                        name: 'Confirm',\n                        backgroundColor: '#3074d3',\n                    },\n                    name: 'confirm',\n                    svg: InputDropdownSvgRoutes.specConfirmSvg,\n                },\n                secondCommand: {\n                    popup: {\n                        name: 'Cancel',\n                        backgroundColor: '#2f2f2f',\n                    },\n                    name: 'cancel',\n                    svg: InputDropdownSvgRoutes.xClearSvg,\n                },\n            },\n            placeholder: '',\n        };\n\n        this.popoverRef?.close();\n\n        this.isInAddMode = true;\n        this.clearTimeoutDropdown = setTimeout(() => {\n            this.isInAddMode = false;\n        }, 200);\n    }\n\n    public onIncorrectInput(event: boolean) {\n        this.incorrectEvent.emit(event);\n    }\n\n    public identity(index: number, item: IOptionModel): number | undefined {\n        return item.id;\n    }\n\n    public toggleNestedList(option: IOptionModel): void {\n        if (option.open) {\n            option.open = false;\n            return;\n        }\n        this._options.filter((item) => (item.open = false));\n\n        option.open = !option.open;\n\n        if (option.open) {\n            this.activeGroupEvent.emit(option);\n        }\n    }\n\n    public onBlurInput(event: boolean) {\n        this.closeDropdown.emit(event);\n    }\n\n    public onClearInputEvent(event: boolean) {\n        this.clearInputEvent.emit(event);\n\n        if (event) {\n            this.popoverRef?.close();\n            // label dropdown\n\n            if (this.inputConfig.dropdownLabel) {\n                this.clearDropdownLabel();\n            }\n            // normal dropdown\n            else {\n                this.onClearSearch();\n            }\n        }\n    }\n\n    public handleHiddenDropdown() {\n        this.isDropDownIsOpen = false;\n        this.inputFormControl.patchValue(this.dropdownValue || '');\n        this.inputRef.inputElement.nativeElement.blur();\n        this.searchInputText.next('');\n        this.inputRef.inputElement.nativeElement.value = '';\n    }\n\n    public handleOpenDropdown() {\n        this.isDropDownIsOpen = true;\n        this.searchInputText.next('');\n        this.inputRef.inputElement.nativeElement.value = '';\n    }\n\n    public showHideDropdown(action: boolean) {\n        if (this.inputConfig.multiselectDropdown) {\n            this.isMultiSelectInputFocus = action;\n        }\n\n        if (this.labelMode !== 'Color') {\n            this.getSuperControl!.setValue(null);\n\n            this.popoverRef?.close();\n        }\n\n        // Details pages\n        if (\n            this.inputConfig.customClass?.includes('details-pages') &&\n            !action\n        ) {\n            this.selectedItem.emit(this._activeItem);\n        }\n    }\n\n    public getMainGroup() {\n        let mainGroup: IOptionModel[] = [];\n        this._options.map((groups) => {\n            mainGroup.push(\n                ...groups[\n                    this.inputConfig.searchinGroupIndex as keyof IOptionModel\n                ]\n            );\n        });\n\n        return mainGroup;\n    }\n\n    public dropDownKeyNavigation({\n        keyCode,\n        data,\n    }: {\n        keyCode: number;\n        data: any;\n    }) {\n        // Navigate down\n        if (keyCode === 40) {\n            this.dropdownNavigation(1);\n        }\n        // Navigate up\n        if (keyCode === 38) {\n            this.dropdownNavigation(-1);\n        }\n\n        // Press 'enter'\n        if (keyCode === 13) {\n            let selectedItem;\n            if (this.inputConfig.searchinGroupIndex) {\n                let mainGroup = this.getMainGroup();\n                selectedItem = mainGroup[this.inputHoveredItem];\n            } else {\n                selectedItem =\n                    this.inputHoveredItem > -1\n                        ? this.dropdownComponentRef.options[\n                              this.inputHoveredItem\n                          ]\n                        : { [this.label]: '' };\n            }\n\n            if (\n                this.canOpenModal &&\n                selectedItem?.[this.label]?.toLowerCase() === 'add new'\n            ) {\n                this.selectedItem.emit({\n                    id: 7655,\n                    name: DropdownStringEnum.ADD_NEW,\n                    canOpenModal: true,\n                });\n            } else {\n                this.setDropdownValue({ option: selectedItem });\n            }\n        }\n\n        if (keyCode === 9) {\n            if (!this.popoverRef.isOpen()) this.popoverRef?.open();\n        }\n    }\n\n    public setDropdownValue({\n        option,\n        optionValue,\n        label,\n        setNotFoundError,\n    }: SelectDropdownValueType) {\n        this.setNotFoundInvalidFlag(setNotFoundError || false);\n        this.lastValidOption = option;\n        this.selectedItem.emit(option);\n        const optValue = optionValue ? optionValue : this.optionValue;\n        const lbel = label ? label : this.label;\n        const controlValue = optValue\n            ? option[optValue as keyof IOptionModel]\n            : option;\n\n        const inputValue = option[lbel as keyof IOptionModel] || controlValue;\n\n        this._activeItem = option;\n        this.setControlValue(controlValue, inputValue);\n        this.popoverRef?.close();\n\n        this.searchInputText.next('');\n    }\n\n    // ----------------------------------  Multiselect Dropdown ----------------------------------\n    public onMultiselectSelect(option: IOptionModel): void {\n        this.isMultiSelectInputFocus = false;\n        //this.inputConfig.label = undefined;\n\n        if (this.multiselectItems.some((item) => item.id === option.id)) {\n            return;\n        }\n\n        this._options = this._options.map((item) => {\n            if (item.id === option.id) {\n                return {\n                    ...item,\n                    active: true,\n                };\n            } else {\n                if (!item.active) {\n                    return {\n                        ...item,\n                        active: false,\n                    };\n                } else {\n                    return {\n                        ...item,\n                        active: true,\n                    };\n                }\n            }\n        });\n\n        this.multiselectItems = this._options.filter((item) => item.active);\n\n        this.selectedItems.emit(this.multiselectItems);\n\n        this._options = this._options.sort(\n            (x, y) => Number(y.active) - Number(x.active)\n        );\n        this.originalOptions = [...this._options];\n\n        this.lastActiveMultiselectItem = this._options\n            .filter((item) => item.active)\n            .slice(-1)[0];\n\n        if (this.inputRef) {\n            this.inputRef.isFocusInput = false;\n            this.inputRef.inputElement.nativeElement.blur();\n        }\n    }\n\n    public removeMultiSelectItem(index: number) {\n        this._options = this.originalOptions.map((item) => {\n            if (item.id === this.multiselectItems[index].id) {\n                return {\n                    ...this.multiselectItems[index],\n                    active: false,\n                };\n            }\n            return item;\n        });\n\n        this._options = this._options.sort(\n            (x, y) => Number(y.active) - Number(x.active)\n        );\n\n        this.originalOptions = this._options;\n        this.multiselectItems.splice(index, 1);\n\n        if (!this.multiselectItems.length) {\n            this.lastActiveMultiselectItem = null;\n        } else {\n            this.lastActiveMultiselectItem = this._options\n                .filter((item) => item.active)\n                .slice(-1)[0];\n        }\n\n        this.selectedItems.emit(\n            this.multiselectItems.map((item) => {\n                return { ...item };\n            })\n        );\n    }\n\n    public deleteAllMultiSelectItems(currentLabel?: string) {\n        this.multiselectItems = [];\n        this._options = this._options.map((item) => {\n            return {\n                ...item,\n                active: false,\n            };\n        });\n        this.originalOptions = this._options;\n        this.selectedItems.emit(null);\n\n        this.lastActiveMultiselectItem = null;\n    }\n\n    public toggleMultiselectDropdown() {\n        if (this.inputConfig.isDisabled) {\n            return;\n        }\n        this.isMultiSelectInputFocus = !this.isMultiSelectInputFocus;\n\n        if (this.isMultiSelectInputFocus) {\n            this.clearTimeoutDropdown = setTimeout(() => {\n                this.popoverRef.open();\n            }, 150);\n        } else {\n            this.inputRef.isFocusInput = false;\n            this.popoverRef?.close();\n        }\n    }\n    // ----------------------------------  End ----------------------------------\n\n    public dropdownValue: string | undefined = '';\n    public setControlValue(value?: string, dropdownInputValue?: string) {\n        this.onChange(value); // Notify Angular form about the change\n        if (value) this.onTouched(); // Mark as touched\n        this.dropdownValue = dropdownInputValue || value;\n        this.inputFormControl.patchValue(dropdownInputValue || value);\n    }\n\n    /**\n     * Navigate through dropdown with keyboard arrows\n     */\n    private dropdownNavigation(step: number) {\n        const nextStep = this.inputHoveredItem + step;\n\n        if (nextStep > this.dropdownComponentRef.dropdownOption.length - 1)\n            this.inputHoveredItem = 0;\n        else if (nextStep < 0)\n            this.inputHoveredItem =\n                this.dropdownComponentRef.dropdownOption.length - 1;\n        else this.inputHoveredItem = nextStep;\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        clearTimeout(this.clearTimeoutDropdown);\n    }\n}\n","<div\n    class=\"application-dropdown\"\n    [ngClass]=\"\n        inputConfig\n            | inputDropdownMultiselectClass\n                : multiselectItems\n                : isMultiSelectInputFocus\n    \"\n>\n    @if (multiselectItems.length) {\n        <p class=\"multiselect-label\">\n            {{ multiSelectLabel }}\n        </p>\n    }\n\n    @if (inputConfig.multiSelectDropdownActive) {\n        <!-- Multiselect arrow -->\n        <svg-icon\n            class=\"multiselect-arrow\"\n            [src]=\"inputDropdownSvgRoutes.inputDropdownArrowSvg\"\n            (click)=\"toggleMultiselectDropdown()\"\n        ></svg-icon>\n    }\n\n    @if (multiselectItems.length && !inputConfig.isDisabled) {\n        <!-- Multiselect clear all -->\n        <div\n            class=\"input-clear multiselect-clear\"\n            mainTooltip=\"Clear All\"\n            ngbTooltip\n            position=\"top\"\n            tooltipBackground=\"#2f2f2f\"\n            (click)=\"deleteAllMultiSelectItems()\"\n        >\n            <svg-icon\n                class=\"input-clear-x\"\n                [src]=\"inputDropdownSvgRoutes.xClearSvg\"\n            ></svg-icon>\n        </div>\n    }\n\n    @if (\n        inputConfig.multiselectDropdown &&\n        multiselectItems.length &&\n        _template === 'multiselect'\n    ) {\n        <!-- Multiselect items -->\n        <div class=\"multiselect-items {{ multiselectTemplate }}\">\n            <ng-container> </ng-container>\n            @for (\n                multiSelect of multiselectItems;\n                track $index;\n                let ind = $index\n            ) {\n                <span class=\"multiselect-item\">\n                    {{ multiSelect?.name }}\n                    <!-- Active - Total Counter -->\n                    @if (\n                        inputConfig.multiSelectItemRange &&\n                        multiSelect?.totalCounter\n                    ) {\n                        <span>\n                            {{ multiSelect?.activeCounter }} of\n                            {{ multiSelect?.totalCounter }}\n                        </span>\n                    }\n\n                    @if (\n                        inputConfig.multiSelectItemRange &&\n                        !multiSelect?.totalCounter\n                    ) {\n                        <span>\n                            {{ multiSelect?.activeCounter }}\n                        </span>\n                    }\n\n                    @if (!inputConfig.isDisabled) {\n                        <!-- Active Counter -->\n                        <div\n                            (click)=\"removeMultiSelectItem(ind)\"\n                            class=\"multiselect-item-clear\"\n                            mainTooltip=\"Clear\"\n                            ngbTooltip\n                            position=\"top\"\n                            tooltipBackground=\"#2f2f2f\"\n                        >\n                            <svg-icon\n                                [src]=\"inputDropdownSvgRoutes.xClearSvg\"\n                            ></svg-icon>\n                        </div>\n                    }\n                </span>\n            }\n        </div>\n    }\n\n    <!-- Dropdown search -->\n\n    @if (!inputConfig.isIconInput) {\n        @if (!searchInputText.value) {\n            <!-- <div\n            (scroll)=\"onScrollDropdown($event.target)\"\n            [ngClass]=\"{\n                scroll: _options | caDropdownCount: _template,\n                'dropdown-options-groups':\n                    _template === 'groups' ||\n                    _template === 'load-broker-contact',\n                'dropdown-options-fuel-franchise':\n                    _template === 'fuel-franchise',\n                'merge-dropdown-body-with-input':\n                    inputConfig.mergeDropdownBodyWithInput,\n                'no-result-container': _options[0]?.name === 'No Results',\n                'svgtext-dispatch-template':\n                    _template == 'svgtext-dispatch-template',\n            }\"\n            class=\"dropdown-options  {{ inputConfig.dropdownWidthClass }}\"\n        > -->\n            <div\n                [class.open]=\"isDropDownIsOpen\"\n                [class.leftIcon]=\"inputConfig.placeholderIcon\"\n                [ngClass]=\"{\n                    scroll: _options | caDropdownCount: _template,\n                    'dropdown-options-groups':\n                        _template === 'groups' ||\n                        _template === 'load-broker-contact',\n                    'dropdown-options-fuel-franchise':\n                        _template === 'fuel-franchise',\n                    'merge-dropdown-body-with-input':\n                        inputConfig.mergeDropdownBodyWithInput,\n                    'svgtext-dispatch-template':\n                        _template == 'svgtext-dispatch-template',\n                }\"\n                class=\"dropdown_value dropdown-options  {{\n                    inputConfig.dropdownWidthClass\n                }}\"\n            >\n                @switch (_template) {\n                    @case (dropdownTemplateTypeEnum.LOAD_DISPATCHES_TTD) {\n                        @if (activeItem) {\n                            <div class=\"dropdown-option dropdown-double-column\">\n                                <app-ca-input-dropdown-load-dispatches-ttd-item\n                                    [showNoResulst]=\"false\"\n                                    [index]=\"0\"\n                                    [searchText]=\"searchInputText.value || ''\"\n                                    [activeItem]=\"activeItem\"\n                                    [option]=\"activeItem!\"\n                                    [label]=\"label\"\n                                >\n                                </app-ca-input-dropdown-load-dispatches-ttd-item>\n                            </div>\n                        }\n                    }\n                    @case (dropdownTemplateTypeEnum.LOAD_BROKER) {\n                        @if (activeItem) {\n                            <app-ca-input-dropdown-load-broker-item\n                                [option]=\"activeItem\"\n                                [searchText]=\"searchInputText.value || ''\"\n                                [isInOption]=\"true\"\n                                [label]=\"label\"\n                            ></app-ca-input-dropdown-load-broker-item>\n                        }\n                    }\n\n                    @case (dropdownTemplateTypeEnum.LOAD_SHIPPER) {\n                        @if (activeItem) {\n                            <app-ca-input-dropdown-load-shipper-item\n                                [activeItem]=\"activeItem\"\n                                [searchText]=\"searchInputText.value || ''\"\n                                [option]=\"activeItem\"\n                                [isInOption]=\"true\"\n                                [label]=\"label\"\n                            ></app-ca-input-dropdown-load-shipper-item>\n                        }\n                    }\n\n                    @case (dropdownTemplateTypeEnum.LOAD_BROKER_CONTACT) {\n                        @if (activeItem) {\n                            <div class=\"load-broker-contact-groups\">\n                                <ca-input-dropdown-load-broker-contact-item\n                                    [activeItem]=\"activeItem\"\n                                    [item]=\"activeItem\"\n                                    [searchText]=\"searchInputText.value || ''\"\n                                    [isInOption]=\"true\"\n                                ></ca-input-dropdown-load-broker-contact-item>\n                            </div>\n                        }\n                    }\n\n                    @case (dropdownTemplateTypeEnum.LOAD_DISPATCHER) {\n                        @if (activeItem) {\n                            <app-ca-input-dropdown-load-dispatcher-item\n                                [option]=\"activeItem\"\n                                [searchText]=\"searchInputText.value || ''\"\n                                [activeItem]=\"activeItem\"\n                                [label]=\"label\"\n                                [dropdownWithImage]=\"\n                                    inputConfig.dropdownImageInput\n                                \"\n                                [isInOption]=\"true\"\n                            >\n                            </app-ca-input-dropdown-load-dispatcher-item>\n                        }\n                    }\n\n                    @default {\n                        <!-- Special Dropdown Selected SVG with or Without Text -->\n                        @if (inputConfig.dropdownImageInput && activeItem) {\n                            <svg-icon\n                                [src]=\"\n                                    inputConfig.dropdownImageInput!\n                                        | inputDropdownGetIcons: activeItem\n                                \"\n                                class=\"dropdown-selected-image {{\n                                    inputConfig.dropdownImageInput?.class\n                                }}\"\n                                [ngClass]=\"{\n                                    'unset-color':\n                                        inputConfig.dropdownImageInput?.class,\n                                }\"\n                                [svgStyle]=\"{\n                                    fill: inputConfig.dropdownImageInput\n                                        ? activeItem?.code\n                                        : '#ffffff',\n                                }\"\n                            >\n                            </svg-icon>\n                        }\n\n                        @if (\n                            inputConfig.dropdownImageInput?.withText ||\n                            !inputConfig.dropdownImageInput\n                        ) {\n                            {{ dropdownValue }}\n                        }\n                    }\n                }\n            </div>\n        }\n\n        <ca-input-test\n            #t2=\"ngbPopover\"\n            [ngbPopover]=\"caInputDropdownPopover\"\n            popoverClass=\"ca-input-dropdown\"\n            [autoClose]=\"'outside'\"\n            [container]=\"'body'\"\n            [placement]=\"\n                _template == 'svgtext-dispatch-template'\n                    ? ['bottom-left', 'top-left']\n                    : ['bottom-left']\n            \"\n            #input\n            [formControl]=\"inputFormControl | formControl\"\n            [parentControl]=\"getSuperControl\"\n            [incorrectValue]=\"isIncorrectValue\"\n            [inputConfig]=\"inputConfig\"\n            [selectedDropdownLabelColor]=\"\n                inputConfig.dropdownLabel\n                    ? activeItem\n                        ? activeItem\n                        : activeItemColor\n                    : null\n            \"\n            [template]=\"_template\"\n            (blurInput)=\"onBlurInput($event)\"\n            (clear)=\"onClearInputEvent($event)\"\n            (commandEvent)=\"commandEvent($event)\"\n            (showHideDropdown)=\"showHideDropdown($event)\"\n            (dropDownKeyNavigation)=\"dropDownKeyNavigation($event)\"\n            (incorrectEvent)=\"onIncorrectInput($event)\"\n            (hidden)=\"handleHiddenDropdown()\"\n            (shown)=\"handleOpenDropdown()\"\n        ></ca-input-test>\n    }\n\n    <!-- Dropdown icon instead of input -->\n    @if (inputConfig.isIconInput) {\n        <div\n            class=\"d-flex justify-content-center align-items-center input-icon-container\"\n            [ngClass]=\"{\n                valid:\n                    inputConfig.isValidIcon &&\n                    !inputConfig.inputIcon?.includes('custom'),\n                active: popoverRef?.isOpen(),\n            }\"\n        >\n            <svg-icon\n                #t2=\"ngbPopover\"\n                [ngbPopover]=\"caInputDropdownPopover\"\n                popoverClass=\"ca-input-dropdown\"\n                [autoClose]=\"'outside'\"\n                [container]=\"'body'\"\n                [placement]=\"['bottom-left']\"\n                class=\"input-icon\"\n                [src]=\"\n                    inputDropdownSvgRoutes.repairPmSvgRoute +\n                    inputConfig.inputIcon\n                \"\n            ></svg-icon>\n        </div>\n    }\n</div>\n<ng-template #caInputDropdownPopover>\n    <!--------------------------- Dropdown options --------------------------->\n    @if (inputConfig?.mergeDropdownBodyWithInput && _options?.length) {\n        <div\n            class=\"dropdown-options-divider {{\n                inputConfig.dropdownWidthClass\n            }}\"\n            [class.dispatch_dropdown]=\"_template == 'svgtext-dispatch-template'\"\n        ></div>\n    }\n\n    @if (\n        (inputConfig?.name != 'Address' &&\n            inputConfig?.name != 'RoutingAddress' &&\n            !inputConfig.isDisabled) ||\n        ((inputConfig?.name == 'Address' ||\n            inputConfig?.name == 'RoutingAddress') &&\n            !inputConfig.isDisabled &&\n            _options?.length)\n    ) {\n        <div\n            (scroll)=\"onScrollDropdown($event.target)\"\n            [ngClass]=\"{\n                scroll: _options | caDropdownCount: _template,\n                'dropdown-options-groups':\n                    _template === 'groups' ||\n                    _template === 'load-broker-contact',\n                'dropdown-options-fuel-franchise':\n                    _template === 'fuel-franchise',\n                'merge-dropdown-body-with-input':\n                    inputConfig.mergeDropdownBodyWithInput,\n                'no-result-container': _options[0]?.name === 'No Results',\n                'svgtext-dispatch-template':\n                    _template == 'svgtext-dispatch-template',\n            }\"\n            class=\"dropdown-options  {{ inputConfig.dropdownWidthClass }}\"\n        >\n            @switch (_template) {\n                <!--------------------------- SVG Template (Render svgs or text if svgs doesn't exist ) --------------------------->\n\n                @case (dropdownTemplateTypeEnum.SVG_TEMPLATE) {\n                    <app-ca-input-dropdown-svg-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [dropdownWithImage]=\"inputConfig.dropdownImageInput\"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-svg-template>\n                    <!-- <ng-container \n                        *ngTemplateOutlet=\"dropdownSvgTemplate\"\n                    ></ng-container> -->\n                }\n\n                <!--------------------------- Svg Text Template (display flex) --------------------------->\n\n                @case (dropdownTemplateTypeEnum.SVGTEXT_TEMPLATE) {\n                    <app-ca-input-dropdown-svgtext-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        [inputConfig]=\"inputConfig\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-svgtext-template>\n\n                    <!-- <ng-container\n                        *ngTemplateOutlet=\"svgTextTemplate\"\n                    ></ng-container> -->\n                }\n\n                <!-------------------------------------------Dispatch dropdown-------------------------------------------->\n\n                @case (dropdownTemplateTypeEnum.SVGTEXT_DISPATCH_TEMPLATE) {\n                    <app-ca-input-dropdown-svgtext-dispatch-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        [inputConfig]=\"inputConfig\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-svgtext-dispatch-template>\n\n                    <!-- <ng-container\n                        *ngTemplateOutlet=\"dispatchTemplate\"\n                    ></ng-container> -->\n                }\n\n                <!--------------------------- Details template (truck, trailer... details-pages)  --------------------------->\n\n                @case (dropdownTemplateTypeEnum.DETAILS_TEMPLATE) {\n                    <app-ca-input-dropdown-details-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        [sort]=\"_sort\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-details-template>\n\n                    <!-- <ng-container\n                        *ngTemplateOutlet=\"detailsTemplate\"\n                    ></ng-container> -->\n                }\n\n                <!--------------------------- Grouping template (can see on contact modal)  --------------------------->\n\n                @case (dropdownTemplateTypeEnum.GROUPS) {\n                    <app-ca-input-dropdown-groups\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-groups>\n                }\n\n                <!--------------------------- Multiselect Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.MULTISELECT) {\n                    <app-ca-input-dropdown-multiselect\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [lastActiveMultiselectItem]=\"lastActiveMultiselectItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onMultiselectSelect)=\"onMultiselectSelect($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-multiselect>\n                }\n                <!--------------------------- Labels Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LABELS) {\n                    <app-ca-input-dropdown-labels\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        [inputConfig]=\"inputConfig\"\n                        [labelMode]=\"labelMode\"\n                        [canAddNew]=\"_canAddNew\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-labels>\n                }\n\n                <!--------------------------- Dispatch Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.DISPATCH) {\n                    <app-ca-input-dropdown-dispatch\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-dispatch>\n                }\n\n                <!--------------------------- Load Dispatcher Template (user avatar + user name) --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_DISPATCHER) {\n                    <app-ca-input-dropdown-load-dispatcher\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                        [inputConfig]=\"inputConfig\"\n                    ></app-ca-input-dropdown-load-dispatcher>\n                }\n\n                <!--------------------------- Load Combine Truck-Trailer-Driver Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_DISPATCHES_TTD) {\n                    <app-ca-input-dropdown-load-dispatches-ttd\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-load-dispatches-ttd>\n                }\n\n                <!--------------------------- Load Broker Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_BROKER) {\n                    <app-ca-input-dropdown-load-broker\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-load-broker>\n                }\n\n                <!--------------------------- Load Broker Contact Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_BROKER_CONTACT) {\n                    <app-ca-input-dropdown-load-broker-contact\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-load-broker-contact>\n                }\n\n                <!--------------------------- Load Shipper Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.LOAD_SHIPPER) {\n                    <app-ca-input-dropdown-load-shipper\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-load-shipper>\n                }\n\n                <!--------------------------- Template Text - Counter --------------------------->\n\n                @case (dropdownTemplateTypeEnum.TEXT_COUNTER) {\n                    <app-ca-input-dropdown-text-counter\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-text-counter>\n                }\n\n                <!--------------------------- Fuel Franchise Template --------------------------->\n\n                @case (dropdownTemplateTypeEnum.FUEL_FRANCHISE) {\n                    <app-ca-input-dropdown-fuel-franchise\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        (toggleNestedList)=\"toggleNestedList($event)\"\n                        (onActiveItemGroup)=\"onActiveItemGroup($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-fuel-franchise>\n                }\n\n                <!-- Double Text Template -->\n\n                @case (dropdownTemplateTypeEnum.DOUBLE_TEXT_TEMPLATE) {\n                    <app-ca-input-dropdown-double-text-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-double-text-template>\n                }\n\n                <!-- Double Column Template -->\n\n                @case (dropdownTemplateTypeEnum.DOUBLE_COLUMN_TEMPLATE) {\n                    <app-ca-input-dropdown-double-text-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-double-text-template>\n                }\n\n                <!-- Triple Column Template -->\n\n                @case (dropdownTemplateTypeEnum.TRIPLE_COLUMN_TEMPLATE) {\n                    <app-ca-input-dropdown-triple-text-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-triple-text-template>\n                }\n\n                <!-- PAYROLL TRUCKS Template -->\n\n                @case (dropdownTemplateTypeEnum.PAYROLL_TRUCKS) {\n                    <app-ca-input-dropdown-payroll-trucks\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-payroll-trucks>\n                }\n\n                <!--------------------------- Default Template - Render Only Text --------------------------->\n                @default {\n                    <app-ca-input-dropdown-default-template\n                        #dropdownComponentRef\n                        [options]=\"\n                            searchInputText.value || ''\n                                | caDropdownOptionsPipe\n                                    : _options\n                                    : inputConfig\n                                    : canAddNew\n                                    : label\n                                    : sort\n                        \"\n                        [activeItem]=\"activeItem\"\n                        [inputConfig]=\"inputConfig\"\n                        [searchText]=\"searchInputText.value || ''\"\n                        (onActiveItem)=\"onActiveItem($event)\"\n                        [inputHoveredItem]=\"inputHoveredItem\"\n                        [label]=\"label\"\n                    ></app-ca-input-dropdown-default-template>\n                }\n            }\n        </div>\n    }\n</ng-template>\n"]}
@@ -31741,6 +31741,7 @@ class CaInputDropdownTestComponent {
31741
31741
  return this.superControl.control;
31742
31742
  }
31743
31743
  writeValue(value) {
31744
+ console.log("WRITE VALUE FIRST", value);
31744
31745
  this.firstWriteValue = value;
31745
31746
  this.writeValueToFormControl(value);
31746
31747
  }