ca-components 1.0.77 → 1.0.78
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.
- package/esm2022/lib/components/ca-input/ca-input.component.mjs +1 -1
- package/esm2022/lib/components/ca-map/ca-map.component.mjs +137 -210
- package/esm2022/lib/components/ca-map/enums/google-map.enum.mjs +2 -1
- package/esm2022/lib/components/ca-map/enums/map-marker-string.enum.mjs +2 -1
- package/esm2022/lib/components/ca-map/models/map.model.mjs +1 -1
- package/esm2022/lib/components/ca-map/utils/constants/index.mjs +2 -1
- package/esm2022/lib/components/ca-map/utils/constants/map-marker-icons.constants.mjs +119 -0
- package/esm2022/lib/components/ca-map/utils/constants/map-options.constants.mjs +1 -2
- package/esm2022/lib/components/ca-map/utils/helpers/map-marker-icon.helper.mjs +50 -12
- package/esm2022/lib/components/ca-map/utils/services/index.mjs +2 -0
- package/esm2022/lib/components/ca-map/utils/services/map-marker-icon.service.mjs +137 -0
- package/esm2022/lib/components/ca-map-dropdown/ca-map-dropdown.component.mjs +25 -11
- package/esm2022/lib/components/ca-progress-bar/ca-progress-bar.component.mjs +15 -15
- package/esm2022/lib/constants/map.constant.mjs +131 -131
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ca-components.mjs +717 -491
- package/fesm2022/ca-components.mjs.map +1 -1
- package/lib/components/ca-filters/ca-filter.component.d.ts +2 -2
- package/lib/components/ca-map/ca-map.component.d.ts +22 -25
- package/lib/components/ca-map/enums/google-map.enum.d.ts +2 -1
- package/lib/components/ca-map/enums/map-marker-string.enum.d.ts +2 -1
- package/lib/components/ca-map/models/map.model.d.ts +8 -3
- package/lib/components/ca-map/utils/constants/index.d.ts +1 -0
- package/lib/components/ca-map/utils/constants/map-marker-icons.constants.d.ts +6 -0
- package/lib/components/ca-map/utils/helpers/map-marker-icon.helper.d.ts +2 -0
- package/lib/components/ca-map/utils/services/index.d.ts +1 -0
- package/lib/components/ca-map/utils/services/map-marker-icon.service.d.ts +23 -0
- package/lib/components/ca-map-dropdown/ca-map-dropdown.component.d.ts +5 -3
- package/lib/components/ca-progress-bar/ca-progress-bar.component.d.ts +3 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -346,4 +346,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
346
346
|
type: Output,
|
|
347
347
|
args: ['dropDownKeyNavigation']
|
|
348
348
|
}] } });
|
|
349
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input/ca-input.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input/ca-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  CUSTOM_ELEMENTS_SCHEMA,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  Self,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NgControl,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { combineLatest, Observable, Subject, takeUntil } from 'rxjs';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// models\nimport { ICaInput } from './config';\nimport { LabelColor, CommandsEvent } from './models';\n\n// pipes\nimport {\n  InputErrorPipe,\n  InputContainerClassPipe,\n  InputClassPipe,\n  LabelClassPipe,\n  ShowClearPipe,\n  ShowInvalidDangerMarkPipe,\n  ShowValidCheckPipe,\n  InputTypePipe,\n  InputDropdownArrowClassPipe,\n  ShowDropdownArrowPipe,\n  InputPlaceholderIconRightClassPipe,\n  InputPlaceholderTextClassPipe,\n  ShowPlaceholderTextPipe\n} from './pipes';\nimport { CaSvgPipe } from '../../pipes/ca-svg.pipe';\nimport { LoadStatusColorPipe } from '../../pipes/load-status-color.pipe';\nimport { ThousandSeparatorPipe } from '../../pipes/thousand-separator.pipe';\n\n// components\nimport { CaAppTooltipV2Component } from '../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\nimport { CaInputClearComponent } from './components/ca-input-clear/ca-input-clear.component';\nimport { CaInputCommandsComponent } from './components/ca-input-commands/ca-input-commands.component';\nimport { CaInputPasswordComponent } from './components/ca-input-password/ca-input-password.component';\nimport { CaInputPlaceholderIconComponent } from './components/ca-input-placeholder-icon/ca-input-placeholder-icon.component';\nimport { CaInputDatetimePickerComponent } from './components/ca-input-datetime-picker/ca-input-datetime-picker.component';\nimport { CaCustomDatetimePickersComponent } from '../ca-custom-datetime-pickers/ca-custom-datetime-pickers.component';\nimport { CaProfileImageComponent } from '../ca-profile-image/ca-profile-image.component';\nimport { CaLoadModalProgressBarComponent } from '../ca-load-modal-progress-bar/ca-load-modal-progress-bar.component';\n\n// services\nimport { InputStateService } from './services';\nimport { CalendarDateTimePickerService } from '../ca-custom-datetime-pickers/services/calendar-datetime-picker.service';\n\n// helpers\nimport { InputChangeValue, InputSvgRoutes } from './utils';\n\n// modules\nimport { NgbModule, NgbPopover } from '@ng-bootstrap/ng-bootstrap';\nimport { NgxMaskModule } from 'ngx-mask';\n\n// directives\nimport { MinMaxValueDirective } from './directives';\n\n// enums\nimport { InputCommandsType, InputStringEnum } from './enums';\nimport { DropdownTemplateTypeEnum } from '../ca-input-dropdown/enums';\n\n@Component({\n  selector: 'app-ca-input',\n  templateUrl: './ca-input.component.html',\n  styleUrls: ['./ca-input.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    // Module\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    AngularSvgIconModule,\n    NgbModule,\n    NgxMaskModule,\n    // Pipe\n    InputErrorPipe,\n    InputContainerClassPipe,\n    InputClassPipe,\n    LabelClassPipe,\n    ShowClearPipe,\n    ShowInvalidDangerMarkPipe,\n    ShowValidCheckPipe,\n    InputTypePipe,\n    InputDropdownArrowClassPipe,\n    ShowDropdownArrowPipe,\n    CaSvgPipe,\n    LoadStatusColorPipe,\n    InputPlaceholderIconRightClassPipe,\n    InputPlaceholderTextClassPipe,\n    ShowPlaceholderTextPipe,\n    // Components\n    CaInputClearComponent,\n    CaAppTooltipV2Component,\n    CaInputPasswordComponent,\n    CaInputPlaceholderIconComponent,\n    CaInputCommandsComponent,\n    CaCustomDatetimePickersComponent,\n    CaInputDatetimePickerComponent,\n    CaProfileImageComponent,\n    CaLoadModalProgressBarComponent,\n    // Directives\n    MinMaxValueDirective\n],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  providers: [InputStateService, CalendarDateTimePickerService],\n})\nexport class CaInputComponent\n  implements OnInit, OnDestroy, OnChanges, AfterViewInit, ControlValueAccessor\n{\n  @ViewChild('input', { static: true }) public input!: ElementRef;\n  @ViewChild(NgbPopover) ngbMainPopover!: NgbPopover;\n\n  @Input() inputConfig!: ICaInput;\n\n  @Input() incorrectValue!: boolean;\n  @Input() selectedDropdownLabelColor!: LabelColor | null;\n  @Input() template!: string;\n\n  @Output('incorrectEvent') incorrectInput: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('blurInput') blurInput: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('focusInput') focusInputEvent: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('change') changeInput: EventEmitter<InputChangeValue> =\n    new EventEmitter<InputChangeValue>();\n  @Output('commandEvent') commandEvent: EventEmitter<CommandsEvent> =\n    new EventEmitter<CommandsEvent>();\n  @Output('clear') clearInputEvent: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n\n  // Dropdown\n  @Output('showHideDropdown') showHideDropdownEvent: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('dropDownKeyNavigation') dropDownKeyNavigationEvent: EventEmitter<{\n    keyCode: number;\n    data: ICaInput | null;\n  }> = new EventEmitter<{\n    keyCode: number;\n    data: ICaInput | null;\n  }>();\n\n  public isTouchedInput: boolean = false;\n\n  // Input Commands\n  public isVisibleCommands: boolean = false;\n\n  // Edit Input\n  public isEditInput: boolean = false;\n\n  // Password\n  public isTogglePassword: boolean = false;\n  public isCapsLockOn: boolean = false;\n\n  // Dropdown\n  public isDropdownToggler: boolean = false;\n\n  // Date\n  public showDateInput: boolean = false;\n  public dateTimeInputDate: Date = new Date();\n  public newInputChanged: boolean = false;\n\n  // Destroy\n  private destroy$: Subject<void> = new Subject<void>();\n\n  public inputSvgRoutes = InputSvgRoutes;\n  public isFocusInput!: boolean;\n  public priceSeperatorWithFilledValue = true;\n\n  public inputCommandsType = InputCommandsType;\n  public inputStringEnum = InputStringEnum;\n  public dropdownTemplateTypeEnum = DropdownTemplateTypeEnum;\n\n  constructor(\n    @Self() public superControl: NgControl,\n    private cdRef: ChangeDetectorRef,\n    public inputStateService: InputStateService,\n    private thousandSeparatorPipe: ThousandSeparatorPipe\n  ) {\n    this.superControl.valueAccessor = this;\n  }\n\n  get getSuperControl() {\n    return this.superControl.control;\n  }\n\n  ngOnInit(): void {\n    this.initChangesListener();\n\n    this.initStateService();\n\n    this.outputListeners();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.setStateInputs(changes);\n  }\n\n  ngAfterViewInit(): void {\n    this.inputStateService.autoFocusFirstInput();\n  }\n\n  public initStateService(): void {\n    this.inputStateService.setSuperControl(this.superControl);\n    this.inputStateService.setInputElementRef(this.input, this.cdRef);\n\n    this.inputStateService.combinedVariables$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(\n        ([\n          focus,\n          touched,\n          isVisibleCommands,\n          isEditInput,\n          isDropdownToggler,\n          dateTimeInputDate,\n          showDateInput,\n          isCapsLockOn,\n        ]) => {\n          this.isFocusInput = focus;\n          this.isTouchedInput = touched;\n          this.isVisibleCommands = isVisibleCommands;\n          this.isEditInput = isEditInput;\n          this.isDropdownToggler = isDropdownToggler;\n          this.dateTimeInputDate = dateTimeInputDate;\n          this.showDateInput = showDateInput;\n          this.isCapsLockOn = isCapsLockOn;\n        }\n      );\n  }\n\n  public outputListeners(): void {\n    const observables: {\n      stream$: Observable<any>;\n      emitter: EventEmitter<any>;\n    }[] = [\n      {\n        stream$: this.inputStateService.commandEvent$,\n        emitter: this.commandEvent,\n      },\n      {\n        stream$: this.inputStateService.clearInputEvent$,\n        emitter: this.clearInputEvent,\n      },\n      {\n        stream$: this.inputStateService.incorrectInput$,\n        emitter: this.incorrectInput,\n      },\n      {\n        stream$: this.inputStateService.blurInput$,\n        emitter: this.blurInput,\n      },\n      {\n        stream$: this.inputStateService.changeInput$,\n        emitter: this.changeInput,\n      },\n      {\n        stream$: this.inputStateService.showHideDropdown$,\n        emitter: this.showHideDropdownEvent,\n      },\n      {\n        stream$: this.inputStateService.dropDownKeyNavigation$,\n        emitter: this.dropDownKeyNavigationEvent,\n      },\n    ];\n\n    observables.forEach(({ stream$, emitter }) =>\n      stream$\n        .pipe(takeUntil(this.destroy$))\n        .subscribe((value: any) => emitter.emit(value))\n    );\n  }\n\n  public initChangesListener(): void {\n    const combinedChanges = combineLatest([\n      this.getSuperControl?.valueChanges,\n      this.getSuperControl?.statusChanges,\n    ]);\n\n    combinedChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.cdRef.detectChanges();\n    });\n\n    this.inputStateService.onChange$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((value) => {\n        this.onChange(value);\n      });\n  }\n\n  public setStateInputs(changes: SimpleChanges): void {\n    if (changes['inputConfig']) {\n      this.inputStateService.setInputConfig(\n        changes['inputConfig']?.currentValue\n      );\n      this.inputStateService.onInputConfigChange();\n    }\n    this.inputStateService.setIncorrectValue(\n      changes['incorrectValue']?.currentValue\n    );\n  }\n\n  public writeValue(obj: InputChangeValue): void {\n    if (this.inputConfig.priceSeparator) {\n      if (obj && this.priceSeperatorWithFilledValue)\n        this.input.nativeElement.value =\n          this.thousandSeparatorPipe.transform(obj);\n      else this.input.nativeElement.value = obj;\n\n      this.priceSeperatorWithFilledValue = false;\n    }\n\n    this.inputStateService.writeValue(obj);\n  }\n\n  public registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  public onChange(_: any): void {}\n\n  public registerOnTouched(): void {}\n\n  public onBlur(event?: FocusEvent): void {\n    this.inputStateService.onBlur(event);\n\n    this.blurInput.emit(true);\n  }\n\n  public onFocus(event?: FocusEvent): void {\n    this.focusInputEvent.emit(true);\n\n    this.inputStateService.onFocus(event);\n  }\n\n  public onKeyPress(event: KeyboardEvent): void {\n    this.inputStateService.onKeypress(event);\n  }\n\n  public onKeydown(event: KeyboardEvent): void {\n    this.inputStateService.onKeydown(event);\n  }\n\n  public onKeyup(event: KeyboardEvent): void {\n    this.inputStateService.onKeyup(event);\n  }\n\n  public transformText(event: Event): void {\n    this.inputStateService.transformText(event);\n  }\n\n  public clearInput(event: Event): void {\n    this.inputStateService.clearInput(event);\n  }\n\n  public onTogglePassword(event: Event): void {\n    event.preventDefault();\n    this.isTogglePassword = !this.isTogglePassword;\n  }\n\n  public onCommands(event: {\n    event: Event;\n    type: string;\n    action: string;\n  }): void {\n    this.inputStateService.onCommands(event.event, event.type, event.action);\n  }\n\n  public onEditInput(event: Event): void {\n    this.inputStateService.onEditInput(event);\n  }\n\n  public toggleDropdownOptions(): void {\n    this.inputStateService.toggleDropdownOptions();\n  }\n\n  public onPlaceholderIconEvent(event: Event): void {\n    this.inputStateService.onPlaceholderIconEvent(event);\n  }\n\n  public setInputCursorAtTheEnd(input: any): void {\n    this.inputStateService.setInputCursorAtTheEnd(input);\n  }\n\n  //-------------------------------------- Date & Time Picker --------------------------------------\n\n  public selectionChange(event: Event): void {\n    this.inputStateService.selectionChange(event);\n  }\n\n  public onDatePaste(event: ClipboardEvent): void {\n    this.inputStateService.onDatePaste(event);\n  }\n\n  public setSelection(event: {\n    preventDefault: () => void;\n    stopPropagation: () => void;\n    target: any;\n  }): void {\n    this.inputStateService.setSelection(event);\n  }\n\n  public changeSelection(event: {\n    e: KeyboardEvent;\n    noPreventDefault: boolean;\n  }): void {\n    this.inputStateService.changeSelection(event.e, event.noPreventDefault);\n  }\n\n  public onPopoverShown(): void {\n    this.inputStateService.onPopoverShown();\n  }\n\n  public onPopoverHidden(): void {\n    this.inputStateService.onPopoverHidden();\n  }\n\n  public closePopover(): void {\n    if (this.ngbMainPopover) this.ngbMainPopover.close();\n  }\n\n  public selectLastOneForSelection(): void {\n    this.inputStateService.selectLastOneForSelection();\n  }\n\n  public selectLastOneAfterMouseUp(): void {\n    this.inputStateService.selectLastOneAfterMouseUp();\n  }\n\n  public trackIdentity = (index: number): number => index;\n\n  ngOnDestroy(): void {\n    this.inputStateService.onDestory();\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div\n  class=\"input-custom-group {{ inputConfig.customClass }}\"\n  [ngClass]=\"\n    getSuperControl\n      | inputContainerClass\n        : isFocusInput\n        : isTouchedInput\n        : inputConfig\n        : getSuperControl?.value\n  \"\n  ngbTooltip\n  [mainCaTooltip]=\"getSuperControl?.errors | inputError: inputConfig.name\"\n  [tooltipBackground]=\"'#DF3C3C'\"\n  [disableTooltip]=\"!inputConfig.requiredLabel || !!superControl.valid\"\n  position=\"bottom\"\n  triggers=\"hover\"\n>\n  <!-- Input Commands -->\n  <ng-container *ngIf=\"inputConfig.commands?.active && isVisibleCommands\">\n    <app-ca-input-commands\n      [inputConfig]=\"inputConfig\"\n      [isFocusInput]=\"isFocusInput\"\n      [isVisibleCommands]=\"isVisibleCommands\"\n      (onCommandsClick)=\"onCommands($event)\"\n    >\n    </app-ca-input-commands>\n  </ng-container>\n\n  <!-- DateTime Picker -->\n  <ng-container\n    *ngIf=\"\n      (inputConfig.name === 'datepicker' ||\n        inputConfig.name === 'timepicker') &&\n      !inputConfig.isDisabled\n    \"\n  >\n    <app-ca-input-datetime-picker\n      [showDateInput]=\"showDateInput\"\n      [inputConfig]=\"inputConfig\"\n      [getSuperControl]=\"getSuperControl\"\n      [isFocusInput]=\"isFocusInput\"\n      [isVisibleCommands]=\"isVisibleCommands\"\n      [isTouchedInput]=\"isTouchedInput\"\n      (selectLastOneForSelectionEmitter)=\"selectLastOneForSelection()\"\n      (selectLastOneAfterMouseUpEmitter)=\"selectLastOneAfterMouseUp()\"\n      (onDatePasteEmitter)=\"onDatePaste($event)\"\n      (onBlurEmitter)=\"onBlur()\"\n      (changeSelectionEmmiter)=\"changeSelection($event)\"\n      (onFocusEmitter)=\"onFocus($event)\"\n      (setSelectionEmmiter)=\"setSelection($event)\"\n    >\n    </app-ca-input-datetime-picker>\n  </ng-container>\n\n  <!-- Input Label -->\n  <ng-container *ngIf=\"!inputConfig.multiSelectDropdownActive\">\n    <label\n      [for]=\"inputConfig.name\"\n      class=\"input-label {{ inputConfig.customClass }} {{\n        inputConfig.multipleLabel?.customClass\n      }}\"\n      [ngClass]=\"\n        getSuperControl?.value | labelClass: isFocusInput : inputConfig\n        : isTouchedInput : getSuperControl?.invalid\n        : getSuperControl?.touched\n      \"\n    >\n      <ng-container *ngIf=\"inputConfig.label\">\n        <span>{{ inputConfig.label }} </span>\n      </ng-container>\n      <ng-container *ngIf=\"inputConfig.multipleLabel?.labels?.length\">\n        <div\n          [class]=\"inputConfig.multipleLabel?.customClass!\"\n          [ngClass]=\"{\n            'multiple-labels-position-on-focus':\n              isFocusInput ||\n              inputConfig.multipleInputValues?.options?.length,\n            required: inputConfig.isRequired && !inputConfig.isDisabled\n          }\"\n        >\n          <span *ngFor=\"let label of inputConfig.multipleLabel?.labels\">\n            {{ label }}\n          </span>\n        </div>\n      </ng-container>\n    </label>\n  </ng-container>\n\n  <!-- Input Clear -->\n  <ng-container *ngIf=\"inputConfig | showClear\">\n    <app-ca-input-clear\n      [inputConfig]=\"inputConfig\"\n      [getSuperControl]=\"getSuperControl\"\n      [isFocusInput]=\"isFocusInput\"\n      [incorrectValue]=\"incorrectValue\"\n      [selectedDropdownLabelColor]=\"selectedDropdownLabelColor\"\n      [template]=\"template\"\n      (clearInputClick)=\"clearInput($event)\"\n    >\n    </app-ca-input-clear>\n  </ng-container>\n\n  <!-- Input Clear for dispatch dropdown -->\n  <ng-container *ngIf=\"template === 'svgtext-dispatch-template'\">\n    <div\n      class=\"input-clear-dispatch\"\n      position=\"top\"\n      (click)=\"clearInput($event)\"\n    >\n      <svg-icon\n        [src]=\"inputSvgRoutes.xClearCommonSvg\"\n        class=\"input-clear-dispatch-icon\"\n      ></svg-icon>\n    </div>\n  </ng-container>\n\n  <!-- Input Pen -->\n  <ng-container\n    *ngIf=\"\n      selectedDropdownLabelColor &&\n      !isEditInput &&\n      !isFocusInput &&\n      getSuperControl?.value\n    \"\n  >\n    <div\n      class=\"input-pen-container\"\n      ngbTooltip\n      [mainCaTooltip]=\"'Edit'\"\n      [tooltipBackground]=\"'#2F2F2F'\"\n      position=\"top\"\n      (click)=\"onEditInput($event)\"\n    >\n      <svg-icon [src]=\"inputSvgRoutes.inputPenSvg\" class=\"input-pen\"></svg-icon>\n    </div>\n  </ng-container>\n\n  <!-- Input Invalid Danger Mark -->\n  <ng-container\n    *ngIf=\"\n      inputConfig\n        | showInvalidDangerMark\n          : getSuperControl\n          : isFocusInput\n          : isTouchedInput\n          : getSuperControl?.value\n    \"\n  >\n    <svg-icon\n      class=\"input-invalid-danger-mark  {{ inputConfig.customClass }}\"\n      [src]=\"inputSvgRoutes.dangerSvg\"\n    >\n    </svg-icon>\n  </ng-container>\n\n  <!-- Input Valid Check -->\n  <ng-container\n    *ngIf=\"\n      getSuperControl\n        | showValidCheck: isFocusInput : inputConfig : getSuperControl?.value\n    \"\n  >\n    <svg-icon\n      class=\"input-required-check {{ inputConfig.customClass }}\"\n      [src]=\"inputSvgRoutes.confirmSvg\"\n    ></svg-icon>\n  </ng-container>\n\n  <!-- Input Password Caps Lock And Eye -->\n  <ng-container *ngIf=\"inputConfig.type === 'password'\">\n    <app-ca-input-password\n      [inputConfig]=\"inputConfig\"\n      [getSuperControl]=\"getSuperControl\"\n      [isFocusInput]=\"isFocusInput\"\n      [isTouchedInput]=\"isTouchedInput\"\n      [isCapsLockOn]=\"isCapsLockOn\"\n      [isTogglePassword]=\"isTogglePassword\"\n      (onTogglePasswordClick)=\"onTogglePassword($event)\"\n    >\n    </app-ca-input-password>\n  </ng-container>\n\n  <!-- Input Dropdown Arrow -->\n  <ng-container *ngIf=\"inputConfig | showDropdownArrow\">\n    <svg-icon\n      class=\"input-dropdown-arrow {{ inputConfig.customClass }}\"\n      [ngClass]=\"\n        getSuperControl\n          | inputDropdownArrowClass\n            : isFocusInput\n            : inputConfig\n            : isTouchedInput\n            : getSuperControl?.value\n      \"\n      [src]=\"inputSvgRoutes.inputDropdownArrowSvg\"\n      (click)=\"toggleDropdownOptions()\"\n    ></svg-icon>\n  </ng-container>\n\n  <!-- Input Placeholder Icon -->\n  <ng-container \n    *ngIf=\"\n      inputConfig.placeholderIcon ||\n      inputConfig.name === 'datepicker' ||\n      inputConfig.name === 'timepicker'\n    \"\n  >\n    <app-ca-input-placeholder-icon\n      [inputConfig]=\"inputConfig\"\n      [getSuperControl]=\"getSuperControl\"\n      [isFocusInput]=\"isFocusInput\"\n      [isTouchedInput]=\"isTouchedInput\"\n      [selectedDropdownLabelColor]=\"selectedDropdownLabelColor\"\n      [isEditInput]=\"isEditInput\"\n      [dateTimePopover]=\"dateTimePopover\"\n      (onPopoverShownEmitter)=\"onPopoverShown()\"\n      (onPopoverHiddenEmitter)=\"onPopoverHidden()\"\n      (onPlaceholderIconEventEmitter)=\"onPlaceholderIconEvent($event)\"\n    >\n    </app-ca-input-placeholder-icon>\n  </ng-container>\n\n  <!-- Input Placeholder Text -->\n  <ng-container\n    *ngIf=\"\n      inputConfig | showPlaceholderText : getSuperControl : \n      isVisibleCommands : getSuperControl?.value\n    \"\n  >\n    <span\n      class=\"ca-placeholder-text {{ inputConfig.customClass }}\"\n      [ngClass]=\"      \n      isFocusInput | inputPlaceholderTextClass\n        : isTouchedInput : getSuperControl : inputConfig\n        : isVisibleCommands : getSuperControl?.value\n      \"\n      [style.left]=\"\n        inputConfig.placeholderText?.toLowerCase() === inputStringEnum.PERSONS ||\n        inputConfig.placeholderText?.toLowerCase() === inputStringEnum.VEHICLES\n          ? 30 +\n            (getSuperControl?.value?.toString()?.length + 1) * 9 +\n            'px'\n          : isFocusInput &&\n            inputConfig.placeholderText?.toLowerCase() !== inputCommandsType.MONTHS\n          ? 'auto'\n          : (getSuperControl?.value?.toString()?.length + 1) * 8 + 'px'\n      \"\n      [style.right]=\"\n        isFocusInput &&\n        inputConfig.placeholderText?.toLowerCase() !== inputCommandsType.MONTHS\n          ? '28px'\n          : 'auto'\n      \"\n      >\n        {{ inputConfig.placeholderText }}\n    </span>\n  </ng-container>\n  \n  <!-- Input Label Counter -->\n  <ng-container\n    *ngIf=\"\n      selectedDropdownLabelColor &&\n      getSuperControl?.value &&\n      !isFocusInput &&\n      !inputConfig.isDisabled &&\n      inputConfig.showCount\n    \"\n  >\n    <p\n      [style.top]=\"'4px'\"\n      [style.left]=\"\n        (getSuperControl?.value?.toString()?.length + 6.5) * 8 + 'px'\n      \"\n      class=\"input-label-counter\"\n    >\n      {{ selectedDropdownLabelColor.count }}\n    </p>\n  </ng-container>\n\n  <!-- Special Dropdown Selected SVG with or Without Text -->\n  <ng-container\n    *ngIf=\"\n      inputConfig?.dropdownImageInput?.svg &&\n      !inputConfig?.hideAllItemsInInputDropdown &&\n      !(!inputConfig.dropdownImageInput?.withText && isFocusInput) &&\n      !(\n          ['truck', 'trailer'].includes(\n              inputConfig.dropdownImageInput?.template!\n          ) &&\n          isFocusInput &&\n          inputConfig.dropdownImageInput?.remove\n      ) &&\n      !inputConfig?.dropdownImageInput?.nameInitialsInsteadUrl\n    \"\n  >\n    <svg-icon\n        [src]=\"inputConfig.dropdownImageInput?.url!\"\n        class=\"dropdown-selected-image {{\n          inputConfig.dropdownImageInput?.class\n        }}\"\n        [ngClass]=\"{\n          'unset-color': isFocusInput && inputConfig.dropdownImageInput?.class\n        }\"\n        [svgStyle]=\"{\n          fill:\n            inputConfig.dropdownImageInput?.color && !isFocusInput\n              ? inputConfig.dropdownImageInput?.color\n              : '#ffffff'\n        }\"\n    >\n    </svg-icon>\n  </ng-container>\n\n  <!-- Special Dropdown Selected Image With Text With Initials name -->\n  <ng-container\n    *ngIf=\"\n      inputConfig?.dropdownImageInput?.image &&\n      !inputConfig?.hideAllItemsInInputDropdown &&\n      inputConfig?.dropdownImageInput?.url &&\n      !inputConfig?.dropdownImageInput?.nameInitialsInsteadUrl\n    \"\n  >\n    <img\n      class=\"dropdown-selected-image name-initials-instead-url\"\n      [src]=\"inputConfig.dropdownImageInput?.url\"\n      [alt]=\"'Input Image'\"\n    />\n  </ng-container>\n  <ng-container\n    *ngIf=\"\n      inputConfig?.dropdownImageInput?.nameInitialsInsteadUrl &&\n      !inputConfig?.hideAllItemsInInputDropdown &&\n      !(!inputConfig.dropdownImageInput?.withText && isFocusInput)\n    \"\n  >\n    <div\n      class=\"no-profile-image dropdown-selected-image name-initials-instead-url\"\n    >\n      <app-ca-profile-image\n          [indx]=\"0\"\n          [size]=\"'small'\"\n          [type]=\"'user'\"\n          [name]=\"inputConfig.dropdownImageInput?.nameInitialsInsteadUrl!\"\n      >\n      </app-ca-profile-image>\n    </div>\n  </ng-container>\n\n  <!-- Multiple Input Values -->\n  <ng-container\n    *ngIf=\"\n      inputConfig?.multipleInputValues?.options?.length && !isFocusInput\n    \"\n  >\n    <div\n      class=\"input-control {{\n        inputConfig.multipleInputValues?.customClass\n      }}\"\n      (click)=\"toggleDropdownOptions()\"\n    >\n      <span\n        style=\"display: flex; gap: 6px; align-items: center\"\n        *ngFor=\"\n          let item of inputConfig.multipleInputValues?.options;\n          let indx = index;\n          trackBy: trackIdentity\n          \"\n      >\n          <!-- Image / SVG -->\n          <ng-container *ngIf=\"item?.logoName && item?.isImg\">\n            <span>\n              <ng-container *ngIf=\"item?.logoName !== 'no-url'\">\n                <img\n                  [ngStyle]=\"{\n                    width: '18px',\n                    'aspect-ratio': 1,\n                    'border-radis': '2px'\n                  }\"\n                  [src]=\"item.logoName\"\n                  [alt]=\"item.value\"\n                />\n              </ng-container>\n              <ng-container *ngIf=\"item.logoName === 'no-url'\">\n                <div class=\"no-profile-image\">\n                  <app-ca-profile-image\n                    [indx]=\"0\"\n                    [size]=\"'small'\"\n                    [name]=\"item.value\"\n                  ></app-ca-profile-image>\n                </div>\n              </ng-container>\n  \n              <!-- Owner Flag -->\n              <ng-container *ngIf=\"item?.isOwner\">\n                <div class=\"load-dispatches-ttd-owner\">\n                  <svg-icon\n                    [src]=\"inputSvgRoutes.ownerBadgeBlueSvg\"\n                  ></svg-icon>\n                </div>\n              </ng-container>\n            </span>\n          </ng-container>\n  \n          <ng-container *ngIf=\"item?.logoName && item?.isSvg\">\n            <svg-icon\n              [ngClass]=\"{\n                'payroll-deduction-truck-svg': template === dropdownTemplateTypeEnum.PAYROLL_TRUCKS\n              }\"\n              class=\"{{ item?.subFolder }}\"\n              [src]=\"item?.logoName!\"\n            ></svg-icon>\n          </ng-container>\n  \n          <!-- Text -->\n          <ng-container *ngIf=\"!item?.isProgressBar\">\n            <span\n              class=\"multiple-input-text\"\n              [ngStyle]=\"{\n                color: '#2F2F2F'\n              }\"\n              [ngClass]=\"{\n                counter: item?.isCounter,\n                'counter-one': item?.value === 1\n              }\"\n            >\n              {{ item.value }}\n              <ng-container *ngIf=\"item?.second_value\">\n                <span\n                  [ngStyle]=\"{ color: '#919191' }\"\n                  >{{ item.second_value }}\n                </span>\n              </ng-container>\n            </span>\n          </ng-container>\n  \n          <!-- Load Broker ProgressBar -->\n          <ng-container *ngIf=\"item?.isProgressBar\">\n            <ca-load-modal-progress-bar\n              [totalAmount]=\"item.second_value!\"\n              [availableCredit]=\"item.value ? item.value : 0\"\n            ></ca-load-modal-progress-bar>\n          </ng-container>\n      </span>\n    </div>\n  \n  </ng-container>\n\n  <!-- Multiple Input Placeholder -->\n  <ng-container\n    *ngIf=\"\n      inputConfig?.multipleInputValues?.options?.length &&\n      isFocusInput &&\n      !getSuperControl?.value\n    \"\n  >\n    <div\n      class=\"input-control multiple-input-placeholder {{\n        inputConfig.multipleInputValues?.customClass\n      }}\"\n      [ngClass]=\"{ \n        focus: isFocusInput,\n        'payroll-deduction-truck': template === dropdownTemplateTypeEnum.PAYROLL_TRUCKS\n      }\"\n    >\n      <span\n        style=\"display: flex; gap: 6px; align-items: center\"\n        *ngFor=\"\n          let item of inputConfig.multipleInputValues?.options;\n          let indx = index;\n          trackBy: trackIdentity\n        \"\n      >\n        <!-- Image / SVG -->\n        <ng-container *ngIf=\"item?.logoName && item?.isImg\">\n          <span\n            [ngClass]=\"{ 'focusable-image': isFocusInput }\"\n          >\n            <ng-container *ngIf=\"item?.logoName !== 'no-url'\">\n              <img\n                [ngStyle]=\"{\n                  width: '18px',\n                  'aspect-ratio': 1,\n                  'border-radis': '2px'\n                }\"\n                [src]=\"item.logoName\"\n                [alt]=\"item.value\"\n              />\n            </ng-container>\n            <ng-container *ngIf=\"item.logoName === 'no-url'\">\n              <div class=\"no-profile-image\">\n                <app-ca-profile-image\n                    [indx]=\"0\"\n                    [size]=\"'small'\"\n                    [name]=\"item.value!\"\n                ></app-ca-profile-image>\n              </div>\n            </ng-container>\n          </span>\n        </ng-container>\n        \n        <ng-container *ngIf=\"item?.logoName && item?.isSvg\">\n          <svg-icon\n            [ngClass]=\"{ \n              'focusable-svg': isFocusInput,\n              'payroll-deduction-truck-svg': template === dropdownTemplateTypeEnum.PAYROLL_TRUCKS\n            }\"\n            class=\"{{ item?.subFolder }} {{\n              item?.logoType?.trim()?.replace(' ', '')?.toLowerCase()\n            }}\"\n            [src]=\"item?.logoName!\"\n          ></svg-icon>\n        </ng-container>\n  \n        <!-- Text -->\n        <ng-container *ngIf=\"!item?.isProgressBar\">\n          <span\n            class=\"multiple-input-text\"\n            [ngClass]=\"{\n              'focusable-text': isFocusInput,\n              counter: item?.isCounter,\n              'counter-focus': item?.isCounter && isFocusInput,\n              'counter-one': item?.value === 1,\n              'ca-add-dot': template === dropdownTemplateTypeEnum.LOAD_DISPATCHER\n            }\"\n            [ngStyle]=\"{\n              color: '#6F9EE0'\n            }\"\n          >\n            {{ item.value }}\n            <ng-container *ngIf=\"item?.second_value\">\n              <span>{{ item.second_value }}</span>\n            </ng-container>\n          </span>\n        </ng-container>\n  \n        <!-- Load Broker ProgressBar -->\n        <ng-container *ngIf=\"item?.isProgressBar\">\n          <ca-load-modal-progress-bar\n            [totalAmount]=\"item.second_value!\"\n            [availableCredit]=\"item.value ? item.value : 0\"\n            [inputFocus]=\"isFocusInput\"\n          ></ca-load-modal-progress-bar>\n        </ng-container>\n      </span>\n    </div>\n  </ng-container>\n\n  <input\n    #input\n    [type]=\"inputConfig.type | inputType: isTogglePassword\"\n    [id]=\"inputConfig.id ? inputConfig.id : inputConfig.name\"\n    [name]=\"inputConfig.name\"\n    [disabled]=\"inputConfig.isDisabled!\"\n    [autocomplete]=\"inputConfig.autocomplete ? inputConfig.autocomplete : 'off'\"\n    [placeholder]=\"\n      (inputConfig.placeholderInsteadOfLabel &&\n      inputConfig.placeholder &&\n      isFocusInput\n        ? inputConfig.placeholder\n        : '') ||\n      (inputConfig.placeholder && isFocusInput ? inputConfig.placeholder : '')\n    \"\n    [minLength]=\"inputConfig.minLength ? inputConfig.minLength : 0\"\n    [maxLength]=\"inputConfig.maxLength ? inputConfig.maxLength : 999\"\n    [mask]=\"inputConfig.mask\"\n    [min]=\"inputConfig.min ? inputConfig.min : 0\"\n    [max]=\"inputConfig.max\"\n    [step]=\"inputConfig.step ? inputConfig.step : null\"\n    [readOnly]=\"inputConfig.readOnly\"\n    appMinMaxValue\n    [minValue]=\"inputConfig.min!\"\n    [maxValue]=\"inputConfig.max!\"\n    inputformat=\"dd-mm-yy\"\n    class=\"input-control\n  {{ inputConfig.textTransform }}\n  {{ inputConfig.textAlign }}\n  {{ inputConfig.customClass }}\n  \"\n    [ngClass]=\"\n      getSuperControl\n        | inputClass\n          : isFocusInput\n          : isTouchedInput\n          : inputConfig\n          : input\n          : isVisibleCommands\n          : getSuperControl?.value\n          : getSuperControl?.invalid\n          : getSuperControl?.touched\n          : isDropdownToggler\n          : isEditInput\n          : template\n    \"\n    (keypress)=\"onKeyPress($event)\"\n    (keydown)=\"onKeydown($event)\"\n    (keyup)=\"onKeyup($event)\"\n    (blur)=\"onBlur($event)\"\n    (focus)=\"onFocus($event)\"\n    (select)=\"selectionChange($event)\"\n    (input)=\"onChange($any($event.target).value); transformText($event)\"\n    [(ngModel)]=\"input.value\"\n    [ngStyle]=\"\n      inputConfig.statusStyle ? (input.value | loadStatusColor) : ''\n    \"\n  />\n\n  <!-- Placeholder Icon on Right Side -->\n  <ng-container *ngIf=\"inputConfig.placeholderIconRightSide\">\n    <svg-icon\n      class=\"placeholder-icon-right-side {{\n        inputConfig.placeholderIconColor\n      }}\"\n      [ngClass]=\"\n        isFocusInput\n          | inputPlaceholderIconRightClass\n            : getSuperControl\n            : inputConfig\n            : isTouchedInput\n            : getSuperControl?.value\n      \"\n      [src]=\"\n        inputConfig.placeholderIconRightSide.toLowerCase()\n          | caSvg : 'common'\n      \"\n    ></svg-icon>\n  </ng-container>\n\n  <!-- Input Error Message -->\n  <ng-container\n    *ngIf=\"\n      !(!getSuperControl?.value && isFocusInput) &&\n      (isTouchedInput || getSuperControl?.touched || getSuperControl?.value) &&\n      getSuperControl?.invalid &&\n      !inputConfig.isInvalidSearchInDropdown &&\n      !inputConfig.isDisabled\n    \"\n  >\n    <ng-container *ngIf=\"!(inputConfig.hideErrorMessage || inputConfig.errorInsideInput)\">\n      <span class=\"input-error {{ inputConfig.customClass }}\">\n        {{ getSuperControl?.errors | inputError: inputConfig.name }}\n      </span>\n    </ng-container>\n\n    <!-- Error Message Inside Input -->\n    <ng-container *ngIf=\"inputConfig.errorInsideInput\">\n      <span class=\"error-inside-input {{ inputConfig.customClass }}\">\n        {{ getSuperControl?.errors | inputError: inputConfig.name }}\n      </span>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *ngIf=\"inputConfig.fixedPlacholder && input.value\">\n    <span class=\"input-fixed-placehoder-label\">\n      {{ inputConfig.fixedPlacholder }}\n    </span>\n  </ng-container>\n</div>\n\n<!-- Popover for DateTime Pickers -->\n<ng-template #dateTimePopover let-data=\"data\">\n  <div class=\"datetime-dropdown-holder\">\n    <app-ca-custom-datetime-pickers\n      [calendarType]=\"\n        inputConfig.name === 'datepicker' ||\n        inputConfig.name === 'datepickerBankCard'\n          ? 'date'\n          : 'time'\n      \"\n      [inputConfig]=\"inputConfig\"\n      [placeholder]=\"'MM/DD/YY'\"\n      [dateTime]=\"dateTimeInputDate\"\n      (closePopover)=\"closePopover()\"\n    ></app-ca-custom-datetime-pickers>\n  </div>\n</ng-template>"]}
|
|
349
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input/ca-input.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input/ca-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  CUSTOM_ELEMENTS_SCHEMA,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  Self,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NgControl,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { combineLatest, Observable, Subject, takeUntil } from 'rxjs';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// models\nimport { ICaInput } from './config';\nimport { LabelColor, CommandsEvent } from './models';\n\n// pipes\nimport {\n  InputErrorPipe,\n  InputContainerClassPipe,\n  InputClassPipe,\n  LabelClassPipe,\n  ShowClearPipe,\n  ShowInvalidDangerMarkPipe,\n  ShowValidCheckPipe,\n  InputTypePipe,\n  InputDropdownArrowClassPipe,\n  ShowDropdownArrowPipe,\n  InputPlaceholderIconRightClassPipe,\n  InputPlaceholderTextClassPipe,\n  ShowPlaceholderTextPipe\n} from './pipes';\nimport { CaSvgPipe } from '../../pipes/ca-svg.pipe';\nimport { LoadStatusColorPipe } from '../../pipes/load-status-color.pipe';\nimport { ThousandSeparatorPipe } from '../../pipes/thousand-separator.pipe';\n\n// components\nimport { CaAppTooltipV2Component } from '../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\nimport { CaInputClearComponent } from './components/ca-input-clear/ca-input-clear.component';\nimport { CaInputCommandsComponent } from './components/ca-input-commands/ca-input-commands.component';\nimport { CaInputPasswordComponent } from './components/ca-input-password/ca-input-password.component';\nimport { CaInputPlaceholderIconComponent } from './components/ca-input-placeholder-icon/ca-input-placeholder-icon.component';\nimport { CaInputDatetimePickerComponent } from './components/ca-input-datetime-picker/ca-input-datetime-picker.component';\nimport { CaCustomDatetimePickersComponent } from '../ca-custom-datetime-pickers/ca-custom-datetime-pickers.component';\nimport { CaProfileImageComponent } from '../ca-profile-image/ca-profile-image.component';\nimport { CaLoadModalProgressBarComponent } from '../ca-load-modal-progress-bar/ca-load-modal-progress-bar.component';\n\n// services\nimport { InputStateService } from './services';\nimport { CalendarDateTimePickerService } from '../ca-custom-datetime-pickers/services/calendar-datetime-picker.service';\n\n// helpers\nimport { InputChangeValue, InputSvgRoutes } from './utils';\n\n// modules\nimport { NgbModule, NgbPopover } from '@ng-bootstrap/ng-bootstrap';\nimport { NgxMaskModule } from 'ngx-mask';\n\n// directives\nimport { MinMaxValueDirective } from './directives';\n\n// enums\nimport { InputCommandsType, InputStringEnum } from './enums';\nimport { DropdownTemplateTypeEnum } from '../ca-input-dropdown/enums';\n\n@Component({\n  selector: 'app-ca-input',\n  templateUrl: './ca-input.component.html',\n  styleUrls: ['./ca-input.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    // Module\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    AngularSvgIconModule,\n    NgbModule,\n    NgxMaskModule,\n    // Pipe\n    InputErrorPipe,\n    InputContainerClassPipe,\n    InputClassPipe,\n    LabelClassPipe,\n    ShowClearPipe,\n    ShowInvalidDangerMarkPipe,\n    ShowValidCheckPipe,\n    InputTypePipe,\n    InputDropdownArrowClassPipe,\n    ShowDropdownArrowPipe,\n    CaSvgPipe,\n    LoadStatusColorPipe,\n    InputPlaceholderIconRightClassPipe,\n    InputPlaceholderTextClassPipe,\n    ShowPlaceholderTextPipe,\n    // Components\n    CaInputClearComponent,\n    CaAppTooltipV2Component,\n    CaInputPasswordComponent,\n    CaInputPlaceholderIconComponent,\n    CaInputCommandsComponent,\n    CaCustomDatetimePickersComponent,\n    CaInputDatetimePickerComponent,\n    CaProfileImageComponent,\n    CaLoadModalProgressBarComponent,\n    // Directives\n    MinMaxValueDirective\n],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  providers: [InputStateService, CalendarDateTimePickerService],\n})\nexport class CaInputComponent\n  implements OnInit, OnDestroy, OnChanges, AfterViewInit, ControlValueAccessor\n{\n  @ViewChild('input', { static: true }) public input!: ElementRef;\n  @ViewChild(NgbPopover) ngbMainPopover!: NgbPopover;\n\n  @Input() inputConfig!: ICaInput;\n\n  @Input() incorrectValue!: boolean;\n  @Input() selectedDropdownLabelColor!: LabelColor | null;\n  @Input() template!: string;\n\n  @Output('incorrectEvent') incorrectInput: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('blurInput') blurInput: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('focusInput') focusInputEvent: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('change') changeInput: EventEmitter<InputChangeValue> =\n    new EventEmitter<InputChangeValue>();\n  @Output('commandEvent') commandEvent: EventEmitter<CommandsEvent> =\n    new EventEmitter<CommandsEvent>();\n  @Output('clear') clearInputEvent: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n\n  // Dropdown\n  @Output('showHideDropdown') showHideDropdownEvent: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('dropDownKeyNavigation') dropDownKeyNavigationEvent: EventEmitter<{\n    keyCode: number;\n    data: ICaInput | null;\n  }> = new EventEmitter<{\n    keyCode: number;\n    data: ICaInput | null;\n  }>();\n\n  public isTouchedInput: boolean = false;\n\n  // Input Commands\n  public isVisibleCommands: boolean = false;\n\n  // Edit Input\n  public isEditInput: boolean = false;\n\n  // Password\n  public isTogglePassword: boolean = false;\n  public isCapsLockOn: boolean = false;\n\n  // Dropdown\n  public isDropdownToggler: boolean = false;\n\n  // Date\n  public showDateInput: boolean = false;\n  public dateTimeInputDate: Date = new Date();\n  public newInputChanged: boolean = false;\n\n  // Destroy\n  private destroy$: Subject<void> = new Subject<void>();\n\n  public inputSvgRoutes = InputSvgRoutes;\n  public isFocusInput!: boolean;\n  public priceSeperatorWithFilledValue = true;\n\n  public inputCommandsType = InputCommandsType;\n  public inputStringEnum = InputStringEnum;\n  public dropdownTemplateTypeEnum = DropdownTemplateTypeEnum;\n\n  constructor(\n    @Self() public superControl: NgControl,\n    private cdRef: ChangeDetectorRef,\n    public inputStateService: InputStateService,\n    private thousandSeparatorPipe: ThousandSeparatorPipe\n  ) {\n    this.superControl.valueAccessor = this;\n  }\n\n  get getSuperControl() {\n    return this.superControl.control;\n  }\n\n  ngOnInit(): void {\n    this.initChangesListener();\n\n    this.initStateService();\n\n    this.outputListeners();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.setStateInputs(changes);\n  }\n\n  ngAfterViewInit(): void {\n    this.inputStateService.autoFocusFirstInput();\n  }\n\n  public initStateService(): void {\n    this.inputStateService.setSuperControl(this.superControl);\n    this.inputStateService.setInputElementRef(this.input, this.cdRef);\n\n    this.inputStateService.combinedVariables$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(\n        ([\n          focus,\n          touched,\n          isVisibleCommands,\n          isEditInput,\n          isDropdownToggler,\n          dateTimeInputDate,\n          showDateInput,\n          isCapsLockOn,\n        ]) => {\n          this.isFocusInput = focus;\n          this.isTouchedInput = touched;\n          this.isVisibleCommands = isVisibleCommands;\n          this.isEditInput = isEditInput;\n          this.isDropdownToggler = isDropdownToggler;\n          this.dateTimeInputDate = dateTimeInputDate;\n          this.showDateInput = showDateInput; \n\n          this.isCapsLockOn = isCapsLockOn;\n        }\n      );\n  }\n\n  public outputListeners(): void {\n    const observables: {\n      stream$: Observable<any>;\n      emitter: EventEmitter<any>;\n    }[] = [\n      {\n        stream$: this.inputStateService.commandEvent$,\n        emitter: this.commandEvent,\n      },\n      {\n        stream$: this.inputStateService.clearInputEvent$,\n        emitter: this.clearInputEvent,\n      },\n      {\n        stream$: this.inputStateService.incorrectInput$,\n        emitter: this.incorrectInput,\n      },\n      {\n        stream$: this.inputStateService.blurInput$,\n        emitter: this.blurInput,\n      },\n      {\n        stream$: this.inputStateService.changeInput$,\n        emitter: this.changeInput,\n      },\n      {\n        stream$: this.inputStateService.showHideDropdown$,\n        emitter: this.showHideDropdownEvent,\n      },\n      {\n        stream$: this.inputStateService.dropDownKeyNavigation$,\n        emitter: this.dropDownKeyNavigationEvent,\n      },\n    ];\n\n    observables.forEach(({ stream$, emitter }) =>\n      stream$\n        .pipe(takeUntil(this.destroy$))\n        .subscribe((value: any) => emitter.emit(value))\n    );\n  }\n\n  public initChangesListener(): void {\n    const combinedChanges = combineLatest([\n      this.getSuperControl?.valueChanges,\n      this.getSuperControl?.statusChanges,\n    ]);\n\n    combinedChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.cdRef.detectChanges();\n    });\n\n    this.inputStateService.onChange$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((value) => {\n        this.onChange(value);\n      });\n  }\n\n  public setStateInputs(changes: SimpleChanges): void {\n    if (changes['inputConfig']) {\n      this.inputStateService.setInputConfig(\n        changes['inputConfig']?.currentValue\n      );\n      this.inputStateService.onInputConfigChange();\n    }\n    this.inputStateService.setIncorrectValue(\n      changes['incorrectValue']?.currentValue\n    );\n  }\n\n  public writeValue(obj: InputChangeValue): void {\n    if (this.inputConfig.priceSeparator) {\n      if (obj && this.priceSeperatorWithFilledValue)\n        this.input.nativeElement.value =\n          this.thousandSeparatorPipe.transform(obj);\n      else this.input.nativeElement.value = obj;\n\n      this.priceSeperatorWithFilledValue = false;\n    }\n\n    this.inputStateService.writeValue(obj);\n  }\n\n  public registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  public onChange(_: any): void {}\n\n  public registerOnTouched(): void {}\n\n  public onBlur(event?: FocusEvent): void {\n    this.inputStateService.onBlur(event);\n\n    this.blurInput.emit(true);\n  }\n\n  public onFocus(event?: FocusEvent): void {\n    this.focusInputEvent.emit(true);\n\n    this.inputStateService.onFocus(event);\n  }\n\n  public onKeyPress(event: KeyboardEvent): void {\n    this.inputStateService.onKeypress(event);\n  }\n\n  public onKeydown(event: KeyboardEvent): void {\n    this.inputStateService.onKeydown(event);\n  }\n\n  public onKeyup(event: KeyboardEvent): void {\n    this.inputStateService.onKeyup(event);\n  }\n\n  public transformText(event: Event): void {\n    this.inputStateService.transformText(event);\n  }\n\n  public clearInput(event: Event): void {\n    this.inputStateService.clearInput(event);\n  }\n\n  public onTogglePassword(event: Event): void {\n    event.preventDefault();\n    this.isTogglePassword = !this.isTogglePassword;\n  }\n\n  public onCommands(event: {\n    event: Event;\n    type: string;\n    action: string;\n  }): void {\n    this.inputStateService.onCommands(event.event, event.type, event.action);\n  }\n\n  public onEditInput(event: Event): void {\n    this.inputStateService.onEditInput(event);\n  }\n\n  public toggleDropdownOptions(): void {\n    this.inputStateService.toggleDropdownOptions();\n  }\n\n  public onPlaceholderIconEvent(event: Event): void {\n    this.inputStateService.onPlaceholderIconEvent(event);\n  }\n\n  public setInputCursorAtTheEnd(input: any): void {\n    this.inputStateService.setInputCursorAtTheEnd(input);\n  }\n\n  //-------------------------------------- Date & Time Picker --------------------------------------\n\n  public selectionChange(event: Event): void {\n    this.inputStateService.selectionChange(event);\n  }\n\n  public onDatePaste(event: ClipboardEvent): void {\n    this.inputStateService.onDatePaste(event);\n  }\n\n  public setSelection(event: {\n    preventDefault: () => void;\n    stopPropagation: () => void;\n    target: any;\n  }): void {\n    this.inputStateService.setSelection(event);\n  }\n\n  public changeSelection(event: {\n    e: KeyboardEvent;\n    noPreventDefault: boolean;\n  }): void {\n    this.inputStateService.changeSelection(event.e, event.noPreventDefault);\n  }\n\n  public onPopoverShown(): void {\n    this.inputStateService.onPopoverShown();\n  }\n\n  public onPopoverHidden(): void {\n    this.inputStateService.onPopoverHidden();\n  }\n\n  public closePopover(): void {\n    if (this.ngbMainPopover) this.ngbMainPopover.close();\n  }\n\n  public selectLastOneForSelection(): void {\n    this.inputStateService.selectLastOneForSelection();\n  }\n\n  public selectLastOneAfterMouseUp(): void {\n    this.inputStateService.selectLastOneAfterMouseUp();\n  }\n\n  public trackIdentity = (index: number): number => index;\n\n  ngOnDestroy(): void {\n    this.inputStateService.onDestory();\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div\n  class=\"input-custom-group {{ inputConfig.customClass }}\"\n  [ngClass]=\"\n    getSuperControl\n      | inputContainerClass\n        : isFocusInput\n        : isTouchedInput\n        : inputConfig\n        : getSuperControl?.value\n  \"\n  ngbTooltip\n  [mainCaTooltip]=\"getSuperControl?.errors | inputError: inputConfig.name\"\n  [tooltipBackground]=\"'#DF3C3C'\"\n  [disableTooltip]=\"!inputConfig.requiredLabel || !!superControl.valid\"\n  position=\"bottom\"\n  triggers=\"hover\"\n>\n  <!-- Input Commands -->\n  <ng-container *ngIf=\"inputConfig.commands?.active && isVisibleCommands\">\n    <app-ca-input-commands\n      [inputConfig]=\"inputConfig\"\n      [isFocusInput]=\"isFocusInput\"\n      [isVisibleCommands]=\"isVisibleCommands\"\n      (onCommandsClick)=\"onCommands($event)\"\n    >\n    </app-ca-input-commands>\n  </ng-container>\n\n  <!-- DateTime Picker -->\n  <ng-container\n    *ngIf=\"\n      (inputConfig.name === 'datepicker' ||\n        inputConfig.name === 'timepicker') &&\n      !inputConfig.isDisabled\n    \"\n  >\n    <app-ca-input-datetime-picker\n      [showDateInput]=\"showDateInput\"\n      [inputConfig]=\"inputConfig\"\n      [getSuperControl]=\"getSuperControl\"\n      [isFocusInput]=\"isFocusInput\"\n      [isVisibleCommands]=\"isVisibleCommands\"\n      [isTouchedInput]=\"isTouchedInput\"\n      (selectLastOneForSelectionEmitter)=\"selectLastOneForSelection()\"\n      (selectLastOneAfterMouseUpEmitter)=\"selectLastOneAfterMouseUp()\"\n      (onDatePasteEmitter)=\"onDatePaste($event)\"\n      (onBlurEmitter)=\"onBlur()\"\n      (changeSelectionEmmiter)=\"changeSelection($event)\"\n      (onFocusEmitter)=\"onFocus($event)\"\n      (setSelectionEmmiter)=\"setSelection($event)\"\n    >\n    </app-ca-input-datetime-picker>\n  </ng-container>\n\n  <!-- Input Label -->\n  <ng-container *ngIf=\"!inputConfig.multiSelectDropdownActive\">\n    <label\n      [for]=\"inputConfig.name\"\n      class=\"input-label {{ inputConfig.customClass }} {{\n        inputConfig.multipleLabel?.customClass\n      }}\"\n      [ngClass]=\"\n        getSuperControl?.value | labelClass: isFocusInput : inputConfig\n        : isTouchedInput : getSuperControl?.invalid\n        : getSuperControl?.touched\n      \"\n    >\n      <ng-container *ngIf=\"inputConfig.label\">\n        <span>{{ inputConfig.label }} </span>\n      </ng-container>\n      <ng-container *ngIf=\"inputConfig.multipleLabel?.labels?.length\">\n        <div\n          [class]=\"inputConfig.multipleLabel?.customClass!\"\n          [ngClass]=\"{\n            'multiple-labels-position-on-focus':\n              isFocusInput ||\n              inputConfig.multipleInputValues?.options?.length,\n            required: inputConfig.isRequired && !inputConfig.isDisabled\n          }\"\n        >\n          <span *ngFor=\"let label of inputConfig.multipleLabel?.labels\">\n            {{ label }}\n          </span>\n        </div>\n      </ng-container>\n    </label>\n  </ng-container>\n\n  <!-- Input Clear -->\n  <ng-container *ngIf=\"inputConfig | showClear\">\n    <app-ca-input-clear\n      [inputConfig]=\"inputConfig\"\n      [getSuperControl]=\"getSuperControl\"\n      [isFocusInput]=\"isFocusInput\"\n      [incorrectValue]=\"incorrectValue\"\n      [selectedDropdownLabelColor]=\"selectedDropdownLabelColor\"\n      [template]=\"template\"\n      (clearInputClick)=\"clearInput($event)\"\n    >\n    </app-ca-input-clear>\n  </ng-container>\n\n  <!-- Input Clear for dispatch dropdown -->\n  <ng-container *ngIf=\"template === 'svgtext-dispatch-template'\">\n    <div\n      class=\"input-clear-dispatch\"\n      position=\"top\"\n      (click)=\"clearInput($event)\"\n    >\n      <svg-icon\n        [src]=\"inputSvgRoutes.xClearCommonSvg\"\n        class=\"input-clear-dispatch-icon\"\n      ></svg-icon>\n    </div>\n  </ng-container>\n\n  <!-- Input Pen -->\n  <ng-container\n    *ngIf=\"\n      selectedDropdownLabelColor &&\n      !isEditInput &&\n      !isFocusInput &&\n      getSuperControl?.value\n    \"\n  >\n    <div\n      class=\"input-pen-container\"\n      ngbTooltip\n      [mainCaTooltip]=\"'Edit'\"\n      [tooltipBackground]=\"'#2F2F2F'\"\n      position=\"top\"\n      (click)=\"onEditInput($event)\"\n    >\n      <svg-icon [src]=\"inputSvgRoutes.inputPenSvg\" class=\"input-pen\"></svg-icon>\n    </div>\n  </ng-container>\n\n  <!-- Input Invalid Danger Mark -->\n  <ng-container\n    *ngIf=\"\n      inputConfig\n        | showInvalidDangerMark\n          : getSuperControl\n          : isFocusInput\n          : isTouchedInput\n          : getSuperControl?.value\n    \"\n  >\n    <svg-icon\n      class=\"input-invalid-danger-mark  {{ inputConfig.customClass }}\"\n      [src]=\"inputSvgRoutes.dangerSvg\"\n    >\n    </svg-icon>\n  </ng-container>\n\n  <!-- Input Valid Check -->\n  <ng-container\n    *ngIf=\"\n      getSuperControl\n        | showValidCheck: isFocusInput : inputConfig : getSuperControl?.value\n    \"\n  >\n    <svg-icon\n      class=\"input-required-check {{ inputConfig.customClass }}\"\n      [src]=\"inputSvgRoutes.confirmSvg\"\n    ></svg-icon>\n  </ng-container>\n\n  <!-- Input Password Caps Lock And Eye -->\n  <ng-container *ngIf=\"inputConfig.type === 'password'\">\n    <app-ca-input-password\n      [inputConfig]=\"inputConfig\"\n      [getSuperControl]=\"getSuperControl\"\n      [isFocusInput]=\"isFocusInput\"\n      [isTouchedInput]=\"isTouchedInput\"\n      [isCapsLockOn]=\"isCapsLockOn\"\n      [isTogglePassword]=\"isTogglePassword\"\n      (onTogglePasswordClick)=\"onTogglePassword($event)\"\n    >\n    </app-ca-input-password>\n  </ng-container>\n\n  <!-- Input Dropdown Arrow -->\n  <ng-container *ngIf=\"inputConfig | showDropdownArrow\">\n    <svg-icon\n      class=\"input-dropdown-arrow {{ inputConfig.customClass }}\"\n      [ngClass]=\"\n        getSuperControl\n          | inputDropdownArrowClass\n            : isFocusInput\n            : inputConfig\n            : isTouchedInput\n            : getSuperControl?.value\n      \"\n      [src]=\"inputSvgRoutes.inputDropdownArrowSvg\"\n      (click)=\"toggleDropdownOptions()\"\n    ></svg-icon>\n  </ng-container>\n\n  <!-- Input Placeholder Icon -->\n  <ng-container \n    *ngIf=\"\n      inputConfig.placeholderIcon ||\n      inputConfig.name === 'datepicker' ||\n      inputConfig.name === 'timepicker'\n    \"\n  >\n    <app-ca-input-placeholder-icon\n      [inputConfig]=\"inputConfig\"\n      [getSuperControl]=\"getSuperControl\"\n      [isFocusInput]=\"isFocusInput\"\n      [isTouchedInput]=\"isTouchedInput\"\n      [selectedDropdownLabelColor]=\"selectedDropdownLabelColor\"\n      [isEditInput]=\"isEditInput\"\n      [dateTimePopover]=\"dateTimePopover\"\n      (onPopoverShownEmitter)=\"onPopoverShown()\"\n      (onPopoverHiddenEmitter)=\"onPopoverHidden()\"\n      (onPlaceholderIconEventEmitter)=\"onPlaceholderIconEvent($event)\"\n    >\n    </app-ca-input-placeholder-icon>\n  </ng-container>\n\n  <!-- Input Placeholder Text -->\n  <ng-container\n    *ngIf=\"\n      inputConfig | showPlaceholderText : getSuperControl : \n      isVisibleCommands : getSuperControl?.value\n    \"\n  >\n    <span\n      class=\"ca-placeholder-text {{ inputConfig.customClass }}\"\n      [ngClass]=\"      \n      isFocusInput | inputPlaceholderTextClass\n        : isTouchedInput : getSuperControl : inputConfig\n        : isVisibleCommands : getSuperControl?.value\n      \"\n      [style.left]=\"\n        inputConfig.placeholderText?.toLowerCase() === inputStringEnum.PERSONS ||\n        inputConfig.placeholderText?.toLowerCase() === inputStringEnum.VEHICLES\n          ? 30 +\n            (getSuperControl?.value?.toString()?.length + 1) * 9 +\n            'px'\n          : isFocusInput &&\n            inputConfig.placeholderText?.toLowerCase() !== inputCommandsType.MONTHS\n          ? 'auto'\n          : (getSuperControl?.value?.toString()?.length + 1) * 8 + 'px'\n      \"\n      [style.right]=\"\n        isFocusInput &&\n        inputConfig.placeholderText?.toLowerCase() !== inputCommandsType.MONTHS\n          ? '28px'\n          : 'auto'\n      \"\n      >\n        {{ inputConfig.placeholderText }}\n    </span>\n  </ng-container>\n  \n  <!-- Input Label Counter -->\n  <ng-container\n    *ngIf=\"\n      selectedDropdownLabelColor &&\n      getSuperControl?.value &&\n      !isFocusInput &&\n      !inputConfig.isDisabled &&\n      inputConfig.showCount\n    \"\n  >\n    <p\n      [style.top]=\"'4px'\"\n      [style.left]=\"\n        (getSuperControl?.value?.toString()?.length + 6.5) * 8 + 'px'\n      \"\n      class=\"input-label-counter\"\n    >\n      {{ selectedDropdownLabelColor.count }}\n    </p>\n  </ng-container>\n\n  <!-- Special Dropdown Selected SVG with or Without Text -->\n  <ng-container\n    *ngIf=\"\n      inputConfig?.dropdownImageInput?.svg &&\n      !inputConfig?.hideAllItemsInInputDropdown &&\n      !(!inputConfig.dropdownImageInput?.withText && isFocusInput) &&\n      !(\n          ['truck', 'trailer'].includes(\n              inputConfig.dropdownImageInput?.template!\n          ) &&\n          isFocusInput &&\n          inputConfig.dropdownImageInput?.remove\n      ) &&\n      !inputConfig?.dropdownImageInput?.nameInitialsInsteadUrl\n    \"\n  >\n    <svg-icon\n        [src]=\"inputConfig.dropdownImageInput?.url!\"\n        class=\"dropdown-selected-image {{\n          inputConfig.dropdownImageInput?.class\n        }}\"\n        [ngClass]=\"{\n          'unset-color': isFocusInput && inputConfig.dropdownImageInput?.class\n        }\"\n        [svgStyle]=\"{\n          fill:\n            inputConfig.dropdownImageInput?.color && !isFocusInput\n              ? inputConfig.dropdownImageInput?.color\n              : '#ffffff'\n        }\"\n    >\n    </svg-icon>\n  </ng-container>\n\n  <!-- Special Dropdown Selected Image With Text With Initials name -->\n  <ng-container\n    *ngIf=\"\n      inputConfig?.dropdownImageInput?.image &&\n      !inputConfig?.hideAllItemsInInputDropdown &&\n      inputConfig?.dropdownImageInput?.url &&\n      !inputConfig?.dropdownImageInput?.nameInitialsInsteadUrl\n    \"\n  >\n    <img\n      class=\"dropdown-selected-image name-initials-instead-url\"\n      [src]=\"inputConfig.dropdownImageInput?.url\"\n      [alt]=\"'Input Image'\"\n    />\n  </ng-container>\n  <ng-container\n    *ngIf=\"\n      inputConfig?.dropdownImageInput?.nameInitialsInsteadUrl &&\n      !inputConfig?.hideAllItemsInInputDropdown &&\n      !(!inputConfig.dropdownImageInput?.withText && isFocusInput)\n    \"\n  >\n    <div\n      class=\"no-profile-image dropdown-selected-image name-initials-instead-url\"\n    >\n      <app-ca-profile-image\n          [indx]=\"0\"\n          [size]=\"'small'\"\n          [type]=\"'user'\"\n          [name]=\"inputConfig.dropdownImageInput?.nameInitialsInsteadUrl!\"\n      >\n      </app-ca-profile-image>\n    </div>\n  </ng-container>\n\n  <!-- Multiple Input Values -->\n  <ng-container\n    *ngIf=\"\n      inputConfig?.multipleInputValues?.options?.length && !isFocusInput\n    \"\n  >\n    <div\n      class=\"input-control {{\n        inputConfig.multipleInputValues?.customClass\n      }}\"\n      (click)=\"toggleDropdownOptions()\"\n    >\n      <span\n        style=\"display: flex; gap: 6px; align-items: center\"\n        *ngFor=\"\n          let item of inputConfig.multipleInputValues?.options;\n          let indx = index;\n          trackBy: trackIdentity\n          \"\n      >\n          <!-- Image / SVG -->\n          <ng-container *ngIf=\"item?.logoName && item?.isImg\">\n            <span>\n              <ng-container *ngIf=\"item?.logoName !== 'no-url'\">\n                <img\n                  [ngStyle]=\"{\n                    width: '18px',\n                    'aspect-ratio': 1,\n                    'border-radis': '2px'\n                  }\"\n                  [src]=\"item.logoName\"\n                  [alt]=\"item.value\"\n                />\n              </ng-container>\n              <ng-container *ngIf=\"item.logoName === 'no-url'\">\n                <div class=\"no-profile-image\">\n                  <app-ca-profile-image\n                    [indx]=\"0\"\n                    [size]=\"'small'\"\n                    [name]=\"item.value\"\n                  ></app-ca-profile-image>\n                </div>\n              </ng-container>\n  \n              <!-- Owner Flag -->\n              <ng-container *ngIf=\"item?.isOwner\">\n                <div class=\"load-dispatches-ttd-owner\">\n                  <svg-icon\n                    [src]=\"inputSvgRoutes.ownerBadgeBlueSvg\"\n                  ></svg-icon>\n                </div>\n              </ng-container>\n            </span>\n          </ng-container>\n  \n          <ng-container *ngIf=\"item?.logoName && item?.isSvg\">\n            <svg-icon\n              [ngClass]=\"{\n                'payroll-deduction-truck-svg': template === dropdownTemplateTypeEnum.PAYROLL_TRUCKS\n              }\"\n              class=\"{{ item?.subFolder }}\"\n              [src]=\"item?.logoName!\"\n            ></svg-icon>\n          </ng-container>\n  \n          <!-- Text -->\n          <ng-container *ngIf=\"!item?.isProgressBar\">\n            <span\n              class=\"multiple-input-text\"\n              [ngStyle]=\"{\n                color: '#2F2F2F'\n              }\"\n              [ngClass]=\"{\n                counter: item?.isCounter,\n                'counter-one': item?.value === 1\n              }\"\n            >\n              {{ item.value }}\n              <ng-container *ngIf=\"item?.second_value\">\n                <span\n                  [ngStyle]=\"{ color: '#919191' }\"\n                  >{{ item.second_value }}\n                </span>\n              </ng-container>\n            </span>\n          </ng-container>\n  \n          <!-- Load Broker ProgressBar -->\n          <ng-container *ngIf=\"item?.isProgressBar\">\n            <ca-load-modal-progress-bar\n              [totalAmount]=\"item.second_value!\"\n              [availableCredit]=\"item.value ? item.value : 0\"\n            ></ca-load-modal-progress-bar>\n          </ng-container>\n      </span>\n    </div>\n  \n  </ng-container>\n\n  <!-- Multiple Input Placeholder -->\n  <ng-container\n    *ngIf=\"\n      inputConfig?.multipleInputValues?.options?.length &&\n      isFocusInput &&\n      !getSuperControl?.value\n    \"\n  >\n    <div\n      class=\"input-control multiple-input-placeholder {{\n        inputConfig.multipleInputValues?.customClass\n      }}\"\n      [ngClass]=\"{ \n        focus: isFocusInput,\n        'payroll-deduction-truck': template === dropdownTemplateTypeEnum.PAYROLL_TRUCKS\n      }\"\n    >\n      <span\n        style=\"display: flex; gap: 6px; align-items: center\"\n        *ngFor=\"\n          let item of inputConfig.multipleInputValues?.options;\n          let indx = index;\n          trackBy: trackIdentity\n        \"\n      >\n        <!-- Image / SVG -->\n        <ng-container *ngIf=\"item?.logoName && item?.isImg\">\n          <span\n            [ngClass]=\"{ 'focusable-image': isFocusInput }\"\n          >\n            <ng-container *ngIf=\"item?.logoName !== 'no-url'\">\n              <img\n                [ngStyle]=\"{\n                  width: '18px',\n                  'aspect-ratio': 1,\n                  'border-radis': '2px'\n                }\"\n                [src]=\"item.logoName\"\n                [alt]=\"item.value\"\n              />\n            </ng-container>\n            <ng-container *ngIf=\"item.logoName === 'no-url'\">\n              <div class=\"no-profile-image\">\n                <app-ca-profile-image\n                    [indx]=\"0\"\n                    [size]=\"'small'\"\n                    [name]=\"item.value!\"\n                ></app-ca-profile-image>\n              </div>\n            </ng-container>\n          </span>\n        </ng-container>\n        \n        <ng-container *ngIf=\"item?.logoName && item?.isSvg\">\n          <svg-icon\n            [ngClass]=\"{ \n              'focusable-svg': isFocusInput,\n              'payroll-deduction-truck-svg': template === dropdownTemplateTypeEnum.PAYROLL_TRUCKS\n            }\"\n            class=\"{{ item?.subFolder }} {{\n              item?.logoType?.trim()?.replace(' ', '')?.toLowerCase()\n            }}\"\n            [src]=\"item?.logoName!\"\n          ></svg-icon>\n        </ng-container>\n  \n        <!-- Text -->\n        <ng-container *ngIf=\"!item?.isProgressBar\">\n          <span\n            class=\"multiple-input-text\"\n            [ngClass]=\"{\n              'focusable-text': isFocusInput,\n              counter: item?.isCounter,\n              'counter-focus': item?.isCounter && isFocusInput,\n              'counter-one': item?.value === 1,\n              'ca-add-dot': template === dropdownTemplateTypeEnum.LOAD_DISPATCHER\n            }\"\n            [ngStyle]=\"{\n              color: '#6F9EE0'\n            }\"\n          >\n            {{ item.value }}\n            <ng-container *ngIf=\"item?.second_value\">\n              <span>{{ item.second_value }}</span>\n            </ng-container>\n          </span>\n        </ng-container>\n  \n        <!-- Load Broker ProgressBar -->\n        <ng-container *ngIf=\"item?.isProgressBar\">\n          <ca-load-modal-progress-bar\n            [totalAmount]=\"item.second_value!\"\n            [availableCredit]=\"item.value ? item.value : 0\"\n            [inputFocus]=\"isFocusInput\"\n          ></ca-load-modal-progress-bar>\n        </ng-container>\n      </span>\n    </div>\n  </ng-container>\n\n  <input\n    #input\n    [type]=\"inputConfig.type | inputType: isTogglePassword\"\n    [id]=\"inputConfig.id ? inputConfig.id : inputConfig.name\"\n    [name]=\"inputConfig.name\"\n    [disabled]=\"inputConfig.isDisabled!\"\n    [autocomplete]=\"inputConfig.autocomplete ? inputConfig.autocomplete : 'off'\"\n    [placeholder]=\"\n      (inputConfig.placeholderInsteadOfLabel &&\n      inputConfig.placeholder &&\n      isFocusInput\n        ? inputConfig.placeholder\n        : '') ||\n      (inputConfig.placeholder && isFocusInput ? inputConfig.placeholder : '')\n    \"\n    [minLength]=\"inputConfig.minLength ? inputConfig.minLength : 0\"\n    [maxLength]=\"inputConfig.maxLength ? inputConfig.maxLength : 999\"\n    [mask]=\"inputConfig.mask\"\n    [min]=\"inputConfig.min ? inputConfig.min : 0\"\n    [max]=\"inputConfig.max\"\n    [step]=\"inputConfig.step ? inputConfig.step : null\"\n    [readOnly]=\"inputConfig.readOnly\"\n    appMinMaxValue\n    [minValue]=\"inputConfig.min!\"\n    [maxValue]=\"inputConfig.max!\"\n    inputformat=\"dd-mm-yy\"\n    class=\"input-control\n  {{ inputConfig.textTransform }}\n  {{ inputConfig.textAlign }}\n  {{ inputConfig.customClass }}\n  \"\n    [ngClass]=\"\n      getSuperControl\n        | inputClass\n          : isFocusInput\n          : isTouchedInput\n          : inputConfig\n          : input\n          : isVisibleCommands\n          : getSuperControl?.value\n          : getSuperControl?.invalid\n          : getSuperControl?.touched\n          : isDropdownToggler\n          : isEditInput\n          : template\n    \"\n    (keypress)=\"onKeyPress($event)\"\n    (keydown)=\"onKeydown($event)\"\n    (keyup)=\"onKeyup($event)\"\n    (blur)=\"onBlur($event)\"\n    (focus)=\"onFocus($event)\"\n    (select)=\"selectionChange($event)\"\n    (input)=\"onChange($any($event.target).value); transformText($event)\"\n    [(ngModel)]=\"input.value\"\n    [ngStyle]=\"\n      inputConfig.statusStyle ? (input.value | loadStatusColor) : ''\n    \"\n  />\n\n  <!-- Placeholder Icon on Right Side -->\n  <ng-container *ngIf=\"inputConfig.placeholderIconRightSide\">\n    <svg-icon\n      class=\"placeholder-icon-right-side {{\n        inputConfig.placeholderIconColor\n      }}\"\n      [ngClass]=\"\n        isFocusInput\n          | inputPlaceholderIconRightClass\n            : getSuperControl\n            : inputConfig\n            : isTouchedInput\n            : getSuperControl?.value\n      \"\n      [src]=\"\n        inputConfig.placeholderIconRightSide.toLowerCase()\n          | caSvg : 'common'\n      \"\n    ></svg-icon>\n  </ng-container>\n\n  <!-- Input Error Message -->\n  <ng-container\n    *ngIf=\"\n      !(!getSuperControl?.value && isFocusInput) &&\n      (isTouchedInput || getSuperControl?.touched || getSuperControl?.value) &&\n      getSuperControl?.invalid &&\n      !inputConfig.isInvalidSearchInDropdown &&\n      !inputConfig.isDisabled\n    \"\n  >\n    <ng-container *ngIf=\"!(inputConfig.hideErrorMessage || inputConfig.errorInsideInput)\">\n      <span class=\"input-error {{ inputConfig.customClass }}\">\n        {{ getSuperControl?.errors | inputError: inputConfig.name }}\n      </span>\n    </ng-container>\n\n    <!-- Error Message Inside Input -->\n    <ng-container *ngIf=\"inputConfig.errorInsideInput\">\n      <span class=\"error-inside-input {{ inputConfig.customClass }}\">\n        {{ getSuperControl?.errors | inputError: inputConfig.name }}\n      </span>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *ngIf=\"inputConfig.fixedPlacholder && input.value\">\n    <span class=\"input-fixed-placehoder-label\">\n      {{ inputConfig.fixedPlacholder }}\n    </span>\n  </ng-container>\n</div>\n\n<!-- Popover for DateTime Pickers -->\n<ng-template #dateTimePopover let-data=\"data\">\n  <div class=\"datetime-dropdown-holder\">\n    <app-ca-custom-datetime-pickers\n      [calendarType]=\"\n        inputConfig.name === 'datepicker' ||\n        inputConfig.name === 'datepickerBankCard'\n          ? 'date'\n          : 'time'\n      \"\n      [inputConfig]=\"inputConfig\"\n      [placeholder]=\"'MM/DD/YY'\"\n      [dateTime]=\"dateTimeInputDate\"\n      (closePopover)=\"closePopover()\"\n    ></app-ca-custom-datetime-pickers>\n  </div>\n</ng-template>"]}
|