oasys-lib 2.2.0-rc.0 → 2.2.0-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/form/combobox/combobox.component.mjs +1 -1
- package/fesm2022/oasys-lib.mjs.map +1 -1
- package/lib/components/form/combobox/combobox.component.d.ts +1 -1
- package/lib/components/form/combobox/combobox.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/assets/bloomandwild/variables.css +1 -1
- package/src/assets/bloomon/variables.css +1 -1
- package/src/assets/global/scss-breakpoints.scss +1 -1
|
@@ -475,4 +475,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
475
475
|
type: HostListener,
|
|
476
476
|
args: ['document:click', ['$event.target']]
|
|
477
477
|
}] } });
|
|
478
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combobox.component.js","sourceRoot":"","sources":["../../../../../../../projects/oasys-lib/src/lib/components/form/combobox/combobox.component.ts","../../../../../../../projects/oasys-lib/src/lib/components/form/combobox/combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, NgClass } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  forwardRef,\n  ElementRef,\n  Inject,\n  AfterViewInit,\n  ViewChild,\n  QueryList,\n  ViewChildren,\n  OnChanges,\n  SimpleChanges,\n  HostListener,\n  signal,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  FormsModule,\n} from '@angular/forms';\nimport { ComboboxOption, ComboboxType } from './combobox';\nimport { LayoutStackComponent } from '../../layout/stack/stack.component';\nimport { LayoutBoxComponent } from '../../layout/box/box.component';\nimport { OasysAutofocusDirective } from '../../../directives/autofocus/autofocus.directive';\nimport { IconComponent } from '../../icon/icon.component';\nimport { EmphasisDirective } from '../../../directives/emphasis/emphasis.directive';\nimport { OasysButtonComponent } from '../../button';\n\n@Component({\n  selector: 'ui-combobox',\n  templateUrl: './combobox.component.html',\n  styleUrls: ['./combobox.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ComboboxComponent),\n      multi: true,\n    },\n  ],\n  standalone: true,\n  imports: [\n    LayoutStackComponent,\n    LayoutBoxComponent,\n    ReactiveFormsModule,\n    FormsModule,\n    NgClass,\n    OasysAutofocusDirective,\n    IconComponent,\n    EmphasisDirective,\n    OasysButtonComponent,\n  ],\n})\nexport class ComboboxComponent implements ControlValueAccessor, OnInit, AfterViewInit, OnChanges {\n  @Input() label!: string;\n  @Input() type: ComboboxType = 'options';\n  @Input() options: ComboboxOption[] = [];\n  @Input() optional = true;\n\n  @Input({ required: false }) hint?: string;\n  @Input({ required: false }) header?: string;\n  @Input({ required: false }) footer?: string;\n  @Input({ required: false }) autofocus = false;\n  @Input({ required: false }) disabled = false;\n  @Input({ required: false }) selected?: ComboboxOption;\n  // Key value from options to be displayed as option label\n  @Input({ required: false }) displayKey?: string;\n  // Key value from options to be used as icon in option label\n  @Input({ required: false }) iconNameKey?: string;\n  // Key value from options be be value\n  @Input({ required: false }) valueKey?: string;\n  // Available for Autocomplete\n  @Input({ required: false }) subtextKey?: string;\n  @Input({ required: false }) placeholder?: string;\n  // Will open the list of options on init\n  @Input({ required: false }) showOptions = false;\n\n  @Output() didChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n  @Output() didSearch: EventEmitter<unknown> = new EventEmitter<unknown>();\n  @Output() didEdit: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  textValue = '';\n  inputDidChange = false; // only show valdiation after a change event (ie. blur)\n  displayOptions: ComboboxOption[] = [];\n  private _selectedOption: ComboboxOption | unknown;\n  private _focusedOption: ComboboxOption | unknown;\n  private _focusedOptionId: number;\n  private _panelOpen = false;\n\n  id!: string;\n\n  /** Whether or not the overlay panel is open. */\n  panelOpen = signal(this._panelOpen);\n\n  /**\n   * Selected option\n   */\n  get selectedOption(): ComboboxOption | unknown {\n    return this._selectedOption || null;\n  }\n\n  /**\n   * Focused Option\n   */\n  get focusedOption(): ComboboxOption | unknown {\n    return this._focusedOption || null;\n  }\n\n  /**\n   * Return the id of the focused option\n   */\n  get focusedId(): number {\n    return this._focusedOptionId;\n  }\n\n  get valueOptionKey(): string {\n    return this.valueKey ? this.valueKey : 'value';\n  }\n\n  get displayOptionKey(): string {\n    return this.displayKey ? this.displayKey : 'label';\n  }\n\n  get subtextOptionKey(): string {\n    return this.subtextKey ? this.subtextKey : 'subtext';\n  }\n\n  @ViewChild('textinput', { read: ElementRef })\n  textInput: ElementRef<HTMLElement>;\n\n  @ViewChild('combobox', { read: ElementRef })\n  combobox: ElementRef<HTMLElement>;\n\n  @ViewChildren('option') optionsList: QueryList<ElementRef<HTMLElement>>;\n\n  constructor(@Inject(DOCUMENT) private document: Document) {}\n\n  onChange: any = () => {};\n  onTouched: any = () => {};\n\n  @HostListener('document:click', ['$event.target'])\n\n  /**\n   * Click outside combobox close the panel\n   */\n  public onClick(targetElement: Node): void {\n    if (this.panelOpen()) {\n      const clickedInside = this.combobox.nativeElement.contains(targetElement);\n      if (!clickedInside) {\n        this.closePanel();\n      }\n    }\n  }\n\n  /**\n   * On Change\n   * @param changes\n   */\n  ngOnChanges(changes: SimpleChanges): void {\n    // Detects if the autocomplete options list is chnaged after a selection of an option.\n    // Example: Address search can have options assigned to a group of options. One postcode to have x number of addreses\n    // If Options list is Changed as part of group option we let the options panel open to let user select a single option. This is considered as change input value(similar with type value)\n    if (this.type === 'autocomplete' && changes['options']) {\n      const optionchanges = changes['options'];\n      if (!this.options) {\n        this.closePanel();\n      }\n      if (\n        optionchanges['currentValue'] !== optionchanges['previousValue'] &&\n        this.options?.length !== 0 &&\n        !optionchanges['firstChange']\n      ) {\n        this.resetOptionsList();\n        this.openPanel();\n      }\n    }\n  }\n\n  /**\n   * On Init\n   */\n  ngOnInit(): void {\n    this.id = this.label + Math.random();\n    this.resetSelection();\n    this.resetOptionsList();\n\n    if (this.selected) {\n      const selectedIndex = this.options.findIndex(\n        (option: ComboboxOption | unknown) =>\n          option[this.valueOptionKey] === this.selected[this.valueOptionKey],\n      );\n      this.selectOption(this.options[selectedIndex], selectedIndex);\n    }\n    if (this.showOptions) {\n      this.openPanel();\n    }\n  }\n\n  /**\n   * After View Init\n   */\n  ngAfterViewInit(): void {\n    this.setupValidationListener();\n  }\n\n  /**\n   * Select Option\n   * @param option\n   */\n  public selectOption(option: ComboboxOption | unknown, index?: number) {\n    this._selectedOption = option;\n    this._focusedOptionId = index;\n    this._focusedOption = option;\n    this.textValue = this._selectedOption[this.displayOptionKey];\n\n    this.onChange(this.textValue);\n    this.didChange.emit(this.selectedOption);\n    this.onTouched();\n    this.closePanel();\n  }\n\n  /**\n   * On Key Navigation\n   * @param event\n   */\n  public onKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Enter':\n        if (this.panelOpen()) {\n          this.pressEnter();\n        } else {\n          this.openPanel(event);\n        }\n        break;\n      case 'Tab':\n        if (this.panelOpen()) {\n          this.closePanel();\n        }\n        break;\n      case 'Escape':\n        if (this.panelOpen()) {\n          this.closePanel();\n        }\n        break;\n    }\n\n    // Logic for open panel\n    if (this.panelOpen()) {\n      this.pressArrows(event);\n      this.optionsList.get(this._focusedOptionId)?.nativeElement.focus();\n    }\n  }\n\n  /**\n   * Toggle Options Panel\n   */\n  togglePanel(): void {\n    this._panelOpen = !this._panelOpen;\n    this.panelOpen.set(this._panelOpen);\n    this.initSelectedFocus();\n  }\n\n  /**\n   * Clase Options Panel\n   */\n  openPanel(event?: Event): void {\n    event?.preventDefault();\n    if (!this._panelOpen) {\n      this._panelOpen = true;\n      this.panelOpen.set(this._panelOpen);\n      this.initSelectedFocus();\n    }\n  }\n\n  /**\n   * Close Options Panel\n   */\n  closePanel(): void {\n    this._panelOpen = false;\n    this.panelOpen.set(this._panelOpen);\n    this.initSelectedFocus();\n  }\n\n  /**\n   * Get Input display value\n   * @param textValue\n   */\n  writeValue(textValue: string): void {\n    if ((this.selected && typeof textValue !== 'string') || textValue === '') {\n      this.textValue = this._selectedOption[this.displayOptionKey];\n    } else {\n      this.textValue = textValue;\n    }\n  }\n\n  /**\n   * Register Form input chnage\n   * @param fn\n   */\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  /**\n   * Register form input touch\n   * @param fn\n   */\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  /**\n   * On Model Change\n   * @param textValue\n   */\n  onModelChange(textValue: string): void {\n    this.textValue = textValue;\n    this.inputDidChange = true;\n    this.onChange(textValue);\n    this.onTouched();\n    this.didChange.emit(this.selectedOption);\n  }\n\n  /**\n   * On Model Change\n   * @param textValue\n   */\n  onModelChangeAutocomplete(textValue: string): void {\n    this.textValue = textValue;\n    this.inputDidChange = true;\n    this.onChange(textValue);\n    this.onTouched();\n    this.didChange.emit(this.selectedOption);\n\n    this.onAutocompleteListSearch(textValue);\n  }\n\n  /**\n   * Event handling for Input value\n   */\n  handleEvent(): void {\n    this.inputDidChange = true;\n\n    const inputElement = this.document.getElementById(this.id.toString());\n    inputElement?.removeEventListener('change', this);\n  }\n\n  /**\n   * Clean Input\n   */\n  cleanInput(): void {\n    this.textValue = '';\n    this.resetSelection();\n    this.resetOptionsList();\n    this.closePanel();\n    this.didSearch.emit(this.textValue);\n  }\n\n  /**\n   * On footer action\n   */\n  onFooterAction(): void {\n    this.didEdit.emit();\n  }\n\n  /**\n   * On Focus Input\n   */\n  onFocusInput(): void {\n    this.textInput.nativeElement.focus();\n  }\n\n  /**\n   * Search in Autocomplete\n   * @param textValue\n   */\n  private onAutocompleteListSearch(textValue: string): void {\n    if (!textValue) {\n      this.closePanel();\n      this.resetSelection();\n    } else {\n      this.openPanel();\n      this.displayOptions = this.options.filter((option: ComboboxOption<unknown>) => {\n        return (\n          this.checkIncludesSubstring(option, this.displayOptionKey) ||\n          this.checkIncludesSubstring(option, this.subtextOptionKey)\n        );\n      });\n      if (this.displayOptions.length === 0) {\n        this.closePanel();\n      }\n    }\n    this.textInput.nativeElement.focus();\n    this.didSearch.emit(this.textValue);\n  }\n\n  /**\n   * Check a susbcring is included in option value\n   * @param option\n   * @returns\n   */\n  private checkIncludesSubstring(option: ComboboxOption<unknown>, key: string): unknown {\n    return option[key]?.toString().toLowerCase().includes(this.textValue.toLowerCase());\n  }\n\n  /**\n   * Set Input Validators\n   */\n  private setupValidationListener(): void {\n    const inputElement = this.document.getElementById(this.id.toString());\n    inputElement?.addEventListener('change', this);\n  }\n\n  /**\n   * Init focus mode or set the selected option as focused\n   */\n  private initSelectedFocus(): void {\n    if (this._panelOpen) {\n      if (this._selectedOption) {\n        this._focusedOption = this._selectedOption;\n      } else {\n        this._focusedOptionId = 0;\n        this._focusedOption = this.options[this._focusedOptionId];\n      }\n    }\n  }\n\n  /**\n   * Arrows Up/Down navigation inside Options Panel\n   */\n  private pressArrows(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'ArrowDown':\n        this._focusedOptionId = Math.min(this._focusedOptionId + 1, this.displayOptions.length - 1);\n        this._focusedOption = this.displayOptions[this._focusedOptionId];\n        this.autocompleteOptionTextPreview();\n        break;\n      case 'ArrowUp':\n        this._focusedOptionId = Math.max(this._focusedOptionId - 1, 0);\n        this._focusedOption = this.displayOptions[this._focusedOptionId];\n\n        this.autocompleteOptionTextPreview();\n        break;\n    }\n  }\n\n  /**\n   * Change textValue to preview the option in autocomplete\n   */\n  private autocompleteOptionTextPreview(): void {\n    if (this.type === 'autocomplete') {\n      this.textValue = this._focusedOption[this.displayOptionKey];\n    }\n  }\n\n  /**\n   * Press Enter inside Options Panel\n   */\n  private pressEnter(): void {\n    if (\n      this.panelOpen() &&\n      this._focusedOptionId < this.displayOptions.length &&\n      this._focusedOptionId >= 0\n    ) {\n      this.selectOption(this.displayOptions[this._focusedOptionId], this._focusedOptionId);\n    }\n  }\n\n  /**\n   * Reset selected option\n   */\n  private resetSelection(): void {\n    this._selectedOption = null;\n    this._focusedOption = null;\n    this._focusedOptionId = 0;\n  }\n\n  /**\n   * Reset to original or unfiltered option list\n   */\n  private resetOptionsList(): void {\n    this.displayOptions = this.options;\n  }\n}\n","<ui-stack class=\"ui-combobox-container\" stack_gap=\"tight\">\n  <div class=\"ui-combobox text-body--default text-body--regular\">\n    <!-- Compbobox Options Input -->\n    @if (type === 'options') {\n      <div\n        #combobox\n        name=\"combobox\"\n        tabindex=\"0\"\n        (keydown)=\"onKeyDown($event)\"\n        (mousedown)=\"togglePanel()\"\n        role=\"combobox\"\n        id=\"activedescendent-edit\"\n        [attr.aria-label]=\"label\"\n        [attr.aria-activedescendant]=\"'activedescendent-opt-' + focusedId\"\n        aria-readonly=\"true\"\n        aria-owns=\"activedescendent-list\"\n        aria-autocomplete=\"list\"\n      >\n        <ui-stack\n          stack_direction=\"x\"\n          stack_distribute=\"space-between\"\n          stack_align=\"center\"\n          stack_gap=\"tight\"\n        >\n          <ui-box box_space=\"none\" box_background=\"transparent\">\n            <!-- Select Label Area -->\n            <div class=\"label-container\" stack_direction=\"x\">\n              <label\n                class=\"text-body--supporting text-body--regular\"\n                role=\"combobox-label\"\n                [for]=\"id\"\n                >{{ label }}</label\n              >\n            </div>\n            <input\n              #textinput\n              [id]=\"id\"\n              [name]=\"id\"\n              [ngModel]=\"textValue\"\n              (ngModelChange)=\"onModelChange($event)\"\n              (blur)=\"onModelChange(textValue)\"\n              [ngClass]=\"inputDidChange ? 'ng-input-did-change' : 'ng-input-did-not-change'\"\n              [attr.autocorrect]=\"'on'\"\n              [attr.disabled]=\"disabled || null\"\n              [autofocus]=\"autofocus\"\n              [autocomplete]=\"'on'\"\n              [required]=\"!optional\"\n              [spellcheck]=\"'on'\"\n              [type]=\"'text'\"\n              [value]=\"selectedOption\"\n              [placeholder]=\"placeholder || ''\"\n              readonly=\"readonly\"\n              class=\"text-body--default text-body--regular\"\n            />\n          </ui-box>\n          <!-- Select Icon Chevron Area -->\n          <div class=\"icon-container\" [ngClass]=\"{ expand: panelOpen() }\">\n            <ui-icon icon_name=\"chevron-down\"></ui-icon>\n          </div>\n        </ui-stack>\n      </div>\n    }\n    <!-- Combobox Autocomplete Input -->\n    @if (type === 'autocomplete') {\n      <div\n        #combobox\n        name=\"combobox\"\n        tabindex=\"0\"\n        (keydown)=\"onKeyDown($event)\"\n        (focus)=\"onFocusInput()\"\n        role=\"combobox\"\n        id=\"activedescendent-edit\"\n        [attr.aria-label]=\"label\"\n        [attr.aria-activedescendant]=\"'activedescendent-opt-' + focusedId\"\n        aria-readonly=\"true\"\n        aria-owns=\"activedescendent-list\"\n        aria-autocomplete=\"list\"\n      >\n        <ui-stack\n          stack_direction=\"x\"\n          stack_distribute=\"space-between\"\n          stack_align=\"center\"\n          stack_gap=\"tight\"\n        >\n          <ui-box box_space=\"none\" box_background=\"transparent\">\n            <!-- Select Label Area -->\n            <div class=\"label-container\" stack_direction=\"x\">\n              <label\n                class=\"text-body--supporting text-body--regular\"\n                role=\"combobox-label\"\n                [for]=\"id\"\n                >{{ label }}</label\n              >\n            </div>\n            <input\n              #textinput\n              [id]=\"id\"\n              [name]=\"id\"\n              [ngModel]=\"textValue\"\n              (ngModelChange)=\"onModelChangeAutocomplete($event)\"\n              [ngClass]=\"inputDidChange ? 'ng-input-did-change' : 'ng-input-did-not-change'\"\n              [attr.autocorrect]=\"'on'\"\n              [attr.disabled]=\"disabled || null\"\n              [autofocus]=\"autofocus\"\n              [autocomplete]=\"'list'\"\n              [required]=\"!optional\"\n              [spellcheck]=\"'on'\"\n              [type]=\"'text'\"\n              [value]=\"textValue\"\n              [placeholder]=\"placeholder || ''\"\n              role=\"combobox\"\n              class=\"text-body--default text-body--regular\"\n            />\n          </ui-box>\n\n          <!-- Combobox Icon Clear Area -->\n          <div class=\"icon-container\" [attr.aria-label]=\"'clean'\" (click)=\"cleanInput()\">\n            @if (textValue) {\n              <ui-icon icon_name=\"close\"></ui-icon>\n            }\n          </div>\n        </ui-stack>\n      </div>\n    }\n    <!-- Combobox Options Panel -->\n    @if (panelOpen()) {\n      <div\n        class=\"ui-combobox-options\"\n        [ngClass]=\"{ expand: panelOpen() }\"\n        [attr.aria-expanded]=\"panelOpen()\"\n        role=\"listbox\"\n        id=\"activedescendent-list\"\n      >\n        <!-- Autocomplete Options Panel Header  -->\n        @if (header && type === 'autocomplete') {\n          <div class=\"ui-combobox-header text-body--supporting\">\n            <span>{{ header }}</span>\n          </div>\n        }\n\n        <!-- Options list -->\n        @for (option of displayOptions; track option; let i = $index) {\n          <div\n            #option\n            class=\"ui-combobox-option\"\n            [ngClass]=\"{\n              selected: selectedOption === option,\n              focus: focusedOption === option,\n            }\"\n            (click)=\"selectOption(option, i)\"\n            (keydown)=\"onKeyDown($event)\"\n            [id]=\"'activedescendent-opt-' + i\"\n            [attr.aria-label]=\"\n              selectedOption === option\n                ? option[displayOptionKey] + ' is selected'\n                : option[displayOptionKey]\n            \"\n          >\n            <ui-stack\n              stack_direction=\"x\"\n              stack_distribute=\"space-between\"\n              stack_align=\"center\"\n              stack_gap=\"tight\"\n            >\n              <!-- Option display -->\n              <div\n                [attr.value]=\"valueKey ? option[valueKey] : option.value\"\n                [attr.ngValue]=\"displayKey ? option[displayKey] : option.label\"\n              >\n                <ui-stack stack_direction=\"x\" stack_align=\"center\" stack_gap=\"tight\">\n                  @if (option.icon_name || (iconNameKey && option[iconNameKey])) {\n                    <ui-icon\n                      [icon_name]=\"iconNameKey ? option[iconNameKey] : option.icon_name\"\n                    ></ui-icon>\n                  }\n                  <!-- Display options label -->\n                  @if (type === 'options') {\n                    <span>{{ option[displayOptionKey] }}</span>\n                  }\n\n                  <!-- Display autocomplete option information and emphasis-->\n                  @if (type === 'autocomplete') {\n                    <ui-stack stack_gap=\"tiny\">\n                      <span\n                        ui-emphasis\n                        [searchText]=\"textValue\"\n                        [displayParagraph]=\"option[displayOptionKey]\"\n                      >\n                      </span>\n                      <p class=\"foreground-secondary-text\">\n                        {{ option[subtextOptionKey] }}\n                      </p>\n                    </ui-stack>\n                  }\n                </ui-stack>\n              </div>\n\n              <!-- Selected icon -->\n              @if (selectedOption === option) {\n                <ui-icon icon_name=\"tick\"></ui-icon>\n              }\n            </ui-stack>\n          </div>\n        }\n        <!-- Autocomplete Options Panel Footer -->\n        @if (footer && type === 'autocomplete') {\n          <div class=\"ui-combobox-footer\">\n            <ui-button button_type=\"tertiary\" (click)=\"onFooterAction()\">\n              {{ footer }}\n            </ui-button>\n          </div>\n        }\n      </div>\n    }\n  </div>\n  <ui-stack stack_gap=\"none\">\n    <div class=\"input-errors\">\n      <div class=\"input-errors-content\">\n        <ng-content select=\"ui-form-errors\"></ng-content>\n      </div>\n    </div>\n    @if (hint) {\n      <ui-box\n        class=\"hint-container\"\n        box_background=\"transparent\"\n        box_space=\"none\"\n        box_space_left=\"near\"\n        box_space_right=\"near\"\n        box_space_bottom=\"near\"\n      >\n        <div class=\"ui-text-input-hint text-body--supporting text-color--supporting\">\n          {{ hint }}\n        </div>\n      </ui-box>\n    }\n  </ui-stack>\n</ui-stack>\n"]}
|
|
478
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combobox.component.js","sourceRoot":"","sources":["../../../../../../../projects/oasys-lib/src/lib/components/form/combobox/combobox.component.ts","../../../../../../../projects/oasys-lib/src/lib/components/form/combobox/combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, NgClass } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  forwardRef,\n  ElementRef,\n  Inject,\n  AfterViewInit,\n  ViewChild,\n  QueryList,\n  ViewChildren,\n  OnChanges,\n  SimpleChanges,\n  HostListener,\n  signal,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  FormsModule,\n} from '@angular/forms';\nimport { ComboboxOption, ComboboxType } from './combobox';\nimport { LayoutStackComponent } from '../../layout/stack/stack.component';\nimport { LayoutBoxComponent } from '../../layout/box/box.component';\nimport { OasysAutofocusDirective } from '../../../directives/autofocus/autofocus.directive';\nimport { IconComponent } from '../../icon/icon.component';\nimport { EmphasisDirective } from '../../../directives/emphasis/emphasis.directive';\nimport { OasysButtonComponent } from '../../button';\n\n@Component({\n  selector: 'ui-combobox',\n  templateUrl: './combobox.component.html',\n  styleUrls: ['./combobox.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ComboboxComponent),\n      multi: true,\n    },\n  ],\n  standalone: true,\n  imports: [\n    LayoutStackComponent,\n    LayoutBoxComponent,\n    ReactiveFormsModule,\n    FormsModule,\n    NgClass,\n    OasysAutofocusDirective,\n    IconComponent,\n    EmphasisDirective,\n    OasysButtonComponent,\n  ],\n})\nexport class ComboboxComponent implements ControlValueAccessor, OnInit, AfterViewInit, OnChanges {\n  @Input() label!: string;\n  @Input() type: ComboboxType = 'options';\n  @Input() options: ComboboxOption[] = [];\n  @Input() optional = true;\n\n  @Input({ required: false }) hint?: string;\n  @Input({ required: false }) header?: string;\n  @Input({ required: false }) footer?: string;\n  @Input({ required: false }) autofocus = false;\n  @Input({ required: false }) disabled = false;\n  @Input({ required: false }) selected?: ComboboxOption | unknown;\n  // Key value from options to be displayed as option label\n  @Input({ required: false }) displayKey?: string;\n  // Key value from options to be used as icon in option label\n  @Input({ required: false }) iconNameKey?: string;\n  // Key value from options be be value\n  @Input({ required: false }) valueKey?: string;\n  // Available for Autocomplete\n  @Input({ required: false }) subtextKey?: string;\n  @Input({ required: false }) placeholder?: string;\n  // Will open the list of options on init\n  @Input({ required: false }) showOptions = false;\n\n  @Output() didChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n  @Output() didSearch: EventEmitter<unknown> = new EventEmitter<unknown>();\n  @Output() didEdit: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  textValue = '';\n  inputDidChange = false; // only show valdiation after a change event (ie. blur)\n  displayOptions: ComboboxOption[] = [];\n  private _selectedOption: ComboboxOption | unknown;\n  private _focusedOption: ComboboxOption | unknown;\n  private _focusedOptionId: number;\n  private _panelOpen = false;\n\n  id!: string;\n\n  /** Whether or not the overlay panel is open. */\n  panelOpen = signal(this._panelOpen);\n\n  /**\n   * Selected option\n   */\n  get selectedOption(): ComboboxOption | unknown {\n    return this._selectedOption || null;\n  }\n\n  /**\n   * Focused Option\n   */\n  get focusedOption(): ComboboxOption | unknown {\n    return this._focusedOption || null;\n  }\n\n  /**\n   * Return the id of the focused option\n   */\n  get focusedId(): number {\n    return this._focusedOptionId;\n  }\n\n  get valueOptionKey(): string {\n    return this.valueKey ? this.valueKey : 'value';\n  }\n\n  get displayOptionKey(): string {\n    return this.displayKey ? this.displayKey : 'label';\n  }\n\n  get subtextOptionKey(): string {\n    return this.subtextKey ? this.subtextKey : 'subtext';\n  }\n\n  @ViewChild('textinput', { read: ElementRef })\n  textInput: ElementRef<HTMLElement>;\n\n  @ViewChild('combobox', { read: ElementRef })\n  combobox: ElementRef<HTMLElement>;\n\n  @ViewChildren('option') optionsList: QueryList<ElementRef<HTMLElement>>;\n\n  constructor(@Inject(DOCUMENT) private document: Document) {}\n\n  onChange: any = () => {};\n  onTouched: any = () => {};\n\n  @HostListener('document:click', ['$event.target'])\n\n  /**\n   * Click outside combobox close the panel\n   */\n  public onClick(targetElement: Node): void {\n    if (this.panelOpen()) {\n      const clickedInside = this.combobox.nativeElement.contains(targetElement);\n      if (!clickedInside) {\n        this.closePanel();\n      }\n    }\n  }\n\n  /**\n   * On Change\n   * @param changes\n   */\n  ngOnChanges(changes: SimpleChanges): void {\n    // Detects if the autocomplete options list is chnaged after a selection of an option.\n    // Example: Address search can have options assigned to a group of options. One postcode to have x number of addreses\n    // If Options list is Changed as part of group option we let the options panel open to let user select a single option. This is considered as change input value(similar with type value)\n    if (this.type === 'autocomplete' && changes['options']) {\n      const optionchanges = changes['options'];\n      if (!this.options) {\n        this.closePanel();\n      }\n      if (\n        optionchanges['currentValue'] !== optionchanges['previousValue'] &&\n        this.options?.length !== 0 &&\n        !optionchanges['firstChange']\n      ) {\n        this.resetOptionsList();\n        this.openPanel();\n      }\n    }\n  }\n\n  /**\n   * On Init\n   */\n  ngOnInit(): void {\n    this.id = this.label + Math.random();\n    this.resetSelection();\n    this.resetOptionsList();\n\n    if (this.selected) {\n      const selectedIndex = this.options.findIndex(\n        (option: ComboboxOption | unknown) =>\n          option[this.valueOptionKey] === this.selected[this.valueOptionKey],\n      );\n      this.selectOption(this.options[selectedIndex], selectedIndex);\n    }\n    if (this.showOptions) {\n      this.openPanel();\n    }\n  }\n\n  /**\n   * After View Init\n   */\n  ngAfterViewInit(): void {\n    this.setupValidationListener();\n  }\n\n  /**\n   * Select Option\n   * @param option\n   */\n  public selectOption(option: ComboboxOption | unknown, index?: number) {\n    this._selectedOption = option;\n    this._focusedOptionId = index;\n    this._focusedOption = option;\n    this.textValue = this._selectedOption[this.displayOptionKey];\n\n    this.onChange(this.textValue);\n    this.didChange.emit(this.selectedOption);\n    this.onTouched();\n    this.closePanel();\n  }\n\n  /**\n   * On Key Navigation\n   * @param event\n   */\n  public onKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Enter':\n        if (this.panelOpen()) {\n          this.pressEnter();\n        } else {\n          this.openPanel(event);\n        }\n        break;\n      case 'Tab':\n        if (this.panelOpen()) {\n          this.closePanel();\n        }\n        break;\n      case 'Escape':\n        if (this.panelOpen()) {\n          this.closePanel();\n        }\n        break;\n    }\n\n    // Logic for open panel\n    if (this.panelOpen()) {\n      this.pressArrows(event);\n      this.optionsList.get(this._focusedOptionId)?.nativeElement.focus();\n    }\n  }\n\n  /**\n   * Toggle Options Panel\n   */\n  togglePanel(): void {\n    this._panelOpen = !this._panelOpen;\n    this.panelOpen.set(this._panelOpen);\n    this.initSelectedFocus();\n  }\n\n  /**\n   * Clase Options Panel\n   */\n  openPanel(event?: Event): void {\n    event?.preventDefault();\n    if (!this._panelOpen) {\n      this._panelOpen = true;\n      this.panelOpen.set(this._panelOpen);\n      this.initSelectedFocus();\n    }\n  }\n\n  /**\n   * Close Options Panel\n   */\n  closePanel(): void {\n    this._panelOpen = false;\n    this.panelOpen.set(this._panelOpen);\n    this.initSelectedFocus();\n  }\n\n  /**\n   * Get Input display value\n   * @param textValue\n   */\n  writeValue(textValue: string): void {\n    if ((this.selected && typeof textValue !== 'string') || textValue === '') {\n      this.textValue = this._selectedOption[this.displayOptionKey];\n    } else {\n      this.textValue = textValue;\n    }\n  }\n\n  /**\n   * Register Form input chnage\n   * @param fn\n   */\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  /**\n   * Register form input touch\n   * @param fn\n   */\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  /**\n   * On Model Change\n   * @param textValue\n   */\n  onModelChange(textValue: string): void {\n    this.textValue = textValue;\n    this.inputDidChange = true;\n    this.onChange(textValue);\n    this.onTouched();\n    this.didChange.emit(this.selectedOption);\n  }\n\n  /**\n   * On Model Change\n   * @param textValue\n   */\n  onModelChangeAutocomplete(textValue: string): void {\n    this.textValue = textValue;\n    this.inputDidChange = true;\n    this.onChange(textValue);\n    this.onTouched();\n    this.didChange.emit(this.selectedOption);\n\n    this.onAutocompleteListSearch(textValue);\n  }\n\n  /**\n   * Event handling for Input value\n   */\n  handleEvent(): void {\n    this.inputDidChange = true;\n\n    const inputElement = this.document.getElementById(this.id.toString());\n    inputElement?.removeEventListener('change', this);\n  }\n\n  /**\n   * Clean Input\n   */\n  cleanInput(): void {\n    this.textValue = '';\n    this.resetSelection();\n    this.resetOptionsList();\n    this.closePanel();\n    this.didSearch.emit(this.textValue);\n  }\n\n  /**\n   * On footer action\n   */\n  onFooterAction(): void {\n    this.didEdit.emit();\n  }\n\n  /**\n   * On Focus Input\n   */\n  onFocusInput(): void {\n    this.textInput.nativeElement.focus();\n  }\n\n  /**\n   * Search in Autocomplete\n   * @param textValue\n   */\n  private onAutocompleteListSearch(textValue: string): void {\n    if (!textValue) {\n      this.closePanel();\n      this.resetSelection();\n    } else {\n      this.openPanel();\n      this.displayOptions = this.options.filter((option: ComboboxOption<unknown>) => {\n        return (\n          this.checkIncludesSubstring(option, this.displayOptionKey) ||\n          this.checkIncludesSubstring(option, this.subtextOptionKey)\n        );\n      });\n      if (this.displayOptions.length === 0) {\n        this.closePanel();\n      }\n    }\n    this.textInput.nativeElement.focus();\n    this.didSearch.emit(this.textValue);\n  }\n\n  /**\n   * Check a susbcring is included in option value\n   * @param option\n   * @returns\n   */\n  private checkIncludesSubstring(option: ComboboxOption<unknown>, key: string): unknown {\n    return option[key]?.toString().toLowerCase().includes(this.textValue.toLowerCase());\n  }\n\n  /**\n   * Set Input Validators\n   */\n  private setupValidationListener(): void {\n    const inputElement = this.document.getElementById(this.id.toString());\n    inputElement?.addEventListener('change', this);\n  }\n\n  /**\n   * Init focus mode or set the selected option as focused\n   */\n  private initSelectedFocus(): void {\n    if (this._panelOpen) {\n      if (this._selectedOption) {\n        this._focusedOption = this._selectedOption;\n      } else {\n        this._focusedOptionId = 0;\n        this._focusedOption = this.options[this._focusedOptionId];\n      }\n    }\n  }\n\n  /**\n   * Arrows Up/Down navigation inside Options Panel\n   */\n  private pressArrows(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'ArrowDown':\n        this._focusedOptionId = Math.min(this._focusedOptionId + 1, this.displayOptions.length - 1);\n        this._focusedOption = this.displayOptions[this._focusedOptionId];\n        this.autocompleteOptionTextPreview();\n        break;\n      case 'ArrowUp':\n        this._focusedOptionId = Math.max(this._focusedOptionId - 1, 0);\n        this._focusedOption = this.displayOptions[this._focusedOptionId];\n\n        this.autocompleteOptionTextPreview();\n        break;\n    }\n  }\n\n  /**\n   * Change textValue to preview the option in autocomplete\n   */\n  private autocompleteOptionTextPreview(): void {\n    if (this.type === 'autocomplete') {\n      this.textValue = this._focusedOption[this.displayOptionKey];\n    }\n  }\n\n  /**\n   * Press Enter inside Options Panel\n   */\n  private pressEnter(): void {\n    if (\n      this.panelOpen() &&\n      this._focusedOptionId < this.displayOptions.length &&\n      this._focusedOptionId >= 0\n    ) {\n      this.selectOption(this.displayOptions[this._focusedOptionId], this._focusedOptionId);\n    }\n  }\n\n  /**\n   * Reset selected option\n   */\n  private resetSelection(): void {\n    this._selectedOption = null;\n    this._focusedOption = null;\n    this._focusedOptionId = 0;\n  }\n\n  /**\n   * Reset to original or unfiltered option list\n   */\n  private resetOptionsList(): void {\n    this.displayOptions = this.options;\n  }\n}\n","<ui-stack class=\"ui-combobox-container\" stack_gap=\"tight\">\n  <div class=\"ui-combobox text-body--default text-body--regular\">\n    <!-- Compbobox Options Input -->\n    @if (type === 'options') {\n      <div\n        #combobox\n        name=\"combobox\"\n        tabindex=\"0\"\n        (keydown)=\"onKeyDown($event)\"\n        (mousedown)=\"togglePanel()\"\n        role=\"combobox\"\n        id=\"activedescendent-edit\"\n        [attr.aria-label]=\"label\"\n        [attr.aria-activedescendant]=\"'activedescendent-opt-' + focusedId\"\n        aria-readonly=\"true\"\n        aria-owns=\"activedescendent-list\"\n        aria-autocomplete=\"list\"\n      >\n        <ui-stack\n          stack_direction=\"x\"\n          stack_distribute=\"space-between\"\n          stack_align=\"center\"\n          stack_gap=\"tight\"\n        >\n          <ui-box box_space=\"none\" box_background=\"transparent\">\n            <!-- Select Label Area -->\n            <div class=\"label-container\" stack_direction=\"x\">\n              <label\n                class=\"text-body--supporting text-body--regular\"\n                role=\"combobox-label\"\n                [for]=\"id\"\n                >{{ label }}</label\n              >\n            </div>\n            <input\n              #textinput\n              [id]=\"id\"\n              [name]=\"id\"\n              [ngModel]=\"textValue\"\n              (ngModelChange)=\"onModelChange($event)\"\n              (blur)=\"onModelChange(textValue)\"\n              [ngClass]=\"inputDidChange ? 'ng-input-did-change' : 'ng-input-did-not-change'\"\n              [attr.autocorrect]=\"'on'\"\n              [attr.disabled]=\"disabled || null\"\n              [autofocus]=\"autofocus\"\n              [autocomplete]=\"'on'\"\n              [required]=\"!optional\"\n              [spellcheck]=\"'on'\"\n              [type]=\"'text'\"\n              [value]=\"selectedOption\"\n              [placeholder]=\"placeholder || ''\"\n              readonly=\"readonly\"\n              class=\"text-body--default text-body--regular\"\n            />\n          </ui-box>\n          <!-- Select Icon Chevron Area -->\n          <div class=\"icon-container\" [ngClass]=\"{ expand: panelOpen() }\">\n            <ui-icon icon_name=\"chevron-down\"></ui-icon>\n          </div>\n        </ui-stack>\n      </div>\n    }\n    <!-- Combobox Autocomplete Input -->\n    @if (type === 'autocomplete') {\n      <div\n        #combobox\n        name=\"combobox\"\n        tabindex=\"0\"\n        (keydown)=\"onKeyDown($event)\"\n        (focus)=\"onFocusInput()\"\n        role=\"combobox\"\n        id=\"activedescendent-edit\"\n        [attr.aria-label]=\"label\"\n        [attr.aria-activedescendant]=\"'activedescendent-opt-' + focusedId\"\n        aria-readonly=\"true\"\n        aria-owns=\"activedescendent-list\"\n        aria-autocomplete=\"list\"\n      >\n        <ui-stack\n          stack_direction=\"x\"\n          stack_distribute=\"space-between\"\n          stack_align=\"center\"\n          stack_gap=\"tight\"\n        >\n          <ui-box box_space=\"none\" box_background=\"transparent\">\n            <!-- Select Label Area -->\n            <div class=\"label-container\" stack_direction=\"x\">\n              <label\n                class=\"text-body--supporting text-body--regular\"\n                role=\"combobox-label\"\n                [for]=\"id\"\n                >{{ label }}</label\n              >\n            </div>\n            <input\n              #textinput\n              [id]=\"id\"\n              [name]=\"id\"\n              [ngModel]=\"textValue\"\n              (ngModelChange)=\"onModelChangeAutocomplete($event)\"\n              [ngClass]=\"inputDidChange ? 'ng-input-did-change' : 'ng-input-did-not-change'\"\n              [attr.autocorrect]=\"'on'\"\n              [attr.disabled]=\"disabled || null\"\n              [autofocus]=\"autofocus\"\n              [autocomplete]=\"'list'\"\n              [required]=\"!optional\"\n              [spellcheck]=\"'on'\"\n              [type]=\"'text'\"\n              [value]=\"textValue\"\n              [placeholder]=\"placeholder || ''\"\n              role=\"combobox\"\n              class=\"text-body--default text-body--regular\"\n            />\n          </ui-box>\n\n          <!-- Combobox Icon Clear Area -->\n          <div class=\"icon-container\" [attr.aria-label]=\"'clean'\" (click)=\"cleanInput()\">\n            @if (textValue) {\n              <ui-icon icon_name=\"close\"></ui-icon>\n            }\n          </div>\n        </ui-stack>\n      </div>\n    }\n    <!-- Combobox Options Panel -->\n    @if (panelOpen()) {\n      <div\n        class=\"ui-combobox-options\"\n        [ngClass]=\"{ expand: panelOpen() }\"\n        [attr.aria-expanded]=\"panelOpen()\"\n        role=\"listbox\"\n        id=\"activedescendent-list\"\n      >\n        <!-- Autocomplete Options Panel Header  -->\n        @if (header && type === 'autocomplete') {\n          <div class=\"ui-combobox-header text-body--supporting\">\n            <span>{{ header }}</span>\n          </div>\n        }\n\n        <!-- Options list -->\n        @for (option of displayOptions; track option; let i = $index) {\n          <div\n            #option\n            class=\"ui-combobox-option\"\n            [ngClass]=\"{\n              selected: selectedOption === option,\n              focus: focusedOption === option,\n            }\"\n            (click)=\"selectOption(option, i)\"\n            (keydown)=\"onKeyDown($event)\"\n            [id]=\"'activedescendent-opt-' + i\"\n            [attr.aria-label]=\"\n              selectedOption === option\n                ? option[displayOptionKey] + ' is selected'\n                : option[displayOptionKey]\n            \"\n          >\n            <ui-stack\n              stack_direction=\"x\"\n              stack_distribute=\"space-between\"\n              stack_align=\"center\"\n              stack_gap=\"tight\"\n            >\n              <!-- Option display -->\n              <div\n                [attr.value]=\"valueKey ? option[valueKey] : option.value\"\n                [attr.ngValue]=\"displayKey ? option[displayKey] : option.label\"\n              >\n                <ui-stack stack_direction=\"x\" stack_align=\"center\" stack_gap=\"tight\">\n                  @if (option.icon_name || (iconNameKey && option[iconNameKey])) {\n                    <ui-icon\n                      [icon_name]=\"iconNameKey ? option[iconNameKey] : option.icon_name\"\n                    ></ui-icon>\n                  }\n                  <!-- Display options label -->\n                  @if (type === 'options') {\n                    <span>{{ option[displayOptionKey] }}</span>\n                  }\n\n                  <!-- Display autocomplete option information and emphasis-->\n                  @if (type === 'autocomplete') {\n                    <ui-stack stack_gap=\"tiny\">\n                      <span\n                        ui-emphasis\n                        [searchText]=\"textValue\"\n                        [displayParagraph]=\"option[displayOptionKey]\"\n                      >\n                      </span>\n                      <p class=\"foreground-secondary-text\">\n                        {{ option[subtextOptionKey] }}\n                      </p>\n                    </ui-stack>\n                  }\n                </ui-stack>\n              </div>\n\n              <!-- Selected icon -->\n              @if (selectedOption === option) {\n                <ui-icon icon_name=\"tick\"></ui-icon>\n              }\n            </ui-stack>\n          </div>\n        }\n        <!-- Autocomplete Options Panel Footer -->\n        @if (footer && type === 'autocomplete') {\n          <div class=\"ui-combobox-footer\">\n            <ui-button button_type=\"tertiary\" (click)=\"onFooterAction()\">\n              {{ footer }}\n            </ui-button>\n          </div>\n        }\n      </div>\n    }\n  </div>\n  <ui-stack stack_gap=\"none\">\n    <div class=\"input-errors\">\n      <div class=\"input-errors-content\">\n        <ng-content select=\"ui-form-errors\"></ng-content>\n      </div>\n    </div>\n    @if (hint) {\n      <ui-box\n        class=\"hint-container\"\n        box_background=\"transparent\"\n        box_space=\"none\"\n        box_space_left=\"near\"\n        box_space_right=\"near\"\n        box_space_bottom=\"near\"\n      >\n        <div class=\"ui-text-input-hint text-body--supporting text-color--supporting\">\n          {{ hint }}\n        </div>\n      </ui-box>\n    }\n  </ui-stack>\n</ui-stack>\n"]}
|