@sarasanalytics-com/design-system 0.0.155 → 0.0.157

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.
@@ -37,7 +37,7 @@ export class FormInputComponent extends FieldType {
37
37
  };
38
38
  }
39
39
  ngOnInit() {
40
- this.inputVal = _get(this.field.props, 'value', _get(this.model, this.key)) || '';
40
+ this.inputVal = _get(this.field.props, 'value', _get(this.model, [this.key])) || '';
41
41
  this.disabled = this.field.props.disabled || false;
42
42
  this.formControl?.setValue(this.inputVal);
43
43
  this.params = this.params || this.field.props['params'];
@@ -319,4 +319,4 @@ export var IInputEventType;
319
319
  IInputEventType["STATE_CHANGE"] = "STATE_CHANGE";
320
320
  IInputEventType["ICON_CLICK"] = "ICON_CLICK";
321
321
  })(IInputEventType || (IInputEventType = {}));
322
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/form-input/form-input.component.ts","../../../../../projects/component-library/src/lib/form-input/form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { FieldType, FieldTypeConfig } from '@ngx-formly/core';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { CommonModule } from '@angular/common';\nimport {\n  getValidationMessage,\n  phoneNumberValidator,\n} from '../../utils/validators';\nimport { IconComponent } from '../icon/icon.component';\nimport { ChipsComponent } from '../chips/chips.component';\nimport { get as _get, set as _set, map } from 'lodash';\nimport { MatTooltipModule } from '@angular/material/tooltip';\n@Component({\n  selector: 'sa-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    FormlyModule,\n    IconComponent,\n    MatTooltipModule,\n    ChipsComponent\n  ],\n  templateUrl: './form-input.component.html',\n  styleUrl: './form-input.component.css',\n})\nexport class FormInputComponent extends FieldType<FieldTypeConfig> {\n  @ViewChild('formInput') formInput!: ElementRef;\n\n  @Input('icon') icon: IInputIcon;\n\n  pretext: string;\n\n  inputState = 'idle';\n  inputVal = '';\n  @Input() params: IInputParam | null;\n  dependent: AbstractControl<any, any> | null;\n  dependentVal: any = null;\n  // dynamicIcon: DynamicIcon | null;\n  // icon: IInputIcon | null;\n\n  type: string = '';\n  validators: any[];\n  asyncValidators: any[];\n\n  inputErrorText: string = 'invalid input';\n\n  showEmailIcon: boolean = false;\n  disabled: boolean = false;\n  chipValues: any[] = [];\n  isMultiValue: boolean = false;\n  currentInputValue: string = '';\n  startInd: number = 0;\n  labelLimit: number = 1;\n\n  private suppressOnBlur = false;\n\n  constructor() {\n    super();\n  }\n\n  ngOnInit() {\n    this.inputVal = _get(this.field.props, 'value', _get(this.model, this.key)) || '';\n    this.disabled = this.field.props.disabled || false;\n    this.formControl?.setValue(this.inputVal);\n\n    this.params = this.params || this.field.props['params'];\n    this.icon = this.icon || this.field.props['icon'] || {};\n    this.type = this.params?.type || '';\n    this.formControl.valueChanges.subscribe((val) => {\n      _set(this.formInput, 'nativeElement.value', val);\n      // Handle multi-value chip updates\n      if (this.isMultiValue && Array.isArray(val)) {\n        this.chipValues = val;\n      }\n    });\n\n    // Initialize multi-value mode if specified\n    if (this.params?.type === 'multi-value' || this.params?.multiValue) {\n      this.isMultiValue = true;\n      this.chipValues = this.model[this.key as string] || this.params?.chipValues || [];\n      this.currentInputValue = '';\n    }\n\n    // this.dynamicIcon = this.field.props['dynamicIcon'];\n    this.setValidators();\n    this.setDependents();\n\n    this.formControl.statusChanges.subscribe((state) => {\n      if (this.type === 'email') {\n        if (!!this.inputVal && !this.formControl.touched) {\n          this.formControl.markAsTouched();\n        }\n        this.showEmailIcon =\n          state === 'VALID' ||\n          (state === 'INVALID' &&\n            this.formControl.hasError('invalid') &&\n            !!this.formControl.value);\n      }\n    });\n    this.formControl.valueChanges.subscribe((val) => {\n      _set(this.formInput, 'nativeElement.value', val);\n    });\n  }\n\n  setValidators() {\n    this.validators = this.params?.validators || this.predefinedValidators[this.type] || [];\n    this.asyncValidators = this.params?.asyncValidators || [];\n    if(!_get(this.field, 'validators.validation', null)) {\n      this.formControl?.setValidators([\n        ...(this.type ? this.predefinedValidators[this.type] || [] : []),\n        ...(this.validators),\n      ]);\n    }\n    if (this.asyncValidators) {\n      this.formControl?.setAsyncValidators(this.asyncValidators);\n    }\n  }\n\n  /*\n    Assuming dependent field is a single select dropdown\n  */\n  setDependents() {\n    if (this.params?.dependent) {\n      this.dependent = this.form.get([this.params?.dependent]);\n\n      this.dependentVal = this.getDependentVal(_get(this.dependent, 'value'));\n      if (this.type === 'tel') {\n        this.pretext = this.dependentVal?.dial_code;\n      }\n\n      this.dependent?.valueChanges.subscribe((val) => {\n        this.dependentVal = this.getDependentVal(val);\n        this.formControl.reset();\n        this.formControl.setValue(this.inputVal);\n        if (this.type === 'tel') {\n          this.pretext = this.dependentVal?.dial_code;\n        }\n      });\n    }\n  }\n  getDependentVal(value: any) {\n    let dependentValue: any;\n    if (Array.isArray(value)) {\n      dependentValue = value.length ? value[0] : null;\n    } else {\n      dependentValue = value;\n    }\n    return dependentValue;\n  }\n\n  checkValidity(defaultInputState = 'focus') {\n    if (\n      this.formControl &&\n      !this.formControl.valid &&\n      this.formControl.touched &&\n      !this.formControl.pending\n    ) {\n      this.inputState = 'invalid';\n      this.inputErrorText =\n        getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input', {\n          field: this.field,\n          nativeValidationObject: this.field.validation,\n        }) || `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`\n    } else {\n      this.inputState = defaultInputState;\n    }\n  }\n\n  onFocus() {\n    if (this.formControl.valid) this.inputState = 'focus';\n  }\n  onBlur() {\n    setTimeout(() => {\n      if (!this.suppressOnBlur) {\n        this.formControl.markAsTouched();\n        this.checkValidity('idle');\n      }\n      this.suppressOnBlur = false;\n    }, 200);\n  }\n\n  onInput(event: any) {\n    if (this.params?.type === 'tel') {\n      this.inputVal = this.inputVal.replace(/[^0-9()+\\- ]/g, '');\n      this.inputVal = this.hyphenatePhoneNumber();\n    }\n    if (this.params?.type === 'percentage') {\n      let value = this.inputVal.replace(/[^0-9.]/g, '');\n      this.inputVal = value ? `${value}%` : '';\n    }\n    this.formControl?.setValue(this.inputVal);\n    this.checkValidity();\n    /*if (this.params?.eventListener) {\n      this.params?.eventListener({\n        type: IInputEventType.INPUT_CHANGE,\n        value: this.inputVal,\n        formControl: this.formControl\n      } as IInputEvent).then(this.onFieldCallback.bind(this));\n    }*/\n  }\n\n  hyphenatePhoneNumber() {\n    let newStr = '';\n    let i = 0;\n    let hyphenatedCount = 1;\n    const value = this.inputVal.replaceAll('-', '');\n    for (; i < value.length; i++) {\n      newStr = newStr + value.charAt(i);\n      if (!(hyphenatedCount % 3)) {\n        if (!((i + 1) % 10) && i + 1 < value.length) {\n          newStr = newStr + '-';\n          hyphenatedCount++;\n        }\n      } else if (\n        !((i + 1 - Math.floor(hyphenatedCount / 3)) % 3) &&\n        i + 1 < value.length\n      ) {\n        newStr = newStr + '-';\n        hyphenatedCount++;\n      }\n    }\n\n    return newStr;\n  }\n\n  onInputFieldClick(event: any = 'input') {\n    if (\n      event === 'input' ||\n      event.target.classList.contains('sa-input-field')\n    ) {\n      this.formInput.nativeElement.focus();\n      if (this.params?.type !== 'email')\n        setTimeout(() => {\n          this.formInput.nativeElement.setSelectionRange(\n            this.inputVal.length,\n            this.inputVal.length,\n          );\n        }, 10);\n    }\n  }\n\n  inputIconClick() {\n    if (this.params?.type === 'password') {\n      this.suppressOnBlur = true;\n      if (this.type === 'password') {\n        this.type = 'text';\n        this.icon.name = 'eyeOff';\n      } else {\n        this.type = 'password';\n        this.icon.name = 'eyeOutlined';\n      }\n      this.onInputFieldClick();\n    }\n  }\n\n  addChip(value: string) {\n    if (!this.isMultiValue || !value.trim()) return;  \n    const chipValue = {\n      label: value.trim(),\n      value: value.trim(),\n      removable: true\n    };\n    this.chipValues.push(chipValue);    \n    const actualValues = map(this.chipValues, (chip: any) => chip.value || chip.label || chip);\n    this.formControl?.setValue(actualValues);\n    this.currentInputValue = '';\n    this.model[this.key as string] = actualValues;\n  }\n  \n  removeChip(index: number) {\n    if (!this.isMultiValue) return;  \n    this.chipValues.splice(index, 1);  \n    const actualValues = map(this.chipValues, (chip: any) => chip.value || chip.label || chip);\n    this.model[this.key as string] = actualValues;\n  }\n\n  onChipKeyDown(event: KeyboardEvent) {\n    if (!this.isMultiValue) return;\n    if (event.key === 'Enter' || event.key === ',') {\n      event.preventDefault();\n      this.addChip(this.currentInputValue);\n    } else if (event.key === 'Backspace' && !this.currentInputValue && this.chipValues.length > 0) {\n      this.removeChip(this.chipValues.length - 1);\n    }\n  }\n  \n  onChipInputChange(event: any) {\n    if (!this.isMultiValue) return;\n    this.currentInputValue = event.target.value;\n  }\n\n  onChipBlur() {\n    if (!this.isMultiValue) return;\n    if (this.currentInputValue.trim()) {\n      this.addChip(this.currentInputValue);\n    }\n  }\n  /*onFieldCallback(param: IInputParam) {\n    this.icon = param.icon || this.icon;\n    this.checkValidity();\n  }*/\n\n  getFormSupportText() {\n    if (this.formControl.invalid && this.formControl.touched) {\n      return (\n        getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input',{\n          field: this.field,\n          nativeValidationObject: _get(this.field, 'validation'),\n        }) ||\n        `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`\n      );\n    } else {\n      return this.params?.supportText || '';\n    }\n  }\n\n  predefinedValidators: any = {\n    email: [Validators.email, Validators.required],\n    password: [Validators.required],\n    tel: [Validators.pattern('^[0-9 +\\\\-()]*$')],\n  };\n\n  getLabelFieldGap(): string {\n    if (this.props?.['bigLabel']) {\n      return 'var(--medium-20px)';\n    } else if (this.props?.['label']) {\n      return 'var(--small-4px)';\n    } else {\n      return '0px'; // No gap\n    }\n  }\n\n  shiftLabel(action: 'clicked' | 'cleared') {\n    if (action === 'clicked') {\n      this.startInd = 0;\n    } else {\n      this.startInd = Math.max(0, this.chipValues.length - this.labelLimit);\n    }\n  }\n}\n\nexport interface IInputIcon {\n  name: string;\n  show?: boolean;\n  color?: string;\n  size?: string;\n}\n\nexport interface IInputParam {\n  validators?: any[];\n  asyncValidators?: any[];\n  supportText?: string;\n  placeholder?: string;\n  type?: string;\n  dependent?: string;\n  eventListener?: Function;\n  icon?: IInputIcon;\n  errors?: { [key: string]: any };\n  className?: string;\n  multiValue?: boolean; // for multi-value chip support\n  chipValues?: any[]; // for multi-value chip support\n}\n\nexport interface IInputEvent {\n  type: IInputEventType;\n  value: string;\n  callBack: any;\n  formControl: FormControl;\n}\nexport enum IInputEventType {\n  INPUT_CHANGE = 'INPUT_CHANGE',\n  STATE_CHANGE = 'STATE_CHANGE',\n  ICON_CLICK = 'ICON_CLICK',\n}\n","<div class=\"sa-input-container {{props?.['inputContainerClass']}}\" [ngStyle]=\"{'gap': getLabelFieldGap()}\">\n    @if (!!props?.['bigLabel'] || !!props?.['bigDescription']) {\n    <div class=\"sa-input-big-label-container\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        <h2 class=\"sa-input-big-label\">\n            {{props?.['bigLabel']}}\n        </h2>\n        <p class=\"sa-input-big-description\">\n            {{props?.['bigDescription']}}\n        </p>\n    </div>\n    }\n    @if(!!props?.['label']){\n    <div class=\"sa-input-label-container\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        <div class=\"sa-input-label-tooltip-container\">\n            <span class=\"sa-input-label\">\n                {{props?.['label']}}\n            </span>\n            @if(!!props?.['tooltip']){\n            <span class=\"tooltip-container\">\n                <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n                    [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n                    [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n            </span>\n            }\n        </div>\n        @if(!!props?.['description']) {\n        <p class=\"sa-input-description\">\n            {{props?.['description']}}\n        </p>\n        }\n    </div>\n    }\n    <div class=\"sa-input\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        @if((pretext || (!!inputVal?.length && (!!params?.placeholder || !!props?.placeholder))) && props?.['showTag']\n        !== false){\n        <span class=\"sa-input-tag\">{{params?.placeholder || props?.placeholder}}</span>\n        }\n        <div class=\"sa-input-field\" [ngClass]=\"formControl.invalid && formControl.touched ? 'invalid' : 'idle' \"\n            (click)=\"onInputFieldClick($event)\">\n            @if(pretext){\n            <div class=\"sa-input-pretext\">\n                {{pretext}}\n            </div>\n            }\n\n            <!-- Multi-value chip display -->\n            @if(isMultiValue) {\n                <div class=\"chip-container\">\n                    <sa-chip \n                        *ngFor=\"let chip of (chipValues || [])?.slice(startInd,startInd+labelLimit) let i = index\"\n                        [text]=\"chip?.value || chip?.label || chip\"\n                        [type]=\"'regular'\"\n                        [state]=\"'primary'\"\n                        [filling]=\"'filled'\"\n                        [iconPosition]=\"'right'\"\n                        [iconPath]=\"'../assets/closeBlueOutlined.svg'\"\n                        (onClickEvent)=\"removeChip(i)\">\n                    </sa-chip>\n                    \n                    <div (click)=\"shiftLabel('clicked')\" class=\"ng-value overflow-label\"\n                        *ngIf=\"(chipValues || []).length > (startInd + labelLimit)\">\n                        <sa-chip [text]=\"'+' + ((chipValues || []).length - (startInd + labelLimit))\" \n                                type=\"regular\"  \n                                state=\"primary\" \n                                filling=\"filled\">\n                        </sa-chip>\n                    </div>\n                    <input\n                        [ngClass]=\"'chip-input'\"\n                        matInput [type]=\"type\"\n                        [disabled]=\"field.props.disabled || false\"\n                        [placeholder]=\"chipValues.length === 0 ? (props?.placeholder || params?.placeholder || '') : ''\"\n                        (focus)=\"onFocus()\"\n                        (blur)=\"onChipBlur()\"\n                        (input)=\"onChipInputChange($event)\"\n                        (keydown)=\"onChipKeyDown($event)\"\n                        [(ngModel)]=\"currentInputValue\"\n                        #formInput />\n                </div>\n            } @else {\n                <!-- Standard single-value input (backward compatibility) -->\n                @if(!!props?.['prefix']){\n                <span matPrefix>{{props?.['prefix']}}&nbsp;</span>\n                }\n                <input\n                    [ngClass]=\"(!!inputVal && (params?.type === 'password' || props?.type === 'password') && icon.name !== 'eyeOff') ? 'masked' : ''\"\n                    matInput [type]=\"props?.type || type\" value=\"\" [pattern]=\"type==='tel' ? '[0-9]' : '' \"\n                    [disabled]=\"field.props.disabled || false\"\n                    [placeholder]=\"!pretext && props?.placeholder || params?.placeholder || ''\" (focus)=\"onFocus()\"\n                    (blur)=\"onBlur()\" (input)=\"onInput($event)\" [(ngModel)]=\"inputVal\" #formInput />\n            }\n\n            @if(params?.type === 'password'){\n            <sa-icon class=\"flex\" icon=\"eyeOutlined\" [size]=\"icon.size || '24'\" (click)=\"inputIconClick()\"\n                [ngClass]=\"!icon.name || icon.name === 'eyeOutlined' ? '' : 'hide'\"></sa-icon>\n            <sa-icon class=\"flex\" icon=\"eyeOff\" [size]=\"icon.size || '24'\" (click)=\"inputIconClick()\"\n                [ngClass]=\"icon.name === 'eyeOff' ? '' : 'hide'\"></sa-icon>\n            }@else if(params?.type === 'email' && icon.show){\n            <sa-icon class=\"flex\" [icon]=\"icon.name || 'checkCircleOutlined'\" [size]=\"icon.size || '24'\"\n                (click)=\"inputIconClick()\" [ngClass]=\"showEmailIcon ? '' : 'hide'\"></sa-icon>\n            }\n            @else if(icon?.name){\n            <sa-icon class=\"flex\" [icon]=\"icon.name\" [size]=\"icon?.size || '24'\" [color]=\"icon?.color || ''\"\n                [ngClass]=\"icon?.show ? '' : 'hide'\"></sa-icon>\n            }\n        </div>\n        @if((!formControl.valid) || (params?.supportText)){\n            <div class=\"support-label {{formControl.invalid && formControl.touched ? params?.className : ''}}\" [ngClass]=\"[\n                formControl.invalid && formControl.touched ? 'invalid' : 'idle'\n              ]\">\n                <!-- {{!formControl.valid ? inputErrorText : params.supportText}} -->\n                {{getFormSupportText()}}\n            </div>\n            }\n    </div>\n</div>"]}
322
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/form-input/form-input.component.ts","../../../../../projects/component-library/src/lib/form-input/form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { FieldType, FieldTypeConfig } from '@ngx-formly/core';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { CommonModule } from '@angular/common';\nimport {\n  getValidationMessage,\n  phoneNumberValidator,\n} from '../../utils/validators';\nimport { IconComponent } from '../icon/icon.component';\nimport { ChipsComponent } from '../chips/chips.component';\nimport { get as _get, set as _set, map } from 'lodash';\nimport { MatTooltipModule } from '@angular/material/tooltip';\n@Component({\n  selector: 'sa-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    FormlyModule,\n    IconComponent,\n    MatTooltipModule,\n    ChipsComponent\n  ],\n  templateUrl: './form-input.component.html',\n  styleUrl: './form-input.component.css',\n})\nexport class FormInputComponent extends FieldType<FieldTypeConfig> {\n  @ViewChild('formInput') formInput!: ElementRef;\n\n  @Input('icon') icon: IInputIcon;\n\n  pretext: string;\n\n  inputState = 'idle';\n  inputVal = '';\n  @Input() params: IInputParam | null;\n  dependent: AbstractControl<any, any> | null;\n  dependentVal: any = null;\n  // dynamicIcon: DynamicIcon | null;\n  // icon: IInputIcon | null;\n\n  type: string = '';\n  validators: any[];\n  asyncValidators: any[];\n\n  inputErrorText: string = 'invalid input';\n\n  showEmailIcon: boolean = false;\n  disabled: boolean = false;\n  chipValues: any[] = [];\n  isMultiValue: boolean = false;\n  currentInputValue: string = '';\n  startInd: number = 0;\n  labelLimit: number = 1;\n\n  private suppressOnBlur = false;\n\n  constructor() {\n    super();\n  }\n\n  ngOnInit() {\n    this.inputVal = _get(this.field.props, 'value', _get(this.model, [this.key as string])) || '';\n    this.disabled = this.field.props.disabled || false;\n    this.formControl?.setValue(this.inputVal);\n\n    this.params = this.params || this.field.props['params'];\n    this.icon = this.icon || this.field.props['icon'] || {};\n    this.type = this.params?.type || '';\n    this.formControl.valueChanges.subscribe((val) => {\n      _set(this.formInput, 'nativeElement.value', val);\n      // Handle multi-value chip updates\n      if (this.isMultiValue && Array.isArray(val)) {\n        this.chipValues = val;\n      }\n    });\n\n    // Initialize multi-value mode if specified\n    if (this.params?.type === 'multi-value' || this.params?.multiValue) {\n      this.isMultiValue = true;\n      this.chipValues = this.model[this.key as string] || this.params?.chipValues || [];\n      this.currentInputValue = '';\n    }\n\n    // this.dynamicIcon = this.field.props['dynamicIcon'];\n    this.setValidators();\n    this.setDependents();\n\n    this.formControl.statusChanges.subscribe((state) => {\n      if (this.type === 'email') {\n        if (!!this.inputVal && !this.formControl.touched) {\n          this.formControl.markAsTouched();\n        }\n        this.showEmailIcon =\n          state === 'VALID' ||\n          (state === 'INVALID' &&\n            this.formControl.hasError('invalid') &&\n            !!this.formControl.value);\n      }\n    });\n    this.formControl.valueChanges.subscribe((val) => {\n      _set(this.formInput, 'nativeElement.value', val);\n    });\n  }\n\n  setValidators() {\n    this.validators = this.params?.validators || this.predefinedValidators[this.type] || [];\n    this.asyncValidators = this.params?.asyncValidators || [];\n    if(!_get(this.field, 'validators.validation', null)) {\n      this.formControl?.setValidators([\n        ...(this.type ? this.predefinedValidators[this.type] || [] : []),\n        ...(this.validators),\n      ]);\n    }\n    if (this.asyncValidators) {\n      this.formControl?.setAsyncValidators(this.asyncValidators);\n    }\n  }\n\n  /*\n    Assuming dependent field is a single select dropdown\n  */\n  setDependents() {\n    if (this.params?.dependent) {\n      this.dependent = this.form.get([this.params?.dependent]);\n\n      this.dependentVal = this.getDependentVal(_get(this.dependent, 'value'));\n      if (this.type === 'tel') {\n        this.pretext = this.dependentVal?.dial_code;\n      }\n\n      this.dependent?.valueChanges.subscribe((val) => {\n        this.dependentVal = this.getDependentVal(val);\n        this.formControl.reset();\n        this.formControl.setValue(this.inputVal);\n        if (this.type === 'tel') {\n          this.pretext = this.dependentVal?.dial_code;\n        }\n      });\n    }\n  }\n  getDependentVal(value: any) {\n    let dependentValue: any;\n    if (Array.isArray(value)) {\n      dependentValue = value.length ? value[0] : null;\n    } else {\n      dependentValue = value;\n    }\n    return dependentValue;\n  }\n\n  checkValidity(defaultInputState = 'focus') {\n    if (\n      this.formControl &&\n      !this.formControl.valid &&\n      this.formControl.touched &&\n      !this.formControl.pending\n    ) {\n      this.inputState = 'invalid';\n      this.inputErrorText =\n        getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input', {\n          field: this.field,\n          nativeValidationObject: this.field.validation,\n        }) || `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`\n    } else {\n      this.inputState = defaultInputState;\n    }\n  }\n\n  onFocus() {\n    if (this.formControl.valid) this.inputState = 'focus';\n  }\n  onBlur() {\n    setTimeout(() => {\n      if (!this.suppressOnBlur) {\n        this.formControl.markAsTouched();\n        this.checkValidity('idle');\n      }\n      this.suppressOnBlur = false;\n    }, 200);\n  }\n\n  onInput(event: any) {\n    if (this.params?.type === 'tel') {\n      this.inputVal = this.inputVal.replace(/[^0-9()+\\- ]/g, '');\n      this.inputVal = this.hyphenatePhoneNumber();\n    }\n    if (this.params?.type === 'percentage') {\n      let value = this.inputVal.replace(/[^0-9.]/g, '');\n      this.inputVal = value ? `${value}%` : '';\n    }\n    this.formControl?.setValue(this.inputVal);\n    this.checkValidity();\n    /*if (this.params?.eventListener) {\n      this.params?.eventListener({\n        type: IInputEventType.INPUT_CHANGE,\n        value: this.inputVal,\n        formControl: this.formControl\n      } as IInputEvent).then(this.onFieldCallback.bind(this));\n    }*/\n  }\n\n  hyphenatePhoneNumber() {\n    let newStr = '';\n    let i = 0;\n    let hyphenatedCount = 1;\n    const value = this.inputVal.replaceAll('-', '');\n    for (; i < value.length; i++) {\n      newStr = newStr + value.charAt(i);\n      if (!(hyphenatedCount % 3)) {\n        if (!((i + 1) % 10) && i + 1 < value.length) {\n          newStr = newStr + '-';\n          hyphenatedCount++;\n        }\n      } else if (\n        !((i + 1 - Math.floor(hyphenatedCount / 3)) % 3) &&\n        i + 1 < value.length\n      ) {\n        newStr = newStr + '-';\n        hyphenatedCount++;\n      }\n    }\n\n    return newStr;\n  }\n\n  onInputFieldClick(event: any = 'input') {\n    if (\n      event === 'input' ||\n      event.target.classList.contains('sa-input-field')\n    ) {\n      this.formInput.nativeElement.focus();\n      if (this.params?.type !== 'email')\n        setTimeout(() => {\n          this.formInput.nativeElement.setSelectionRange(\n            this.inputVal.length,\n            this.inputVal.length,\n          );\n        }, 10);\n    }\n  }\n\n  inputIconClick() {\n    if (this.params?.type === 'password') {\n      this.suppressOnBlur = true;\n      if (this.type === 'password') {\n        this.type = 'text';\n        this.icon.name = 'eyeOff';\n      } else {\n        this.type = 'password';\n        this.icon.name = 'eyeOutlined';\n      }\n      this.onInputFieldClick();\n    }\n  }\n\n  addChip(value: string) {\n    if (!this.isMultiValue || !value.trim()) return;  \n    const chipValue = {\n      label: value.trim(),\n      value: value.trim(),\n      removable: true\n    };\n    this.chipValues.push(chipValue);    \n    const actualValues = map(this.chipValues, (chip: any) => chip.value || chip.label || chip);\n    this.formControl?.setValue(actualValues);\n    this.currentInputValue = '';\n    this.model[this.key as string] = actualValues;\n  }\n  \n  removeChip(index: number) {\n    if (!this.isMultiValue) return;  \n    this.chipValues.splice(index, 1);  \n    const actualValues = map(this.chipValues, (chip: any) => chip.value || chip.label || chip);\n    this.model[this.key as string] = actualValues;\n  }\n\n  onChipKeyDown(event: KeyboardEvent) {\n    if (!this.isMultiValue) return;\n    if (event.key === 'Enter' || event.key === ',') {\n      event.preventDefault();\n      this.addChip(this.currentInputValue);\n    } else if (event.key === 'Backspace' && !this.currentInputValue && this.chipValues.length > 0) {\n      this.removeChip(this.chipValues.length - 1);\n    }\n  }\n  \n  onChipInputChange(event: any) {\n    if (!this.isMultiValue) return;\n    this.currentInputValue = event.target.value;\n  }\n\n  onChipBlur() {\n    if (!this.isMultiValue) return;\n    if (this.currentInputValue.trim()) {\n      this.addChip(this.currentInputValue);\n    }\n  }\n  /*onFieldCallback(param: IInputParam) {\n    this.icon = param.icon || this.icon;\n    this.checkValidity();\n  }*/\n\n  getFormSupportText() {\n    if (this.formControl.invalid && this.formControl.touched) {\n      return (\n        getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input',{\n          field: this.field,\n          nativeValidationObject: _get(this.field, 'validation'),\n        }) ||\n        `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`\n      );\n    } else {\n      return this.params?.supportText || '';\n    }\n  }\n\n  predefinedValidators: any = {\n    email: [Validators.email, Validators.required],\n    password: [Validators.required],\n    tel: [Validators.pattern('^[0-9 +\\\\-()]*$')],\n  };\n\n  getLabelFieldGap(): string {\n    if (this.props?.['bigLabel']) {\n      return 'var(--medium-20px)';\n    } else if (this.props?.['label']) {\n      return 'var(--small-4px)';\n    } else {\n      return '0px'; // No gap\n    }\n  }\n\n  shiftLabel(action: 'clicked' | 'cleared') {\n    if (action === 'clicked') {\n      this.startInd = 0;\n    } else {\n      this.startInd = Math.max(0, this.chipValues.length - this.labelLimit);\n    }\n  }\n}\n\nexport interface IInputIcon {\n  name: string;\n  show?: boolean;\n  color?: string;\n  size?: string;\n}\n\nexport interface IInputParam {\n  validators?: any[];\n  asyncValidators?: any[];\n  supportText?: string;\n  placeholder?: string;\n  type?: string;\n  dependent?: string;\n  eventListener?: Function;\n  icon?: IInputIcon;\n  errors?: { [key: string]: any };\n  className?: string;\n  multiValue?: boolean; // for multi-value chip support\n  chipValues?: any[]; // for multi-value chip support\n}\n\nexport interface IInputEvent {\n  type: IInputEventType;\n  value: string;\n  callBack: any;\n  formControl: FormControl;\n}\nexport enum IInputEventType {\n  INPUT_CHANGE = 'INPUT_CHANGE',\n  STATE_CHANGE = 'STATE_CHANGE',\n  ICON_CLICK = 'ICON_CLICK',\n}\n","<div class=\"sa-input-container {{props?.['inputContainerClass']}}\" [ngStyle]=\"{'gap': getLabelFieldGap()}\">\n    @if (!!props?.['bigLabel'] || !!props?.['bigDescription']) {\n    <div class=\"sa-input-big-label-container\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        <h2 class=\"sa-input-big-label\">\n            {{props?.['bigLabel']}}\n        </h2>\n        <p class=\"sa-input-big-description\">\n            {{props?.['bigDescription']}}\n        </p>\n    </div>\n    }\n    @if(!!props?.['label']){\n    <div class=\"sa-input-label-container\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        <div class=\"sa-input-label-tooltip-container\">\n            <span class=\"sa-input-label\">\n                {{props?.['label']}}\n            </span>\n            @if(!!props?.['tooltip']){\n            <span class=\"tooltip-container\">\n                <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n                    [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n                    [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n            </span>\n            }\n        </div>\n        @if(!!props?.['description']) {\n        <p class=\"sa-input-description\">\n            {{props?.['description']}}\n        </p>\n        }\n    </div>\n    }\n    <div class=\"sa-input\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        @if((pretext || (!!inputVal?.length && (!!params?.placeholder || !!props?.placeholder))) && props?.['showTag']\n        !== false){\n        <span class=\"sa-input-tag\">{{params?.placeholder || props?.placeholder}}</span>\n        }\n        <div class=\"sa-input-field\" [ngClass]=\"formControl.invalid && formControl.touched ? 'invalid' : 'idle' \"\n            (click)=\"onInputFieldClick($event)\">\n            @if(pretext){\n            <div class=\"sa-input-pretext\">\n                {{pretext}}\n            </div>\n            }\n\n            <!-- Multi-value chip display -->\n            @if(isMultiValue) {\n                <div class=\"chip-container\">\n                    <sa-chip \n                        *ngFor=\"let chip of (chipValues || [])?.slice(startInd,startInd+labelLimit) let i = index\"\n                        [text]=\"chip?.value || chip?.label || chip\"\n                        [type]=\"'regular'\"\n                        [state]=\"'primary'\"\n                        [filling]=\"'filled'\"\n                        [iconPosition]=\"'right'\"\n                        [iconPath]=\"'../assets/closeBlueOutlined.svg'\"\n                        (onClickEvent)=\"removeChip(i)\">\n                    </sa-chip>\n                    \n                    <div (click)=\"shiftLabel('clicked')\" class=\"ng-value overflow-label\"\n                        *ngIf=\"(chipValues || []).length > (startInd + labelLimit)\">\n                        <sa-chip [text]=\"'+' + ((chipValues || []).length - (startInd + labelLimit))\" \n                                type=\"regular\"  \n                                state=\"primary\" \n                                filling=\"filled\">\n                        </sa-chip>\n                    </div>\n                    <input\n                        [ngClass]=\"'chip-input'\"\n                        matInput [type]=\"type\"\n                        [disabled]=\"field.props.disabled || false\"\n                        [placeholder]=\"chipValues.length === 0 ? (props?.placeholder || params?.placeholder || '') : ''\"\n                        (focus)=\"onFocus()\"\n                        (blur)=\"onChipBlur()\"\n                        (input)=\"onChipInputChange($event)\"\n                        (keydown)=\"onChipKeyDown($event)\"\n                        [(ngModel)]=\"currentInputValue\"\n                        #formInput />\n                </div>\n            } @else {\n                <!-- Standard single-value input (backward compatibility) -->\n                @if(!!props?.['prefix']){\n                <span matPrefix>{{props?.['prefix']}}&nbsp;</span>\n                }\n                <input\n                    [ngClass]=\"(!!inputVal && (params?.type === 'password' || props?.type === 'password') && icon.name !== 'eyeOff') ? 'masked' : ''\"\n                    matInput [type]=\"props?.type || type\" value=\"\" [pattern]=\"type==='tel' ? '[0-9]' : '' \"\n                    [disabled]=\"field.props.disabled || false\"\n                    [placeholder]=\"!pretext && props?.placeholder || params?.placeholder || ''\" (focus)=\"onFocus()\"\n                    (blur)=\"onBlur()\" (input)=\"onInput($event)\" [(ngModel)]=\"inputVal\" #formInput />\n            }\n\n            @if(params?.type === 'password'){\n            <sa-icon class=\"flex\" icon=\"eyeOutlined\" [size]=\"icon.size || '24'\" (click)=\"inputIconClick()\"\n                [ngClass]=\"!icon.name || icon.name === 'eyeOutlined' ? '' : 'hide'\"></sa-icon>\n            <sa-icon class=\"flex\" icon=\"eyeOff\" [size]=\"icon.size || '24'\" (click)=\"inputIconClick()\"\n                [ngClass]=\"icon.name === 'eyeOff' ? '' : 'hide'\"></sa-icon>\n            }@else if(params?.type === 'email' && icon.show){\n            <sa-icon class=\"flex\" [icon]=\"icon.name || 'checkCircleOutlined'\" [size]=\"icon.size || '24'\"\n                (click)=\"inputIconClick()\" [ngClass]=\"showEmailIcon ? '' : 'hide'\"></sa-icon>\n            }\n            @else if(icon?.name){\n            <sa-icon class=\"flex\" [icon]=\"icon.name\" [size]=\"icon?.size || '24'\" [color]=\"icon?.color || ''\"\n                [ngClass]=\"icon?.show ? '' : 'hide'\"></sa-icon>\n            }\n        </div>\n        @if((!formControl.valid) || (params?.supportText)){\n            <div class=\"support-label {{formControl.invalid && formControl.touched ? params?.className : ''}}\" [ngClass]=\"[\n                formControl.invalid && formControl.touched ? 'invalid' : 'idle'\n              ]\">\n                <!-- {{!formControl.valid ? inputErrorText : params.supportText}} -->\n                {{getFormSupportText()}}\n            </div>\n            }\n    </div>\n</div>"]}
@@ -294,7 +294,7 @@ export class FormSelectComponent extends FieldType {
294
294
  }
295
295
  }
296
296
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: FormSelectComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
297
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: FormSelectComponent, isStandalone: true, selector: "lib-form-select", outputs: { hoverEvent: "hoverEvent" }, viewQueries: [{ propertyName: "ngSelect", first: true, predicate: NgSelectComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"sa-select-container {{props?.['inputContainerClass']}}\">\n @if(!!props?.['label']){\n <div class=\"sa-select-label-container\">\n <div class=\"sa-select-label-tooltip-container\">\n <span class=\"sa-select-label\">\n {{props?.['label']}}\n </span>\n @if(!!props?.['tooltip']){\n <span class=\"tooltip-container\">\n <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n </span>\n }\n </div>\n @if(!!props?.['description']) {\n <p class=\"sa-select-description\">\n {{props?.['description']}}\n </p>\n }\n </div>\n }\n <div class=\"sa-select-field-container\">\n <div [style.visibility]=\"(props?.['showTag'] !== false && (openState || topLabel)) ? 'visible' : 'hidden'\"\n class=\"clicked-label\">{{params.label}}\n </div>\n <div\n class=\"ng-select-field {{openState ? 'activated' : 'idle'}} {{field.props.disabled ? 'disabled' : ''}} {{formControl.valid ? '' : 'invalid'}}\">\n <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"left-icon svg-icon\" [style]=\"svgStyle\"\n (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\"\n *ngIf=\"(params.dropIconPosition == 'left' || params.dropIconPosition == 'both')\">\n </div>\n <ng-select (change)=\"onNgSelectChange($event)\" (remove)=\"shiftLabel('removed')\" (clear)=\"shiftLabel('cleared')\"\n (search)=\"openClose(true)\" (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\" [isOpen]=\"openState\"\n [placeholder]=\"placeholderLabel\" [bindLabel]=\"props?.['bindLabel'] || 'name'\" [bindValue]=\"props?.['bindValue'] || null\" [items]=\"selectables\" [multiple]=\"params?.multiple\"\n [formControl]=\"formControl\" [style] [formlyAttributes]=\"field\" [searchable]=\"field.props['searchable']\" [clearable]=\"false\" class=\"form-ng-select\"> \n <!-- Multi-label template for displaying selected items as chips -->\n <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n <div *ngFor=\"let item of (items ? items.slice(startInd,startInd+labelLimit): [])\">\n <sa-chip (onClickEvent)=\" (!field.props.disabled) ? clear(item) : null\" \n [id]=\"getFullObjectFromValue(item)[params?.bindValue || props?.['bindValue'] || 'id']\"\n [iconPath]=\"params.iconPath\" \n [text]=\"getFullObjectFromValue(item)[params?.bindLabel || props?.['bindLabel'] || 'name']\" \n [type]=\"params.type\"\n [state]=\"field.props.disabled ? 'neutral' : params.state\" \n [filling]=\"params.filling\"\n [iconPosition]=\"params.iconPosition\">\n </sa-chip>\n </div>\n <div (click)=\"shiftLabel('clicked')\" class=\"ng-value overflow-label\"\n *ngIf=\"items.length > (startInd+labelLimit)\">\n <sa-chip text=\"+{{items.length-(startInd+labelLimit)}}\" \n [type]=\"params.type || 'regular'\" \n [state]=\"params.state || 'primary'\" \n [filling]=\"params.filling || 'filled'\">\n </sa-chip>\n </div>\n <div (click)=\"shiftLabel('cleared')\" *ngIf=\"startInd > 0\"\n class=\"ng-value overflow-label\">\n <sa-chip text=\"...\" \n [type]=\"params.type || 'regular'\" \n [state]=\"params.state || 'default'\" \n [filling]=\"params.filling || 'filled'\">\n </sa-chip>\n </div>\n </ng-template>\n \n <!-- Universal option template with tooltip support for any select type -->\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\n <div class=\"option-container\" [ngClass]=\"{'checkbox-option': params?.showCheckboxes, 'single-option-with-tooltip': !params?.showCheckboxes}\">\n <!-- Checkbox for multi-select -->\n <input *ngIf=\"params?.showCheckboxes\" \n type=\"checkbox\" \n [checked]=\"isOptionSelected(item)\" \n (mousedown)=\"toggleItemSelection(item, $event)\"\n (click)=\"$event.stopPropagation(); $event.preventDefault()\"\n class=\"option-checkbox\">\n \n <!-- Option label -->\n <span class=\"option-label\">{{ item[props?.['bindLabel'] || 'name'] }}</span>\n \n <!-- Tooltip icon - shows when item has description/tooltip -->\n <sa-icon *ngIf=\"item.description || item.tooltip\" \n [icon]=\"'infoCircleOutlined'\" \n [size]=\"'16'\" \n class=\"option-tooltip-icon d-flex\"\n [matTooltip]=\"item.description || item.tooltip || ''\" \n matTooltipClass=\"custom-tooltip\"\n [matTooltipDisabled]=\"!(item.description || item.tooltip)\">\n </sa-icon>\n </div>\n </ng-template>\n \n <!-- Simple header template for Select All / Unselect All when in checkbox mode -->\n <ng-template ng-header-tmp *ngIf=\"params?.showCheckboxes && params?.multiple\">\n <div class=\"select-all-header\">\n <span class=\"select-all-label\" (click)=\"selectAll()\">Select all</span>\n <span class=\"unselect-all-label\" (click)=\"unselectAll()\">Unselect all</span>\n </div>\n </ng-template>\n\n <ng-template ng-arrow-tmp>\n <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex custom-dropdown-arrow\" [size]=\"'18'\"></sa-icon>\n </ng-template>\n </ng-select>\n <div *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\" class=\"right-icon\">\n <sa-icon [icon]=\"'downChevronOutlined'\" tabindex=\"0\" class=\"d-flex\" [size]=\"'18'\" (click)=\"openClose(!this.openState)\"\n (blur)=\"openClose(false)\" ></sa-icon>\n </div>\n <!-- <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"right-icon svg-icon\" [style]=\"svgStyle\"\n (click)=\"openClose(true)\" (blur)=\"openClose(false)\"\n *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\">\n </div> -->\n\n <div class=\"fallback-arrow\" *ngIf=\"!openState\">\n <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex\" [size]=\"'18'\"></sa-icon>\n </div>\n </div>\n @if(!formControl.valid){\n <div class=\"error-message-container\">\n <span class=\"error-message\">\n <formly-validation-message [field]=\"field\"></formly-validation-message>\n </span>\n </div>\n }\n <div class=\"support-label\">{{params.supportText}}</div>\n</div>", styles: [".idle{--border: 1px solid var(--grey-50)}.activated{--border: 1px solid var(--primary-300)}.disabled{border:1px solid var(--grey-50)!important}.ng-select-field:hover{--border: 1px solid var(--primary-300);--font-color: var(--text-highemphasis)}.ng-select-field{width:100%;box-sizing:border-box;position:relative;display:inline-flex;padding:0px var(--small-12px) 0 var(--medium-30px);height:40px;justify-content:center;align-items:center;border:var(--border);border-radius:var(--small-4px);font-family:var(--font);font-size:14px;font-style:normal;font-weight:400;line-height:20px;letter-spacing:.25px;--font-color: var(--text-lowemphasis)}.invalid{border:1px solid var(--semantic-error-500, #BD271E)}.ng-select{width:inherit;display:inline-flex;justify-content:center;align-items:center;flex-shrink:0}::ng-deep .ng-arrow-wrapper{pointer-events:none}.custom-select-container .ng-select{padding-left:1.25rem}.ng-select ::ng-deep .ng-select-container{display:inline-flex;justify-content:center;align-items:center;flex-shrink:0;font-family:var(--font);box-sizing:border-box;border:none}.ng-select ::ng-deep .ng-dropdown-panel{margin-top:2px;border:1px solid var(--grey-50);box-shadow:none;z-index:1000}.ng-select ::ng-deep .ng-select-container{box-shadow:none;position:relative;z-index:1}::ng-deep .ng-select.ng-select-focused:not(.ng-select-opened)>.ng-select-container{box-shadow:none}.ng-select ::ng-deep .ng-value-container{padding:0!important;flex-wrap:nowrap!important;display:flex;justify-content:flex-start;gap:5px;overflow-x:hidden}.ng-select ::ng-deep .ng-value{flex:none;margin:0!important}.overflow-label{padding:0 5px;cursor:pointer}.ng-select ::ng-deep .ng-placeholder{padding:0!important;position:inherit!important;color:var(--text-lowemphasis)}.ng-select ::ng-deep .ng-input{padding:0!important;position:inherit!important}.ng-select ::ng-deep .ng-clear-wrapper{z-index:9;display:flex;margin-left:5px}.ng-select ::ng-deep .ng-arrow{border-color:none!important;border-style:none!important;border-width:0!important}.svg-icon{-webkit-mask-size:contain;mask-size:contain;width:20px;height:20px;background-color:gray}.svg-icon:hover{cursor:pointer}.ng-select ::ng-deep .ng-arrow-wrapper,::ng-deep .ng-select-filtered .ng-select-container .ng-value-container .ng-value{display:none}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{background-color:var(--ng-select-chip-bg, var(--primary-50))}.support-label{font-family:var(--font);font-size:11px;font-style:normal;font-weight:400;line-height:16px;letter-spacing:.5px;color:var(--text-lowemphasis);padding:var(--small-4px) var(--small-16px) 0px var(--small-16px)}.clicked-label{position:relative;width:max-content;font-family:var(--font);font-size:11px;font-style:normal;font-weight:500;line-height:16px;letter-spacing:.5px;color:var(--text-lowemphasis);padding:0 var(--small-8px);margin-left:12px;margin-bottom:-8px;z-index:9999;background-color:#fff}.ng-select ::ng-deep .ng-dropdown-panel{width:calc(100% + 24px);left:-12px;margin-top:6px}.custom-select-container .ng-select ::ng-deep .ng-dropdown-panel{left:.45rem}.d-flex{display:flex}.custom-select-container.sa-select-container{display:flex;flex-direction:column;gap:var(--small-12px, 12px)}.sa-select-label-tooltip-container{display:flex;gap:var(--small-4px);align-items:center}.sa-select-label{color:var(--text-highemphasis, #1B1D20);font-family:var(--font);font-size:var(--small-14px);font-style:normal;font-weight:500;line-height:var(--medium-20px);letter-spacing:.1px}.right-icon{padding-right:1.2rem;color:#757575}.invalid .right-icon{color:var(--semantic-error-500, #BD271E)}.error-message{color:var(--semantic-error-500, #BD271E);font-family:var(--font);font-size:11px;font-style:normal;font-weight:400;line-height:var(--small-16px);letter-spacing:.5px}.checkbox-option{display:flex;align-items:center;padding:8px 12px;cursor:pointer;gap:8px;transition:background-color .2s ease}.checkbox-option:hover{background-color:var(--grey-50, #F9FAFB)}.option-checkbox{width:16px;height:16px;margin-right:8px;cursor:pointer;accent-color:var(--primary-500, #6B46C1)}.option-label{font-size:14px;font-weight:400;color:var(--text-high-emphasis, #1D2939);line-height:20px;letter-spacing:.25px}.single-option-with-tooltip{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;gap:8px;transition:background-color .2s ease;width:100%}.single-option-with-tooltip .option-label{flex:1;font-size:14px;font-weight:400;color:var(--text-high-emphasis, #1D2939);line-height:20px;letter-spacing:.25px}.option-tooltip-icon{color:var(--grey-400, #98A2B3);cursor:pointer;flex-shrink:0}.option-tooltip-icon:hover{color:var(--primary-500, #6B46C1)}.select-all-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--grey-200, #E4E7EC);background-color:var(--grey-25, #FCFCFD);cursor:pointer;transition:background-color .2s ease}.select-all-header:hover{background-color:var(--grey-50, #F9FAFB)}.select-all-label,.unselect-all-label{font-size:14px;font-weight:500;color:var(--primary-500, #6B46C1);line-height:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.select-all-label:hover,.unselect-all-label:hover{background-color:var(--primary-50, #F3F4F6)}.unselect-all-label{color:var(--grey-600, #475467)}.unselect-all-label:hover{background-color:var(--grey-100, #F2F4F7)}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-placeholder{color:var(--text-medium-emphasis, #6D6979)}::ng-deep .form-ng-select.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected{background-color:transparent!important}::ng-deep .form-ng-select.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-highlighted{background-color:var(--grey-50, #F9FAFB)!important}::ng-deep .ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{padding:0}.custom-dropdown-arrow{color:var(--Grey-600, #475467);cursor:pointer;transition:transform .2s ease}.ng-select.ng-select-opened .custom-dropdown-arrow{transform:rotate(180deg)}.form-ng-select.ng-select ::ng-deep .ng-arrow-wrapper{display:flex!important;align-items:center;justify-content:center;padding-right:12px;width:18px;height:18px}.ng-select ::ng-deep .ng-arrow-wrapper .ng-arrow{display:none}.ng-select.ng-select-multiple ::ng-deep .ng-arrow-wrapper{display:flex!important}.fallback-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;color:var(--Grey-600, #475467)}.ng-select ::ng-deep .ng-arrow-wrapper:not(:empty)+.fallback-arrow{display:none}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: FormlyModule }, { kind: "directive", type: i2.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "component", type: i2.ɵFormlyValidationMessage, selector: "formly-validation-message", inputs: ["field"] }, { kind: "ngmodule", type: NgSelectModule }, { kind: "component", type: i3.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i3.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "directive", type: i3.NgMultiLabelTemplateDirective, selector: "[ng-multi-label-tmp]" }, { kind: "directive", type: i3.NgHeaderTemplateDirective, selector: "[ng-header-tmp]" }, { kind: "component", type: ChipsComponent, selector: "sa-chip", inputs: ["id", "iconPath", "text", "type", "state", "filling", "iconPosition", "largeStateIcon", "largeStateText", "tooltip", "className"], outputs: ["onClickEvent"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: IconComponent, selector: "sa-icon", inputs: ["img", "icon", "size", "color", "iconPath", "iconUrl", "customClass", "href", "hrefTarget", "iconPosition"], outputs: ["onClickEvent"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
297
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: FormSelectComponent, isStandalone: true, selector: "lib-form-select", outputs: { hoverEvent: "hoverEvent" }, viewQueries: [{ propertyName: "ngSelect", first: true, predicate: NgSelectComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"sa-select-container {{props?.['inputContainerClass']}}\">\n @if(!!props?.['label']){\n <div class=\"sa-select-label-container\">\n <div class=\"sa-select-label-tooltip-container\">\n <span class=\"sa-select-label\">\n {{props?.['label']}}\n </span>\n @if(!!props?.['tooltip']){\n <span class=\"tooltip-container\">\n <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n </span>\n }\n </div>\n @if(!!props?.['description']) {\n <p class=\"sa-select-description\">\n {{props?.['description']}}\n </p>\n }\n </div>\n }\n <div class=\"sa-select-field-container\">\n <div [style.visibility]=\"(props?.['showTag'] !== false && (openState || topLabel)) ? 'visible' : 'hidden'\"\n class=\"clicked-label\">{{params.label}}\n </div>\n <div\n class=\"ng-select-field {{openState ? 'activated' : 'idle'}} {{field.props.disabled ? 'disabled' : ''}} {{formControl.valid ? '' : 'invalid'}}\">\n <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"left-icon svg-icon\" [style]=\"svgStyle\"\n (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\"\n *ngIf=\"(params.dropIconPosition == 'left' || params.dropIconPosition == 'both')\">\n </div>\n <ng-select (change)=\"onNgSelectChange($event)\" (remove)=\"shiftLabel('removed')\" (clear)=\"shiftLabel('cleared')\"\n (search)=\"openClose(true)\" (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\" [isOpen]=\"openState\"\n [placeholder]=\"placeholderLabel\" [bindLabel]=\"props?.['bindLabel'] || 'name'\" [bindValue]=\"props?.['bindValue'] || null\" [items]=\"selectables\" [multiple]=\"params?.multiple\"\n [formControl]=\"formControl\" [style] [formlyAttributes]=\"field\" [searchable]=\"field.props['searchable']\" [clearable]=\"false\" [closeOnSelect]=\"!params?.showCheckboxes\" class=\"form-ng-select\"> \n <!-- Multi-label template for displaying selected items as chips -->\n <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n <div *ngFor=\"let item of (items ? items.slice(startInd,startInd+labelLimit): [])\">\n <sa-chip (onClickEvent)=\" (!field.props.disabled) ? clear(item) : null\" \n [id]=\"getFullObjectFromValue(item)[params?.bindValue || props?.['bindValue'] || 'id']\"\n [iconPath]=\"params.iconPath\" \n [text]=\"getFullObjectFromValue(item)[params?.bindLabel || props?.['bindLabel'] || 'name']\" \n [type]=\"params.type\"\n [state]=\"field.props.disabled ? 'neutral' : params.state\" \n [filling]=\"params.filling\"\n [iconPosition]=\"params.iconPosition\">\n </sa-chip>\n </div>\n <div (click)=\"shiftLabel('clicked')\" class=\"ng-value overflow-label\"\n *ngIf=\"items.length > (startInd+labelLimit)\">\n <sa-chip text=\"+{{items.length-(startInd+labelLimit)}}\" \n [type]=\"params.type || 'regular'\" \n [state]=\"params.state || 'primary'\" \n [filling]=\"params.filling || 'filled'\">\n </sa-chip>\n </div>\n <div (click)=\"shiftLabel('cleared')\" *ngIf=\"startInd > 0\"\n class=\"ng-value overflow-label\">\n <sa-chip text=\"...\" \n [type]=\"params.type || 'regular'\" \n [state]=\"params.state || 'default'\" \n [filling]=\"params.filling || 'filled'\">\n </sa-chip>\n </div>\n </ng-template>\n \n <!-- Universal option template with tooltip support for any select type -->\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\n <div class=\"option-container\" [ngClass]=\"{'checkbox-option': params?.showCheckboxes, 'single-option-with-tooltip': !params?.showCheckboxes}\">\n <!-- Checkbox for multi-select -->\n <input *ngIf=\"params?.showCheckboxes\" \n type=\"checkbox\" \n [checked]=\"isOptionSelected(item)\" \n (mousedown)=\"toggleItemSelection(item, $event)\"\n (click)=\"$event.stopPropagation(); $event.preventDefault()\"\n class=\"option-checkbox\">\n \n <!-- Option label -->\n <span class=\"option-label\">{{ item[props?.['bindLabel'] || 'name'] }}</span>\n \n <!-- Tooltip icon - shows when item has description/tooltip -->\n <sa-icon *ngIf=\"item.description || item.tooltip\" \n [icon]=\"'infoCircleOutlined'\" \n [size]=\"'16'\" \n class=\"option-tooltip-icon d-flex\"\n [matTooltip]=\"item.description || item.tooltip || ''\" \n matTooltipClass=\"custom-tooltip\"\n [matTooltipDisabled]=\"!(item.description || item.tooltip)\">\n </sa-icon>\n </div>\n </ng-template>\n \n <!-- Simple header template for Select All / Unselect All when in checkbox mode -->\n <ng-template ng-header-tmp *ngIf=\"params?.showCheckboxes && params?.multiple\">\n <div class=\"select-all-header\">\n <span class=\"select-all-label\" (click)=\"selectAll()\">Select all</span>\n <span class=\"unselect-all-label\" (click)=\"unselectAll()\">Unselect all</span>\n </div>\n </ng-template>\n\n <ng-template ng-arrow-tmp>\n <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex custom-dropdown-arrow\" [size]=\"'18'\"></sa-icon>\n </ng-template>\n </ng-select>\n <div *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\" class=\"right-icon\">\n <sa-icon [icon]=\"'downChevronOutlined'\" tabindex=\"0\" class=\"d-flex\" [size]=\"'18'\" (click)=\"openClose(!this.openState)\"\n (blur)=\"openClose(false)\" ></sa-icon>\n </div>\n <!-- <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"right-icon svg-icon\" [style]=\"svgStyle\"\n (click)=\"openClose(true)\" (blur)=\"openClose(false)\"\n *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\">\n </div> -->\n\n <div class=\"fallback-arrow\" *ngIf=\"!openState\">\n <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex\" [size]=\"'18'\"></sa-icon>\n </div>\n </div>\n @if(!formControl.valid){\n <div class=\"error-message-container\">\n <span class=\"error-message\">\n <formly-validation-message [field]=\"field\"></formly-validation-message>\n </span>\n </div>\n }\n <div class=\"support-label\">{{params.supportText}}</div>\n</div>", styles: [".idle{--border: 1px solid var(--grey-50)}.activated{--border: 1px solid var(--primary-300)}.disabled{border:1px solid var(--grey-50)!important}.ng-select-field:hover{--border: 1px solid var(--primary-300);--font-color: var(--text-highemphasis)}.ng-select-field{width:100%;box-sizing:border-box;position:relative;display:inline-flex;padding:0px var(--small-12px) 0 var(--medium-30px);height:40px;justify-content:center;align-items:center;border:var(--border);border-radius:var(--small-4px);font-family:var(--font);font-size:14px;font-style:normal;font-weight:400;line-height:20px;letter-spacing:.25px;--font-color: var(--text-lowemphasis)}.invalid{border:1px solid var(--semantic-error-500, #BD271E)}.ng-select{width:inherit;display:inline-flex;justify-content:center;align-items:center;flex-shrink:0}::ng-deep .ng-arrow-wrapper{pointer-events:none}.custom-select-container .ng-select{padding-left:1.25rem}.ng-select ::ng-deep .ng-select-container{display:inline-flex;justify-content:center;align-items:center;flex-shrink:0;font-family:var(--font);box-sizing:border-box;border:none}.ng-select ::ng-deep .ng-dropdown-panel{margin-top:2px;border:1px solid var(--grey-50);box-shadow:none;z-index:1000}.ng-select ::ng-deep .ng-select-container{box-shadow:none;position:relative;z-index:1}::ng-deep .ng-select.ng-select-focused:not(.ng-select-opened)>.ng-select-container{box-shadow:none}.ng-select ::ng-deep .ng-value-container{padding:0!important;flex-wrap:nowrap!important;display:flex;justify-content:flex-start;gap:5px;overflow-x:hidden}.ng-select ::ng-deep .ng-value{flex:none;margin:0!important}.overflow-label{padding:0 5px;cursor:pointer}.ng-select ::ng-deep .ng-placeholder{padding:0!important;position:inherit!important;color:var(--text-lowemphasis)}.ng-select ::ng-deep .ng-input{padding:0!important;position:inherit!important}.ng-select ::ng-deep .ng-clear-wrapper{z-index:9;display:flex;margin-left:5px}.ng-select ::ng-deep .ng-arrow{border-color:none!important;border-style:none!important;border-width:0!important}.svg-icon{-webkit-mask-size:contain;mask-size:contain;width:20px;height:20px;background-color:gray}.svg-icon:hover{cursor:pointer}.ng-select ::ng-deep .ng-arrow-wrapper,::ng-deep .ng-select-filtered .ng-select-container .ng-value-container .ng-value{display:none}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{background-color:var(--ng-select-chip-bg, var(--primary-50))}.support-label{font-family:var(--font);font-size:11px;font-style:normal;font-weight:400;line-height:16px;letter-spacing:.5px;color:var(--text-lowemphasis);padding:var(--small-4px) var(--small-16px) 0px var(--small-16px)}.clicked-label{position:relative;width:max-content;font-family:var(--font);font-size:11px;font-style:normal;font-weight:500;line-height:16px;letter-spacing:.5px;color:var(--text-lowemphasis);padding:0 var(--small-8px);margin-left:12px;margin-bottom:-8px;z-index:9999;background-color:#fff}.ng-select ::ng-deep .ng-dropdown-panel{width:calc(100% + 24px);left:-12px;margin-top:6px}.custom-select-container .ng-select ::ng-deep .ng-dropdown-panel{left:.45rem}.d-flex{display:flex}.custom-select-container.sa-select-container{display:flex;flex-direction:column;gap:var(--small-12px, 12px)}.sa-select-label-tooltip-container{display:flex;gap:var(--small-4px);align-items:center}.sa-select-label{color:var(--text-highemphasis, #1B1D20);font-family:var(--font);font-size:var(--small-14px);font-style:normal;font-weight:500;line-height:var(--medium-20px);letter-spacing:.1px}.right-icon{padding-right:1.2rem;color:#757575}.invalid .right-icon{color:var(--semantic-error-500, #BD271E)}.error-message{color:var(--semantic-error-500, #BD271E);font-family:var(--font);font-size:11px;font-style:normal;font-weight:400;line-height:var(--small-16px);letter-spacing:.5px}.checkbox-option{display:flex;align-items:center;padding:8px 12px;cursor:pointer;gap:8px;transition:background-color .2s ease}.checkbox-option:hover{background-color:var(--grey-50, #F9FAFB)}.option-checkbox{width:16px;height:16px;margin-right:8px;cursor:pointer;accent-color:var(--primary-500, #6B46C1)}.option-label{font-size:14px;font-weight:400;color:var(--text-high-emphasis, #1D2939);line-height:20px;letter-spacing:.25px}.single-option-with-tooltip{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;gap:8px;transition:background-color .2s ease;width:100%}.single-option-with-tooltip .option-label{flex:1;font-size:14px;font-weight:400;color:var(--text-high-emphasis, #1D2939);line-height:20px;letter-spacing:.25px}.option-tooltip-icon{color:var(--grey-400, #98A2B3);cursor:pointer;flex-shrink:0}.option-tooltip-icon:hover{color:var(--primary-500, #6B46C1)}.select-all-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--grey-200, #E4E7EC);background-color:var(--grey-25, #FCFCFD);cursor:pointer;transition:background-color .2s ease}.select-all-header:hover{background-color:var(--grey-50, #F9FAFB)}.select-all-label,.unselect-all-label{font-size:14px;font-weight:500;color:var(--primary-500, #6B46C1);line-height:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.select-all-label:hover,.unselect-all-label:hover{background-color:var(--primary-50, #F3F4F6)}.unselect-all-label{color:var(--grey-600, #475467)}.unselect-all-label:hover{background-color:var(--grey-100, #F2F4F7)}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-placeholder{color:var(--text-medium-emphasis, #6D6979)}::ng-deep .form-ng-select.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected{background-color:transparent!important}::ng-deep .form-ng-select.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-highlighted{background-color:var(--grey-50, #F9FAFB)!important}::ng-deep .ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{padding:0}.custom-dropdown-arrow{color:var(--Grey-600, #475467);cursor:pointer;transition:transform .2s ease}.ng-select.ng-select-opened .custom-dropdown-arrow{transform:rotate(180deg)}.form-ng-select.ng-select ::ng-deep .ng-arrow-wrapper{display:flex!important;align-items:center;justify-content:center;padding-right:12px;width:18px;height:18px}.ng-select ::ng-deep .ng-arrow-wrapper .ng-arrow{display:none}.ng-select.ng-select-multiple ::ng-deep .ng-arrow-wrapper{display:flex!important}.fallback-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;color:var(--Grey-600, #475467)}.ng-select ::ng-deep .ng-arrow-wrapper:not(:empty)+.fallback-arrow{display:none}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: FormlyModule }, { kind: "directive", type: i2.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "component", type: i2.ɵFormlyValidationMessage, selector: "formly-validation-message", inputs: ["field"] }, { kind: "ngmodule", type: NgSelectModule }, { kind: "component", type: i3.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i3.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "directive", type: i3.NgMultiLabelTemplateDirective, selector: "[ng-multi-label-tmp]" }, { kind: "directive", type: i3.NgHeaderTemplateDirective, selector: "[ng-header-tmp]" }, { kind: "component", type: ChipsComponent, selector: "sa-chip", inputs: ["id", "iconPath", "text", "type", "state", "filling", "iconPosition", "largeStateIcon", "largeStateText", "tooltip", "className"], outputs: ["onClickEvent"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: IconComponent, selector: "sa-icon", inputs: ["img", "icon", "size", "color", "iconPath", "iconUrl", "customClass", "href", "hrefTarget", "iconPosition"], outputs: ["onClickEvent"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
298
298
  }
299
299
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: FormSelectComponent, decorators: [{
300
300
  type: Component,
@@ -310,7 +310,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
310
310
  IconComponent,
311
311
  CommonModule,
312
312
  MatTooltipModule
313
- ], template: "<div class=\"sa-select-container {{props?.['inputContainerClass']}}\">\n @if(!!props?.['label']){\n <div class=\"sa-select-label-container\">\n <div class=\"sa-select-label-tooltip-container\">\n <span class=\"sa-select-label\">\n {{props?.['label']}}\n </span>\n @if(!!props?.['tooltip']){\n <span class=\"tooltip-container\">\n <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n </span>\n }\n </div>\n @if(!!props?.['description']) {\n <p class=\"sa-select-description\">\n {{props?.['description']}}\n </p>\n }\n </div>\n }\n <div class=\"sa-select-field-container\">\n <div [style.visibility]=\"(props?.['showTag'] !== false && (openState || topLabel)) ? 'visible' : 'hidden'\"\n class=\"clicked-label\">{{params.label}}\n </div>\n <div\n class=\"ng-select-field {{openState ? 'activated' : 'idle'}} {{field.props.disabled ? 'disabled' : ''}} {{formControl.valid ? '' : 'invalid'}}\">\n <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"left-icon svg-icon\" [style]=\"svgStyle\"\n (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\"\n *ngIf=\"(params.dropIconPosition == 'left' || params.dropIconPosition == 'both')\">\n </div>\n <ng-select (change)=\"onNgSelectChange($event)\" (remove)=\"shiftLabel('removed')\" (clear)=\"shiftLabel('cleared')\"\n (search)=\"openClose(true)\" (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\" [isOpen]=\"openState\"\n [placeholder]=\"placeholderLabel\" [bindLabel]=\"props?.['bindLabel'] || 'name'\" [bindValue]=\"props?.['bindValue'] || null\" [items]=\"selectables\" [multiple]=\"params?.multiple\"\n [formControl]=\"formControl\" [style] [formlyAttributes]=\"field\" [searchable]=\"field.props['searchable']\" [clearable]=\"false\" class=\"form-ng-select\"> \n <!-- Multi-label template for displaying selected items as chips -->\n <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n <div *ngFor=\"let item of (items ? items.slice(startInd,startInd+labelLimit): [])\">\n <sa-chip (onClickEvent)=\" (!field.props.disabled) ? clear(item) : null\" \n [id]=\"getFullObjectFromValue(item)[params?.bindValue || props?.['bindValue'] || 'id']\"\n [iconPath]=\"params.iconPath\" \n [text]=\"getFullObjectFromValue(item)[params?.bindLabel || props?.['bindLabel'] || 'name']\" \n [type]=\"params.type\"\n [state]=\"field.props.disabled ? 'neutral' : params.state\" \n [filling]=\"params.filling\"\n [iconPosition]=\"params.iconPosition\">\n </sa-chip>\n </div>\n <div (click)=\"shiftLabel('clicked')\" class=\"ng-value overflow-label\"\n *ngIf=\"items.length > (startInd+labelLimit)\">\n <sa-chip text=\"+{{items.length-(startInd+labelLimit)}}\" \n [type]=\"params.type || 'regular'\" \n [state]=\"params.state || 'primary'\" \n [filling]=\"params.filling || 'filled'\">\n </sa-chip>\n </div>\n <div (click)=\"shiftLabel('cleared')\" *ngIf=\"startInd > 0\"\n class=\"ng-value overflow-label\">\n <sa-chip text=\"...\" \n [type]=\"params.type || 'regular'\" \n [state]=\"params.state || 'default'\" \n [filling]=\"params.filling || 'filled'\">\n </sa-chip>\n </div>\n </ng-template>\n \n <!-- Universal option template with tooltip support for any select type -->\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\n <div class=\"option-container\" [ngClass]=\"{'checkbox-option': params?.showCheckboxes, 'single-option-with-tooltip': !params?.showCheckboxes}\">\n <!-- Checkbox for multi-select -->\n <input *ngIf=\"params?.showCheckboxes\" \n type=\"checkbox\" \n [checked]=\"isOptionSelected(item)\" \n (mousedown)=\"toggleItemSelection(item, $event)\"\n (click)=\"$event.stopPropagation(); $event.preventDefault()\"\n class=\"option-checkbox\">\n \n <!-- Option label -->\n <span class=\"option-label\">{{ item[props?.['bindLabel'] || 'name'] }}</span>\n \n <!-- Tooltip icon - shows when item has description/tooltip -->\n <sa-icon *ngIf=\"item.description || item.tooltip\" \n [icon]=\"'infoCircleOutlined'\" \n [size]=\"'16'\" \n class=\"option-tooltip-icon d-flex\"\n [matTooltip]=\"item.description || item.tooltip || ''\" \n matTooltipClass=\"custom-tooltip\"\n [matTooltipDisabled]=\"!(item.description || item.tooltip)\">\n </sa-icon>\n </div>\n </ng-template>\n \n <!-- Simple header template for Select All / Unselect All when in checkbox mode -->\n <ng-template ng-header-tmp *ngIf=\"params?.showCheckboxes && params?.multiple\">\n <div class=\"select-all-header\">\n <span class=\"select-all-label\" (click)=\"selectAll()\">Select all</span>\n <span class=\"unselect-all-label\" (click)=\"unselectAll()\">Unselect all</span>\n </div>\n </ng-template>\n\n <ng-template ng-arrow-tmp>\n <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex custom-dropdown-arrow\" [size]=\"'18'\"></sa-icon>\n </ng-template>\n </ng-select>\n <div *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\" class=\"right-icon\">\n <sa-icon [icon]=\"'downChevronOutlined'\" tabindex=\"0\" class=\"d-flex\" [size]=\"'18'\" (click)=\"openClose(!this.openState)\"\n (blur)=\"openClose(false)\" ></sa-icon>\n </div>\n <!-- <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"right-icon svg-icon\" [style]=\"svgStyle\"\n (click)=\"openClose(true)\" (blur)=\"openClose(false)\"\n *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\">\n </div> -->\n\n <div class=\"fallback-arrow\" *ngIf=\"!openState\">\n <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex\" [size]=\"'18'\"></sa-icon>\n </div>\n </div>\n @if(!formControl.valid){\n <div class=\"error-message-container\">\n <span class=\"error-message\">\n <formly-validation-message [field]=\"field\"></formly-validation-message>\n </span>\n </div>\n }\n <div class=\"support-label\">{{params.supportText}}</div>\n</div>", styles: [".idle{--border: 1px solid var(--grey-50)}.activated{--border: 1px solid var(--primary-300)}.disabled{border:1px solid var(--grey-50)!important}.ng-select-field:hover{--border: 1px solid var(--primary-300);--font-color: var(--text-highemphasis)}.ng-select-field{width:100%;box-sizing:border-box;position:relative;display:inline-flex;padding:0px var(--small-12px) 0 var(--medium-30px);height:40px;justify-content:center;align-items:center;border:var(--border);border-radius:var(--small-4px);font-family:var(--font);font-size:14px;font-style:normal;font-weight:400;line-height:20px;letter-spacing:.25px;--font-color: var(--text-lowemphasis)}.invalid{border:1px solid var(--semantic-error-500, #BD271E)}.ng-select{width:inherit;display:inline-flex;justify-content:center;align-items:center;flex-shrink:0}::ng-deep .ng-arrow-wrapper{pointer-events:none}.custom-select-container .ng-select{padding-left:1.25rem}.ng-select ::ng-deep .ng-select-container{display:inline-flex;justify-content:center;align-items:center;flex-shrink:0;font-family:var(--font);box-sizing:border-box;border:none}.ng-select ::ng-deep .ng-dropdown-panel{margin-top:2px;border:1px solid var(--grey-50);box-shadow:none;z-index:1000}.ng-select ::ng-deep .ng-select-container{box-shadow:none;position:relative;z-index:1}::ng-deep .ng-select.ng-select-focused:not(.ng-select-opened)>.ng-select-container{box-shadow:none}.ng-select ::ng-deep .ng-value-container{padding:0!important;flex-wrap:nowrap!important;display:flex;justify-content:flex-start;gap:5px;overflow-x:hidden}.ng-select ::ng-deep .ng-value{flex:none;margin:0!important}.overflow-label{padding:0 5px;cursor:pointer}.ng-select ::ng-deep .ng-placeholder{padding:0!important;position:inherit!important;color:var(--text-lowemphasis)}.ng-select ::ng-deep .ng-input{padding:0!important;position:inherit!important}.ng-select ::ng-deep .ng-clear-wrapper{z-index:9;display:flex;margin-left:5px}.ng-select ::ng-deep .ng-arrow{border-color:none!important;border-style:none!important;border-width:0!important}.svg-icon{-webkit-mask-size:contain;mask-size:contain;width:20px;height:20px;background-color:gray}.svg-icon:hover{cursor:pointer}.ng-select ::ng-deep .ng-arrow-wrapper,::ng-deep .ng-select-filtered .ng-select-container .ng-value-container .ng-value{display:none}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{background-color:var(--ng-select-chip-bg, var(--primary-50))}.support-label{font-family:var(--font);font-size:11px;font-style:normal;font-weight:400;line-height:16px;letter-spacing:.5px;color:var(--text-lowemphasis);padding:var(--small-4px) var(--small-16px) 0px var(--small-16px)}.clicked-label{position:relative;width:max-content;font-family:var(--font);font-size:11px;font-style:normal;font-weight:500;line-height:16px;letter-spacing:.5px;color:var(--text-lowemphasis);padding:0 var(--small-8px);margin-left:12px;margin-bottom:-8px;z-index:9999;background-color:#fff}.ng-select ::ng-deep .ng-dropdown-panel{width:calc(100% + 24px);left:-12px;margin-top:6px}.custom-select-container .ng-select ::ng-deep .ng-dropdown-panel{left:.45rem}.d-flex{display:flex}.custom-select-container.sa-select-container{display:flex;flex-direction:column;gap:var(--small-12px, 12px)}.sa-select-label-tooltip-container{display:flex;gap:var(--small-4px);align-items:center}.sa-select-label{color:var(--text-highemphasis, #1B1D20);font-family:var(--font);font-size:var(--small-14px);font-style:normal;font-weight:500;line-height:var(--medium-20px);letter-spacing:.1px}.right-icon{padding-right:1.2rem;color:#757575}.invalid .right-icon{color:var(--semantic-error-500, #BD271E)}.error-message{color:var(--semantic-error-500, #BD271E);font-family:var(--font);font-size:11px;font-style:normal;font-weight:400;line-height:var(--small-16px);letter-spacing:.5px}.checkbox-option{display:flex;align-items:center;padding:8px 12px;cursor:pointer;gap:8px;transition:background-color .2s ease}.checkbox-option:hover{background-color:var(--grey-50, #F9FAFB)}.option-checkbox{width:16px;height:16px;margin-right:8px;cursor:pointer;accent-color:var(--primary-500, #6B46C1)}.option-label{font-size:14px;font-weight:400;color:var(--text-high-emphasis, #1D2939);line-height:20px;letter-spacing:.25px}.single-option-with-tooltip{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;gap:8px;transition:background-color .2s ease;width:100%}.single-option-with-tooltip .option-label{flex:1;font-size:14px;font-weight:400;color:var(--text-high-emphasis, #1D2939);line-height:20px;letter-spacing:.25px}.option-tooltip-icon{color:var(--grey-400, #98A2B3);cursor:pointer;flex-shrink:0}.option-tooltip-icon:hover{color:var(--primary-500, #6B46C1)}.select-all-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--grey-200, #E4E7EC);background-color:var(--grey-25, #FCFCFD);cursor:pointer;transition:background-color .2s ease}.select-all-header:hover{background-color:var(--grey-50, #F9FAFB)}.select-all-label,.unselect-all-label{font-size:14px;font-weight:500;color:var(--primary-500, #6B46C1);line-height:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.select-all-label:hover,.unselect-all-label:hover{background-color:var(--primary-50, #F3F4F6)}.unselect-all-label{color:var(--grey-600, #475467)}.unselect-all-label:hover{background-color:var(--grey-100, #F2F4F7)}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-placeholder{color:var(--text-medium-emphasis, #6D6979)}::ng-deep .form-ng-select.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected{background-color:transparent!important}::ng-deep .form-ng-select.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-highlighted{background-color:var(--grey-50, #F9FAFB)!important}::ng-deep .ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{padding:0}.custom-dropdown-arrow{color:var(--Grey-600, #475467);cursor:pointer;transition:transform .2s ease}.ng-select.ng-select-opened .custom-dropdown-arrow{transform:rotate(180deg)}.form-ng-select.ng-select ::ng-deep .ng-arrow-wrapper{display:flex!important;align-items:center;justify-content:center;padding-right:12px;width:18px;height:18px}.ng-select ::ng-deep .ng-arrow-wrapper .ng-arrow{display:none}.ng-select.ng-select-multiple ::ng-deep .ng-arrow-wrapper{display:flex!important}.fallback-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;color:var(--Grey-600, #475467)}.ng-select ::ng-deep .ng-arrow-wrapper:not(:empty)+.fallback-arrow{display:none}\n"] }]
313
+ ], template: "<div class=\"sa-select-container {{props?.['inputContainerClass']}}\">\n @if(!!props?.['label']){\n <div class=\"sa-select-label-container\">\n <div class=\"sa-select-label-tooltip-container\">\n <span class=\"sa-select-label\">\n {{props?.['label']}}\n </span>\n @if(!!props?.['tooltip']){\n <span class=\"tooltip-container\">\n <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n </span>\n }\n </div>\n @if(!!props?.['description']) {\n <p class=\"sa-select-description\">\n {{props?.['description']}}\n </p>\n }\n </div>\n }\n <div class=\"sa-select-field-container\">\n <div [style.visibility]=\"(props?.['showTag'] !== false && (openState || topLabel)) ? 'visible' : 'hidden'\"\n class=\"clicked-label\">{{params.label}}\n </div>\n <div\n class=\"ng-select-field {{openState ? 'activated' : 'idle'}} {{field.props.disabled ? 'disabled' : ''}} {{formControl.valid ? '' : 'invalid'}}\">\n <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"left-icon svg-icon\" [style]=\"svgStyle\"\n (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\"\n *ngIf=\"(params.dropIconPosition == 'left' || params.dropIconPosition == 'both')\">\n </div>\n <ng-select (change)=\"onNgSelectChange($event)\" (remove)=\"shiftLabel('removed')\" (clear)=\"shiftLabel('cleared')\"\n (search)=\"openClose(true)\" (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\" [isOpen]=\"openState\"\n [placeholder]=\"placeholderLabel\" [bindLabel]=\"props?.['bindLabel'] || 'name'\" [bindValue]=\"props?.['bindValue'] || null\" [items]=\"selectables\" [multiple]=\"params?.multiple\"\n [formControl]=\"formControl\" [style] [formlyAttributes]=\"field\" [searchable]=\"field.props['searchable']\" [clearable]=\"false\" [closeOnSelect]=\"!params?.showCheckboxes\" class=\"form-ng-select\"> \n <!-- Multi-label template for displaying selected items as chips -->\n <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n <div *ngFor=\"let item of (items ? items.slice(startInd,startInd+labelLimit): [])\">\n <sa-chip (onClickEvent)=\" (!field.props.disabled) ? clear(item) : null\" \n [id]=\"getFullObjectFromValue(item)[params?.bindValue || props?.['bindValue'] || 'id']\"\n [iconPath]=\"params.iconPath\" \n [text]=\"getFullObjectFromValue(item)[params?.bindLabel || props?.['bindLabel'] || 'name']\" \n [type]=\"params.type\"\n [state]=\"field.props.disabled ? 'neutral' : params.state\" \n [filling]=\"params.filling\"\n [iconPosition]=\"params.iconPosition\">\n </sa-chip>\n </div>\n <div (click)=\"shiftLabel('clicked')\" class=\"ng-value overflow-label\"\n *ngIf=\"items.length > (startInd+labelLimit)\">\n <sa-chip text=\"+{{items.length-(startInd+labelLimit)}}\" \n [type]=\"params.type || 'regular'\" \n [state]=\"params.state || 'primary'\" \n [filling]=\"params.filling || 'filled'\">\n </sa-chip>\n </div>\n <div (click)=\"shiftLabel('cleared')\" *ngIf=\"startInd > 0\"\n class=\"ng-value overflow-label\">\n <sa-chip text=\"...\" \n [type]=\"params.type || 'regular'\" \n [state]=\"params.state || 'default'\" \n [filling]=\"params.filling || 'filled'\">\n </sa-chip>\n </div>\n </ng-template>\n \n <!-- Universal option template with tooltip support for any select type -->\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\n <div class=\"option-container\" [ngClass]=\"{'checkbox-option': params?.showCheckboxes, 'single-option-with-tooltip': !params?.showCheckboxes}\">\n <!-- Checkbox for multi-select -->\n <input *ngIf=\"params?.showCheckboxes\" \n type=\"checkbox\" \n [checked]=\"isOptionSelected(item)\" \n (mousedown)=\"toggleItemSelection(item, $event)\"\n (click)=\"$event.stopPropagation(); $event.preventDefault()\"\n class=\"option-checkbox\">\n \n <!-- Option label -->\n <span class=\"option-label\">{{ item[props?.['bindLabel'] || 'name'] }}</span>\n \n <!-- Tooltip icon - shows when item has description/tooltip -->\n <sa-icon *ngIf=\"item.description || item.tooltip\" \n [icon]=\"'infoCircleOutlined'\" \n [size]=\"'16'\" \n class=\"option-tooltip-icon d-flex\"\n [matTooltip]=\"item.description || item.tooltip || ''\" \n matTooltipClass=\"custom-tooltip\"\n [matTooltipDisabled]=\"!(item.description || item.tooltip)\">\n </sa-icon>\n </div>\n </ng-template>\n \n <!-- Simple header template for Select All / Unselect All when in checkbox mode -->\n <ng-template ng-header-tmp *ngIf=\"params?.showCheckboxes && params?.multiple\">\n <div class=\"select-all-header\">\n <span class=\"select-all-label\" (click)=\"selectAll()\">Select all</span>\n <span class=\"unselect-all-label\" (click)=\"unselectAll()\">Unselect all</span>\n </div>\n </ng-template>\n\n <ng-template ng-arrow-tmp>\n <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex custom-dropdown-arrow\" [size]=\"'18'\"></sa-icon>\n </ng-template>\n </ng-select>\n <div *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\" class=\"right-icon\">\n <sa-icon [icon]=\"'downChevronOutlined'\" tabindex=\"0\" class=\"d-flex\" [size]=\"'18'\" (click)=\"openClose(!this.openState)\"\n (blur)=\"openClose(false)\" ></sa-icon>\n </div>\n <!-- <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"right-icon svg-icon\" [style]=\"svgStyle\"\n (click)=\"openClose(true)\" (blur)=\"openClose(false)\"\n *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\">\n </div> -->\n\n <div class=\"fallback-arrow\" *ngIf=\"!openState\">\n <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex\" [size]=\"'18'\"></sa-icon>\n </div>\n </div>\n @if(!formControl.valid){\n <div class=\"error-message-container\">\n <span class=\"error-message\">\n <formly-validation-message [field]=\"field\"></formly-validation-message>\n </span>\n </div>\n }\n <div class=\"support-label\">{{params.supportText}}</div>\n</div>", styles: [".idle{--border: 1px solid var(--grey-50)}.activated{--border: 1px solid var(--primary-300)}.disabled{border:1px solid var(--grey-50)!important}.ng-select-field:hover{--border: 1px solid var(--primary-300);--font-color: var(--text-highemphasis)}.ng-select-field{width:100%;box-sizing:border-box;position:relative;display:inline-flex;padding:0px var(--small-12px) 0 var(--medium-30px);height:40px;justify-content:center;align-items:center;border:var(--border);border-radius:var(--small-4px);font-family:var(--font);font-size:14px;font-style:normal;font-weight:400;line-height:20px;letter-spacing:.25px;--font-color: var(--text-lowemphasis)}.invalid{border:1px solid var(--semantic-error-500, #BD271E)}.ng-select{width:inherit;display:inline-flex;justify-content:center;align-items:center;flex-shrink:0}::ng-deep .ng-arrow-wrapper{pointer-events:none}.custom-select-container .ng-select{padding-left:1.25rem}.ng-select ::ng-deep .ng-select-container{display:inline-flex;justify-content:center;align-items:center;flex-shrink:0;font-family:var(--font);box-sizing:border-box;border:none}.ng-select ::ng-deep .ng-dropdown-panel{margin-top:2px;border:1px solid var(--grey-50);box-shadow:none;z-index:1000}.ng-select ::ng-deep .ng-select-container{box-shadow:none;position:relative;z-index:1}::ng-deep .ng-select.ng-select-focused:not(.ng-select-opened)>.ng-select-container{box-shadow:none}.ng-select ::ng-deep .ng-value-container{padding:0!important;flex-wrap:nowrap!important;display:flex;justify-content:flex-start;gap:5px;overflow-x:hidden}.ng-select ::ng-deep .ng-value{flex:none;margin:0!important}.overflow-label{padding:0 5px;cursor:pointer}.ng-select ::ng-deep .ng-placeholder{padding:0!important;position:inherit!important;color:var(--text-lowemphasis)}.ng-select ::ng-deep .ng-input{padding:0!important;position:inherit!important}.ng-select ::ng-deep .ng-clear-wrapper{z-index:9;display:flex;margin-left:5px}.ng-select ::ng-deep .ng-arrow{border-color:none!important;border-style:none!important;border-width:0!important}.svg-icon{-webkit-mask-size:contain;mask-size:contain;width:20px;height:20px;background-color:gray}.svg-icon:hover{cursor:pointer}.ng-select ::ng-deep .ng-arrow-wrapper,::ng-deep .ng-select-filtered .ng-select-container .ng-value-container .ng-value{display:none}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{background-color:var(--ng-select-chip-bg, var(--primary-50))}.support-label{font-family:var(--font);font-size:11px;font-style:normal;font-weight:400;line-height:16px;letter-spacing:.5px;color:var(--text-lowemphasis);padding:var(--small-4px) var(--small-16px) 0px var(--small-16px)}.clicked-label{position:relative;width:max-content;font-family:var(--font);font-size:11px;font-style:normal;font-weight:500;line-height:16px;letter-spacing:.5px;color:var(--text-lowemphasis);padding:0 var(--small-8px);margin-left:12px;margin-bottom:-8px;z-index:9999;background-color:#fff}.ng-select ::ng-deep .ng-dropdown-panel{width:calc(100% + 24px);left:-12px;margin-top:6px}.custom-select-container .ng-select ::ng-deep .ng-dropdown-panel{left:.45rem}.d-flex{display:flex}.custom-select-container.sa-select-container{display:flex;flex-direction:column;gap:var(--small-12px, 12px)}.sa-select-label-tooltip-container{display:flex;gap:var(--small-4px);align-items:center}.sa-select-label{color:var(--text-highemphasis, #1B1D20);font-family:var(--font);font-size:var(--small-14px);font-style:normal;font-weight:500;line-height:var(--medium-20px);letter-spacing:.1px}.right-icon{padding-right:1.2rem;color:#757575}.invalid .right-icon{color:var(--semantic-error-500, #BD271E)}.error-message{color:var(--semantic-error-500, #BD271E);font-family:var(--font);font-size:11px;font-style:normal;font-weight:400;line-height:var(--small-16px);letter-spacing:.5px}.checkbox-option{display:flex;align-items:center;padding:8px 12px;cursor:pointer;gap:8px;transition:background-color .2s ease}.checkbox-option:hover{background-color:var(--grey-50, #F9FAFB)}.option-checkbox{width:16px;height:16px;margin-right:8px;cursor:pointer;accent-color:var(--primary-500, #6B46C1)}.option-label{font-size:14px;font-weight:400;color:var(--text-high-emphasis, #1D2939);line-height:20px;letter-spacing:.25px}.single-option-with-tooltip{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;gap:8px;transition:background-color .2s ease;width:100%}.single-option-with-tooltip .option-label{flex:1;font-size:14px;font-weight:400;color:var(--text-high-emphasis, #1D2939);line-height:20px;letter-spacing:.25px}.option-tooltip-icon{color:var(--grey-400, #98A2B3);cursor:pointer;flex-shrink:0}.option-tooltip-icon:hover{color:var(--primary-500, #6B46C1)}.select-all-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--grey-200, #E4E7EC);background-color:var(--grey-25, #FCFCFD);cursor:pointer;transition:background-color .2s ease}.select-all-header:hover{background-color:var(--grey-50, #F9FAFB)}.select-all-label,.unselect-all-label{font-size:14px;font-weight:500;color:var(--primary-500, #6B46C1);line-height:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.select-all-label:hover,.unselect-all-label:hover{background-color:var(--primary-50, #F3F4F6)}.unselect-all-label{color:var(--grey-600, #475467)}.unselect-all-label:hover{background-color:var(--grey-100, #F2F4F7)}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-placeholder{color:var(--text-medium-emphasis, #6D6979)}::ng-deep .form-ng-select.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected{background-color:transparent!important}::ng-deep .form-ng-select.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-highlighted{background-color:var(--grey-50, #F9FAFB)!important}::ng-deep .ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{padding:0}.custom-dropdown-arrow{color:var(--Grey-600, #475467);cursor:pointer;transition:transform .2s ease}.ng-select.ng-select-opened .custom-dropdown-arrow{transform:rotate(180deg)}.form-ng-select.ng-select ::ng-deep .ng-arrow-wrapper{display:flex!important;align-items:center;justify-content:center;padding-right:12px;width:18px;height:18px}.ng-select ::ng-deep .ng-arrow-wrapper .ng-arrow{display:none}.ng-select.ng-select-multiple ::ng-deep .ng-arrow-wrapper{display:flex!important}.fallback-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;color:var(--Grey-600, #475467)}.ng-select ::ng-deep .ng-arrow-wrapper:not(:empty)+.fallback-arrow{display:none}\n"] }]
314
314
  }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { hoverEvent: [{
315
315
  type: Output,
316
316
  args: ['hoverEvent']
@@ -318,4 +318,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
318
318
  type: ViewChild,
319
319
  args: [NgSelectComponent]
320
320
  }] } });
321
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-select.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/form-select/form-select.component.ts","../../../../../projects/component-library/src/lib/form-select/form-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Output, ViewChild, ElementRef } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { FieldType, FieldTypeConfig } from '@ngx-formly/core';\nimport { NgSelectComponent, NgSelectModule } from '@ng-select/ng-select';\nimport { ChipsComponent } from '../chips/chips.component';\nimport { NgIf, NgFor } from '@angular/common';\nimport { IconComponent } from '../icon/icon.component';\nimport { CommonModule } from '@angular/common';\nimport { MatTooltip, MatTooltipModule } from '@angular/material/tooltip';\nimport { SelectInterface, SelectSubInterface } from '../../public-api';\n\n@Component({\n  selector: 'lib-form-select',\n  standalone: true,\n  imports: [\n    ReactiveFormsModule,\n    FormlyModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    ChipsComponent,\n    NgIf,\n    NgFor,\n    MatTooltipModule,\n    IconComponent,\n    CommonModule,\n    MatTooltipModule\n  ],\n  templateUrl: './form-select.component.html',\n  styleUrl: './form-select.component.css'\n})\nexport class FormSelectComponent extends FieldType<FieldTypeConfig> {\n  selectables: any;\n  params: any;\n\n  // Helper method to get full object from bound value\n  getFullObjectFromValue(value: any): any {\n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    if (!bindValue) return value;\n    \n    return this.selectables.find((item: any) => item[bindValue] === value) || value;\n  }\n\n  svgStyle = {};\n  openState: boolean = false;\n  topLabel: boolean;\n  startInd: number = 0;\n  labelLimit: number = 2;\n\n  placeholderLabel: string;\n  @Output('hoverEvent') hoverEvent: EventEmitter<selectHoverEvent> = new EventEmitter();\n  @ViewChild(NgSelectComponent) ngSelect!: NgSelectComponent;\n\n  constructor(private elementRef: ElementRef) {\n    super();\n  }\n  \n  ngOnInit() {\n    this.selectables = this.field.props.options;    \n    this.params = this.field.props['params'] || {};\n    \n    // Fallback to field.props if params is empty\n    if (!this.params || Object.keys(this.params).length === 0) {\n      this.params = this.field.props;\n    }\n    \n    \n    this.placeholderLabel = this.params.label || this.field.props.placeholder;\n    this.svgStyle = {\n      '-webkit-mask-image': `url(${this.params.dropIcon})})`,\n      'mask-image': `url(${this.params.dropIcon})`,\n    }\n    \n    // Set CSS custom property for chip background based on state\n    this.setChipBackgroundColor();\n  }\n\n  private setChipBackgroundColor(): void {\n    const state = this.params?.state;\n    let backgroundColor = 'var(--primary-50)'; // default fallback\n    \n    // Map chip states to appropriate background colors\n    switch(state) {\n      case 'neutral':\n        backgroundColor = 'var(--grey-50)';\n        break;\n      case 'success':\n        backgroundColor = 'var(--success-50)';\n        break;\n      case 'error':\n        backgroundColor = 'var(--error-50)';\n        break;\n      case 'warning':\n        backgroundColor = 'var(--warning-50)';\n        break;\n      case 'primary':\n      default:\n        backgroundColor = 'var(--primary-50)';\n        break;\n    }\n    \n    if (typeof document !== 'undefined' && this.elementRef?.nativeElement) {\n        this.elementRef.nativeElement.style.setProperty('--ng-select-chip-bg', backgroundColor);\n    }\n  }\n  openClose(state: boolean) {\n    if (this.field.props.disabled) return;\n    this.openState = state;\n    if (state || this.formControl.value?.length > 0) {\n      this.placeholderLabel = this.params.placeholder\n      } else {\n        this.placeholderLabel = this.params.label;\n    }\n  }\n  shiftLabel(action: string) {\n  if (action == 'clicked') this.startInd++;\n  if (action == 'cleared') this.startInd = 0;\n  if (action == 'removed' && this.startInd > 0) this.startInd--;\n  this.topLabel = this.formControl.value?.length > 0; \n  this.placeholderLabel = this.openState || this.formControl.value?.length > 0 \n    ? this.params.placeholder \n    : this.params.label;\n}\n\n  toggleOption(item: any, event: Event): void {\n    event.stopPropagation();\n    event.preventDefault();\n    \n    if (!this.params?.multiple) {\n      // Single select mode\n      this.formControl.setValue(item);\n      this.openState = false; \n      return;\n    }\n\n    // Multi-select mode\n    const currentValue = this.formControl.value || [];\n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    const itemValue = bindValue ? item[bindValue] : item;\n    \n    const index = currentValue.findIndex((selected: any) => {\n      const selectedValue = bindValue ? selected[bindValue] : selected;\n      return selectedValue === itemValue;\n    });\n\n    let newValue;\n    if (index > -1) {\n      newValue = [...currentValue];\n      newValue.splice(index, 1);\n    } else {\n      newValue = [...currentValue, item];\n    }\n    \n    this.formControl.setValue(newValue);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n    \n    this.checkForZero(newValue);\n    \n    this.formControl.updateValueAndValidity();\n  }\n\n\n  onNgSelectChange(selected: any): void {\n    // Only handle ng-select changes when NOT in checkbox mode\n    if (!this.params?.showCheckboxes) {\n      this.checkForZero(selected);\n    } else {\n      // In checkbox mode, prevent ng-select from changing the form control\n      // Restore the current value to prevent ng-select interference\n      const currentValue = this.formControl.value || [];\n      this.openState = true;\n      setTimeout(() => {\n        this.formControl.setValue(currentValue, { emitEvent: false });\n        this.openState = true;\n      }, 0);\n    }\n  }\n\n  selectAll(): void {\n    if (!this.params?.multiple) return;\n    \n    // Check if we have bindValue configured\n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    \n    let allValues;\n    if (bindValue) {\n      // If bindValue is configured, extract only the bound values\n      allValues = this.selectables.map((item: any) => item[bindValue]);\n    } else {\n      // If no bindValue, store full objects\n      allValues = [...this.selectables];\n    }\n    \n    this.formControl.setValue(allValues);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n    \n    this.checkForZero(allValues);\n    \n    this.formControl.updateValueAndValidity();\n    \n    // Ensure Formly integration\n    if (this.field && this.field.formControl) {\n      this.field.formControl.setValue(allValues);\n      this.field.formControl.updateValueAndValidity();\n    }\n  }\n\n  unselectAll(): void {\n    if (!this.params?.multiple) return;\n    \n    const emptyValue: any[] = [];\n    \n    this.formControl.setValue(emptyValue);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n    \n    this.checkForZero(emptyValue);\n    \n    this.formControl.updateValueAndValidity();\n    \n    if (this.field && this.field.formControl) {\n      this.field.formControl.setValue(emptyValue);\n      this.field.formControl.updateValueAndValidity();\n    }\n  }\n\n  isAllSelected(): boolean {\n    const currentValue = this.formControl.value || [];\n    return Array.isArray(currentValue) && \n           currentValue.length === this.selectables.length &&\n           this.selectables.every((item: any) => this.isOptionSelected(item));\n  }\n\n  isSomeSelected(): boolean {\n    const currentValue = this.formControl.value || [];\n    return Array.isArray(currentValue) && \n           currentValue.length > 0 && \n           currentValue.length < this.selectables.length;\n  }\n  toggleItemSelection(item: any, event: Event): void {\n    event.stopPropagation();\n    event.preventDefault();\n    \n    if (!this.params?.multiple) return;\n    \n    const currentValue = this.formControl.value || [];\n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    \n    let itemIndex = -1;\n    let itemValue = bindValue ? item[bindValue] : item;\n    \n    if (bindValue) {\n      // When using bindValue, currentValue should contain only the bound values\n      itemIndex = currentValue.findIndex((selected: any) => selected === itemValue);\n    } else {\n      // When not using bindValue, compare full objects\n      itemIndex = currentValue.findIndex((selected: any) => {\n        if (typeof selected === 'object' && typeof item === 'object') {\n          return JSON.stringify(selected) === JSON.stringify(item);\n        }\n        return selected === item;\n      });\n    }\n    \n    let newValue;\n    if (itemIndex > -1) {\n      // Remove the item\n      newValue = [...currentValue];\n      newValue.splice(itemIndex, 1);\n    } else {\n      // Add the item\n      if (bindValue) {\n        // Add only the bound value\n        newValue = [...currentValue, itemValue];\n      } else {\n        // Add the full object\n        newValue = [...currentValue, item];\n      }\n    }\n    \n    this.formControl.setValue(newValue);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n    \n    this.checkForZero(newValue);\n    \n    this.formControl.updateValueAndValidity();\n    \n    if (this.field && this.field.formControl) {\n      this.field.formControl.setValue(newValue);\n      this.field.formControl.updateValueAndValidity();\n    }\n    \n    // Force Angular change detection to update the UI\n    setTimeout(() => {\n      if (this.ngSelect && !this.ngSelect.isOpen) {\n        this.ngSelect.open();\n      }\n    }, 0);\n  }\n\n  isOptionSelected(item: any): boolean {\n    const currentValue = this.formControl.value || [];\n    if (!Array.isArray(currentValue)) return false;\n    \n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    \n    if (bindValue) {\n      // When using bindValue, currentValue contains only the bound values\n      const itemValue = item[bindValue];\n      return currentValue.includes(itemValue);\n    } else {\n      // When not using bindValue, compare full objects\n      return currentValue.some((selected: any) => {\n        if (typeof selected === 'object' && typeof item === 'object') {\n          return JSON.stringify(selected) === JSON.stringify(item);\n        }\n        return selected === item;\n      });\n    }\n  }\n\n  checkForZero(selected: any, state?: boolean) {\n    // Use the passed selected parameter if available, otherwise fall back to form control value\n    const valueToCheck = selected !== undefined ? selected : this.formControl.value;\n    \n    this.topLabel = valueToCheck?.length == 0 ? false : true;\n    // console.log(\"test\", this.formControl.value?.length)\n    // console.log(\"test\", this.openState)\n    // console.log(\"placeholder--- \", this.placeholderLabel)\n    // console.log(\"params.label--- \", this.params.label)\n    this.openState = state;\n    if (state || valueToCheck?.length > 0) {\n      this.placeholderLabel = this.params.placeholder;\n    } else {\n      this.placeholderLabel = this.params.label;\n    }\n  }\n  mouseHover(item: SelectSubInterface, event: any = null, tooltip: MatTooltip) {  // New method for mouseenter event\n    this.hoverEvent.emit({\n      event,\n      item\n    });\n    if (tooltip) {\n      tooltip.show();\n    }\n  }\n}\n\nexport interface selectHoverEvent {\n  event: any,\n  item: SelectSubInterface\n}","<div class=\"sa-select-container {{props?.['inputContainerClass']}}\">\n  @if(!!props?.['label']){\n  <div class=\"sa-select-label-container\">\n    <div class=\"sa-select-label-tooltip-container\">\n      <span class=\"sa-select-label\">\n        {{props?.['label']}}\n      </span>\n      @if(!!props?.['tooltip']){\n      <span class=\"tooltip-container\">\n        <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n          [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n          [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n      </span>\n      }\n    </div>\n    @if(!!props?.['description']) {\n    <p class=\"sa-select-description\">\n      {{props?.['description']}}\n    </p>\n    }\n  </div>\n  }\n  <div class=\"sa-select-field-container\">\n    <div [style.visibility]=\"(props?.['showTag'] !== false && (openState || topLabel)) ? 'visible' : 'hidden'\"\n      class=\"clicked-label\">{{params.label}}\n    </div>\n    <div\n      class=\"ng-select-field {{openState ? 'activated' : 'idle'}} {{field.props.disabled ? 'disabled' : ''}} {{formControl.valid ? '' : 'invalid'}}\">\n      <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"left-icon svg-icon\" [style]=\"svgStyle\"\n        (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\"\n        *ngIf=\"(params.dropIconPosition == 'left' || params.dropIconPosition == 'both')\">\n      </div>\n      <ng-select (change)=\"onNgSelectChange($event)\" (remove)=\"shiftLabel('removed')\" (clear)=\"shiftLabel('cleared')\"\n      (search)=\"openClose(true)\" (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\" [isOpen]=\"openState\"\n      [placeholder]=\"placeholderLabel\" [bindLabel]=\"props?.['bindLabel'] || 'name'\" [bindValue]=\"props?.['bindValue'] || null\" [items]=\"selectables\" [multiple]=\"params?.multiple\"\n      [formControl]=\"formControl\" [style] [formlyAttributes]=\"field\" [searchable]=\"field.props['searchable']\" [clearable]=\"false\" class=\"form-ng-select\">      \n      <!-- Multi-label template for displaying selected items as chips -->\n      <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n        <div *ngFor=\"let item of (items ? items.slice(startInd,startInd+labelLimit): [])\">\n          <sa-chip (onClickEvent)=\" (!field.props.disabled) ?  clear(item) : null\" \n            [id]=\"getFullObjectFromValue(item)[params?.bindValue || props?.['bindValue'] || 'id']\"\n            [iconPath]=\"params.iconPath\" \n            [text]=\"getFullObjectFromValue(item)[params?.bindLabel || props?.['bindLabel'] || 'name']\" \n            [type]=\"params.type\"\n            [state]=\"field.props.disabled ? 'neutral' : params.state\" \n            [filling]=\"params.filling\"\n            [iconPosition]=\"params.iconPosition\">\n          </sa-chip>\n        </div>\n        <div (click)=\"shiftLabel('clicked')\" class=\"ng-value overflow-label\"\n          *ngIf=\"items.length > (startInd+labelLimit)\">\n          <sa-chip text=\"+{{items.length-(startInd+labelLimit)}}\" \n                   [type]=\"params.type || 'regular'\" \n                   [state]=\"params.state || 'primary'\" \n                   [filling]=\"params.filling || 'filled'\">\n          </sa-chip>\n        </div>\n        <div (click)=\"shiftLabel('cleared')\" *ngIf=\"startInd > 0\"\n          class=\"ng-value overflow-label\">\n          <sa-chip text=\"...\" \n                   [type]=\"params.type || 'regular'\" \n                   [state]=\"params.state || 'default'\" \n                   [filling]=\"params.filling || 'filled'\">\n          </sa-chip>\n        </div>\n      </ng-template>\n      \n      <!-- Universal option template with tooltip support for any select type -->\n      <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\n        <div class=\"option-container\" [ngClass]=\"{'checkbox-option': params?.showCheckboxes, 'single-option-with-tooltip': !params?.showCheckboxes}\">\n          <!-- Checkbox for multi-select -->\n          <input *ngIf=\"params?.showCheckboxes\" \n                 type=\"checkbox\" \n                 [checked]=\"isOptionSelected(item)\" \n                 (mousedown)=\"toggleItemSelection(item, $event)\"\n                 (click)=\"$event.stopPropagation(); $event.preventDefault()\"\n                 class=\"option-checkbox\">\n          \n          <!-- Option label -->\n          <span class=\"option-label\">{{ item[props?.['bindLabel'] || 'name'] }}</span>\n          \n          <!-- Tooltip icon - shows when item has description/tooltip -->\n          <sa-icon *ngIf=\"item.description || item.tooltip\" \n                   [icon]=\"'infoCircleOutlined'\" \n                   [size]=\"'16'\" \n                   class=\"option-tooltip-icon d-flex\"\n                   [matTooltip]=\"item.description || item.tooltip || ''\" \n                   matTooltipClass=\"custom-tooltip\"\n                   [matTooltipDisabled]=\"!(item.description || item.tooltip)\">\n          </sa-icon>\n        </div>\n      </ng-template>\n      \n      <!-- Simple header template for Select All / Unselect All when in checkbox mode -->\n      <ng-template ng-header-tmp *ngIf=\"params?.showCheckboxes && params?.multiple\">\n        <div class=\"select-all-header\">\n          <span class=\"select-all-label\" (click)=\"selectAll()\">Select all</span>\n          <span class=\"unselect-all-label\" (click)=\"unselectAll()\">Unselect all</span>\n        </div>\n      </ng-template>\n\n      <ng-template ng-arrow-tmp>\n        <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex custom-dropdown-arrow\" [size]=\"'18'\"></sa-icon>\n      </ng-template>\n    </ng-select>\n    <div *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\" class=\"right-icon\">\n      <sa-icon [icon]=\"'downChevronOutlined'\" tabindex=\"0\" class=\"d-flex\" [size]=\"'18'\" (click)=\"openClose(!this.openState)\"\n        (blur)=\"openClose(false)\" ></sa-icon>\n    </div>\n    <!-- <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"right-icon svg-icon\" [style]=\"svgStyle\"\n      (click)=\"openClose(true)\" (blur)=\"openClose(false)\"\n      *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\">\n    </div> -->\n\n <div class=\"fallback-arrow\" *ngIf=\"!openState\">\n  <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex\" [size]=\"'18'\"></sa-icon>\n </div>\n  </div>\n  @if(!formControl.valid){\n  <div class=\"error-message-container\">\n    <span class=\"error-message\">\n      <formly-validation-message [field]=\"field\"></formly-validation-message>\n    </span>\n  </div>\n  }\n  <div class=\"support-label\">{{params.supportText}}</div>\n</div>"]}
321
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-select.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/form-select/form-select.component.ts","../../../../../projects/component-library/src/lib/form-select/form-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Output, ViewChild, ElementRef } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { FieldType, FieldTypeConfig } from '@ngx-formly/core';\nimport { NgSelectComponent, NgSelectModule } from '@ng-select/ng-select';\nimport { ChipsComponent } from '../chips/chips.component';\nimport { NgIf, NgFor } from '@angular/common';\nimport { IconComponent } from '../icon/icon.component';\nimport { CommonModule } from '@angular/common';\nimport { MatTooltip, MatTooltipModule } from '@angular/material/tooltip';\nimport { SelectInterface, SelectSubInterface } from '../../public-api';\n\n@Component({\n  selector: 'lib-form-select',\n  standalone: true,\n  imports: [\n    ReactiveFormsModule,\n    FormlyModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    ChipsComponent,\n    NgIf,\n    NgFor,\n    MatTooltipModule,\n    IconComponent,\n    CommonModule,\n    MatTooltipModule\n  ],\n  templateUrl: './form-select.component.html',\n  styleUrl: './form-select.component.css'\n})\nexport class FormSelectComponent extends FieldType<FieldTypeConfig> {\n  selectables: any;\n  params: any;\n\n  // Helper method to get full object from bound value\n  getFullObjectFromValue(value: any): any {\n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    if (!bindValue) return value;\n    \n    return this.selectables.find((item: any) => item[bindValue] === value) || value;\n  }\n\n  svgStyle = {};\n  openState: boolean = false;\n  topLabel: boolean;\n  startInd: number = 0;\n  labelLimit: number = 2;\n\n  placeholderLabel: string;\n  @Output('hoverEvent') hoverEvent: EventEmitter<selectHoverEvent> = new EventEmitter();\n  @ViewChild(NgSelectComponent) ngSelect!: NgSelectComponent;\n\n  constructor(private elementRef: ElementRef) {\n    super();\n  }\n  \n  ngOnInit() {\n    this.selectables = this.field.props.options;    \n    this.params = this.field.props['params'] || {};\n    \n    // Fallback to field.props if params is empty\n    if (!this.params || Object.keys(this.params).length === 0) {\n      this.params = this.field.props;\n    }\n    \n    \n    this.placeholderLabel = this.params.label || this.field.props.placeholder;\n    this.svgStyle = {\n      '-webkit-mask-image': `url(${this.params.dropIcon})})`,\n      'mask-image': `url(${this.params.dropIcon})`,\n    }\n    \n    // Set CSS custom property for chip background based on state\n    this.setChipBackgroundColor();\n  }\n\n  private setChipBackgroundColor(): void {\n    const state = this.params?.state;\n    let backgroundColor = 'var(--primary-50)'; // default fallback\n    \n    // Map chip states to appropriate background colors\n    switch(state) {\n      case 'neutral':\n        backgroundColor = 'var(--grey-50)';\n        break;\n      case 'success':\n        backgroundColor = 'var(--success-50)';\n        break;\n      case 'error':\n        backgroundColor = 'var(--error-50)';\n        break;\n      case 'warning':\n        backgroundColor = 'var(--warning-50)';\n        break;\n      case 'primary':\n      default:\n        backgroundColor = 'var(--primary-50)';\n        break;\n    }\n    \n    if (typeof document !== 'undefined' && this.elementRef?.nativeElement) {\n        this.elementRef.nativeElement.style.setProperty('--ng-select-chip-bg', backgroundColor);\n    }\n  }\n  openClose(state: boolean) {\n    if (this.field.props.disabled) return;\n    this.openState = state;\n    if (state || this.formControl.value?.length > 0) {\n      this.placeholderLabel = this.params.placeholder\n      } else {\n        this.placeholderLabel = this.params.label;\n    }\n  }\n  shiftLabel(action: string) {\n  if (action == 'clicked') this.startInd++;\n  if (action == 'cleared') this.startInd = 0;\n  if (action == 'removed' && this.startInd > 0) this.startInd--;\n  this.topLabel = this.formControl.value?.length > 0; \n  this.placeholderLabel = this.openState || this.formControl.value?.length > 0 \n    ? this.params.placeholder \n    : this.params.label;\n}\n\n  toggleOption(item: any, event: Event): void {\n    event.stopPropagation();\n    event.preventDefault();\n    \n    if (!this.params?.multiple) {\n      // Single select mode\n      this.formControl.setValue(item);\n      this.openState = false; \n      return;\n    }\n\n    // Multi-select mode\n    const currentValue = this.formControl.value || [];\n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    const itemValue = bindValue ? item[bindValue] : item;\n    \n    const index = currentValue.findIndex((selected: any) => {\n      const selectedValue = bindValue ? selected[bindValue] : selected;\n      return selectedValue === itemValue;\n    });\n\n    let newValue;\n    if (index > -1) {\n      newValue = [...currentValue];\n      newValue.splice(index, 1);\n    } else {\n      newValue = [...currentValue, item];\n    }\n    \n    this.formControl.setValue(newValue);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n    \n    this.checkForZero(newValue);\n    \n    this.formControl.updateValueAndValidity();\n  }\n\n\n  onNgSelectChange(selected: any): void {\n    // Only handle ng-select changes when NOT in checkbox mode\n    if (!this.params?.showCheckboxes) {\n      this.checkForZero(selected);\n    } else {\n      // In checkbox mode, prevent ng-select from changing the form control\n      // Restore the current value to prevent ng-select interference\n      const currentValue = this.formControl.value || [];\n      this.openState = true;\n      setTimeout(() => {\n        this.formControl.setValue(currentValue, { emitEvent: false });\n        this.openState = true;\n      }, 0);\n    }\n  }\n\n  selectAll(): void {\n    if (!this.params?.multiple) return;\n    \n    // Check if we have bindValue configured\n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    \n    let allValues;\n    if (bindValue) {\n      // If bindValue is configured, extract only the bound values\n      allValues = this.selectables.map((item: any) => item[bindValue]);\n    } else {\n      // If no bindValue, store full objects\n      allValues = [...this.selectables];\n    }\n    \n    this.formControl.setValue(allValues);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n    \n    this.checkForZero(allValues);\n    \n    this.formControl.updateValueAndValidity();\n    \n    // Ensure Formly integration\n    if (this.field && this.field.formControl) {\n      this.field.formControl.setValue(allValues);\n      this.field.formControl.updateValueAndValidity();\n    }\n  }\n\n  unselectAll(): void {\n    if (!this.params?.multiple) return;\n    \n    const emptyValue: any[] = [];\n    \n    this.formControl.setValue(emptyValue);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n    \n    this.checkForZero(emptyValue);\n    \n    this.formControl.updateValueAndValidity();\n    \n    if (this.field && this.field.formControl) {\n      this.field.formControl.setValue(emptyValue);\n      this.field.formControl.updateValueAndValidity();\n    }\n  }\n\n  isAllSelected(): boolean {\n    const currentValue = this.formControl.value || [];\n    return Array.isArray(currentValue) && \n           currentValue.length === this.selectables.length &&\n           this.selectables.every((item: any) => this.isOptionSelected(item));\n  }\n\n  isSomeSelected(): boolean {\n    const currentValue = this.formControl.value || [];\n    return Array.isArray(currentValue) && \n           currentValue.length > 0 && \n           currentValue.length < this.selectables.length;\n  }\n  toggleItemSelection(item: any, event: Event): void {\n    event.stopPropagation();\n    event.preventDefault();\n    \n    if (!this.params?.multiple) return;\n    \n    const currentValue = this.formControl.value || [];\n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    \n    let itemIndex = -1;\n    let itemValue = bindValue ? item[bindValue] : item;\n    \n    if (bindValue) {\n      // When using bindValue, currentValue should contain only the bound values\n      itemIndex = currentValue.findIndex((selected: any) => selected === itemValue);\n    } else {\n      // When not using bindValue, compare full objects\n      itemIndex = currentValue.findIndex((selected: any) => {\n        if (typeof selected === 'object' && typeof item === 'object') {\n          return JSON.stringify(selected) === JSON.stringify(item);\n        }\n        return selected === item;\n      });\n    }\n    \n    let newValue;\n    if (itemIndex > -1) {\n      // Remove the item\n      newValue = [...currentValue];\n      newValue.splice(itemIndex, 1);\n    } else {\n      // Add the item\n      if (bindValue) {\n        // Add only the bound value\n        newValue = [...currentValue, itemValue];\n      } else {\n        // Add the full object\n        newValue = [...currentValue, item];\n      }\n    }\n    \n    this.formControl.setValue(newValue);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n    \n    this.checkForZero(newValue);\n    \n    this.formControl.updateValueAndValidity();\n    \n    if (this.field && this.field.formControl) {\n      this.field.formControl.setValue(newValue);\n      this.field.formControl.updateValueAndValidity();\n    }\n    \n    // Force Angular change detection to update the UI\n    setTimeout(() => {\n      if (this.ngSelect && !this.ngSelect.isOpen) {\n        this.ngSelect.open();\n      }\n    }, 0);\n  }\n\n  isOptionSelected(item: any): boolean {\n    const currentValue = this.formControl.value || [];\n    if (!Array.isArray(currentValue)) return false;\n    \n    const bindValue = this.params?.bindValue || this.field.props?.['bindValue'];\n    \n    if (bindValue) {\n      // When using bindValue, currentValue contains only the bound values\n      const itemValue = item[bindValue];\n      return currentValue.includes(itemValue);\n    } else {\n      // When not using bindValue, compare full objects\n      return currentValue.some((selected: any) => {\n        if (typeof selected === 'object' && typeof item === 'object') {\n          return JSON.stringify(selected) === JSON.stringify(item);\n        }\n        return selected === item;\n      });\n    }\n  }\n\n  checkForZero(selected: any, state?: boolean) {\n    // Use the passed selected parameter if available, otherwise fall back to form control value\n    const valueToCheck = selected !== undefined ? selected : this.formControl.value;\n    \n    this.topLabel = valueToCheck?.length == 0 ? false : true;\n    // console.log(\"test\", this.formControl.value?.length)\n    // console.log(\"test\", this.openState)\n    // console.log(\"placeholder--- \", this.placeholderLabel)\n    // console.log(\"params.label--- \", this.params.label)\n    this.openState = state;\n    if (state || valueToCheck?.length > 0) {\n      this.placeholderLabel = this.params.placeholder;\n    } else {\n      this.placeholderLabel = this.params.label;\n    }\n  }\n  mouseHover(item: SelectSubInterface, event: any = null, tooltip: MatTooltip) {  // New method for mouseenter event\n    this.hoverEvent.emit({\n      event,\n      item\n    });\n    if (tooltip) {\n      tooltip.show();\n    }\n  }\n}\n\nexport interface selectHoverEvent {\n  event: any,\n  item: SelectSubInterface\n}","<div class=\"sa-select-container {{props?.['inputContainerClass']}}\">\n  @if(!!props?.['label']){\n  <div class=\"sa-select-label-container\">\n    <div class=\"sa-select-label-tooltip-container\">\n      <span class=\"sa-select-label\">\n        {{props?.['label']}}\n      </span>\n      @if(!!props?.['tooltip']){\n      <span class=\"tooltip-container\">\n        <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n          [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n          [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n      </span>\n      }\n    </div>\n    @if(!!props?.['description']) {\n    <p class=\"sa-select-description\">\n      {{props?.['description']}}\n    </p>\n    }\n  </div>\n  }\n  <div class=\"sa-select-field-container\">\n    <div [style.visibility]=\"(props?.['showTag'] !== false && (openState || topLabel)) ? 'visible' : 'hidden'\"\n      class=\"clicked-label\">{{params.label}}\n    </div>\n    <div\n      class=\"ng-select-field {{openState ? 'activated' : 'idle'}} {{field.props.disabled ? 'disabled' : ''}} {{formControl.valid ? '' : 'invalid'}}\">\n      <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"left-icon svg-icon\" [style]=\"svgStyle\"\n        (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\"\n        *ngIf=\"(params.dropIconPosition == 'left' || params.dropIconPosition == 'both')\">\n      </div>\n      <ng-select (change)=\"onNgSelectChange($event)\" (remove)=\"shiftLabel('removed')\" (clear)=\"shiftLabel('cleared')\"\n      (search)=\"openClose(true)\" (click)=\"openClose(!this.openState)\" (blur)=\"openClose(false)\" [isOpen]=\"openState\"\n      [placeholder]=\"placeholderLabel\" [bindLabel]=\"props?.['bindLabel'] || 'name'\" [bindValue]=\"props?.['bindValue'] || null\" [items]=\"selectables\" [multiple]=\"params?.multiple\"\n      [formControl]=\"formControl\" [style] [formlyAttributes]=\"field\" [searchable]=\"field.props['searchable']\" [clearable]=\"false\" [closeOnSelect]=\"!params?.showCheckboxes\" class=\"form-ng-select\">      \n      <!-- Multi-label template for displaying selected items as chips -->\n      <ng-template ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n        <div *ngFor=\"let item of (items ? items.slice(startInd,startInd+labelLimit): [])\">\n          <sa-chip (onClickEvent)=\" (!field.props.disabled) ?  clear(item) : null\" \n            [id]=\"getFullObjectFromValue(item)[params?.bindValue || props?.['bindValue'] || 'id']\"\n            [iconPath]=\"params.iconPath\" \n            [text]=\"getFullObjectFromValue(item)[params?.bindLabel || props?.['bindLabel'] || 'name']\" \n            [type]=\"params.type\"\n            [state]=\"field.props.disabled ? 'neutral' : params.state\" \n            [filling]=\"params.filling\"\n            [iconPosition]=\"params.iconPosition\">\n          </sa-chip>\n        </div>\n        <div (click)=\"shiftLabel('clicked')\" class=\"ng-value overflow-label\"\n          *ngIf=\"items.length > (startInd+labelLimit)\">\n          <sa-chip text=\"+{{items.length-(startInd+labelLimit)}}\" \n                   [type]=\"params.type || 'regular'\" \n                   [state]=\"params.state || 'primary'\" \n                   [filling]=\"params.filling || 'filled'\">\n          </sa-chip>\n        </div>\n        <div (click)=\"shiftLabel('cleared')\" *ngIf=\"startInd > 0\"\n          class=\"ng-value overflow-label\">\n          <sa-chip text=\"...\" \n                   [type]=\"params.type || 'regular'\" \n                   [state]=\"params.state || 'default'\" \n                   [filling]=\"params.filling || 'filled'\">\n          </sa-chip>\n        </div>\n      </ng-template>\n      \n      <!-- Universal option template with tooltip support for any select type -->\n      <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\n        <div class=\"option-container\" [ngClass]=\"{'checkbox-option': params?.showCheckboxes, 'single-option-with-tooltip': !params?.showCheckboxes}\">\n          <!-- Checkbox for multi-select -->\n          <input *ngIf=\"params?.showCheckboxes\" \n                 type=\"checkbox\" \n                 [checked]=\"isOptionSelected(item)\" \n                 (mousedown)=\"toggleItemSelection(item, $event)\"\n                 (click)=\"$event.stopPropagation(); $event.preventDefault()\"\n                 class=\"option-checkbox\">\n          \n          <!-- Option label -->\n          <span class=\"option-label\">{{ item[props?.['bindLabel'] || 'name'] }}</span>\n          \n          <!-- Tooltip icon - shows when item has description/tooltip -->\n          <sa-icon *ngIf=\"item.description || item.tooltip\" \n                   [icon]=\"'infoCircleOutlined'\" \n                   [size]=\"'16'\" \n                   class=\"option-tooltip-icon d-flex\"\n                   [matTooltip]=\"item.description || item.tooltip || ''\" \n                   matTooltipClass=\"custom-tooltip\"\n                   [matTooltipDisabled]=\"!(item.description || item.tooltip)\">\n          </sa-icon>\n        </div>\n      </ng-template>\n      \n      <!-- Simple header template for Select All / Unselect All when in checkbox mode -->\n      <ng-template ng-header-tmp *ngIf=\"params?.showCheckboxes && params?.multiple\">\n        <div class=\"select-all-header\">\n          <span class=\"select-all-label\" (click)=\"selectAll()\">Select all</span>\n          <span class=\"unselect-all-label\" (click)=\"unselectAll()\">Unselect all</span>\n        </div>\n      </ng-template>\n\n      <ng-template ng-arrow-tmp>\n        <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex custom-dropdown-arrow\" [size]=\"'18'\"></sa-icon>\n      </ng-template>\n    </ng-select>\n    <div *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\" class=\"right-icon\">\n      <sa-icon [icon]=\"'downChevronOutlined'\" tabindex=\"0\" class=\"d-flex\" [size]=\"'18'\" (click)=\"openClose(!this.openState)\"\n        (blur)=\"openClose(false)\" ></sa-icon>\n    </div>\n    <!-- <div role=\"button\" title=\"drop-button\" tabindex=\"0\" class=\"right-icon svg-icon\" [style]=\"svgStyle\"\n      (click)=\"openClose(true)\" (blur)=\"openClose(false)\"\n      *ngIf=\"(params.dropIconPosition == 'right' || params.dropIconPosition == 'both')\">\n    </div> -->\n\n <div class=\"fallback-arrow\" *ngIf=\"!openState\">\n  <sa-icon [icon]=\"'downChevronOutlined'\" class=\"d-flex\" [size]=\"'18'\"></sa-icon>\n </div>\n  </div>\n  @if(!formControl.valid){\n  <div class=\"error-message-container\">\n    <span class=\"error-message\">\n      <formly-validation-message [field]=\"field\"></formly-validation-message>\n    </span>\n  </div>\n  }\n  <div class=\"support-label\">{{params.supportText}}</div>\n</div>"]}