@ardium-ui/ui 3.4.1 → 3.4.3

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.
@@ -126,6 +126,13 @@ export class SimpleItemStorage {
126
126
  selectItemByValue(modelValue);
127
127
  }
128
128
  }
129
+ _validateSingleElementType(item) {
130
+ if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {
131
+ console.warn(`ARD-FT${this._ardParentComp._componentId}0: Setting object(${JSON.stringify(item)}) as your model with [valueFrom] is not allowed unless [compareWith] is used.`);
132
+ return false;
133
+ }
134
+ return true;
135
+ }
129
136
  /**
130
137
  * Validates that all values of the value to be written are able to be accurately compared against the storage items.
131
138
  *
@@ -137,16 +144,13 @@ export class SimpleItemStorage {
137
144
  * @returns true if all items are valid, otherwise false.
138
145
  */
139
146
  _validateWriteValue(ngModel) {
140
- if (!isArray(ngModel)) {
141
- throw new Error(`ARD-FT${this._ardParentComp._componentId}0: <ard-${this._ardParentComp._componentName}> expects its value to be an array, got "${ngModel}".`);
142
- }
143
- return ngModel.every(item => {
144
- if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {
145
- console.warn(`ARD-FT${this._ardParentComp._componentId}0: Setting object(${JSON.stringify(item)}) as your model with [valueFrom] is not allowed unless [compareWith] is used.`);
146
- return false;
147
+ if (this._ardParentComp.multiselectable()) {
148
+ if (!isArray(ngModel)) {
149
+ throw new Error(`ARD-FT${this._ardParentComp._componentId}0: <ard-${this._ardParentComp._componentName}> expects its value to be an array, got "${ngModel}".`);
147
150
  }
148
- return true;
149
- });
151
+ return ngModel.every(this._validateSingleElementType);
152
+ }
153
+ return this._validateSingleElementType(ngModel);
150
154
  }
151
155
  findItemByValue(valueToFind) {
152
156
  let findBy;
@@ -343,4 +347,4 @@ export class SimpleItemStorage {
343
347
  return this.highlightSingleItem(itemToHighlight);
344
348
  }
345
349
  }
346
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-item-storage.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/_internal/item-storages/simple-item-storage.ts"],"names":[],"mappings":"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","sourcesContent":["import { Signal, computed, signal } from '@angular/core';\r\nimport { resolvePath } from 'resolve-object-path';\r\nimport { evaluate, isArray, isDefined, isObject, isPrimitive } from 'simple-bool';\r\nimport { ArdOptionSimple, CompareWithFn } from '../../types/item-storage.types';\r\nimport { Nullable } from '../../types/utility.types';\r\n\r\nexport interface ItemStorageHostDefaults {\r\n  valueFrom: string;\r\n  labelFrom: string;\r\n  disabledFrom: string;\r\n}\r\nexport interface SimpleItemStorageHost {\r\n  readonly valueFrom: Signal<Nullable<string>>;\r\n  readonly labelFrom: Signal<Nullable<string>>;\r\n  readonly disabledFrom: Signal<Nullable<string>>;\r\n  readonly invertDisabled: Signal<boolean>;\r\n  readonly DEFAULTS: ItemStorageHostDefaults;\r\n  readonly compareWith: Signal<Nullable<CompareWithFn>>;\r\n  readonly multiselectable: Signal<boolean>;\r\n  readonly isValueRequired: Signal<boolean>;\r\n  readonly maxSelectedItems: Signal<Nullable<number>>;\r\n  readonly _componentId: string;\r\n  readonly _componentName: string;\r\n}\r\n\r\nexport class SimpleItemStorage {\r\n  private readonly _items = signal<ArdOptionSimple[]>([]);\r\n  private readonly _highlightedItems = signal<ArdOptionSimple[]>([]);\r\n  private readonly _selectedItems = signal<ArdOptionSimple[]>([]);\r\n\r\n  constructor(private readonly _ardParentComp: SimpleItemStorageHost) {}\r\n\r\n  /**\r\n   * Gets all items.\r\n   */\r\n  readonly items = this._items.asReadonly();\r\n  /**\r\n   * Gets all currently highlighted items.\r\n   */\r\n  readonly highlightedItems = this._highlightedItems.asReadonly();\r\n  /**\r\n   * Gets all currently selected items.\r\n   */\r\n  readonly selectedItems = this._selectedItems.asReadonly();\r\n  /**\r\n   * Gets the values of the currently selected items.\r\n   */\r\n  readonly value = computed(() => this._itemsToValue(this._selectedItems()));\r\n  /**\r\n   * Maps an array of items into their values.\r\n   * @param items The items to convert to value.\r\n   * @returns An array of item values.\r\n   */\r\n  private _itemsToValue(items: ArdOptionSimple[]): any[] {\r\n    return items.map(item => item.value());\r\n  }\r\n\r\n  /**\r\n   * Returns true if at least one item is highlighted, otherwise false.\r\n   */\r\n  readonly isAnyItemHighlighted = computed(() => this._highlightedItems().length > 0);\r\n  /**\r\n   * Returns true if the parent component defines the limit of concurrently selectable items and the amount of currently selected items matches that limit. Otherwise returns false.\r\n   *\r\n   * **TLDR**: true if `maxSelectedItems` is defined and the number of selected items matches that value.\r\n   */\r\n  readonly isItemLimitReached = computed(() => {\r\n    const msi = this._ardParentComp.maxSelectedItems();\r\n    if (!this._ardParentComp.multiselectable() || !isDefined(msi)) {\r\n      return false;\r\n    }\r\n    return msi <= this.selectedItems().length;\r\n  });\r\n\r\n  /**\r\n   * Sets the component's items. Takes into account the values defined by the parent component for `valueFrom`, `labelFrom`, and `disabledFrom`.\r\n   * @param items An array of items to be set as the component's items.\r\n   * @returns true if at least one of the items is of primitive type, otherwise false.\r\n   */\r\n  setItems(items: unknown[]): void {\r\n    let areItemsPrimitive = false;\r\n    if (items.some(isPrimitive)) {\r\n      items = items.map(this._primitiveItemsMapFn);\r\n      areItemsPrimitive = true;\r\n    }\r\n\r\n    this._items.set(\r\n      items.map((item, index) => {\r\n        return this._setItemsMapFn(item, index, areItemsPrimitive);\r\n      })\r\n    );\r\n  }\r\n  private _primitiveItemsMapFn<T>(item: T): { value: T } {\r\n    return { value: item };\r\n  }\r\n  private _setItemsMapFn(rawItemData: any, index: number, areItemsPrimitive: boolean): ArdOptionSimple {\r\n    if (areItemsPrimitive) {\r\n      return {\r\n        itemData: signal(rawItemData),\r\n        index: index,\r\n        value: signal(rawItemData.value),\r\n        label: signal(rawItemData.value?.toString?.() ?? String(rawItemData.value)),\r\n        disabled: signal(false),\r\n        selected: signal(false),\r\n        highlighted: signal(false),\r\n      };\r\n    }\r\n    //get value\r\n    const valuePath =\r\n      this._ardParentComp.valueFrom() ?? this._ardParentComp.labelFrom() ?? this._ardParentComp.DEFAULTS.valueFrom;\r\n    const value = resolvePath(rawItemData, valuePath);\r\n\r\n    //get label\r\n    const labelPath =\r\n      this._ardParentComp.labelFrom() ?? this._ardParentComp.valueFrom() ?? this._ardParentComp.DEFAULTS.labelFrom;\r\n    const label = resolvePath(rawItemData, labelPath) ?? value;\r\n\r\n    //get disabled\r\n    const disabledPath = this._ardParentComp.disabledFrom() ?? this._ardParentComp.DEFAULTS.disabledFrom;\r\n    let disabled = evaluate(resolvePath(rawItemData, disabledPath));\r\n    if (this._ardParentComp.invertDisabled()) {\r\n      disabled = !disabled;\r\n    }\r\n\r\n    //return\r\n    return {\r\n      itemData: signal(rawItemData),\r\n      index: index,\r\n      value: signal(value),\r\n      label: signal(label?.toString?.() ?? String(label)),\r\n      disabled: signal(disabled),\r\n      selected: signal(false),\r\n      highlighted: signal(false),\r\n    };\r\n  }\r\n  /**\r\n   * Writes a new value to the item storage. Selects the correct items based on the provided values, warning the user if the value is not found.\r\n   * @param ngModel The value of the ngModel to set.\r\n   */\r\n  writeValue(ngModel: any[]): void {\r\n    this._forceUnselectAll();\r\n\r\n    if (!this._validateWriteValue(ngModel)) return;\r\n\r\n    const selectItemByValue = (value: any) => {\r\n      const item = this.findItemByValue(value);\r\n\r\n      if (item) {\r\n        this.selectItem(item);\r\n        return;\r\n      }\r\n      console.warn(\r\n        `ARD-WA${this._ardParentComp._componentId}1: Couldn't find an item with value ${value?.toString?.() || String(value)}.`\r\n      );\r\n    };\r\n\r\n    for (const modelValue of ngModel) {\r\n      selectItemByValue(modelValue);\r\n    }\r\n  }\r\n  /**\r\n   * Validates that all values of the value to be written are able to be accurately compared against the storage items.\r\n   *\r\n   * An item from the ngModel array is considered valid if it is a primitive value, or if all of the below points are met:\r\n   * 1. The parent component defines the `compareWith` property.\r\n   * 2. The ngModel value item is an object (or array).\r\n   * 3. The parent component has a defined `valueFrom` property.\r\n   * @param ngModel The value of ngModel to validate.\r\n   * @returns true if all items are valid, otherwise false.\r\n   */\r\n  private _validateWriteValue(ngModel: unknown): boolean {\r\n    if (!isArray(ngModel)) {\r\n      throw new Error(\r\n        `ARD-FT${this._ardParentComp._componentId}0: <ard-${this._ardParentComp._componentName}> expects its value to be an array, got \"${ngModel}\".`\r\n      );\r\n    }\r\n    return ngModel.every(item => {\r\n      if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {\r\n        console.warn(\r\n          `ARD-FT${this._ardParentComp._componentId}0: Setting object(${JSON.stringify(\r\n            item\r\n          )}) as your model with [valueFrom] is not allowed unless [compareWith] is used.`\r\n        );\r\n        return false;\r\n      }\r\n      return true;\r\n    });\r\n  }\r\n  findItemByValue(valueToFind: any): ArdOptionSimple | undefined {\r\n    let findBy: (item: ArdOptionSimple) => boolean;\r\n    const cmpFn = this._ardParentComp.compareWith();\r\n    if (isDefined(cmpFn)) {\r\n      findBy = item => cmpFn(valueToFind, item.value());\r\n    } else {\r\n      findBy = item => item.value() === valueToFind;\r\n    }\r\n    return this._items().find(item => findBy(item));\r\n  }\r\n\r\n  /**\r\n   * Unselects all selected items.\r\n   *\r\n   * If the parent component requires at least one value to be selected at all times, the first selected items is left selected.\r\n   * @returns An array of items cleared, mapped to only their values.\r\n   */\r\n  unselectAll(): any[] {\r\n    for (const item of this._selectedItems()) {\r\n      item.selected.set(false);\r\n    }\r\n\r\n    const ret = this.value();\r\n\r\n    if (this._ardParentComp.isValueRequired() && this._selectedItems().length > 0) {\r\n      this._selectedItems().first().selected.set(true);\r\n      ret.splice(0, 1);\r\n    }\r\n\r\n    this._selectedItems.set([]);\r\n\r\n    return ret;\r\n  }\r\n  /**\r\n   * Unselects all selected items, no matter what the component settings are.\r\n   * @returns An array of items cleared, mapped to only their values.\r\n   */\r\n  private _forceUnselectAll(): any[] {\r\n    for (const item of this._selectedItems()) {\r\n      item.selected.set(false);\r\n    }\r\n\r\n    const ret = this._itemsToValue(this._selectedItems());\r\n\r\n    this._selectedItems.set([]);\r\n\r\n    return ret;\r\n  }\r\n  /**\r\n   * Selects one or multiple items.\r\n   *\r\n   * Accounts for the limit of concurrently selected items defined by the parent component.\r\n   * @param items A rest operator array of item objects to be selected.\r\n   * @returns A tuple containing three arrays, all mapped to only their values:\r\n   * - An array of items selected,\r\n   * - An array of items unselected,\r\n   * - An array of items failed to select due to the limit.\r\n   */\r\n  selectItem(...items: ArdOptionSimple[]): [any[], any[], any[]] {\r\n    if (this.isItemLimitReached()) {\r\n      return [[], [], this._itemsToValue(items)];\r\n    }\r\n    let unselected = [];\r\n    if (!this._ardParentComp.multiselectable()) {\r\n      unselected = this._forceUnselectAll();\r\n    }\r\n\r\n    let itemsSelectedCount = 0;\r\n    const itemsSelected: ArdOptionSimple[] = [];\r\n    for (const item of items) {\r\n      itemsSelectedCount++;\r\n      if (item.selected()) continue;\r\n      if (this.isItemLimitReached()) {\r\n        break;\r\n      }\r\n      item.selected.set(true);\r\n      itemsSelected.push(item);\r\n    }\r\n    this._selectedItems.update(v => [...v, ...itemsSelected]);\r\n\r\n    const itemsFailedToSelect = items.slice(itemsSelectedCount - 1);\r\n    return [this._itemsToValue(itemsSelected), unselected, this._itemsToValue(itemsFailedToSelect)];\r\n  }\r\n  /**\r\n   *\r\n   * @param items A rest operator array of item objects to be unselected.\r\n   * @returns An array of items unselected, mapped to only their values.\r\n   */\r\n  unselectItem(...items: ArdOptionSimple[]): any[] {\r\n    let skippedItem = false;\r\n    for (const item of items) {\r\n      if (this._ardParentComp.isValueRequired() && !skippedItem) {\r\n        skippedItem = true;\r\n        continue;\r\n      }\r\n\r\n      if (!item.selected()) continue;\r\n      item.selected.set(false);\r\n    }\r\n    this._selectedItems.update(v => v.filter(v => v.selected()));\r\n\r\n    return this._itemsToValue(items);\r\n  }\r\n\r\n  /**\r\n   * Unhighlights all currently highlighted items.\r\n   */\r\n  unhighlightAll(): void {\r\n    for (const item of this._highlightedItems()) {\r\n      item.highlighted.set(false);\r\n    }\r\n    this._highlightedItems.set([]);\r\n  }\r\n  /**\r\n   * Highlights the given item, while unhighlighting all other items. Does nothing when the item is disabled.\r\n   * @param item The item to be highlighted.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightSingleItem(item: ArdOptionSimple): ArdOptionSimple | null {\r\n    if (!item || item.disabled()) return null;\r\n    this.unhighlightAll();\r\n    return this.highlightItem(item);\r\n  }\r\n  /**\r\n   * Highlights all given items.\r\n   * @param items A rest operator array of items to be highlighted.\r\n   * @returns The last highlighted item.\r\n   */\r\n  highlightItem(...items: ArdOptionSimple[]): ArdOptionSimple {\r\n    for (const item of items) {\r\n      item.highlighted.set(true);\r\n    }\r\n    this._highlightedItems.update(v => [...v, ...items]);\r\n    return items.last();\r\n  }\r\n  /**\r\n   * Unhighlights all given items.\r\n   * @param items A rest operator array of items to be unhighlighted.\r\n   */\r\n  unhighlightItem(...items: ArdOptionSimple[]): void {\r\n    for (const item of items) {\r\n      if (!item || !item.highlighted()) return;\r\n\r\n      item.highlighted.set(false);\r\n    }\r\n    this._highlightedItems.update(v => v.filter(v => v.highlighted()));\r\n  }\r\n  /**\r\n   * Highlights the first item out of all items.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightFirstItem(): ArdOptionSimple | null {\r\n    this.unhighlightAll();\r\n\r\n    const itemToHighlight = this.highlightableItems().first();\r\n    return this.highlightItem(itemToHighlight);\r\n  }\r\n  /**\r\n   * Highlights the last item out of all items.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightLastItem(): ArdOptionSimple | null {\r\n    this.unhighlightAll();\r\n\r\n    const itemToHighlight = this.highlightableItems().last();\r\n    return this.highlightItem(itemToHighlight);\r\n  }\r\n  /**\r\n   * Highlights all non-disabled items.\r\n   */\r\n  highlightAllItems(): void {\r\n    const itemsToHighlight = this.highlightableItems();\r\n\r\n    this.highlightItem(...itemsToHighlight);\r\n  }\r\n  /**\r\n   * Highlights the next non-disabled item defined by the offset amount.\r\n   *\r\n   * If `hasShift` is set to true, all originally highlighted items are kept. Otherwise, all original items are unselected.\r\n   * @param offset The amount of items to offset the highlight by.\r\n   * @param hasShift Whether the user has the shift key pressed.\r\n   * @returns The item highlighted.\r\n   */\r\n  highlightNextItem(offset: number, hasShift?: boolean): ArdOptionSimple | null {\r\n    if (!this.isAnyItemHighlighted()) {\r\n      return this.highlightFirstItem();\r\n    }\r\n    const currentItem = this.highlightedItems().last();\r\n    const itemsWithoutDisabled = this._items().filter(\r\n      item => !item.disabled() && (!this.isItemLimitReached() || item.selected())\r\n    );\r\n    const currentIndexInItems = itemsWithoutDisabled.findIndex(item => item.index === currentItem.index);\r\n\r\n    let nextItemIndex = currentIndexInItems + offset;\r\n    if (nextItemIndex >= itemsWithoutDisabled.length) {\r\n      nextItemIndex -= itemsWithoutDisabled.length;\r\n    }\r\n    if (nextItemIndex < 0) {\r\n      nextItemIndex += itemsWithoutDisabled.length;\r\n    }\r\n    const itemToHighlight = itemsWithoutDisabled[nextItemIndex];\r\n\r\n    if (hasShift && this._ardParentComp.multiselectable()) {\r\n      if (itemToHighlight.highlighted()) {\r\n        this.unhighlightItem(currentItem);\r\n      }\r\n      return this.highlightItem(itemToHighlight);\r\n    }\r\n    return this.highlightSingleItem(itemToHighlight);\r\n  }\r\n  /**\r\n   * Finds all highlightable items. An item is considered highlightable if it is **not** disabled.\r\n   * @returns An array of all highlightable items.\r\n   */\r\n  private readonly highlightableItems = computed(() => this._items().filter(item => !item.disabled()));\r\n}\r\n"]}
350
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-item-storage.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/_internal/item-storages/simple-item-storage.ts"],"names":[],"mappings":"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","sourcesContent":["import { Signal, computed, signal } from '@angular/core';\r\nimport { resolvePath } from 'resolve-object-path';\r\nimport { evaluate, isArray, isDefined, isObject, isPrimitive } from 'simple-bool';\r\nimport { ArdOptionSimple, CompareWithFn } from '../../types/item-storage.types';\r\nimport { Nullable } from '../../types/utility.types';\r\n\r\nexport interface ItemStorageHostDefaults {\r\n  valueFrom: string;\r\n  labelFrom: string;\r\n  disabledFrom: string;\r\n}\r\nexport interface SimpleItemStorageHost {\r\n  readonly valueFrom: Signal<Nullable<string>>;\r\n  readonly labelFrom: Signal<Nullable<string>>;\r\n  readonly disabledFrom: Signal<Nullable<string>>;\r\n  readonly invertDisabled: Signal<boolean>;\r\n  readonly DEFAULTS: ItemStorageHostDefaults;\r\n  readonly compareWith: Signal<Nullable<CompareWithFn>>;\r\n  readonly multiselectable: Signal<boolean>;\r\n  readonly isValueRequired: Signal<boolean>;\r\n  readonly maxSelectedItems: Signal<Nullable<number>>;\r\n  readonly _componentId: string;\r\n  readonly _componentName: string;\r\n}\r\n\r\nexport class SimpleItemStorage {\r\n  private readonly _items = signal<ArdOptionSimple[]>([]);\r\n  private readonly _highlightedItems = signal<ArdOptionSimple[]>([]);\r\n  private readonly _selectedItems = signal<ArdOptionSimple[]>([]);\r\n\r\n  constructor(private readonly _ardParentComp: SimpleItemStorageHost) {}\r\n\r\n  /**\r\n   * Gets all items.\r\n   */\r\n  readonly items = this._items.asReadonly();\r\n  /**\r\n   * Gets all currently highlighted items.\r\n   */\r\n  readonly highlightedItems = this._highlightedItems.asReadonly();\r\n  /**\r\n   * Gets all currently selected items.\r\n   */\r\n  readonly selectedItems = this._selectedItems.asReadonly();\r\n  /**\r\n   * Gets the values of the currently selected items.\r\n   */\r\n  readonly value = computed(() => this._itemsToValue(this._selectedItems()));\r\n  /**\r\n   * Maps an array of items into their values.\r\n   * @param items The items to convert to value.\r\n   * @returns An array of item values.\r\n   */\r\n  private _itemsToValue(items: ArdOptionSimple[]): any[] {\r\n    return items.map(item => item.value());\r\n  }\r\n\r\n  /**\r\n   * Returns true if at least one item is highlighted, otherwise false.\r\n   */\r\n  readonly isAnyItemHighlighted = computed(() => this._highlightedItems().length > 0);\r\n  /**\r\n   * Returns true if the parent component defines the limit of concurrently selectable items and the amount of currently selected items matches that limit. Otherwise returns false.\r\n   *\r\n   * **TLDR**: true if `maxSelectedItems` is defined and the number of selected items matches that value.\r\n   */\r\n  readonly isItemLimitReached = computed(() => {\r\n    const msi = this._ardParentComp.maxSelectedItems();\r\n    if (!this._ardParentComp.multiselectable() || !isDefined(msi)) {\r\n      return false;\r\n    }\r\n    return msi <= this.selectedItems().length;\r\n  });\r\n\r\n  /**\r\n   * Sets the component's items. Takes into account the values defined by the parent component for `valueFrom`, `labelFrom`, and `disabledFrom`.\r\n   * @param items An array of items to be set as the component's items.\r\n   * @returns true if at least one of the items is of primitive type, otherwise false.\r\n   */\r\n  setItems(items: unknown[]): void {\r\n    let areItemsPrimitive = false;\r\n    if (items.some(isPrimitive)) {\r\n      items = items.map(this._primitiveItemsMapFn);\r\n      areItemsPrimitive = true;\r\n    }\r\n\r\n    this._items.set(\r\n      items.map((item, index) => {\r\n        return this._setItemsMapFn(item, index, areItemsPrimitive);\r\n      })\r\n    );\r\n  }\r\n  private _primitiveItemsMapFn<T>(item: T): { value: T } {\r\n    return { value: item };\r\n  }\r\n  private _setItemsMapFn(rawItemData: any, index: number, areItemsPrimitive: boolean): ArdOptionSimple {\r\n    if (areItemsPrimitive) {\r\n      return {\r\n        itemData: signal(rawItemData),\r\n        index: index,\r\n        value: signal(rawItemData.value),\r\n        label: signal(rawItemData.value?.toString?.() ?? String(rawItemData.value)),\r\n        disabled: signal(false),\r\n        selected: signal(false),\r\n        highlighted: signal(false),\r\n      };\r\n    }\r\n    //get value\r\n    const valuePath =\r\n      this._ardParentComp.valueFrom() ?? this._ardParentComp.labelFrom() ?? this._ardParentComp.DEFAULTS.valueFrom;\r\n    const value = resolvePath(rawItemData, valuePath);\r\n\r\n    //get label\r\n    const labelPath =\r\n      this._ardParentComp.labelFrom() ?? this._ardParentComp.valueFrom() ?? this._ardParentComp.DEFAULTS.labelFrom;\r\n    const label = resolvePath(rawItemData, labelPath) ?? value;\r\n\r\n    //get disabled\r\n    const disabledPath = this._ardParentComp.disabledFrom() ?? this._ardParentComp.DEFAULTS.disabledFrom;\r\n    let disabled = evaluate(resolvePath(rawItemData, disabledPath));\r\n    if (this._ardParentComp.invertDisabled()) {\r\n      disabled = !disabled;\r\n    }\r\n\r\n    //return\r\n    return {\r\n      itemData: signal(rawItemData),\r\n      index: index,\r\n      value: signal(value),\r\n      label: signal(label?.toString?.() ?? String(label)),\r\n      disabled: signal(disabled),\r\n      selected: signal(false),\r\n      highlighted: signal(false),\r\n    };\r\n  }\r\n  /**\r\n   * Writes a new value to the item storage. Selects the correct items based on the provided values, warning the user if the value is not found.\r\n   * @param ngModel The value of the ngModel to set.\r\n   */\r\n  writeValue(ngModel: any[]): void {\r\n    this._forceUnselectAll();\r\n\r\n    if (!this._validateWriteValue(ngModel)) return;\r\n\r\n    const selectItemByValue = (value: any) => {\r\n      const item = this.findItemByValue(value);\r\n\r\n      if (item) {\r\n        this.selectItem(item);\r\n        return;\r\n      }\r\n      console.warn(\r\n        `ARD-WA${this._ardParentComp._componentId}1: Couldn't find an item with value ${value?.toString?.() || String(value)}.`\r\n      );\r\n    };\r\n\r\n    for (const modelValue of ngModel) {\r\n      selectItemByValue(modelValue);\r\n    }\r\n  }\r\n\r\n  private _validateSingleElementType(item: unknown): boolean {\r\n    if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {\r\n      console.warn(\r\n        `ARD-FT${this._ardParentComp._componentId}0: Setting object(${JSON.stringify(\r\n          item\r\n        )}) as your model with [valueFrom] is not allowed unless [compareWith] is used.`\r\n      );\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n  /**\r\n   * Validates that all values of the value to be written are able to be accurately compared against the storage items.\r\n   *\r\n   * An item from the ngModel array is considered valid if it is a primitive value, or if all of the below points are met:\r\n   * 1. The parent component defines the `compareWith` property.\r\n   * 2. The ngModel value item is an object (or array).\r\n   * 3. The parent component has a defined `valueFrom` property.\r\n   * @param ngModel The value of ngModel to validate.\r\n   * @returns true if all items are valid, otherwise false.\r\n   */\r\n  private _validateWriteValue(ngModel: unknown): boolean {\r\n    if (this._ardParentComp.multiselectable()) {\r\n      if (!isArray(ngModel)) {\r\n        throw new Error(\r\n          `ARD-FT${this._ardParentComp._componentId}0: <ard-${this._ardParentComp._componentName}> expects its value to be an array, got \"${ngModel}\".`\r\n        );\r\n      }\r\n      return ngModel.every(this._validateSingleElementType);\r\n    }\r\n    return this._validateSingleElementType(ngModel);\r\n  }\r\n  \r\n  findItemByValue(valueToFind: any): ArdOptionSimple | undefined {\r\n    let findBy: (item: ArdOptionSimple) => boolean;\r\n    const cmpFn = this._ardParentComp.compareWith();\r\n    if (isDefined(cmpFn)) {\r\n      findBy = item => cmpFn(valueToFind, item.value());\r\n    } else {\r\n      findBy = item => item.value() === valueToFind;\r\n    }\r\n    return this._items().find(item => findBy(item));\r\n  }\r\n\r\n  /**\r\n   * Unselects all selected items.\r\n   *\r\n   * If the parent component requires at least one value to be selected at all times, the first selected items is left selected.\r\n   * @returns An array of items cleared, mapped to only their values.\r\n   */\r\n  unselectAll(): any[] {\r\n    for (const item of this._selectedItems()) {\r\n      item.selected.set(false);\r\n    }\r\n\r\n    const ret = this.value();\r\n\r\n    if (this._ardParentComp.isValueRequired() && this._selectedItems().length > 0) {\r\n      this._selectedItems().first().selected.set(true);\r\n      ret.splice(0, 1);\r\n    }\r\n\r\n    this._selectedItems.set([]);\r\n\r\n    return ret;\r\n  }\r\n  /**\r\n   * Unselects all selected items, no matter what the component settings are.\r\n   * @returns An array of items cleared, mapped to only their values.\r\n   */\r\n  private _forceUnselectAll(): any[] {\r\n    for (const item of this._selectedItems()) {\r\n      item.selected.set(false);\r\n    }\r\n\r\n    const ret = this._itemsToValue(this._selectedItems());\r\n\r\n    this._selectedItems.set([]);\r\n\r\n    return ret;\r\n  }\r\n  /**\r\n   * Selects one or multiple items.\r\n   *\r\n   * Accounts for the limit of concurrently selected items defined by the parent component.\r\n   * @param items A rest operator array of item objects to be selected.\r\n   * @returns A tuple containing three arrays, all mapped to only their values:\r\n   * - An array of items selected,\r\n   * - An array of items unselected,\r\n   * - An array of items failed to select due to the limit.\r\n   */\r\n  selectItem(...items: ArdOptionSimple[]): [any[], any[], any[]] {\r\n    if (this.isItemLimitReached()) {\r\n      return [[], [], this._itemsToValue(items)];\r\n    }\r\n    let unselected = [];\r\n    if (!this._ardParentComp.multiselectable()) {\r\n      unselected = this._forceUnselectAll();\r\n    }\r\n\r\n    let itemsSelectedCount = 0;\r\n    const itemsSelected: ArdOptionSimple[] = [];\r\n    for (const item of items) {\r\n      itemsSelectedCount++;\r\n      if (item.selected()) continue;\r\n      if (this.isItemLimitReached()) {\r\n        break;\r\n      }\r\n      item.selected.set(true);\r\n      itemsSelected.push(item);\r\n    }\r\n    this._selectedItems.update(v => [...v, ...itemsSelected]);\r\n\r\n    const itemsFailedToSelect = items.slice(itemsSelectedCount - 1);\r\n    return [this._itemsToValue(itemsSelected), unselected, this._itemsToValue(itemsFailedToSelect)];\r\n  }\r\n  /**\r\n   *\r\n   * @param items A rest operator array of item objects to be unselected.\r\n   * @returns An array of items unselected, mapped to only their values.\r\n   */\r\n  unselectItem(...items: ArdOptionSimple[]): any[] {\r\n    let skippedItem = false;\r\n    for (const item of items) {\r\n      if (this._ardParentComp.isValueRequired() && !skippedItem) {\r\n        skippedItem = true;\r\n        continue;\r\n      }\r\n\r\n      if (!item.selected()) continue;\r\n      item.selected.set(false);\r\n    }\r\n    this._selectedItems.update(v => v.filter(v => v.selected()));\r\n\r\n    return this._itemsToValue(items);\r\n  }\r\n\r\n  /**\r\n   * Unhighlights all currently highlighted items.\r\n   */\r\n  unhighlightAll(): void {\r\n    for (const item of this._highlightedItems()) {\r\n      item.highlighted.set(false);\r\n    }\r\n    this._highlightedItems.set([]);\r\n  }\r\n  /**\r\n   * Highlights the given item, while unhighlighting all other items. Does nothing when the item is disabled.\r\n   * @param item The item to be highlighted.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightSingleItem(item: ArdOptionSimple): ArdOptionSimple | null {\r\n    if (!item || item.disabled()) return null;\r\n    this.unhighlightAll();\r\n    return this.highlightItem(item);\r\n  }\r\n  /**\r\n   * Highlights all given items.\r\n   * @param items A rest operator array of items to be highlighted.\r\n   * @returns The last highlighted item.\r\n   */\r\n  highlightItem(...items: ArdOptionSimple[]): ArdOptionSimple {\r\n    for (const item of items) {\r\n      item.highlighted.set(true);\r\n    }\r\n    this._highlightedItems.update(v => [...v, ...items]);\r\n    return items.last();\r\n  }\r\n  /**\r\n   * Unhighlights all given items.\r\n   * @param items A rest operator array of items to be unhighlighted.\r\n   */\r\n  unhighlightItem(...items: ArdOptionSimple[]): void {\r\n    for (const item of items) {\r\n      if (!item || !item.highlighted()) return;\r\n\r\n      item.highlighted.set(false);\r\n    }\r\n    this._highlightedItems.update(v => v.filter(v => v.highlighted()));\r\n  }\r\n  /**\r\n   * Highlights the first item out of all items.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightFirstItem(): ArdOptionSimple | null {\r\n    this.unhighlightAll();\r\n\r\n    const itemToHighlight = this.highlightableItems().first();\r\n    return this.highlightItem(itemToHighlight);\r\n  }\r\n  /**\r\n   * Highlights the last item out of all items.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightLastItem(): ArdOptionSimple | null {\r\n    this.unhighlightAll();\r\n\r\n    const itemToHighlight = this.highlightableItems().last();\r\n    return this.highlightItem(itemToHighlight);\r\n  }\r\n  /**\r\n   * Highlights all non-disabled items.\r\n   */\r\n  highlightAllItems(): void {\r\n    const itemsToHighlight = this.highlightableItems();\r\n\r\n    this.highlightItem(...itemsToHighlight);\r\n  }\r\n  /**\r\n   * Highlights the next non-disabled item defined by the offset amount.\r\n   *\r\n   * If `hasShift` is set to true, all originally highlighted items are kept. Otherwise, all original items are unselected.\r\n   * @param offset The amount of items to offset the highlight by.\r\n   * @param hasShift Whether the user has the shift key pressed.\r\n   * @returns The item highlighted.\r\n   */\r\n  highlightNextItem(offset: number, hasShift?: boolean): ArdOptionSimple | null {\r\n    if (!this.isAnyItemHighlighted()) {\r\n      return this.highlightFirstItem();\r\n    }\r\n    const currentItem = this.highlightedItems().last();\r\n    const itemsWithoutDisabled = this._items().filter(\r\n      item => !item.disabled() && (!this.isItemLimitReached() || item.selected())\r\n    );\r\n    const currentIndexInItems = itemsWithoutDisabled.findIndex(item => item.index === currentItem.index);\r\n\r\n    let nextItemIndex = currentIndexInItems + offset;\r\n    if (nextItemIndex >= itemsWithoutDisabled.length) {\r\n      nextItemIndex -= itemsWithoutDisabled.length;\r\n    }\r\n    if (nextItemIndex < 0) {\r\n      nextItemIndex += itemsWithoutDisabled.length;\r\n    }\r\n    const itemToHighlight = itemsWithoutDisabled[nextItemIndex];\r\n\r\n    if (hasShift && this._ardParentComp.multiselectable()) {\r\n      if (itemToHighlight.highlighted()) {\r\n        this.unhighlightItem(currentItem);\r\n      }\r\n      return this.highlightItem(itemToHighlight);\r\n    }\r\n    return this.highlightSingleItem(itemToHighlight);\r\n  }\r\n  /**\r\n   * Finds all highlightable items. An item is considered highlightable if it is **not** disabled.\r\n   * @returns An array of all highlightable items.\r\n   */\r\n  private readonly highlightableItems = computed(() => this._items().filter(item => !item.disabled()));\r\n}\r\n"]}
@@ -69,7 +69,7 @@ export class ArdiumDigitInputComponent extends _FormFieldComponentBase {
69
69
  const attributes = {
70
70
  autocorrect: 'off',
71
71
  autocapitalize: 'off',
72
- autocomplete: 'postal-code',
72
+ autocomplete: 'off',
73
73
  ...this.inputAttrs(),
74
74
  };
75
75
  for (const key of Object.keys(attributes)) {
@@ -261,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
261
261
  }] }], propDecorators: { value: [{
262
262
  type: Input
263
263
  }] } });
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"digit-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.component.ts","../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AutofillMonitor } from '@angular/cdk/text-field';\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  computed,\r\n  effect,\r\n  forwardRef,\r\n  inject,\r\n  input,\r\n  output,\r\n  signal,\r\n  viewChildren,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { Subscription } from 'rxjs';\r\nimport { _FormFieldComponentBase } from '../../_internal/form-field-component';\r\nimport { FormElementAppearance, FormElementVariant } from '../../types/theming.types';\r\nimport { ARD_DIGIT_INPUT_DEFAULTS, ArdDigitInputDefaults } from './digit-input.defaults';\r\nimport { DigitInputModel } from './digit-input.model';\r\nimport { DigitInputAutoFillParseFn, DigitInputConfig, DigitInputShape, DigitInputTransform } from './digit-input.types';\r\nimport { DigitInputModelHost } from './digit-input.utils';\r\n\r\n@Component({\r\n  selector: 'ard-digit-input',\r\n  templateUrl: './digit-input.component.html',\r\n  styleUrls: ['./digit-input.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ArdiumDigitInputComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: _FormFieldComponentBase,\r\n      useExisting: ArdiumDigitInputComponent,\r\n    },\r\n  ],\r\n})\r\nexport class ArdiumDigitInputComponent\r\n  extends _FormFieldComponentBase\r\n  implements ControlValueAccessor, DigitInputModelHost, OnInit, AfterViewInit, OnDestroy\r\n{\r\n  protected override readonly _DEFAULTS!: ArdDigitInputDefaults;\r\n  constructor(@Inject(ARD_DIGIT_INPUT_DEFAULTS) defaults: ArdDigitInputDefaults) {\r\n    super(defaults);\r\n  }\r\n\r\n  private readonly _autoFillMonitor = inject(AutofillMonitor);\r\n\r\n  //! inputs ref\r\n  readonly inputs = viewChildren<ElementRef<HTMLInputElement>>('input');\r\n\r\n  readonly inputAttrs = input<Record<string, any>>(this._DEFAULTS.inputAttrs);\r\n\r\n  private _setInputAttributes() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      const inputEl = input.nativeElement;\r\n      const attributes: Record<string, string> = {\r\n        autocorrect: 'off',\r\n        autocapitalize: 'off',\r\n        autocomplete: 'postal-code',\r\n        ...this.inputAttrs(),\r\n      };\r\n\r\n      for (const key of Object.keys(attributes)) {\r\n        inputEl.setAttribute(key, attributes[key]);\r\n      }\r\n    }\r\n  }\r\n\r\n  //! auto-fill\r\n  readonly autoFillParseFn = input<DigitInputAutoFillParseFn>(this._DEFAULTS.autoFillParseFn);\r\n\r\n  readonly isAutofilled = signal<boolean>(false);\r\n  private readonly _wasAutofillValueRead = signal<boolean>(false);\r\n\r\n  private _autoFillSubs: Subscription[] = [];\r\n  private _subscribeToAutoFillOnInputs() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      const sub = this._autoFillMonitor.monitor(input).subscribe(event => {\r\n        this.isAutofilled.set(event.isAutofilled);\r\n      });\r\n      this._autoFillSubs.push(sub);\r\n    }\r\n  }\r\n\r\n  private _unsubscribeFromAutoFill() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      this._autoFillMonitor.stopMonitoring(input);\r\n    }\r\n    for (const sub of this._autoFillSubs) {\r\n      sub.unsubscribe();\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n    this._unsubscribeFromAutoFill();\r\n  }\r\n\r\n  //! data model\r\n  private readonly model = new DigitInputModel(this);\r\n\r\n  //! appearance\r\n  readonly appearance = input<FormElementAppearance>(this._DEFAULTS.appearance);\r\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\r\n  readonly shape = input<DigitInputShape>(this._DEFAULTS.shape);\r\n\r\n  readonly compact = input<boolean, any>(this._DEFAULTS.compact, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly ngClasses = computed((): string =>\r\n    [\r\n      `ard-appearance-${this.appearance()}`,\r\n      `ard-variant-${this.variant()}`,\r\n      `ard-shape-${this.shape()}`,\r\n      this.compact() ? 'ard-compact' : '',\r\n      this.isAutofilled() ? 'ard-autofilled' : '',\r\n    ].join(' ')\r\n  );\r\n\r\n  //! model access points\r\n  readonly config = input.required<void, DigitInputConfig>({\r\n    transform: v => this.model.setConfig(v),\r\n  });\r\n  readonly configArrayData = this.model.configArrayData;\r\n\r\n  readonly transform = input<DigitInputTransform>(this._DEFAULTS.transform);\r\n\r\n  private _oldConfigArrayDataLength = -1;\r\n  readonly configArrayDataEffect = effect(() => {\r\n    if (this.configArrayData().length === this._oldConfigArrayDataLength) return;\r\n\r\n    this._oldConfigArrayDataLength = this.configArrayData().length;\r\n    this._emitChange();\r\n  });\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this._oldConfigArrayDataLength = this.configArrayData().length;\r\n  }\r\n\r\n  isInputEmpty(index: number): boolean {\r\n    return !this.model.isDefinedAtIndex(index);\r\n  }\r\n\r\n  //! control value accessor's write value implementation\r\n  private _valueBeforeViewInit?: any;\r\n  writeValue(v: any): void {\r\n    if (!this._wasViewInit) {\r\n      this._valueBeforeViewInit = v;\r\n      return;\r\n    }\r\n    this._writeValue(v);\r\n  }\r\n  private _writeValue(v: any): boolean {\r\n    return this.model.writeValue(v);\r\n  }\r\n\r\n  private _wasViewInit = false;\r\n  ngAfterViewInit(): void {\r\n    this._wasViewInit = true;\r\n\r\n    if (this._valueBeforeViewInit) {\r\n      this._writeValue(this._valueBeforeViewInit);\r\n    }\r\n\r\n    this._setInputAttributes();\r\n    this._subscribeToAutoFillOnInputs();\r\n  }\r\n\r\n  //! value two-way binding\r\n  readonly outputAsString = input<boolean, any>(this._DEFAULTS.outputAsString, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly outputControlValueAccessorOnFinish = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  @Input()\r\n  set value(v: string | (string | null)[] | null) {\r\n    this.writeValue(v);\r\n  }\r\n  readonly valueChange = output<string | (string | null)[] | null>();\r\n\r\n  readonly stringValue = this.model.stringValue;\r\n\r\n  readonly emittableValue = computed((): string | (string | null)[] | null => {\r\n    if (this.outputAsString()) return this.model.stringValue();\r\n    return this.model.value();\r\n  });\r\n\r\n  //! event emitters\r\n  readonly finishedValue = output<string | (string | null)[] | null>();\r\n\r\n  readonly focusIndexEvent = output<number>({ alias: 'focusIndex' });\r\n  readonly blurIndexEvent = output<number>({ alias: 'blurIndex' });\r\n\r\n  //! event handlers\r\n  onPaste(event: ClipboardEvent, index: number): void {\r\n    const value = event.clipboardData?.getData('text');\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    if (!value) return;\r\n\r\n    this._handleMultiDigitChange(value, index);\r\n  }\r\n  onInput(event: Event, index: number): void {\r\n    const value = (event.target as HTMLInputElement).value;\r\n    if (this.isAutofilled()) {\r\n      if (!this._wasAutofillValueRead()) {\r\n        this._wasAutofillValueRead.set(true);\r\n        setTimeout(() => {\r\n          this._wasAutofillValueRead.set(false);\r\n\r\n          const parsedValue = this.autoFillParseFn()(value);\r\n\r\n          this._handleMultiDigitChange(parsedValue, 0);\r\n        }, 0);\r\n      }\r\n      return;\r\n    }\r\n    const wasValidCharacter = this._updateSingleInputValue(value, index);\r\n    if (!wasValidCharacter) return;\r\n    this.focusByIndex(index + 1);\r\n  }\r\n  private _handleMultiDigitChange(value: string, startIndex: number): void {\r\n    const maxLength = this.inputs().length - startIndex;\r\n    value\r\n      .slice(0, maxLength)\r\n      .split('')\r\n      .forEach((char, i) => {\r\n        this.model.resetInputValue(startIndex + i);\r\n        this.model.validateInputAndSetValue(char, startIndex + i);\r\n      });\r\n\r\n    this.focusByIndex(startIndex - 1 + Math.min(value.length, maxLength));\r\n\r\n    this._emitChange();\r\n  }\r\n  private _updateSingleInputValue(value: string, index: number): boolean {\r\n    const changeResult = this.model.validateInputAndSetValue(value, index);\r\n\r\n    if (changeResult?.wasChanged) {\r\n      this._emitChange();\r\n    }\r\n\r\n    return changeResult?.wasValidChar ?? false;\r\n  }\r\n  focusByIndex(index: number): boolean;\r\n  focusByIndex(index: number, tryFocusingNext: boolean, direction: 1 | -1): boolean;\r\n  focusByIndex(index: number, tryFocusingNext?: boolean, direction?: 1 | -1): boolean {\r\n    if (index < 0 || index >= this.inputs().length) return false;\r\n    const nextEl = this.inputs()[index]?.nativeElement;\r\n    if (!nextEl) return false;\r\n\r\n    if (nextEl.getAttribute('data-ard-static') !== null) {\r\n      return this.focusByIndex(index + (direction ?? 1));\r\n    }\r\n    nextEl.focus();\r\n    if (tryFocusingNext && direction && document.activeElement !== nextEl) {\r\n      return this.focusByIndex(index + direction);\r\n    }\r\n    return document.activeElement === nextEl;\r\n  }\r\n  //focus, blur, change\r\n  onFocusMaster(event: FocusEvent, index: number): void {\r\n    this.focusIndexEvent.emit(index);\r\n    (event.target as HTMLInputElement).setSelectionRange(0, 1);\r\n\r\n    this.onFocus(event);\r\n  }\r\n  onBlurMaster(event: FocusEvent, index: number): void {\r\n    this.blurIndexEvent.emit(index);\r\n    this.onBlur(event);\r\n  }\r\n  protected _emitChange(): void {\r\n    const v = this.emittableValue();\r\n    if (!this.outputControlValueAccessorOnFinish() || this.model.isValueFull()) this._onChangeRegistered?.(v);\r\n    this.valueChange.emit(v);\r\n    if (this.model.isValueFull()) {\r\n      this.finishedValue.emit(v);\r\n    }\r\n  }\r\n  onKeydown(event: KeyboardEvent, index: number): void {\r\n    switch (event.key) {\r\n      case 'ArrowLeft':\r\n        this.focusByIndex(index - 1, true, -1);\r\n        return;\r\n      case 'ArrowRight':\r\n        this.focusByIndex(index + 1, true, +1);\r\n        return;\r\n      case 'Home':\r\n        this.focusByIndex(0, true, 1);\r\n        return;\r\n      case 'End':\r\n        this.focusByIndex(this.inputs.length - 1, true, -1);\r\n        return;\r\n      case 'Backspace':\r\n      case 'Delete':\r\n        this._updateSingleInputValue('', index);\r\n        this.focusByIndex(index - 1, true, -1);\r\n        event.preventDefault();\r\n        return;\r\n    }\r\n  }\r\n}\r\n","<div\r\n  class=\"ard-digit-input\"\r\n  [ngClass]=\"ngClasses()\"\r\n  [class.ard-has-error]=\"hasError()\"\r\n  [class.ard-is-success]=\"isSuccess()\"\r\n>\r\n  @for (data of configArrayData(); track $index) {\r\n  <div\r\n    class=\"ard-digit-input__item\"\r\n    [class.ard-digit-input__item-with-input]=\"data.type === 'input'\"\r\n  >\r\n    @if (data.type === 'input') {\r\n    <input\r\n      #input\r\n      #focusableElement\r\n      class=\"ard-digit-input__input\"\r\n      type=\"text\"\r\n      [readonly]=\"data.readonly\"\r\n      [placeholder]=\"data.placeholder\"\r\n      [attr.tabindex]=\"tabIndex()\"\r\n      [class.ard-digit-input__input-readonly]=\"data.readonly\"\r\n      [class.ard-digit-input__input-empty]=\"isInputEmpty(data.index!)\"\r\n      (paste)=\"onPaste($event, data.index!)\"\r\n      (input)=\"onInput($event, data.index!)\"\r\n      (focus)=\"onFocusMaster($event, data.index!)\"\r\n      (blur)=\"onBlurMaster($event, data.index!)\"\r\n      (keydown)=\"onKeydown($event, data.index!)\"\r\n    />\r\n    } @else {\r\n    <div class=\"ard-digit-input__static\">\r\n      {{ data.char }}\r\n    </div>\r\n    <input\r\n      #input\r\n      type=\"text\"\r\n      class=\"ard-digit-input__static-input\"\r\n      data-ard-static\r\n      autocomplete=\"off\"\r\n      tabindex=\"-1\"\r\n      aria-hidden=\"true\"\r\n      [value]=\"data.char\"\r\n    />\r\n    }\r\n  </div>\r\n  }\r\n</div>\r\n"]}
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"digit-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.component.ts","../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAEL,uBAAuB,EACvB,SAAS,EAET,MAAM,EACN,KAAK,EAGL,iBAAiB,EACjB,QAAQ,EACR,MAAM,EACN,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,EACN,MAAM,EACN,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAE1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,sCAAsC,CAAC;AAE/E,OAAO,EAAE,wBAAwB,EAAyB,MAAM,wBAAwB,CAAC;AACzF,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;AAsBtD,MAAM,OAAO,yBACX,SAAQ,uBAAuB;IAI/B,YAA8C,QAA+B;QAC3E,KAAK,CAAC,QAAQ,CAAC,CAAC;QAGD,qBAAgB,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAE5D,cAAc;QACL,WAAM,GAAG,YAAY,CAA+B,OAAO,CAAC,CAAC;QAE7D,eAAU,GAAG,KAAK,CAAsB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAmB5E,aAAa;QACJ,oBAAe,GAAG,KAAK,CAA4B,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;QAEnF,iBAAY,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QAC9B,0BAAqB,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QAExD,kBAAa,GAAmB,EAAE,CAAC;QA0B3C,cAAc;QACG,UAAK,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC;QAEnD,cAAc;QACL,eAAU,GAAG,KAAK,CAAwB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACrE,YAAO,GAAG,KAAK,CAAqB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC5D,UAAK,GAAG,KAAK,CAAkB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAErD,YAAO,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEpG,cAAS,GAAG,QAAQ,CAAC,GAAW,EAAE,CACzC;YACE,kBAAkB,IAAI,CAAC,UAAU,EAAE,EAAE;YACrC,eAAe,IAAI,CAAC,OAAO,EAAE,EAAE;YAC/B,aAAa,IAAI,CAAC,KAAK,EAAE,EAAE;YAC3B,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE;SAC5C,CAAC,IAAI,CAAC,GAAG,CAAC,CACZ,CAAC;QAEF,uBAAuB;QACd,WAAM,GAAG,KAAK,CAAC,QAAQ,CAAyB;YACvD,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;SACxC,CAAC,CAAC;QACM,oBAAe,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC;QAE7C,cAAS,GAAG,KAAK,CAAsB,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAElE,8BAAyB,GAAG,CAAC,CAAC,CAAC;QAC9B,0BAAqB,GAAG,MAAM,CAAC,GAAG,EAAE;YAC3C,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,yBAAyB;gBAAE,OAAO;YAE7E,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,CAAC;YAC/D,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;QAwBK,iBAAY,GAAG,KAAK,CAAC;QAY7B,yBAAyB;QAChB,mBAAc,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAElH,uCAAkC,GAAG,KAAK,CAAe,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAM9G,gBAAW,GAAG,MAAM,EAAqC,CAAC;QAE1D,gBAAW,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;QAErC,mBAAc,GAAG,QAAQ,CAAC,GAAsC,EAAE;YACzE,IAAI,IAAI,CAAC,cAAc,EAAE;gBAAE,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;YAC3D,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,kBAAkB;QACT,kBAAa,GAAG,MAAM,EAAqC,CAAC;QAE5D,oBAAe,GAAG,MAAM,CAAS,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC;QAC1D,mBAAc,GAAG,MAAM,CAAS,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;IAtJjE,CAAC;IASO,mBAAmB;QACzB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC7B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,MAAM,OAAO,GAAG,KAAK,CAAC,aAAa,CAAC;YACpC,MAAM,UAAU,GAA2B;gBACzC,WAAW,EAAE,KAAK;gBAClB,cAAc,EAAE,KAAK;gBACrB,YAAY,EAAE,KAAK;gBACnB,GAAG,IAAI,CAAC,UAAU,EAAE;aACrB,CAAC;YAEF,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC1C,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;YAC7C,CAAC;QACH,CAAC;IACH,CAAC;IASO,4BAA4B;QAClC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC7B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;gBACjE,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YAC5C,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC;IAEO,wBAAwB;QAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC7B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC9C,CAAC;QACD,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACrC,GAAG,CAAC,WAAW,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAClC,CAAC;IAsCQ,QAAQ;QACf,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,CAAC;IACjE,CAAC;IAED,YAAY,CAAC,KAAa;QACxB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IAID,UAAU,CAAC,CAAM;QACf,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC;YAC9B,OAAO;QACT,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IACO,WAAW,CAAC,CAAM;QACxB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAClC,CAAC;IAGD,eAAe;QACb,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAEzB,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACtC,CAAC;IAOD,IACI,KAAK,CAAC,CAAoC;QAC5C,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IAgBD,kBAAkB;IAClB,OAAO,CAAC,KAAqB,EAAE,KAAa;QAC1C,MAAM,KAAK,GAAG,KAAK,CAAC,aAAa,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;QACnD,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAC7C,CAAC;IACD,OAAO,CAAC,KAAY,EAAE,KAAa;QACjC,MAAM,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACvD,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,EAAE,CAAC;gBAClC,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACrC,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBAEtC,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,KAAK,CAAC,CAAC;oBAElD,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;gBAC/C,CAAC,EAAE,CAAC,CAAC,CAAC;YACR,CAAC;YACD,OAAO;QACT,CAAC;QACD,MAAM,iBAAiB,GAAG,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACrE,IAAI,CAAC,iBAAiB;YAAE,OAAO;QAC/B,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IAC/B,CAAC;IACO,uBAAuB,CAAC,KAAa,EAAE,UAAkB;QAC/D,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,GAAG,UAAU,CAAC;QACpD,KAAK;aACF,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC;aACnB,KAAK,CAAC,EAAE,CAAC;aACT,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE;YACnB,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;YAC3C,IAAI,CAAC,KAAK,CAAC,wBAAwB,CAAC,IAAI,EAAE,UAAU,GAAG,CAAC,CAAC,CAAC;QAC5D,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;QAEtE,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IACO,uBAAuB,CAAC,KAAa,EAAE,KAAa;QAC1D,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,wBAAwB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAEvE,IAAI,YAAY,EAAE,UAAU,EAAE,CAAC;YAC7B,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;QAED,OAAO,YAAY,EAAE,YAAY,IAAI,KAAK,CAAC;IAC7C,CAAC;IAGD,YAAY,CAAC,KAAa,EAAE,eAAyB,EAAE,SAAkB;QACvE,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QAC7D,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,EAAE,aAAa,CAAC;QACnD,IAAI,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QAE1B,IAAI,MAAM,CAAC,YAAY,CAAC,iBAAiB,CAAC,KAAK,IAAI,EAAE,CAAC;YACpD,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC;QACrD,CAAC;QACD,MAAM,CAAC,KAAK,EAAE,CAAC;QACf,IAAI,eAAe,IAAI,SAAS,IAAI,QAAQ,CAAC,aAAa,KAAK,MAAM,EAAE,CAAC;YACtE,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC;QAC9C,CAAC;QACD,OAAO,QAAQ,CAAC,aAAa,KAAK,MAAM,CAAC;IAC3C,CAAC;IACD,qBAAqB;IACrB,aAAa,CAAC,KAAiB,EAAE,KAAa;QAC5C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,KAAK,CAAC,MAA2B,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAE3D,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACtB,CAAC;IACD,YAAY,CAAC,KAAiB,EAAE,KAAa;QAC3C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;IACS,WAAW;QACnB,MAAM,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAChC,IAAI,CAAC,IAAI,CAAC,kCAAkC,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;YAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1G,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,CAAC;YAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IACD,SAAS,CAAC,KAAoB,EAAE,KAAa;QAC3C,QAAQ,KAAK,CAAC,GAAG,EAAE,CAAC;YAClB,KAAK,WAAW;gBACd,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBACvC,OAAO;YACT,KAAK,YAAY;gBACf,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBACvC,OAAO;YACT,KAAK,MAAM;gBACT,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;gBAC9B,OAAO;YACT,KAAK,KAAK;gBACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBACpD,OAAO;YACT,KAAK,WAAW,CAAC;YACjB,KAAK,QAAQ;gBACX,IAAI,CAAC,uBAAuB,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;gBACxC,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBACvC,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,OAAO;QACX,CAAC;IACH,CAAC;+GA1QU,yBAAyB,kBAKhB,wBAAwB;mGALjC,yBAAyB,4qDAZzB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC;gBACxD,KAAK,EAAE,IAAI;aACZ;YACD;gBACE,OAAO,EAAE,uBAAuB;gBAChC,WAAW,EAAE,yBAAyB;aACvC;SACF,qJC9CH,+5CA8CA;;4FDEa,yBAAyB;kBAlBrC,SAAS;+BACE,iBAAiB,iBAGZ,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC;4BACxD,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,uBAAuB;4BAChC,WAAW,2BAA2B;yBACvC;qBACF;;0BAOY,MAAM;2BAAC,wBAAwB;yCAwIxC,KAAK;sBADR,KAAK","sourcesContent":["import { AutofillMonitor } from '@angular/cdk/text-field';\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  computed,\r\n  effect,\r\n  forwardRef,\r\n  inject,\r\n  input,\r\n  output,\r\n  signal,\r\n  viewChildren,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { Subscription } from 'rxjs';\r\nimport { _FormFieldComponentBase } from '../../_internal/form-field-component';\r\nimport { FormElementAppearance, FormElementVariant } from '../../types/theming.types';\r\nimport { ARD_DIGIT_INPUT_DEFAULTS, ArdDigitInputDefaults } from './digit-input.defaults';\r\nimport { DigitInputModel } from './digit-input.model';\r\nimport { DigitInputAutoFillParseFn, DigitInputConfig, DigitInputShape, DigitInputTransform } from './digit-input.types';\r\nimport { DigitInputModelHost } from './digit-input.utils';\r\n\r\n@Component({\r\n  selector: 'ard-digit-input',\r\n  templateUrl: './digit-input.component.html',\r\n  styleUrls: ['./digit-input.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ArdiumDigitInputComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: _FormFieldComponentBase,\r\n      useExisting: ArdiumDigitInputComponent,\r\n    },\r\n  ],\r\n})\r\nexport class ArdiumDigitInputComponent\r\n  extends _FormFieldComponentBase\r\n  implements ControlValueAccessor, DigitInputModelHost, OnInit, AfterViewInit, OnDestroy\r\n{\r\n  protected override readonly _DEFAULTS!: ArdDigitInputDefaults;\r\n  constructor(@Inject(ARD_DIGIT_INPUT_DEFAULTS) defaults: ArdDigitInputDefaults) {\r\n    super(defaults);\r\n  }\r\n\r\n  private readonly _autoFillMonitor = inject(AutofillMonitor);\r\n\r\n  //! inputs ref\r\n  readonly inputs = viewChildren<ElementRef<HTMLInputElement>>('input');\r\n\r\n  readonly inputAttrs = input<Record<string, any>>(this._DEFAULTS.inputAttrs);\r\n\r\n  private _setInputAttributes() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      const inputEl = input.nativeElement;\r\n      const attributes: Record<string, string> = {\r\n        autocorrect: 'off',\r\n        autocapitalize: 'off',\r\n        autocomplete: 'off',\r\n        ...this.inputAttrs(),\r\n      };\r\n\r\n      for (const key of Object.keys(attributes)) {\r\n        inputEl.setAttribute(key, attributes[key]);\r\n      }\r\n    }\r\n  }\r\n\r\n  //! auto-fill\r\n  readonly autoFillParseFn = input<DigitInputAutoFillParseFn>(this._DEFAULTS.autoFillParseFn);\r\n\r\n  readonly isAutofilled = signal<boolean>(false);\r\n  private readonly _wasAutofillValueRead = signal<boolean>(false);\r\n\r\n  private _autoFillSubs: Subscription[] = [];\r\n  private _subscribeToAutoFillOnInputs() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      const sub = this._autoFillMonitor.monitor(input).subscribe(event => {\r\n        this.isAutofilled.set(event.isAutofilled);\r\n      });\r\n      this._autoFillSubs.push(sub);\r\n    }\r\n  }\r\n\r\n  private _unsubscribeFromAutoFill() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      this._autoFillMonitor.stopMonitoring(input);\r\n    }\r\n    for (const sub of this._autoFillSubs) {\r\n      sub.unsubscribe();\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n    this._unsubscribeFromAutoFill();\r\n  }\r\n\r\n  //! data model\r\n  private readonly model = new DigitInputModel(this);\r\n\r\n  //! appearance\r\n  readonly appearance = input<FormElementAppearance>(this._DEFAULTS.appearance);\r\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\r\n  readonly shape = input<DigitInputShape>(this._DEFAULTS.shape);\r\n\r\n  readonly compact = input<boolean, any>(this._DEFAULTS.compact, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly ngClasses = computed((): string =>\r\n    [\r\n      `ard-appearance-${this.appearance()}`,\r\n      `ard-variant-${this.variant()}`,\r\n      `ard-shape-${this.shape()}`,\r\n      this.compact() ? 'ard-compact' : '',\r\n      this.isAutofilled() ? 'ard-autofilled' : '',\r\n    ].join(' ')\r\n  );\r\n\r\n  //! model access points\r\n  readonly config = input.required<void, DigitInputConfig>({\r\n    transform: v => this.model.setConfig(v),\r\n  });\r\n  readonly configArrayData = this.model.configArrayData;\r\n\r\n  readonly transform = input<DigitInputTransform>(this._DEFAULTS.transform);\r\n\r\n  private _oldConfigArrayDataLength = -1;\r\n  readonly configArrayDataEffect = effect(() => {\r\n    if (this.configArrayData().length === this._oldConfigArrayDataLength) return;\r\n\r\n    this._oldConfigArrayDataLength = this.configArrayData().length;\r\n    this._emitChange();\r\n  });\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this._oldConfigArrayDataLength = this.configArrayData().length;\r\n  }\r\n\r\n  isInputEmpty(index: number): boolean {\r\n    return !this.model.isDefinedAtIndex(index);\r\n  }\r\n\r\n  //! control value accessor's write value implementation\r\n  private _valueBeforeViewInit?: any;\r\n  writeValue(v: any): void {\r\n    if (!this._wasViewInit) {\r\n      this._valueBeforeViewInit = v;\r\n      return;\r\n    }\r\n    this._writeValue(v);\r\n  }\r\n  private _writeValue(v: any): boolean {\r\n    return this.model.writeValue(v);\r\n  }\r\n\r\n  private _wasViewInit = false;\r\n  ngAfterViewInit(): void {\r\n    this._wasViewInit = true;\r\n\r\n    if (this._valueBeforeViewInit) {\r\n      this._writeValue(this._valueBeforeViewInit);\r\n    }\r\n\r\n    this._setInputAttributes();\r\n    this._subscribeToAutoFillOnInputs();\r\n  }\r\n\r\n  //! value two-way binding\r\n  readonly outputAsString = input<boolean, any>(this._DEFAULTS.outputAsString, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly outputControlValueAccessorOnFinish = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  @Input()\r\n  set value(v: string | (string | null)[] | null) {\r\n    this.writeValue(v);\r\n  }\r\n  readonly valueChange = output<string | (string | null)[] | null>();\r\n\r\n  readonly stringValue = this.model.stringValue;\r\n\r\n  readonly emittableValue = computed((): string | (string | null)[] | null => {\r\n    if (this.outputAsString()) return this.model.stringValue();\r\n    return this.model.value();\r\n  });\r\n\r\n  //! event emitters\r\n  readonly finishedValue = output<string | (string | null)[] | null>();\r\n\r\n  readonly focusIndexEvent = output<number>({ alias: 'focusIndex' });\r\n  readonly blurIndexEvent = output<number>({ alias: 'blurIndex' });\r\n\r\n  //! event handlers\r\n  onPaste(event: ClipboardEvent, index: number): void {\r\n    const value = event.clipboardData?.getData('text');\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    if (!value) return;\r\n\r\n    this._handleMultiDigitChange(value, index);\r\n  }\r\n  onInput(event: Event, index: number): void {\r\n    const value = (event.target as HTMLInputElement).value;\r\n    if (this.isAutofilled()) {\r\n      if (!this._wasAutofillValueRead()) {\r\n        this._wasAutofillValueRead.set(true);\r\n        setTimeout(() => {\r\n          this._wasAutofillValueRead.set(false);\r\n\r\n          const parsedValue = this.autoFillParseFn()(value);\r\n\r\n          this._handleMultiDigitChange(parsedValue, 0);\r\n        }, 0);\r\n      }\r\n      return;\r\n    }\r\n    const wasValidCharacter = this._updateSingleInputValue(value, index);\r\n    if (!wasValidCharacter) return;\r\n    this.focusByIndex(index + 1);\r\n  }\r\n  private _handleMultiDigitChange(value: string, startIndex: number): void {\r\n    const maxLength = this.inputs().length - startIndex;\r\n    value\r\n      .slice(0, maxLength)\r\n      .split('')\r\n      .forEach((char, i) => {\r\n        this.model.resetInputValue(startIndex + i);\r\n        this.model.validateInputAndSetValue(char, startIndex + i);\r\n      });\r\n\r\n    this.focusByIndex(startIndex - 1 + Math.min(value.length, maxLength));\r\n\r\n    this._emitChange();\r\n  }\r\n  private _updateSingleInputValue(value: string, index: number): boolean {\r\n    const changeResult = this.model.validateInputAndSetValue(value, index);\r\n\r\n    if (changeResult?.wasChanged) {\r\n      this._emitChange();\r\n    }\r\n\r\n    return changeResult?.wasValidChar ?? false;\r\n  }\r\n  focusByIndex(index: number): boolean;\r\n  focusByIndex(index: number, tryFocusingNext: boolean, direction: 1 | -1): boolean;\r\n  focusByIndex(index: number, tryFocusingNext?: boolean, direction?: 1 | -1): boolean {\r\n    if (index < 0 || index >= this.inputs().length) return false;\r\n    const nextEl = this.inputs()[index]?.nativeElement;\r\n    if (!nextEl) return false;\r\n\r\n    if (nextEl.getAttribute('data-ard-static') !== null) {\r\n      return this.focusByIndex(index + (direction ?? 1));\r\n    }\r\n    nextEl.focus();\r\n    if (tryFocusingNext && direction && document.activeElement !== nextEl) {\r\n      return this.focusByIndex(index + direction);\r\n    }\r\n    return document.activeElement === nextEl;\r\n  }\r\n  //focus, blur, change\r\n  onFocusMaster(event: FocusEvent, index: number): void {\r\n    this.focusIndexEvent.emit(index);\r\n    (event.target as HTMLInputElement).setSelectionRange(0, 1);\r\n\r\n    this.onFocus(event);\r\n  }\r\n  onBlurMaster(event: FocusEvent, index: number): void {\r\n    this.blurIndexEvent.emit(index);\r\n    this.onBlur(event);\r\n  }\r\n  protected _emitChange(): void {\r\n    const v = this.emittableValue();\r\n    if (!this.outputControlValueAccessorOnFinish() || this.model.isValueFull()) this._onChangeRegistered?.(v);\r\n    this.valueChange.emit(v);\r\n    if (this.model.isValueFull()) {\r\n      this.finishedValue.emit(v);\r\n    }\r\n  }\r\n  onKeydown(event: KeyboardEvent, index: number): void {\r\n    switch (event.key) {\r\n      case 'ArrowLeft':\r\n        this.focusByIndex(index - 1, true, -1);\r\n        return;\r\n      case 'ArrowRight':\r\n        this.focusByIndex(index + 1, true, +1);\r\n        return;\r\n      case 'Home':\r\n        this.focusByIndex(0, true, 1);\r\n        return;\r\n      case 'End':\r\n        this.focusByIndex(this.inputs.length - 1, true, -1);\r\n        return;\r\n      case 'Backspace':\r\n      case 'Delete':\r\n        this._updateSingleInputValue('', index);\r\n        this.focusByIndex(index - 1, true, -1);\r\n        event.preventDefault();\r\n        return;\r\n    }\r\n  }\r\n}\r\n","<div\r\n  class=\"ard-digit-input\"\r\n  [ngClass]=\"ngClasses()\"\r\n  [class.ard-has-error]=\"hasError()\"\r\n  [class.ard-is-success]=\"isSuccess()\"\r\n>\r\n  @for (data of configArrayData(); track $index) {\r\n  <div\r\n    class=\"ard-digit-input__item\"\r\n    [class.ard-digit-input__item-with-input]=\"data.type === 'input'\"\r\n  >\r\n    @if (data.type === 'input') {\r\n    <input\r\n      #input\r\n      #focusableElement\r\n      class=\"ard-digit-input__input\"\r\n      type=\"text\"\r\n      [readonly]=\"data.readonly\"\r\n      [placeholder]=\"data.placeholder\"\r\n      [attr.tabindex]=\"tabIndex()\"\r\n      [class.ard-digit-input__input-readonly]=\"data.readonly\"\r\n      [class.ard-digit-input__input-empty]=\"isInputEmpty(data.index!)\"\r\n      (paste)=\"onPaste($event, data.index!)\"\r\n      (input)=\"onInput($event, data.index!)\"\r\n      (focus)=\"onFocusMaster($event, data.index!)\"\r\n      (blur)=\"onBlurMaster($event, data.index!)\"\r\n      (keydown)=\"onKeydown($event, data.index!)\"\r\n    />\r\n    } @else {\r\n    <div class=\"ard-digit-input__static\">\r\n      {{ data.char }}\r\n    </div>\r\n    <input\r\n      #input\r\n      type=\"text\"\r\n      class=\"ard-digit-input__static-input\"\r\n      data-ard-static\r\n      autocomplete=\"off\"\r\n      tabindex=\"-1\"\r\n      aria-hidden=\"true\"\r\n      [value]=\"data.char\"\r\n    />\r\n    }\r\n  </div>\r\n  }\r\n</div>\r\n"]}
@@ -672,7 +672,7 @@ class ArdiumDigitInputComponent extends _FormFieldComponentBase {
672
672
  const attributes = {
673
673
  autocorrect: 'off',
674
674
  autocapitalize: 'off',
675
- autocomplete: 'postal-code',
675
+ autocomplete: 'off',
676
676
  ...this.inputAttrs(),
677
677
  };
678
678
  for (const key of Object.keys(attributes)) {
@@ -6549,6 +6549,13 @@ class SimpleItemStorage {
6549
6549
  selectItemByValue(modelValue);
6550
6550
  }
6551
6551
  }
6552
+ _validateSingleElementType(item) {
6553
+ if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {
6554
+ console.warn(`ARD-FT${this._ardParentComp._componentId}0: Setting object(${JSON.stringify(item)}) as your model with [valueFrom] is not allowed unless [compareWith] is used.`);
6555
+ return false;
6556
+ }
6557
+ return true;
6558
+ }
6552
6559
  /**
6553
6560
  * Validates that all values of the value to be written are able to be accurately compared against the storage items.
6554
6561
  *
@@ -6560,16 +6567,13 @@ class SimpleItemStorage {
6560
6567
  * @returns true if all items are valid, otherwise false.
6561
6568
  */
6562
6569
  _validateWriteValue(ngModel) {
6563
- if (!isArray(ngModel)) {
6564
- throw new Error(`ARD-FT${this._ardParentComp._componentId}0: <ard-${this._ardParentComp._componentName}> expects its value to be an array, got "${ngModel}".`);
6565
- }
6566
- return ngModel.every(item => {
6567
- if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {
6568
- console.warn(`ARD-FT${this._ardParentComp._componentId}0: Setting object(${JSON.stringify(item)}) as your model with [valueFrom] is not allowed unless [compareWith] is used.`);
6569
- return false;
6570
+ if (this._ardParentComp.multiselectable()) {
6571
+ if (!isArray(ngModel)) {
6572
+ throw new Error(`ARD-FT${this._ardParentComp._componentId}0: <ard-${this._ardParentComp._componentName}> expects its value to be an array, got "${ngModel}".`);
6570
6573
  }
6571
- return true;
6572
- });
6574
+ return ngModel.every(this._validateSingleElementType);
6575
+ }
6576
+ return this._validateSingleElementType(ngModel);
6573
6577
  }
6574
6578
  findItemByValue(valueToFind) {
6575
6579
  let findBy;