@ardium-ui/ui 3.3.0-alpha.5 → 3.3.0-alpha.6

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.
@@ -1,6 +1,6 @@
1
1
  import { computed, signal } from '@angular/core';
2
2
  import { resolvePath } from 'resolve-object-path';
3
- import { evaluate, isDefined, isObject, isPrimitive } from 'simple-bool';
3
+ import { evaluate, isArray, isDefined, isObject, isPrimitive } from 'simple-bool';
4
4
  export class SimpleItemStorage {
5
5
  constructor(_ardParentComp) {
6
6
  this._ardParentComp = _ardParentComp;
@@ -137,6 +137,9 @@ export class SimpleItemStorage {
137
137
  * @returns true if all items are valid, otherwise false.
138
138
  */
139
139
  _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
+ }
140
143
  return ngModel.every(item => {
141
144
  if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {
142
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.`);
@@ -340,4 +343,4 @@ export class SimpleItemStorage {
340
343
  return this.highlightSingleItem(itemToHighlight);
341
344
  }
342
345
  }
343
- //# 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';\nimport { resolvePath } from 'resolve-object-path';\nimport { evaluate, isDefined, isObject, isPrimitive } from 'simple-bool';\nimport { ArdOptionSimple, CompareWithFn } from '../../types/item-storage.types';\nimport { Nullable } from '../../types/utility.types';\n\nexport interface ItemStorageHostDefaults {\n  valueFrom: string;\n  labelFrom: string;\n  disabledFrom: string;\n}\nexport interface SimpleItemStorageHost {\n  readonly valueFrom: Signal<Nullable<string>>;\n  readonly labelFrom: Signal<Nullable<string>>;\n  readonly disabledFrom: Signal<Nullable<string>>;\n  readonly invertDisabled: Signal<boolean>;\n  readonly DEFAULTS: ItemStorageHostDefaults;\n  readonly compareWith: Signal<Nullable<CompareWithFn>>;\n  readonly multiselectable: Signal<boolean>;\n  readonly isValueRequired: Signal<boolean>;\n  readonly maxSelectedItems: Signal<Nullable<number>>;\n  readonly _componentId: string;\n}\n\nexport class SimpleItemStorage {\n  private readonly _items = signal<ArdOptionSimple[]>([]);\n  private readonly _highlightedItems = signal<ArdOptionSimple[]>([]);\n  private readonly _selectedItems = signal<ArdOptionSimple[]>([]);\n\n  constructor(private readonly _ardParentComp: SimpleItemStorageHost) {}\n\n  /**\n   * Gets all items.\n   */\n  readonly items = this._items.asReadonly();\n  /**\n   * Gets all currently highlighted items.\n   */\n  readonly highlightedItems = this._highlightedItems.asReadonly();\n  /**\n   * Gets all currently selected items.\n   */\n  readonly selectedItems = this._selectedItems.asReadonly();\n  /**\n   * Gets the values of the currently selected items.\n   */\n  readonly value = computed(() => this._itemsToValue(this._selectedItems()));\n  /**\n   * Maps an array of items into their values.\n   * @param items The items to convert to value.\n   * @returns An array of item values.\n   */\n  private _itemsToValue(items: ArdOptionSimple[]): any[] {\n    return items.map(item => item.value());\n  }\n\n  /**\n   * Returns true if at least one item is highlighted, otherwise false.\n   */\n  readonly isAnyItemHighlighted = computed(() => this._highlightedItems().length > 0);\n  /**\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.\n   *\n   * **TLDR**: true if `maxSelectedItems` is defined and the number of selected items matches that value.\n   */\n  readonly isItemLimitReached = computed(() => {\n    const msi = this._ardParentComp.maxSelectedItems();\n    if (!this._ardParentComp.multiselectable() || !isDefined(msi)) {\n      return false;\n    }\n    return msi <= this.selectedItems().length;\n  });\n\n  /**\n   * Sets the component's items. Takes into account the values defined by the parent component for `valueFrom`, `labelFrom`, and `disabledFrom`.\n   * @param items An array of items to be set as the component's items.\n   * @returns true if at least one of the items is of primitive type, otherwise false.\n   */\n  setItems(items: unknown[]): void {\n    let areItemsPrimitive = false;\n    if (items.some(isPrimitive)) {\n      items = items.map(this._primitiveItemsMapFn);\n      areItemsPrimitive = true;\n    }\n\n    this._items.set(\n      items.map((item, index) => {\n        return this._setItemsMapFn(item, index, areItemsPrimitive);\n      })\n    );\n  }\n  private _primitiveItemsMapFn<T>(item: T): { value: T } {\n    return { value: item };\n  }\n  private _setItemsMapFn(rawItemData: any, index: number, areItemsPrimitive: boolean): ArdOptionSimple {\n    if (areItemsPrimitive) {\n      return {\n        itemData: signal(rawItemData),\n        index: index,\n        value: signal(rawItemData.value),\n        label: signal(rawItemData.value?.toString?.() ?? String(rawItemData.value)),\n        disabled: signal(false),\n        selected: signal(false),\n        highlighted: signal(false),\n      };\n    }\n    //get value\n    const valuePath =\n      this._ardParentComp.valueFrom() ?? this._ardParentComp.labelFrom() ?? this._ardParentComp.DEFAULTS.valueFrom;\n    const value = resolvePath(rawItemData, valuePath);\n\n    //get label\n    const labelPath =\n      this._ardParentComp.labelFrom() ?? this._ardParentComp.valueFrom() ?? this._ardParentComp.DEFAULTS.labelFrom;\n    const label = resolvePath(rawItemData, labelPath) ?? value;\n\n    //get disabled\n    const disabledPath = this._ardParentComp.disabledFrom() ?? this._ardParentComp.DEFAULTS.disabledFrom;\n    let disabled = evaluate(resolvePath(rawItemData, disabledPath));\n    if (this._ardParentComp.invertDisabled()) {\n      disabled = !disabled;\n    }\n\n    //return\n    return {\n      itemData: signal(rawItemData),\n      index: index,\n      value: signal(value),\n      label: signal(label?.toString?.() ?? String(label)),\n      disabled: signal(disabled),\n      selected: signal(false),\n      highlighted: signal(false),\n    };\n  }\n  /**\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.\n   * @param ngModel The value of the ngModel to set.\n   */\n  writeValue(ngModel: any[]): void {\n    this._forceUnselectAll();\n\n    if (!this._validateWriteValue(ngModel)) return;\n\n    const selectItemByValue = (value: any) => {\n      const item = this.findItemByValue(value);\n\n      if (item) {\n        this.selectItem(item);\n        return;\n      }\n      console.warn(\n        `ARD-WA${this._ardParentComp._componentId}1: Couldn't find an item with value ${value?.toString?.() || String(value)}.`\n      );\n    };\n\n    for (const modelValue of ngModel) {\n      selectItemByValue(modelValue);\n    }\n  }\n  /**\n   * Validates that all values of the value to be written are able to be accurately compared against the storage items.\n   *\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:\n   * 1. The parent component defines the `compareWith` property.\n   * 2. The ngModel value item is an object (or array).\n   * 3. The parent component has a defined `valueFrom` property.\n   * @param ngModel The value of ngModel to validate.\n   * @returns true if all items are valid, otherwise false.\n   */\n  private _validateWriteValue(ngModel: any[]): boolean {\n    return ngModel.every(item => {\n      if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {\n        console.warn(\n          `ARD-FT${this._ardParentComp._componentId}0: Setting object(${JSON.stringify(\n            item\n          )}) as your model with [valueFrom] is not allowed unless [compareWith] is used.`\n        );\n        return false;\n      }\n      return true;\n    });\n  }\n  findItemByValue(valueToFind: any): ArdOptionSimple | undefined {\n    let findBy: (item: ArdOptionSimple) => boolean;\n    const cmpFn = this._ardParentComp.compareWith();\n    if (isDefined(cmpFn)) {\n      findBy = item => cmpFn(valueToFind, item.value());\n    } else {\n      findBy = item => item.value() === valueToFind;\n    }\n    return this._items().find(item => findBy(item));\n  }\n\n  /**\n   * Unselects all selected items.\n   *\n   * If the parent component requires at least one value to be selected at all times, the first selected items is left selected.\n   * @returns An array of items cleared, mapped to only their values.\n   */\n  unselectAll(): any[] {\n    for (const item of this._selectedItems()) {\n      item.selected.set(false);\n    }\n\n    const ret = this.value();\n\n    if (this._ardParentComp.isValueRequired() && this._selectedItems().length > 0) {\n      this._selectedItems().first().selected.set(true);\n      ret.splice(0, 1);\n    }\n\n    this._selectedItems.set([]);\n\n    return ret;\n  }\n  /**\n   * Unselects all selected items, no matter what the component settings are.\n   * @returns An array of items cleared, mapped to only their values.\n   */\n  private _forceUnselectAll(): any[] {\n    for (const item of this._selectedItems()) {\n      item.selected.set(false);\n    }\n\n    const ret = this._itemsToValue(this._selectedItems());\n\n    this._selectedItems.set([]);\n\n    return ret;\n  }\n  /**\n   * Selects one or multiple items.\n   *\n   * Accounts for the limit of concurrently selected items defined by the parent component.\n   * @param items A rest operator array of item objects to be selected.\n   * @returns A tuple containing three arrays, all mapped to only their values:\n   * - An array of items selected,\n   * - An array of items unselected,\n   * - An array of items failed to select due to the limit.\n   */\n  selectItem(...items: ArdOptionSimple[]): [any[], any[], any[]] {\n    if (this.isItemLimitReached()) {\n      return [[], [], this._itemsToValue(items)];\n    }\n    let unselected = [];\n    if (!this._ardParentComp.multiselectable()) {\n      unselected = this._forceUnselectAll();\n    }\n\n    let itemsSelectedCount = 0;\n    const itemsSelected: ArdOptionSimple[] = [];\n    for (const item of items) {\n      itemsSelectedCount++;\n      if (item.selected()) continue;\n      if (this.isItemLimitReached()) {\n        break;\n      }\n      item.selected.set(true);\n      itemsSelected.push(item);\n    }\n    this._selectedItems.update(v => [...v, ...itemsSelected]);\n\n    const itemsFailedToSelect = items.slice(itemsSelectedCount - 1);\n    return [this._itemsToValue(itemsSelected), unselected, this._itemsToValue(itemsFailedToSelect)];\n  }\n  /**\n   *\n   * @param items A rest operator array of item objects to be unselected.\n   * @returns An array of items unselected, mapped to only their values.\n   */\n  unselectItem(...items: ArdOptionSimple[]): any[] {\n    let skippedItem = false;\n    for (const item of items) {\n      if (this._ardParentComp.isValueRequired() && !skippedItem) {\n        skippedItem = true;\n        continue;\n      }\n\n      if (!item.selected()) continue;\n      item.selected.set(false);\n    }\n    this._selectedItems.update(v => v.filter(v => v.selected()));\n\n    return this._itemsToValue(items);\n  }\n\n  /**\n   * Unhighlights all currently highlighted items.\n   */\n  unhighlightAll(): void {\n    for (const item of this._highlightedItems()) {\n      item.highlighted.set(false);\n    }\n    this._highlightedItems.set([]);\n  }\n  /**\n   * Highlights the given item, while unhighlighting all other items. Does nothing when the item is disabled.\n   * @param item The item to be highlighted.\n   * @returns The highlighted item.\n   */\n  highlightSingleItem(item: ArdOptionSimple): ArdOptionSimple | null {\n    if (!item || item.disabled()) return null;\n    this.unhighlightAll();\n    return this.highlightItem(item);\n  }\n  /**\n   * Highlights all given items.\n   * @param items A rest operator array of items to be highlighted.\n   * @returns The last highlighted item.\n   */\n  highlightItem(...items: ArdOptionSimple[]): ArdOptionSimple {\n    for (const item of items) {\n      item.highlighted.set(true);\n    }\n    this._highlightedItems.update(v => [...v, ...items]);\n    return items.last();\n  }\n  /**\n   * Unhighlights all given items.\n   * @param items A rest operator array of items to be unhighlighted.\n   */\n  unhighlightItem(...items: ArdOptionSimple[]): void {\n    for (const item of items) {\n      if (!item || !item.highlighted()) return;\n\n      item.highlighted.set(false);\n    }\n    this._highlightedItems.update(v => v.filter(v => v.highlighted()));\n  }\n  /**\n   * Highlights the first item out of all items.\n   * @returns The highlighted item.\n   */\n  highlightFirstItem(): ArdOptionSimple | null {\n    this.unhighlightAll();\n\n    const itemToHighlight = this.highlightableItems().first();\n    return this.highlightItem(itemToHighlight);\n  }\n  /**\n   * Highlights the last item out of all items.\n   * @returns The highlighted item.\n   */\n  highlightLastItem(): ArdOptionSimple | null {\n    this.unhighlightAll();\n\n    const itemToHighlight = this.highlightableItems().last();\n    return this.highlightItem(itemToHighlight);\n  }\n  /**\n   * Highlights all non-disabled items.\n   */\n  highlightAllItems(): void {\n    const itemsToHighlight = this.highlightableItems();\n\n    this.highlightItem(...itemsToHighlight);\n  }\n  /**\n   * Highlights the next non-disabled item defined by the offset amount.\n   *\n   * If `hasShift` is set to true, all originally highlighted items are kept. Otherwise, all original items are unselected.\n   * @param offset The amount of items to offset the highlight by.\n   * @param hasShift Whether the user has the shift key pressed.\n   * @returns The item highlighted.\n   */\n  highlightNextItem(offset: number, hasShift?: boolean): ArdOptionSimple | null {\n    if (!this.isAnyItemHighlighted()) {\n      return this.highlightFirstItem();\n    }\n    const currentItem = this.highlightedItems().last();\n    const itemsWithoutDisabled = this._items().filter(\n      item => !item.disabled() && (!this.isItemLimitReached() || item.selected())\n    );\n    const currentIndexInItems = itemsWithoutDisabled.findIndex(item => item.index === currentItem.index);\n\n    let nextItemIndex = currentIndexInItems + offset;\n    if (nextItemIndex >= itemsWithoutDisabled.length) {\n      nextItemIndex -= itemsWithoutDisabled.length;\n    }\n    if (nextItemIndex < 0) {\n      nextItemIndex += itemsWithoutDisabled.length;\n    }\n    const itemToHighlight = itemsWithoutDisabled[nextItemIndex];\n\n    if (hasShift && this._ardParentComp.multiselectable()) {\n      if (itemToHighlight.highlighted()) {\n        this.unhighlightItem(currentItem);\n      }\n      return this.highlightItem(itemToHighlight);\n    }\n    return this.highlightSingleItem(itemToHighlight);\n  }\n  /**\n   * Finds all highlightable items. An item is considered highlightable if it is **not** disabled.\n   * @returns An array of all highlightable items.\n   */\n  private readonly highlightableItems = computed(() => this._items().filter(item => !item.disabled()));\n}\n"]}
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';\nimport { resolvePath } from 'resolve-object-path';\nimport { evaluate, isArray, isDefined, isObject, isPrimitive } from 'simple-bool';\nimport { ArdOptionSimple, CompareWithFn } from '../../types/item-storage.types';\nimport { Nullable } from '../../types/utility.types';\n\nexport interface ItemStorageHostDefaults {\n  valueFrom: string;\n  labelFrom: string;\n  disabledFrom: string;\n}\nexport interface SimpleItemStorageHost {\n  readonly valueFrom: Signal<Nullable<string>>;\n  readonly labelFrom: Signal<Nullable<string>>;\n  readonly disabledFrom: Signal<Nullable<string>>;\n  readonly invertDisabled: Signal<boolean>;\n  readonly DEFAULTS: ItemStorageHostDefaults;\n  readonly compareWith: Signal<Nullable<CompareWithFn>>;\n  readonly multiselectable: Signal<boolean>;\n  readonly isValueRequired: Signal<boolean>;\n  readonly maxSelectedItems: Signal<Nullable<number>>;\n  readonly _componentId: string;\n  readonly _componentName: string;\n}\n\nexport class SimpleItemStorage {\n  private readonly _items = signal<ArdOptionSimple[]>([]);\n  private readonly _highlightedItems = signal<ArdOptionSimple[]>([]);\n  private readonly _selectedItems = signal<ArdOptionSimple[]>([]);\n\n  constructor(private readonly _ardParentComp: SimpleItemStorageHost) {}\n\n  /**\n   * Gets all items.\n   */\n  readonly items = this._items.asReadonly();\n  /**\n   * Gets all currently highlighted items.\n   */\n  readonly highlightedItems = this._highlightedItems.asReadonly();\n  /**\n   * Gets all currently selected items.\n   */\n  readonly selectedItems = this._selectedItems.asReadonly();\n  /**\n   * Gets the values of the currently selected items.\n   */\n  readonly value = computed(() => this._itemsToValue(this._selectedItems()));\n  /**\n   * Maps an array of items into their values.\n   * @param items The items to convert to value.\n   * @returns An array of item values.\n   */\n  private _itemsToValue(items: ArdOptionSimple[]): any[] {\n    return items.map(item => item.value());\n  }\n\n  /**\n   * Returns true if at least one item is highlighted, otherwise false.\n   */\n  readonly isAnyItemHighlighted = computed(() => this._highlightedItems().length > 0);\n  /**\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.\n   *\n   * **TLDR**: true if `maxSelectedItems` is defined and the number of selected items matches that value.\n   */\n  readonly isItemLimitReached = computed(() => {\n    const msi = this._ardParentComp.maxSelectedItems();\n    if (!this._ardParentComp.multiselectable() || !isDefined(msi)) {\n      return false;\n    }\n    return msi <= this.selectedItems().length;\n  });\n\n  /**\n   * Sets the component's items. Takes into account the values defined by the parent component for `valueFrom`, `labelFrom`, and `disabledFrom`.\n   * @param items An array of items to be set as the component's items.\n   * @returns true if at least one of the items is of primitive type, otherwise false.\n   */\n  setItems(items: unknown[]): void {\n    let areItemsPrimitive = false;\n    if (items.some(isPrimitive)) {\n      items = items.map(this._primitiveItemsMapFn);\n      areItemsPrimitive = true;\n    }\n\n    this._items.set(\n      items.map((item, index) => {\n        return this._setItemsMapFn(item, index, areItemsPrimitive);\n      })\n    );\n  }\n  private _primitiveItemsMapFn<T>(item: T): { value: T } {\n    return { value: item };\n  }\n  private _setItemsMapFn(rawItemData: any, index: number, areItemsPrimitive: boolean): ArdOptionSimple {\n    if (areItemsPrimitive) {\n      return {\n        itemData: signal(rawItemData),\n        index: index,\n        value: signal(rawItemData.value),\n        label: signal(rawItemData.value?.toString?.() ?? String(rawItemData.value)),\n        disabled: signal(false),\n        selected: signal(false),\n        highlighted: signal(false),\n      };\n    }\n    //get value\n    const valuePath =\n      this._ardParentComp.valueFrom() ?? this._ardParentComp.labelFrom() ?? this._ardParentComp.DEFAULTS.valueFrom;\n    const value = resolvePath(rawItemData, valuePath);\n\n    //get label\n    const labelPath =\n      this._ardParentComp.labelFrom() ?? this._ardParentComp.valueFrom() ?? this._ardParentComp.DEFAULTS.labelFrom;\n    const label = resolvePath(rawItemData, labelPath) ?? value;\n\n    //get disabled\n    const disabledPath = this._ardParentComp.disabledFrom() ?? this._ardParentComp.DEFAULTS.disabledFrom;\n    let disabled = evaluate(resolvePath(rawItemData, disabledPath));\n    if (this._ardParentComp.invertDisabled()) {\n      disabled = !disabled;\n    }\n\n    //return\n    return {\n      itemData: signal(rawItemData),\n      index: index,\n      value: signal(value),\n      label: signal(label?.toString?.() ?? String(label)),\n      disabled: signal(disabled),\n      selected: signal(false),\n      highlighted: signal(false),\n    };\n  }\n  /**\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.\n   * @param ngModel The value of the ngModel to set.\n   */\n  writeValue(ngModel: any[]): void {\n    this._forceUnselectAll();\n\n    if (!this._validateWriteValue(ngModel)) return;\n\n    const selectItemByValue = (value: any) => {\n      const item = this.findItemByValue(value);\n\n      if (item) {\n        this.selectItem(item);\n        return;\n      }\n      console.warn(\n        `ARD-WA${this._ardParentComp._componentId}1: Couldn't find an item with value ${value?.toString?.() || String(value)}.`\n      );\n    };\n\n    for (const modelValue of ngModel) {\n      selectItemByValue(modelValue);\n    }\n  }\n  /**\n   * Validates that all values of the value to be written are able to be accurately compared against the storage items.\n   *\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:\n   * 1. The parent component defines the `compareWith` property.\n   * 2. The ngModel value item is an object (or array).\n   * 3. The parent component has a defined `valueFrom` property.\n   * @param ngModel The value of ngModel to validate.\n   * @returns true if all items are valid, otherwise false.\n   */\n  private _validateWriteValue(ngModel: unknown): boolean {\n    if (!isArray(ngModel)) {\n      throw new Error(\n        `ARD-FT${this._ardParentComp._componentId}0: <ard-${this._ardParentComp._componentName}> expects its value to be an array, got \"${ngModel}\".`\n      );\n    }\n    return ngModel.every(item => {\n      if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {\n        console.warn(\n          `ARD-FT${this._ardParentComp._componentId}0: Setting object(${JSON.stringify(\n            item\n          )}) as your model with [valueFrom] is not allowed unless [compareWith] is used.`\n        );\n        return false;\n      }\n      return true;\n    });\n  }\n  findItemByValue(valueToFind: any): ArdOptionSimple | undefined {\n    let findBy: (item: ArdOptionSimple) => boolean;\n    const cmpFn = this._ardParentComp.compareWith();\n    if (isDefined(cmpFn)) {\n      findBy = item => cmpFn(valueToFind, item.value());\n    } else {\n      findBy = item => item.value() === valueToFind;\n    }\n    return this._items().find(item => findBy(item));\n  }\n\n  /**\n   * Unselects all selected items.\n   *\n   * If the parent component requires at least one value to be selected at all times, the first selected items is left selected.\n   * @returns An array of items cleared, mapped to only their values.\n   */\n  unselectAll(): any[] {\n    for (const item of this._selectedItems()) {\n      item.selected.set(false);\n    }\n\n    const ret = this.value();\n\n    if (this._ardParentComp.isValueRequired() && this._selectedItems().length > 0) {\n      this._selectedItems().first().selected.set(true);\n      ret.splice(0, 1);\n    }\n\n    this._selectedItems.set([]);\n\n    return ret;\n  }\n  /**\n   * Unselects all selected items, no matter what the component settings are.\n   * @returns An array of items cleared, mapped to only their values.\n   */\n  private _forceUnselectAll(): any[] {\n    for (const item of this._selectedItems()) {\n      item.selected.set(false);\n    }\n\n    const ret = this._itemsToValue(this._selectedItems());\n\n    this._selectedItems.set([]);\n\n    return ret;\n  }\n  /**\n   * Selects one or multiple items.\n   *\n   * Accounts for the limit of concurrently selected items defined by the parent component.\n   * @param items A rest operator array of item objects to be selected.\n   * @returns A tuple containing three arrays, all mapped to only their values:\n   * - An array of items selected,\n   * - An array of items unselected,\n   * - An array of items failed to select due to the limit.\n   */\n  selectItem(...items: ArdOptionSimple[]): [any[], any[], any[]] {\n    if (this.isItemLimitReached()) {\n      return [[], [], this._itemsToValue(items)];\n    }\n    let unselected = [];\n    if (!this._ardParentComp.multiselectable()) {\n      unselected = this._forceUnselectAll();\n    }\n\n    let itemsSelectedCount = 0;\n    const itemsSelected: ArdOptionSimple[] = [];\n    for (const item of items) {\n      itemsSelectedCount++;\n      if (item.selected()) continue;\n      if (this.isItemLimitReached()) {\n        break;\n      }\n      item.selected.set(true);\n      itemsSelected.push(item);\n    }\n    this._selectedItems.update(v => [...v, ...itemsSelected]);\n\n    const itemsFailedToSelect = items.slice(itemsSelectedCount - 1);\n    return [this._itemsToValue(itemsSelected), unselected, this._itemsToValue(itemsFailedToSelect)];\n  }\n  /**\n   *\n   * @param items A rest operator array of item objects to be unselected.\n   * @returns An array of items unselected, mapped to only their values.\n   */\n  unselectItem(...items: ArdOptionSimple[]): any[] {\n    let skippedItem = false;\n    for (const item of items) {\n      if (this._ardParentComp.isValueRequired() && !skippedItem) {\n        skippedItem = true;\n        continue;\n      }\n\n      if (!item.selected()) continue;\n      item.selected.set(false);\n    }\n    this._selectedItems.update(v => v.filter(v => v.selected()));\n\n    return this._itemsToValue(items);\n  }\n\n  /**\n   * Unhighlights all currently highlighted items.\n   */\n  unhighlightAll(): void {\n    for (const item of this._highlightedItems()) {\n      item.highlighted.set(false);\n    }\n    this._highlightedItems.set([]);\n  }\n  /**\n   * Highlights the given item, while unhighlighting all other items. Does nothing when the item is disabled.\n   * @param item The item to be highlighted.\n   * @returns The highlighted item.\n   */\n  highlightSingleItem(item: ArdOptionSimple): ArdOptionSimple | null {\n    if (!item || item.disabled()) return null;\n    this.unhighlightAll();\n    return this.highlightItem(item);\n  }\n  /**\n   * Highlights all given items.\n   * @param items A rest operator array of items to be highlighted.\n   * @returns The last highlighted item.\n   */\n  highlightItem(...items: ArdOptionSimple[]): ArdOptionSimple {\n    for (const item of items) {\n      item.highlighted.set(true);\n    }\n    this._highlightedItems.update(v => [...v, ...items]);\n    return items.last();\n  }\n  /**\n   * Unhighlights all given items.\n   * @param items A rest operator array of items to be unhighlighted.\n   */\n  unhighlightItem(...items: ArdOptionSimple[]): void {\n    for (const item of items) {\n      if (!item || !item.highlighted()) return;\n\n      item.highlighted.set(false);\n    }\n    this._highlightedItems.update(v => v.filter(v => v.highlighted()));\n  }\n  /**\n   * Highlights the first item out of all items.\n   * @returns The highlighted item.\n   */\n  highlightFirstItem(): ArdOptionSimple | null {\n    this.unhighlightAll();\n\n    const itemToHighlight = this.highlightableItems().first();\n    return this.highlightItem(itemToHighlight);\n  }\n  /**\n   * Highlights the last item out of all items.\n   * @returns The highlighted item.\n   */\n  highlightLastItem(): ArdOptionSimple | null {\n    this.unhighlightAll();\n\n    const itemToHighlight = this.highlightableItems().last();\n    return this.highlightItem(itemToHighlight);\n  }\n  /**\n   * Highlights all non-disabled items.\n   */\n  highlightAllItems(): void {\n    const itemsToHighlight = this.highlightableItems();\n\n    this.highlightItem(...itemsToHighlight);\n  }\n  /**\n   * Highlights the next non-disabled item defined by the offset amount.\n   *\n   * If `hasShift` is set to true, all originally highlighted items are kept. Otherwise, all original items are unselected.\n   * @param offset The amount of items to offset the highlight by.\n   * @param hasShift Whether the user has the shift key pressed.\n   * @returns The item highlighted.\n   */\n  highlightNextItem(offset: number, hasShift?: boolean): ArdOptionSimple | null {\n    if (!this.isAnyItemHighlighted()) {\n      return this.highlightFirstItem();\n    }\n    const currentItem = this.highlightedItems().last();\n    const itemsWithoutDisabled = this._items().filter(\n      item => !item.disabled() && (!this.isItemLimitReached() || item.selected())\n    );\n    const currentIndexInItems = itemsWithoutDisabled.findIndex(item => item.index === currentItem.index);\n\n    let nextItemIndex = currentIndexInItems + offset;\n    if (nextItemIndex >= itemsWithoutDisabled.length) {\n      nextItemIndex -= itemsWithoutDisabled.length;\n    }\n    if (nextItemIndex < 0) {\n      nextItemIndex += itemsWithoutDisabled.length;\n    }\n    const itemToHighlight = itemsWithoutDisabled[nextItemIndex];\n\n    if (hasShift && this._ardParentComp.multiselectable()) {\n      if (itemToHighlight.highlighted()) {\n        this.unhighlightItem(currentItem);\n      }\n      return this.highlightItem(itemToHighlight);\n    }\n    return this.highlightSingleItem(itemToHighlight);\n  }\n  /**\n   * Finds all highlightable items. An item is considered highlightable if it is **not** disabled.\n   * @returns An array of all highlightable items.\n   */\n  private readonly highlightableItems = computed(() => this._items().filter(item => !item.disabled()));\n}\n"]}
@@ -1,10 +1,10 @@
1
1
  import { ChangeDetectorRef, Directive, HostBinding, HostListener, Input, computed, inject, input, output, signal, } from '@angular/core';
2
2
  import { coerceArrayProperty, coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';
3
+ import { _FormFieldComponentBase, _formFieldComponentDefaults } from './form-field-component';
3
4
  import { SimpleItemStorage } from './item-storages/simple-item-storage';
4
- import { _NgModelComponentBase, _ngModelComponentDefaults } from './ngmodel-component';
5
5
  import * as i0 from "@angular/core";
6
6
  export const _selectableListComponentDefaults = {
7
- ..._ngModelComponentDefaults,
7
+ ..._formFieldComponentDefaults,
8
8
  valueFrom: 'value',
9
9
  labelFrom: 'label',
10
10
  disabledFrom: 'disabled',
@@ -14,7 +14,7 @@ export const _selectableListComponentDefaults = {
14
14
  invertDisabled: false,
15
15
  maxSelectedItems: undefined,
16
16
  };
17
- export class _SelectableListComponentBase extends _NgModelComponentBase {
17
+ export class _SelectableListComponentBase extends _FormFieldComponentBase {
18
18
  constructor() {
19
19
  super(...arguments);
20
20
  //! public constants
@@ -268,4 +268,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
268
268
  type: HostListener,
269
269
  args: ['keydown', ['$event']]
270
270
  }] } });
271
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selectable-list-component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/_internal/selectable-list-component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Directive,\n  HostBinding,\n  HostListener,\n  Input,\n  computed,\n  inject,\n  input,\n  output,\n  signal,\n} from '@angular/core';\nimport { ControlValueAccessor } from '@angular/forms';\nimport { coerceArrayProperty, coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\nimport { ArdOptionSimple, CompareWithFn, OptionContext } from '../types/item-storage.types';\nimport { Nullable } from '../types/utility.types';\nimport { SimpleItemStorage, SimpleItemStorageHost } from './item-storages/simple-item-storage';\nimport { _NgModelComponentBase, _NgModelComponentDefaults, _ngModelComponentDefaults } from './ngmodel-component';\n\nexport interface _SelectableListComponentDefaults extends _NgModelComponentDefaults {\n  valueFrom: string;\n  labelFrom: string;\n  disabledFrom: string;\n  compareWith: Nullable<CompareWithFn>;\n  multiselectable: boolean;\n  requireValue: boolean;\n  invertDisabled: boolean;\n  maxSelectedItems: Nullable<number>;\n}\nexport const _selectableListComponentDefaults: _SelectableListComponentDefaults = {\n  ..._ngModelComponentDefaults,\n  valueFrom: 'value',\n  labelFrom: 'label',\n  disabledFrom: 'disabled',\n  compareWith: undefined,\n  multiselectable: false,\n  requireValue: false,\n  invertDisabled: false,\n  maxSelectedItems: undefined,\n};\n\n@Directive()\nexport abstract class _SelectableListComponentBase\n  extends _NgModelComponentBase\n  implements ControlValueAccessor, SimpleItemStorageHost\n{\n  protected override readonly _DEFAULTS!: _SelectableListComponentDefaults;\n\n  //! public constants\n  readonly itemStorage = new SimpleItemStorage(this);\n  readonly element!: HTMLElement;\n  readonly DEFAULTS = this._DEFAULTS;\n\n  abstract readonly _componentId: string;\n  abstract readonly _componentName: string;\n\n  private readonly _cd = inject(ChangeDetectorRef);\n\n  //! binding-related inputs\n  readonly valueFrom = input<string>(this._DEFAULTS.valueFrom);\n  readonly labelFrom = input<string>(this._DEFAULTS.labelFrom);\n  readonly disabledFrom = input<string>(this._DEFAULTS.disabledFrom);\n  readonly compareWith = input<Nullable<CompareWithFn>>(this._DEFAULTS.compareWith);\n\n  //! items setter/getter\n  @Input()\n  get items(): any[] {\n    return this.itemStorage.items();\n  }\n  set items(value: any) {\n    if (!Array.isArray(value)) value = coerceArrayProperty(value);\n\n    this.itemStorage.setItems(value);\n  }\n\n  //! multiselectable\n  readonly multiselectable = input<boolean, any>(this._DEFAULTS.multiselectable, { transform: v => coerceBooleanProperty(v) });\n\n  @HostBinding('attr.multiple')\n  @HostBinding('class.ard-multiselect')\n  get _multiselectableHostAttribute() {\n    return this.multiselectable();\n  }\n\n  readonly singleselectable = computed(() => !this.multiselectable());\n\n  //! require value\n  readonly requireValue = input<boolean, any>(this._DEFAULTS.requireValue, { transform: v => coerceBooleanProperty(v) });\n\n  readonly isValueRequired = computed(() => this.requireValue() || !this.multiselectable());\n\n  @HostBinding('class.ard-require-value')\n  get _requireValueHostAttribute() {\n    return this.requireValue();\n  }\n\n  //! coerced properties\n  readonly invertDisabled = input<boolean, any>(this._DEFAULTS.invertDisabled, { transform: v => coerceBooleanProperty(v) });\n  readonly maxSelectedItems = input<Nullable<number>, any>(this._DEFAULTS.maxSelectedItems, {\n    transform: v => coerceNumberProperty(v, undefined),\n  });\n\n  //! control value accessor\n  //override the writeValue and setDisabledState defined in _NgModelComponent\n  override setDisabledState(state: boolean): void {\n    this.disabled.set(state);\n    this._cd.markForCheck();\n  }\n  writeValue(ngModel: any[]): void {\n    this.itemStorage.writeValue(ngModel);\n    this._cd.markForCheck();\n  }\n\n  //! change & touch event emitters\n  readonly touched = signal<boolean>(false);\n\n  @HostBinding('class.ard-touched')\n  get _touchedHostAttribute(): boolean {\n    return this.touched();\n  }\n\n  protected _emitChange(): void {\n    const value = this.itemStorage.value();\n    this._onChangeRegistered?.(value);\n    this.changeEvent.emit(value);\n    this.valueChange.emit(value);\n  }\n  protected _onTouched(): void {\n    if (this.touched()) return;\n\n    this._onTouchedRegistered?.();\n    this.touched.set(true);\n  }\n\n  //! focus & blur handlers\n  private readonly lastBlurTimestamp = signal<Nullable<number>>(undefined);\n  override onFocus(event: FocusEvent): void {\n    super.onFocus(event);\n\n    const lbt = this.lastBlurTimestamp();\n    if (this.touched() || !lbt || lbt + 1 < Date.now()) return;\n    this.lastBlurTimestamp.set(null);\n\n    this._onTouched();\n  }\n  override onBlur(event: FocusEvent): void {\n    super.onBlur(event);\n\n    if (!this.touched()) this.lastBlurTimestamp.set(Date.now());\n  }\n\n  //! getters\n  readonly highlightedItems = computed<ArdOptionSimple[]>(() => this.itemStorage.highlightedItems());\n  readonly firstHighlightedItem = computed<Nullable<ArdOptionSimple>>(() => this.highlightedItems()?.first());\n  readonly isItemLimitReached = computed(() => this.itemStorage.isItemLimitReached());\n\n  //! context providers\n  getOptionContext(item: ArdOptionSimple): OptionContext<ArdOptionSimple> {\n    return {\n      $implicit: item,\n      item,\n      itemData: item.itemData(),\n    };\n  }\n\n  //! value input & output\n  @Input()\n  set value(newValue: any) {\n    if (!Array.isArray(newValue)) newValue = coerceArrayProperty(newValue);\n    this.writeValue(newValue);\n  }\n  readonly valueChange = output<any[]>();\n\n  //! output events\n  readonly changeEvent = output<any[]>({ alias: 'change' });\n  readonly addEvent = output<any[]>({ alias: 'add' });\n  readonly removeEvent = output<any[]>({ alias: 'remove' });\n\n  //! item selection handlers\n  toggleItem(item: ArdOptionSimple): void {\n    if (item.selected()) {\n      if (this.singleselectable()) return;\n\n      this.unselectItem(item);\n      return;\n    }\n    this.selectItem(item);\n  }\n  selectItem(...items: ArdOptionSimple[]): void {\n    const [selected, unselected] = this.itemStorage.selectItem(...items);\n\n    if (unselected.length > 0) this.removeEvent.emit(unselected);\n\n    if (selected.length > 0) {\n      this.addEvent.emit(selected);\n      this._emitChange();\n    }\n  }\n  unselectItem(...items: ArdOptionSimple[]): void {\n    const unselected = this.itemStorage.unselectItem(...items);\n\n    if (unselected.length > 0) this.removeEvent.emit(unselected);\n\n    this._emitChange();\n  }\n\n  //! highligh-related\n\n  readonly isMouseBeingUsed = signal<boolean>(false);\n  @HostListener('mousemove')\n  onMouseMove() {\n    this.isMouseBeingUsed.set(true);\n  }\n  onItemMouseEnter(option: ArdOptionSimple, event: MouseEvent): void {\n    if (!this.isMouseBeingUsed) return;\n    this.itemStorage.highlightSingleItem(option);\n    event.stopPropagation();\n  }\n  onItemMouseLeave(option: ArdOptionSimple, event: MouseEvent): void {\n    if (!this.isMouseBeingUsed) return;\n    this.itemStorage.unhighlightItem(option);\n    event.stopPropagation();\n  }\n\n  //! click handlers\n  onItemClick(option: ArdOptionSimple, event: MouseEvent): void {\n    event.stopPropagation();\n    this.toggleItem(option);\n  }\n\n  //! key press handlers\n  @HostListener('keydown', ['$event'])\n  onKeyPress(event: KeyboardEvent): void {\n    switch (event.code) {\n      case 'Space':\n      case 'Enter': {\n        this._toggleHighlightedItems(event);\n        return;\n      }\n      case 'ArrowRight': {\n        this._highlightNext(event);\n        return;\n      }\n      case 'ArrowLeft': {\n        this._highlightPrevious(event);\n        return;\n      }\n      case 'Home': {\n        this._highlightFirst(event);\n        return;\n      }\n      case 'End': {\n        this._highlightLast(event);\n        return;\n      }\n      case 'KeyA': {\n        if (event.ctrlKey) {\n          this._highlightAll();\n          return;\n        }\n      }\n    }\n  }\n  private _toggleHighlightedItems(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n\n    const highlightedItems = this.highlightedItems();\n\n    if (highlightedItems.every(item => item.selected)) {\n      this.unselectItem(...highlightedItems);\n    } else {\n      this.selectItem(...highlightedItems);\n    }\n  }\n  private _highlightPrevious(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n    this.isMouseBeingUsed.set(false);\n\n    this.itemStorage.highlightNextItem(-1, event.shiftKey);\n  }\n  private _highlightNext(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n    this.isMouseBeingUsed.set(false);\n\n    this.itemStorage.highlightNextItem(+1, event.shiftKey);\n  }\n  private _highlightFirst(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n    this.isMouseBeingUsed.set(false);\n\n    this.itemStorage.highlightFirstItem();\n  }\n  private _highlightLast(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n    this.isMouseBeingUsed.set(false);\n\n    this.itemStorage.highlightLastItem();\n  }\n  private _highlightAll(): void {\n    this.itemStorage.highlightAllItems();\n  }\n}\n"]}
271
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selectable-list-component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/_internal/selectable-list-component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Directive,\n  HostBinding,\n  HostListener,\n  Input,\n  computed,\n  inject,\n  input,\n  output,\n  signal,\n} from '@angular/core';\nimport { ControlValueAccessor } from '@angular/forms';\nimport { coerceArrayProperty, coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\nimport { ArdOptionSimple, CompareWithFn, OptionContext } from '../types/item-storage.types';\nimport { Nullable } from '../types/utility.types';\nimport { _FormFieldComponentBase, _FormFieldComponentDefaults, _formFieldComponentDefaults } from './form-field-component';\nimport { SimpleItemStorage, SimpleItemStorageHost } from './item-storages/simple-item-storage';\n\nexport interface _SelectableListComponentDefaults extends _FormFieldComponentDefaults {\n  valueFrom: string;\n  labelFrom: string;\n  disabledFrom: string;\n  compareWith: Nullable<CompareWithFn>;\n  multiselectable: boolean;\n  requireValue: boolean;\n  invertDisabled: boolean;\n  maxSelectedItems: Nullable<number>;\n}\nexport const _selectableListComponentDefaults: _SelectableListComponentDefaults = {\n  ..._formFieldComponentDefaults,\n  valueFrom: 'value',\n  labelFrom: 'label',\n  disabledFrom: 'disabled',\n  compareWith: undefined,\n  multiselectable: false,\n  requireValue: false,\n  invertDisabled: false,\n  maxSelectedItems: undefined,\n};\n\n@Directive()\nexport abstract class _SelectableListComponentBase\n  extends _FormFieldComponentBase\n  implements ControlValueAccessor, SimpleItemStorageHost\n{\n  protected override readonly _DEFAULTS!: _SelectableListComponentDefaults;\n\n  //! public constants\n  readonly itemStorage = new SimpleItemStorage(this);\n  readonly element!: HTMLElement;\n  readonly DEFAULTS = this._DEFAULTS;\n\n  abstract readonly _componentId: string;\n  abstract readonly _componentName: string;\n\n  private readonly _cd = inject(ChangeDetectorRef);\n\n  //! binding-related inputs\n  readonly valueFrom = input<string>(this._DEFAULTS.valueFrom);\n  readonly labelFrom = input<string>(this._DEFAULTS.labelFrom);\n  readonly disabledFrom = input<string>(this._DEFAULTS.disabledFrom);\n  readonly compareWith = input<Nullable<CompareWithFn>>(this._DEFAULTS.compareWith);\n\n  //! items setter/getter\n  @Input()\n  get items(): any[] {\n    return this.itemStorage.items();\n  }\n  set items(value: any) {\n    if (!Array.isArray(value)) value = coerceArrayProperty(value);\n\n    this.itemStorage.setItems(value);\n  }\n\n  //! multiselectable\n  readonly multiselectable = input<boolean, any>(this._DEFAULTS.multiselectable, { transform: v => coerceBooleanProperty(v) });\n\n  @HostBinding('attr.multiple')\n  @HostBinding('class.ard-multiselect')\n  get _multiselectableHostAttribute() {\n    return this.multiselectable();\n  }\n\n  readonly singleselectable = computed(() => !this.multiselectable());\n\n  //! require value\n  readonly requireValue = input<boolean, any>(this._DEFAULTS.requireValue, { transform: v => coerceBooleanProperty(v) });\n\n  readonly isValueRequired = computed(() => this.requireValue() || !this.multiselectable());\n\n  @HostBinding('class.ard-require-value')\n  get _requireValueHostAttribute() {\n    return this.requireValue();\n  }\n\n  //! coerced properties\n  readonly invertDisabled = input<boolean, any>(this._DEFAULTS.invertDisabled, { transform: v => coerceBooleanProperty(v) });\n  readonly maxSelectedItems = input<Nullable<number>, any>(this._DEFAULTS.maxSelectedItems, {\n    transform: v => coerceNumberProperty(v, undefined),\n  });\n\n  //! control value accessor\n  //override the writeValue and setDisabledState defined in _NgModelComponent\n  override setDisabledState(state: boolean): void {\n    this.disabled.set(state);\n    this._cd.markForCheck();\n  }\n  writeValue(ngModel: any[]): void {\n    this.itemStorage.writeValue(ngModel);\n    this._cd.markForCheck();\n  }\n\n  //! change & touch event emitters\n  readonly touched = signal<boolean>(false);\n\n  @HostBinding('class.ard-touched')\n  get _touchedHostAttribute(): boolean {\n    return this.touched();\n  }\n\n  protected _emitChange(): void {\n    const value = this.itemStorage.value();\n    this._onChangeRegistered?.(value);\n    this.changeEvent.emit(value);\n    this.valueChange.emit(value);\n  }\n  protected _onTouched(): void {\n    if (this.touched()) return;\n\n    this._onTouchedRegistered?.();\n    this.touched.set(true);\n  }\n\n  //! focus & blur handlers\n  private readonly lastBlurTimestamp = signal<Nullable<number>>(undefined);\n  override onFocus(event: FocusEvent): void {\n    super.onFocus(event);\n\n    const lbt = this.lastBlurTimestamp();\n    if (this.touched() || !lbt || lbt + 1 < Date.now()) return;\n    this.lastBlurTimestamp.set(null);\n\n    this._onTouched();\n  }\n  override onBlur(event: FocusEvent): void {\n    super.onBlur(event);\n\n    if (!this.touched()) this.lastBlurTimestamp.set(Date.now());\n  }\n\n  //! getters\n  readonly highlightedItems = computed<ArdOptionSimple[]>(() => this.itemStorage.highlightedItems());\n  readonly firstHighlightedItem = computed<Nullable<ArdOptionSimple>>(() => this.highlightedItems()?.first());\n  readonly isItemLimitReached = computed(() => this.itemStorage.isItemLimitReached());\n\n  //! context providers\n  getOptionContext(item: ArdOptionSimple): OptionContext<ArdOptionSimple> {\n    return {\n      $implicit: item,\n      item,\n      itemData: item.itemData(),\n    };\n  }\n\n  //! value input & output\n  @Input()\n  set value(newValue: any) {\n    if (!Array.isArray(newValue)) newValue = coerceArrayProperty(newValue);\n    this.writeValue(newValue);\n  }\n  readonly valueChange = output<any[]>();\n\n  //! output events\n  readonly changeEvent = output<any[]>({ alias: 'change' });\n  readonly addEvent = output<any[]>({ alias: 'add' });\n  readonly removeEvent = output<any[]>({ alias: 'remove' });\n\n  //! item selection handlers\n  toggleItem(item: ArdOptionSimple): void {\n    if (item.selected()) {\n      if (this.singleselectable()) return;\n\n      this.unselectItem(item);\n      return;\n    }\n    this.selectItem(item);\n  }\n  selectItem(...items: ArdOptionSimple[]): void {\n    const [selected, unselected] = this.itemStorage.selectItem(...items);\n\n    if (unselected.length > 0) this.removeEvent.emit(unselected);\n\n    if (selected.length > 0) {\n      this.addEvent.emit(selected);\n      this._emitChange();\n    }\n  }\n  unselectItem(...items: ArdOptionSimple[]): void {\n    const unselected = this.itemStorage.unselectItem(...items);\n\n    if (unselected.length > 0) this.removeEvent.emit(unselected);\n\n    this._emitChange();\n  }\n\n  //! highligh-related\n\n  readonly isMouseBeingUsed = signal<boolean>(false);\n  @HostListener('mousemove')\n  onMouseMove() {\n    this.isMouseBeingUsed.set(true);\n  }\n  onItemMouseEnter(option: ArdOptionSimple, event: MouseEvent): void {\n    if (!this.isMouseBeingUsed) return;\n    this.itemStorage.highlightSingleItem(option);\n    event.stopPropagation();\n  }\n  onItemMouseLeave(option: ArdOptionSimple, event: MouseEvent): void {\n    if (!this.isMouseBeingUsed) return;\n    this.itemStorage.unhighlightItem(option);\n    event.stopPropagation();\n  }\n\n  //! click handlers\n  onItemClick(option: ArdOptionSimple, event: MouseEvent): void {\n    event.stopPropagation();\n    this.toggleItem(option);\n  }\n\n  //! key press handlers\n  @HostListener('keydown', ['$event'])\n  onKeyPress(event: KeyboardEvent): void {\n    switch (event.code) {\n      case 'Space':\n      case 'Enter': {\n        this._toggleHighlightedItems(event);\n        return;\n      }\n      case 'ArrowRight': {\n        this._highlightNext(event);\n        return;\n      }\n      case 'ArrowLeft': {\n        this._highlightPrevious(event);\n        return;\n      }\n      case 'Home': {\n        this._highlightFirst(event);\n        return;\n      }\n      case 'End': {\n        this._highlightLast(event);\n        return;\n      }\n      case 'KeyA': {\n        if (event.ctrlKey) {\n          this._highlightAll();\n          return;\n        }\n      }\n    }\n  }\n  private _toggleHighlightedItems(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n\n    const highlightedItems = this.highlightedItems();\n\n    if (highlightedItems.every(item => item.selected)) {\n      this.unselectItem(...highlightedItems);\n    } else {\n      this.selectItem(...highlightedItems);\n    }\n  }\n  private _highlightPrevious(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n    this.isMouseBeingUsed.set(false);\n\n    this.itemStorage.highlightNextItem(-1, event.shiftKey);\n  }\n  private _highlightNext(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n    this.isMouseBeingUsed.set(false);\n\n    this.itemStorage.highlightNextItem(+1, event.shiftKey);\n  }\n  private _highlightFirst(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n    this.isMouseBeingUsed.set(false);\n\n    this.itemStorage.highlightFirstItem();\n  }\n  private _highlightLast(event: KeyboardEvent): void {\n    if (!this.isFocused()) return;\n\n    event.preventDefault();\n    this.isMouseBeingUsed.set(false);\n\n    this.itemStorage.highlightLastItem();\n  }\n  private _highlightAll(): void {\n    this.itemStorage.highlightAllItems();\n  }\n}\n"]}
@@ -1,5 +1,7 @@
1
- import { ChangeDetectionStrategy, Component, Inject, ViewEncapsulation, computed, contentChild, input, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, Inject, ViewEncapsulation, computed, contentChild, forwardRef, input, } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
2
3
  import { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';
4
+ import { _FormFieldComponentBase } from '../_internal/form-field-component';
3
5
  import { _SelectableListComponentBase } from '../_internal/selectable-list-component';
4
6
  import { ARD_SEGMENT_DEFAULTS } from './segment.defaults';
5
7
  import { ArdSegmentOptionTemplateDirective } from './segment.directives';
@@ -91,13 +93,33 @@ export class ArdiumSegmentComponent extends _SelectableListComponentBase {
91
93
  this.itemStorage.unhighlightAll();
92
94
  }
93
95
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumSegmentComponent, deps: [{ token: ARD_SEGMENT_DEFAULTS }], target: i0.ɵɵFactoryTarget.Component }); }
94
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumSegmentComponent, selector: "ard-segment", inputs: { appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: true, isRequired: false, transformFunction: null }, iconBased: { classPropertyName: "iconBased", publicName: "iconBased", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, autoFocus: { classPropertyName: "autoFocus", publicName: "autoFocus", isSignal: true, isRequired: false, transformFunction: null }, uniformWidths: { classPropertyName: "uniformWidths", publicName: "uniformWidths", isSignal: true, isRequired: false, transformFunction: null }, itemsPerRow: { classPropertyName: "itemsPerRow", publicName: "itemsPerRow", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "optionTemplate", first: true, predicate: ArdSegmentOptionTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\n #focusableElement\n class=\"ard-segment-container\"\n [class.ard-disabled]=\"disabled()\"\n [ariaDisabled]=\"disabled()\"\n [ngClass]=\"ngClasses()\"\n [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n [attr.tabindex]=\"tabIndex()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n>\n @for (row of itemRows(); track $index) {\n <div\n class=\"ard-segment-row\"\n [class.ard-segment-row-partial]=\"row.isNotFull\"\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n >\n @for (option of row.options; track $index) {\n <button\n type=\"button\"\n class=\"ard-segment-option\"\n tabindex=\"-1\"\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n [class.ard-option-selected]=\"option.selected()\"\n [class.ard-option-highlighted]=\"option.highlighted()\"\n [ariaSelected]=\"option.selected()\"\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\n (click)=\"onItemClick(option, $event)\"\n >\n <div class=\"ard-focus-overlay\"></div>\n <div class=\"ard-button-content\">\n <span class=\"ard-option-label\">\n <ng-template #defaultOptionTemplate>\n {{ option.label() }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\n />\n </span>\n </div>\n </button>\n }\n </div>\n }\n</div>\n", styles: [".ard-segment-container{display:flex;flex-direction:column}.ard-segment-container.ard-align-left .ard-segment-option{justify-content:left}.ard-segment-container.ard-align-middle .ard-segment-option{justify-content:center}.ard-segment-container.ard-align-right .ard-segment-option{justify-content:right}.ard-segment-row{width:100%;display:flex;align-items:center}.ard-segment-row.ard-segment-row-uniform{display:grid;grid-template-columns:repeat(var(--ard-_segment-row-items),1fr)}.ard-segment-option{-webkit-user-select:none;user-select:none}.ard-option-disabled{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
96
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumSegmentComponent, selector: "ard-segment", inputs: { appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: true, isRequired: false, transformFunction: null }, iconBased: { classPropertyName: "iconBased", publicName: "iconBased", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, autoFocus: { classPropertyName: "autoFocus", publicName: "autoFocus", isSignal: true, isRequired: false, transformFunction: null }, uniformWidths: { classPropertyName: "uniformWidths", publicName: "uniformWidths", isSignal: true, isRequired: false, transformFunction: null }, itemsPerRow: { classPropertyName: "itemsPerRow", publicName: "itemsPerRow", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
97
+ {
98
+ provide: NG_VALUE_ACCESSOR,
99
+ useExisting: forwardRef(() => ArdiumSegmentComponent),
100
+ multi: true,
101
+ },
102
+ {
103
+ provide: _FormFieldComponentBase,
104
+ useExisting: ArdiumSegmentComponent,
105
+ },
106
+ ], queries: [{ propertyName: "optionTemplate", first: true, predicate: ArdSegmentOptionTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\n #focusableElement\n class=\"ard-segment-container\"\n [class.ard-disabled]=\"disabled()\"\n [ariaDisabled]=\"disabled()\"\n [ngClass]=\"ngClasses()\"\n [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n [attr.tabindex]=\"tabIndex()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n>\n @for (row of itemRows(); track $index) {\n <div\n class=\"ard-segment-row\"\n [class.ard-segment-row-partial]=\"row.isNotFull\"\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n >\n @for (option of row.options; track $index) {\n <button\n type=\"button\"\n class=\"ard-segment-option\"\n tabindex=\"-1\"\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n [class.ard-option-selected]=\"option.selected()\"\n [class.ard-option-highlighted]=\"option.highlighted()\"\n [ariaSelected]=\"option.selected()\"\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\n (click)=\"onItemClick(option, $event)\"\n >\n <div class=\"ard-focus-overlay\"></div>\n <div class=\"ard-button-content\">\n <span class=\"ard-option-label\">\n <ng-template #defaultOptionTemplate>\n {{ option.label() }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\n />\n </span>\n </div>\n </button>\n }\n </div>\n }\n</div>\n", styles: [".ard-segment-container{display:flex;flex-direction:column}.ard-segment-container.ard-align-left .ard-segment-option{justify-content:left}.ard-segment-container.ard-align-middle .ard-segment-option{justify-content:center}.ard-segment-container.ard-align-right .ard-segment-option{justify-content:right}.ard-segment-row{width:100%;display:flex;align-items:center}.ard-segment-row.ard-segment-row-uniform{display:grid;grid-template-columns:repeat(var(--ard-_segment-row-items),1fr)}.ard-segment-option{-webkit-user-select:none;user-select:none}.ard-option-disabled{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
95
107
  }
96
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumSegmentComponent, decorators: [{
97
109
  type: Component,
98
- args: [{ selector: 'ard-segment', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n #focusableElement\n class=\"ard-segment-container\"\n [class.ard-disabled]=\"disabled()\"\n [ariaDisabled]=\"disabled()\"\n [ngClass]=\"ngClasses()\"\n [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n [attr.tabindex]=\"tabIndex()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n>\n @for (row of itemRows(); track $index) {\n <div\n class=\"ard-segment-row\"\n [class.ard-segment-row-partial]=\"row.isNotFull\"\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n >\n @for (option of row.options; track $index) {\n <button\n type=\"button\"\n class=\"ard-segment-option\"\n tabindex=\"-1\"\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n [class.ard-option-selected]=\"option.selected()\"\n [class.ard-option-highlighted]=\"option.highlighted()\"\n [ariaSelected]=\"option.selected()\"\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\n (click)=\"onItemClick(option, $event)\"\n >\n <div class=\"ard-focus-overlay\"></div>\n <div class=\"ard-button-content\">\n <span class=\"ard-option-label\">\n <ng-template #defaultOptionTemplate>\n {{ option.label() }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\n />\n </span>\n </div>\n </button>\n }\n </div>\n }\n</div>\n", styles: [".ard-segment-container{display:flex;flex-direction:column}.ard-segment-container.ard-align-left .ard-segment-option{justify-content:left}.ard-segment-container.ard-align-middle .ard-segment-option{justify-content:center}.ard-segment-container.ard-align-right .ard-segment-option{justify-content:right}.ard-segment-row{width:100%;display:flex;align-items:center}.ard-segment-row.ard-segment-row-uniform{display:grid;grid-template-columns:repeat(var(--ard-_segment-row-items),1fr)}.ard-segment-option{-webkit-user-select:none;user-select:none}.ard-option-disabled{pointer-events:none}\n"] }]
110
+ args: [{ selector: 'ard-segment', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
111
+ {
112
+ provide: NG_VALUE_ACCESSOR,
113
+ useExisting: forwardRef(() => ArdiumSegmentComponent),
114
+ multi: true,
115
+ },
116
+ {
117
+ provide: _FormFieldComponentBase,
118
+ useExisting: ArdiumSegmentComponent,
119
+ },
120
+ ], template: "<div\n #focusableElement\n class=\"ard-segment-container\"\n [class.ard-disabled]=\"disabled()\"\n [ariaDisabled]=\"disabled()\"\n [ngClass]=\"ngClasses()\"\n [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n [attr.tabindex]=\"tabIndex()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n>\n @for (row of itemRows(); track $index) {\n <div\n class=\"ard-segment-row\"\n [class.ard-segment-row-partial]=\"row.isNotFull\"\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n >\n @for (option of row.options; track $index) {\n <button\n type=\"button\"\n class=\"ard-segment-option\"\n tabindex=\"-1\"\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n [class.ard-option-selected]=\"option.selected()\"\n [class.ard-option-highlighted]=\"option.highlighted()\"\n [ariaSelected]=\"option.selected()\"\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\n (click)=\"onItemClick(option, $event)\"\n >\n <div class=\"ard-focus-overlay\"></div>\n <div class=\"ard-button-content\">\n <span class=\"ard-option-label\">\n <ng-template #defaultOptionTemplate>\n {{ option.label() }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\n />\n </span>\n </div>\n </button>\n }\n </div>\n }\n</div>\n", styles: [".ard-segment-container{display:flex;flex-direction:column}.ard-segment-container.ard-align-left .ard-segment-option{justify-content:left}.ard-segment-container.ard-align-middle .ard-segment-option{justify-content:center}.ard-segment-container.ard-align-right .ard-segment-option{justify-content:right}.ard-segment-row{width:100%;display:flex;align-items:center}.ard-segment-row.ard-segment-row-uniform{display:grid;grid-template-columns:repeat(var(--ard-_segment-row-items),1fr)}.ard-segment-option{-webkit-user-select:none;user-select:none}.ard-option-disabled{pointer-events:none}\n"] }]
99
121
  }], ctorParameters: () => [{ type: undefined, decorators: [{
100
122
  type: Inject,
101
123
  args: [ARD_SEGMENT_DEFAULTS]
102
124
  }] }] });
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"segment.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/segment/segment.component.ts","../../../../../projects/ui/src/lib/segment/segment.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,MAAM,EACN,iBAAiB,EACjB,QAAQ,EACR,YAAY,EACZ,KAAK,GACN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,4BAA4B,EAAE,MAAM,wCAAwC,CAAC;AAKtF,OAAO,EAAE,oBAAoB,EAAsB,MAAM,oBAAoB,CAAC;AAC9E,OAAO,EAAE,iCAAiC,EAAE,MAAM,sBAAsB,CAAC;;;AAezE,MAAM,OAAO,sBAAuB,SAAQ,4BAA4B;IAKtE,YAA0C,QAA4B;QACpE,KAAK,CAAC,QAAQ,CAAC,CAAC;QALA,iBAAY,GAAW,KAAK,CAAC;QAC7B,mBAAc,GAAW,SAAS,CAAC;QAOrD,cAAc;QACL,eAAU,GAAG,KAAK,CAAoB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACjE,YAAO,GAAG,KAAK,CAAiB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACxD,UAAK,GAAG,KAAK,CAAiB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACpD,UAAK,GAAG,KAAK,CAAmB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAEtD,cAAS,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACxG,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,CAAS,GAAG,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,aAAa,IAAI,CAAC,KAAK,EAAE,EAAE;YAC3B,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE;YACxC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe;SAC9D,CAAC,IAAI,CAAC,GAAG,CAAC,CACZ,CAAC;QAEF,sBAAsB;QACb,cAAS,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACxG,kBAAa,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEhH,gBAAW,GAAG,KAAK,CAAc,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE;YACpE,SAAS,EAAE,CAAC,CAAC,EAAE;gBACb,MAAM,QAAQ,GAAG,oBAAoB,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;gBACrE,IAAI,QAAQ,KAAK,CAAC;oBAAE,MAAM,IAAI,KAAK,CAAC,6DAA6D,CAAC,CAAC;gBACnG,IAAI,QAAQ,GAAG,CAAC;oBACd,MAAM,IAAI,KAAK,CAAC,mFAAmF,QAAQ,IAAI,CAAC,CAAC;gBACnH,IAAI,QAAQ,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;oBACvB,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,gDAAgD;oBAChG,OAAO,CAAC,IAAI,CACV,IAAI,KAAK,CACP,uFAAuF,QAAQ,gCAAgC,YAAY,IAAI,CAChJ,CACF,CAAC;oBACF,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC7B,CAAC;gBACD,OAAO,QAAQ,CAAC;YAClB,CAAC;SACF,CAAC,CAAC;QAKH,mBAAmB;QACV,mBAAc,GAAG,YAAY,CAAC,iCAAiC,CAAC,CAAC;QAS1E,oBAAoB;QACX,aAAQ,GAAG,QAAQ,CAAe,GAAG,EAAE;YAC9C,MAAM,QAAQ,GAAiB,EAAE,CAAC;YAClC,IAAI,UAAU,GAAsB,EAAE,CAAC;YACvC,cAAc;YACd,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBAC9B,UAAU;gBACV,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAEtB,uCAAuC;gBACvC,IAAI,IAAI,CAAC,WAAW,EAAE,IAAI,UAAU,CAAC,MAAM,KAAK,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;oBACnE,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAC;oBACvC,UAAU,GAAG,EAAE,CAAC;gBAClB,CAAC;YACH,CAAC;YACD,sCAAsC;YACtC,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC5B,QAAQ,CAAC,IAAI,CAAC;oBACZ,OAAO,EAAE,UAAU;oBACnB,SAAS,EAAE,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;iBACvC,CAAC,CAAC;YACL,CAAC;YACD,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC,CAAC;IAlFH,CAAC;IA6CD,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,WAAW,EAAE,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;IAClF,CAAC;IAKD,mBAAmB;IACnB,kBAAkB;QAChB,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YACrB,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;IACH,CAAC;IA2BD,0BAA0B;IACjB,OAAO,CAAC,KAAiB;QAChC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAErB,IAAI,IAAI,CAAC,WAAW,CAAC,oBAAoB,EAAE;YAAE,OAAO;QAEpD,IAAI,CAAC,WAAW,CAAC,kBAAkB,EAAE,CAAC;IACxC,CAAC;IAEQ,MAAM,CAAC,KAAiB;QAC/B,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAEpB,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,CAAC;IACpC,CAAC;+GAxGU,sBAAsB,kBAKb,oBAAoB;mGAL7B,sBAAsB,gwCAyDM,iCAAiC,uFCzF1E,k2DAkDA;;4FDlBa,sBAAsB;kBAPlC,SAAS;+BACE,aAAa,iBAGR,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;;0BAOlC,MAAM;2BAAC,oBAAoB","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  ViewEncapsulation,\n  computed,\n  contentChild,\n  input,\n} from '@angular/core';\nimport { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\nimport { _SelectableListComponentBase } from '../_internal/selectable-list-component';\nimport { OneAxisAlignment } from '../types/alignment.types';\nimport { ComponentColor } from '../types/colors.types';\nimport { ArdOptionSimple } from '../types/item-storage.types';\nimport { SimpleItemStorageHost } from './../_internal/item-storages/simple-item-storage';\nimport { ARD_SEGMENT_DEFAULTS, ArdSegmentDefaults } from './segment.defaults';\nimport { ArdSegmentOptionTemplateDirective } from './segment.directives';\nimport { SegmentAppearance, SegmentVariant } from './segment.types';\n\ninterface SegmentRow {\n  options: ArdOptionSimple[];\n  isNotFull?: boolean;\n}\n\n@Component({\n  selector: 'ard-segment',\n  templateUrl: './segment.component.html',\n  styleUrls: ['./segment.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ArdiumSegmentComponent extends _SelectableListComponentBase implements SimpleItemStorageHost, AfterContentInit {\n  override readonly _componentId: string = '104';\n  override readonly _componentName: string = 'segment';\n\n  protected override readonly _DEFAULTS!: ArdSegmentDefaults;\n  constructor(@Inject(ARD_SEGMENT_DEFAULTS) defaults: ArdSegmentDefaults) {\n    super(defaults);\n  }\n\n  //! appearance\n  readonly appearance = input<SegmentAppearance>(this._DEFAULTS.appearance);\n  readonly variant = input<SegmentVariant>(this._DEFAULTS.variant);\n  readonly color = input<ComponentColor>(this._DEFAULTS.color);\n  readonly align = input<OneAxisAlignment>(this._DEFAULTS.align);\n\n  readonly iconBased = input<boolean, any>(this._DEFAULTS.iconBased, { transform: v => coerceBooleanProperty(v) });\n  readonly compact = input<boolean, any>(this._DEFAULTS.compact, { transform: v => coerceBooleanProperty(v) });\n\n  readonly ngClasses = computed<string>(() =>\n    [\n      `ard-appearance-${this.appearance()}`,\n      `ard-variant-${this.variant()}`,\n      `ard-color-${this.color()}`,\n      `ard-align-${this.align()}`,\n      this.iconBased() ? 'ard-icon-based' : '',\n      this.compact() ? 'ard-compact' : '',\n      this.itemRows().length > 1 ? 'ard-multirow' : 'ard-singlerow',\n    ].join(' ')\n  );\n\n  //! coerced properties\n  readonly autoFocus = input<boolean, any>(this._DEFAULTS.autoFocus, { transform: v => coerceBooleanProperty(v) });\n  readonly uniformWidths = input<boolean, any>(this._DEFAULTS.uniformWidths, { transform: v => coerceBooleanProperty(v) });\n\n  readonly itemsPerRow = input<number, any>(this._DEFAULTS.itemsPerRow, {\n    transform: v => {\n      const newValue = coerceNumberProperty(v, this._DEFAULTS.itemsPerRow);\n      if (newValue === 0) throw new Error(`ARD-FT1040a: Cannot set <ard-segment>'s [itemsPerRow] to 0.`);\n      if (newValue < 0)\n        throw new Error(`ARD-FT1040b: Cannot set <ard-segment>'s [itemsPerRow] to a negative value, got \"${newValue}\".`);\n      if (newValue % 1 !== 0) {\n        const roundedValue = Math.round(newValue) || 1; // round to nearest int, but never round to zero\n        console.warn(\n          new Error(\n            `ARD-WA1040c: Cannot set <ard-segment>'s [itemsPerRow] to a non-interger value, got \"${newValue}\". The value was rounded to \"${roundedValue}\".`\n          )\n        );\n        return Math.ceil(newValue);\n      }\n      return newValue;\n    },\n  });\n  get itemsInActualRow(): number {\n    return this.itemsPerRow() === Infinity ? this.items.length : this.itemsPerRow();\n  }\n\n  //! option template\n  readonly optionTemplate = contentChild(ArdSegmentOptionTemplateDirective);\n\n  //! lifecycle hooks\n  ngAfterContentInit(): void {\n    if (this.autoFocus()) {\n      this.focus();\n    }\n  }\n\n  //! item row getters\n  readonly itemRows = computed<SegmentRow[]>(() => {\n    const itemRows: SegmentRow[] = [];\n    let currentRow: ArdOptionSimple[] = [];\n    //get all rows\n    for (const item of this.items) {\n      //add item\n      currentRow.push(item);\n\n      //push if item amount reached the limit\n      if (this.itemsPerRow() && currentRow.length === this.itemsPerRow()) {\n        itemRows.push({ options: currentRow });\n        currentRow = [];\n      }\n    }\n    //push the last row if it is not empty\n    if (currentRow.length !== 0) {\n      itemRows.push({\n        options: currentRow,\n        isNotFull: Boolean(this.itemsPerRow()),\n      });\n    }\n    return itemRows;\n  });\n\n  //! focus handler override\n  override onFocus(event: FocusEvent): void {\n    super.onFocus(event);\n\n    if (this.itemStorage.isAnyItemHighlighted()) return;\n\n    this.itemStorage.highlightFirstItem();\n  }\n\n  override onBlur(event: FocusEvent): void {\n    super.onBlur(event);\n\n    this.itemStorage.unhighlightAll();\n  }\n}\n","<div\n  #focusableElement\n  class=\"ard-segment-container\"\n  [class.ard-disabled]=\"disabled()\"\n  [ariaDisabled]=\"disabled()\"\n  [ngClass]=\"ngClasses()\"\n  [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n  [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n  [attr.tabindex]=\"tabIndex()\"\n  (focus)=\"onFocus($event)\"\n  (blur)=\"onBlur($event)\"\n>\n  @for (row of itemRows(); track $index) {\n    <div\n      class=\"ard-segment-row\"\n      [class.ard-segment-row-partial]=\"row.isNotFull\"\n      [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n      [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n    >\n      @for (option of row.options; track $index) {\n        <button\n          type=\"button\"\n          class=\"ard-segment-option\"\n          tabindex=\"-1\"\n          [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n          [class.ard-option-selected]=\"option.selected()\"\n          [class.ard-option-highlighted]=\"option.highlighted()\"\n          [ariaSelected]=\"option.selected()\"\n          (mouseenter)=\"onItemMouseEnter(option, $event)\"\n          (mouseleave)=\"onItemMouseLeave(option, $event)\"\n          (click)=\"onItemClick(option, $event)\"\n        >\n          <div class=\"ard-focus-overlay\"></div>\n          <div class=\"ard-button-content\">\n            <span class=\"ard-option-label\">\n              <ng-template #defaultOptionTemplate>\n                {{ option.label() }}\n              </ng-template>\n\n              <ng-template\n                [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n                [ngTemplateOutletContext]=\"getOptionContext(option)\"\n              />\n            </span>\n          </div>\n        </button>\n      }\n    </div>\n  }\n</div>\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"segment.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/segment/segment.component.ts","../../../../../projects/ui/src/lib/segment/segment.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  ViewEncapsulation,\n  computed,\n  contentChild,\n  forwardRef,\n  input,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\nimport { _FormFieldComponentBase } from '../_internal/form-field-component';\nimport { _SelectableListComponentBase } from '../_internal/selectable-list-component';\nimport { OneAxisAlignment } from '../types/alignment.types';\nimport { ComponentColor } from '../types/colors.types';\nimport { ArdOptionSimple } from '../types/item-storage.types';\nimport { SimpleItemStorageHost } from './../_internal/item-storages/simple-item-storage';\nimport { ARD_SEGMENT_DEFAULTS, ArdSegmentDefaults } from './segment.defaults';\nimport { ArdSegmentOptionTemplateDirective } from './segment.directives';\nimport { SegmentAppearance, SegmentVariant } from './segment.types';\n\ninterface SegmentRow {\n  options: ArdOptionSimple[];\n  isNotFull?: boolean;\n}\n\n@Component({\n  selector: 'ard-segment',\n  templateUrl: './segment.component.html',\n  styleUrls: ['./segment.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ArdiumSegmentComponent),\n      multi: true,\n    },\n    {\n      provide: _FormFieldComponentBase,\n      useExisting: ArdiumSegmentComponent,\n    },\n  ],\n})\nexport class ArdiumSegmentComponent extends _SelectableListComponentBase implements SimpleItemStorageHost, AfterContentInit {\n  override readonly _componentId: string = '104';\n  override readonly _componentName: string = 'segment';\n\n  protected override readonly _DEFAULTS!: ArdSegmentDefaults;\n  constructor(@Inject(ARD_SEGMENT_DEFAULTS) defaults: ArdSegmentDefaults) {\n    super(defaults);\n  }\n\n  //! appearance\n  readonly appearance = input<SegmentAppearance>(this._DEFAULTS.appearance);\n  readonly variant = input<SegmentVariant>(this._DEFAULTS.variant);\n  readonly color = input<ComponentColor>(this._DEFAULTS.color);\n  readonly align = input<OneAxisAlignment>(this._DEFAULTS.align);\n\n  readonly iconBased = input<boolean, any>(this._DEFAULTS.iconBased, { transform: v => coerceBooleanProperty(v) });\n  readonly compact = input<boolean, any>(this._DEFAULTS.compact, { transform: v => coerceBooleanProperty(v) });\n\n  readonly ngClasses = computed<string>(() =>\n    [\n      `ard-appearance-${this.appearance()}`,\n      `ard-variant-${this.variant()}`,\n      `ard-color-${this.color()}`,\n      `ard-align-${this.align()}`,\n      this.iconBased() ? 'ard-icon-based' : '',\n      this.compact() ? 'ard-compact' : '',\n      this.itemRows().length > 1 ? 'ard-multirow' : 'ard-singlerow',\n    ].join(' ')\n  );\n\n  //! coerced properties\n  readonly autoFocus = input<boolean, any>(this._DEFAULTS.autoFocus, { transform: v => coerceBooleanProperty(v) });\n  readonly uniformWidths = input<boolean, any>(this._DEFAULTS.uniformWidths, { transform: v => coerceBooleanProperty(v) });\n\n  readonly itemsPerRow = input<number, any>(this._DEFAULTS.itemsPerRow, {\n    transform: v => {\n      const newValue = coerceNumberProperty(v, this._DEFAULTS.itemsPerRow);\n      if (newValue === 0) throw new Error(`ARD-FT1040a: Cannot set <ard-segment>'s [itemsPerRow] to 0.`);\n      if (newValue < 0)\n        throw new Error(`ARD-FT1040b: Cannot set <ard-segment>'s [itemsPerRow] to a negative value, got \"${newValue}\".`);\n      if (newValue % 1 !== 0) {\n        const roundedValue = Math.round(newValue) || 1; // round to nearest int, but never round to zero\n        console.warn(\n          new Error(\n            `ARD-WA1040c: Cannot set <ard-segment>'s [itemsPerRow] to a non-interger value, got \"${newValue}\". The value was rounded to \"${roundedValue}\".`\n          )\n        );\n        return Math.ceil(newValue);\n      }\n      return newValue;\n    },\n  });\n  get itemsInActualRow(): number {\n    return this.itemsPerRow() === Infinity ? this.items.length : this.itemsPerRow();\n  }\n\n  //! option template\n  readonly optionTemplate = contentChild(ArdSegmentOptionTemplateDirective);\n\n  //! lifecycle hooks\n  ngAfterContentInit(): void {\n    if (this.autoFocus()) {\n      this.focus();\n    }\n  }\n\n  //! item row getters\n  readonly itemRows = computed<SegmentRow[]>(() => {\n    const itemRows: SegmentRow[] = [];\n    let currentRow: ArdOptionSimple[] = [];\n    //get all rows\n    for (const item of this.items) {\n      //add item\n      currentRow.push(item);\n\n      //push if item amount reached the limit\n      if (this.itemsPerRow() && currentRow.length === this.itemsPerRow()) {\n        itemRows.push({ options: currentRow });\n        currentRow = [];\n      }\n    }\n    //push the last row if it is not empty\n    if (currentRow.length !== 0) {\n      itemRows.push({\n        options: currentRow,\n        isNotFull: Boolean(this.itemsPerRow()),\n      });\n    }\n    return itemRows;\n  });\n\n  //! focus handler override\n  override onFocus(event: FocusEvent): void {\n    super.onFocus(event);\n\n    if (this.itemStorage.isAnyItemHighlighted()) return;\n\n    this.itemStorage.highlightFirstItem();\n  }\n\n  override onBlur(event: FocusEvent): void {\n    super.onBlur(event);\n\n    this.itemStorage.unhighlightAll();\n  }\n}\n","<div\n  #focusableElement\n  class=\"ard-segment-container\"\n  [class.ard-disabled]=\"disabled()\"\n  [ariaDisabled]=\"disabled()\"\n  [ngClass]=\"ngClasses()\"\n  [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n  [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n  [attr.tabindex]=\"tabIndex()\"\n  (focus)=\"onFocus($event)\"\n  (blur)=\"onBlur($event)\"\n>\n  @for (row of itemRows(); track $index) {\n    <div\n      class=\"ard-segment-row\"\n      [class.ard-segment-row-partial]=\"row.isNotFull\"\n      [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n      [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n    >\n      @for (option of row.options; track $index) {\n        <button\n          type=\"button\"\n          class=\"ard-segment-option\"\n          tabindex=\"-1\"\n          [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n          [class.ard-option-selected]=\"option.selected()\"\n          [class.ard-option-highlighted]=\"option.highlighted()\"\n          [ariaSelected]=\"option.selected()\"\n          (mouseenter)=\"onItemMouseEnter(option, $event)\"\n          (mouseleave)=\"onItemMouseLeave(option, $event)\"\n          (click)=\"onItemClick(option, $event)\"\n        >\n          <div class=\"ard-focus-overlay\"></div>\n          <div class=\"ard-button-content\">\n            <span class=\"ard-option-label\">\n              <ng-template #defaultOptionTemplate>\n                {{ option.label() }}\n              </ng-template>\n\n              <ng-template\n                [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n                [ngTemplateOutletContext]=\"getOptionContext(option)\"\n              />\n            </span>\n          </div>\n        </button>\n      }\n    </div>\n  }\n</div>\n"]}
@@ -6374,6 +6374,9 @@ class SimpleItemStorage {
6374
6374
  * @returns true if all items are valid, otherwise false.
6375
6375
  */
6376
6376
  _validateWriteValue(ngModel) {
6377
+ if (!isArray(ngModel)) {
6378
+ throw new Error(`ARD-FT${this._ardParentComp._componentId}0: <ard-${this._ardParentComp._componentName}> expects its value to be an array, got "${ngModel}".`);
6379
+ }
6377
6380
  return ngModel.every(item => {
6378
6381
  if (!isDefined(this._ardParentComp.compareWith()) && isObject(item) && this._ardParentComp.valueFrom()) {
6379
6382
  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.`);
@@ -6579,7 +6582,7 @@ class SimpleItemStorage {
6579
6582
  }
6580
6583
 
6581
6584
  const _selectableListComponentDefaults = {
6582
- ..._ngModelComponentDefaults,
6585
+ ..._formFieldComponentDefaults,
6583
6586
  valueFrom: 'value',
6584
6587
  labelFrom: 'label',
6585
6588
  disabledFrom: 'disabled',
@@ -6589,7 +6592,7 @@ const _selectableListComponentDefaults = {
6589
6592
  invertDisabled: false,
6590
6593
  maxSelectedItems: undefined,
6591
6594
  };
6592
- class _SelectableListComponentBase extends _NgModelComponentBase {
6595
+ class _SelectableListComponentBase extends _FormFieldComponentBase {
6593
6596
  constructor() {
6594
6597
  super(...arguments);
6595
6598
  //! public constants
@@ -6975,11 +6978,31 @@ class ArdiumSegmentComponent extends _SelectableListComponentBase {
6975
6978
  this.itemStorage.unhighlightAll();
6976
6979
  }
6977
6980
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumSegmentComponent, deps: [{ token: ARD_SEGMENT_DEFAULTS }], target: i0.ɵɵFactoryTarget.Component }); }
6978
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumSegmentComponent, selector: "ard-segment", inputs: { appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: true, isRequired: false, transformFunction: null }, iconBased: { classPropertyName: "iconBased", publicName: "iconBased", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, autoFocus: { classPropertyName: "autoFocus", publicName: "autoFocus", isSignal: true, isRequired: false, transformFunction: null }, uniformWidths: { classPropertyName: "uniformWidths", publicName: "uniformWidths", isSignal: true, isRequired: false, transformFunction: null }, itemsPerRow: { classPropertyName: "itemsPerRow", publicName: "itemsPerRow", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "optionTemplate", first: true, predicate: ArdSegmentOptionTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\n #focusableElement\n class=\"ard-segment-container\"\n [class.ard-disabled]=\"disabled()\"\n [ariaDisabled]=\"disabled()\"\n [ngClass]=\"ngClasses()\"\n [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n [attr.tabindex]=\"tabIndex()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n>\n @for (row of itemRows(); track $index) {\n <div\n class=\"ard-segment-row\"\n [class.ard-segment-row-partial]=\"row.isNotFull\"\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n >\n @for (option of row.options; track $index) {\n <button\n type=\"button\"\n class=\"ard-segment-option\"\n tabindex=\"-1\"\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n [class.ard-option-selected]=\"option.selected()\"\n [class.ard-option-highlighted]=\"option.highlighted()\"\n [ariaSelected]=\"option.selected()\"\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\n (click)=\"onItemClick(option, $event)\"\n >\n <div class=\"ard-focus-overlay\"></div>\n <div class=\"ard-button-content\">\n <span class=\"ard-option-label\">\n <ng-template #defaultOptionTemplate>\n {{ option.label() }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\n />\n </span>\n </div>\n </button>\n }\n </div>\n }\n</div>\n", styles: [".ard-segment-container{display:flex;flex-direction:column}.ard-segment-container.ard-align-left .ard-segment-option{justify-content:left}.ard-segment-container.ard-align-middle .ard-segment-option{justify-content:center}.ard-segment-container.ard-align-right .ard-segment-option{justify-content:right}.ard-segment-row{width:100%;display:flex;align-items:center}.ard-segment-row.ard-segment-row-uniform{display:grid;grid-template-columns:repeat(var(--ard-_segment-row-items),1fr)}.ard-segment-option{-webkit-user-select:none;user-select:none}.ard-option-disabled{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
6981
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumSegmentComponent, selector: "ard-segment", inputs: { appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: true, isRequired: false, transformFunction: null }, iconBased: { classPropertyName: "iconBased", publicName: "iconBased", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, autoFocus: { classPropertyName: "autoFocus", publicName: "autoFocus", isSignal: true, isRequired: false, transformFunction: null }, uniformWidths: { classPropertyName: "uniformWidths", publicName: "uniformWidths", isSignal: true, isRequired: false, transformFunction: null }, itemsPerRow: { classPropertyName: "itemsPerRow", publicName: "itemsPerRow", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
6982
+ {
6983
+ provide: NG_VALUE_ACCESSOR,
6984
+ useExisting: forwardRef(() => ArdiumSegmentComponent),
6985
+ multi: true,
6986
+ },
6987
+ {
6988
+ provide: _FormFieldComponentBase,
6989
+ useExisting: ArdiumSegmentComponent,
6990
+ },
6991
+ ], queries: [{ propertyName: "optionTemplate", first: true, predicate: ArdSegmentOptionTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\n #focusableElement\n class=\"ard-segment-container\"\n [class.ard-disabled]=\"disabled()\"\n [ariaDisabled]=\"disabled()\"\n [ngClass]=\"ngClasses()\"\n [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n [attr.tabindex]=\"tabIndex()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n>\n @for (row of itemRows(); track $index) {\n <div\n class=\"ard-segment-row\"\n [class.ard-segment-row-partial]=\"row.isNotFull\"\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n >\n @for (option of row.options; track $index) {\n <button\n type=\"button\"\n class=\"ard-segment-option\"\n tabindex=\"-1\"\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n [class.ard-option-selected]=\"option.selected()\"\n [class.ard-option-highlighted]=\"option.highlighted()\"\n [ariaSelected]=\"option.selected()\"\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\n (click)=\"onItemClick(option, $event)\"\n >\n <div class=\"ard-focus-overlay\"></div>\n <div class=\"ard-button-content\">\n <span class=\"ard-option-label\">\n <ng-template #defaultOptionTemplate>\n {{ option.label() }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\n />\n </span>\n </div>\n </button>\n }\n </div>\n }\n</div>\n", styles: [".ard-segment-container{display:flex;flex-direction:column}.ard-segment-container.ard-align-left .ard-segment-option{justify-content:left}.ard-segment-container.ard-align-middle .ard-segment-option{justify-content:center}.ard-segment-container.ard-align-right .ard-segment-option{justify-content:right}.ard-segment-row{width:100%;display:flex;align-items:center}.ard-segment-row.ard-segment-row-uniform{display:grid;grid-template-columns:repeat(var(--ard-_segment-row-items),1fr)}.ard-segment-option{-webkit-user-select:none;user-select:none}.ard-option-disabled{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
6979
6992
  }
6980
6993
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumSegmentComponent, decorators: [{
6981
6994
  type: Component,
6982
- args: [{ selector: 'ard-segment', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n #focusableElement\n class=\"ard-segment-container\"\n [class.ard-disabled]=\"disabled()\"\n [ariaDisabled]=\"disabled()\"\n [ngClass]=\"ngClasses()\"\n [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n [attr.tabindex]=\"tabIndex()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n>\n @for (row of itemRows(); track $index) {\n <div\n class=\"ard-segment-row\"\n [class.ard-segment-row-partial]=\"row.isNotFull\"\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n >\n @for (option of row.options; track $index) {\n <button\n type=\"button\"\n class=\"ard-segment-option\"\n tabindex=\"-1\"\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n [class.ard-option-selected]=\"option.selected()\"\n [class.ard-option-highlighted]=\"option.highlighted()\"\n [ariaSelected]=\"option.selected()\"\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\n (click)=\"onItemClick(option, $event)\"\n >\n <div class=\"ard-focus-overlay\"></div>\n <div class=\"ard-button-content\">\n <span class=\"ard-option-label\">\n <ng-template #defaultOptionTemplate>\n {{ option.label() }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\n />\n </span>\n </div>\n </button>\n }\n </div>\n }\n</div>\n", styles: [".ard-segment-container{display:flex;flex-direction:column}.ard-segment-container.ard-align-left .ard-segment-option{justify-content:left}.ard-segment-container.ard-align-middle .ard-segment-option{justify-content:center}.ard-segment-container.ard-align-right .ard-segment-option{justify-content:right}.ard-segment-row{width:100%;display:flex;align-items:center}.ard-segment-row.ard-segment-row-uniform{display:grid;grid-template-columns:repeat(var(--ard-_segment-row-items),1fr)}.ard-segment-option{-webkit-user-select:none;user-select:none}.ard-option-disabled{pointer-events:none}\n"] }]
6995
+ args: [{ selector: 'ard-segment', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
6996
+ {
6997
+ provide: NG_VALUE_ACCESSOR,
6998
+ useExisting: forwardRef(() => ArdiumSegmentComponent),
6999
+ multi: true,
7000
+ },
7001
+ {
7002
+ provide: _FormFieldComponentBase,
7003
+ useExisting: ArdiumSegmentComponent,
7004
+ },
7005
+ ], template: "<div\n #focusableElement\n class=\"ard-segment-container\"\n [class.ard-disabled]=\"disabled()\"\n [ariaDisabled]=\"disabled()\"\n [ngClass]=\"ngClasses()\"\n [class.ard-focus-visible]=\"isFocused() && !isMouseBeingUsed\"\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\n [attr.tabindex]=\"tabIndex()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n>\n @for (row of itemRows(); track $index) {\n <div\n class=\"ard-segment-row\"\n [class.ard-segment-row-partial]=\"row.isNotFull\"\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\n >\n @for (option of row.options; track $index) {\n <button\n type=\"button\"\n class=\"ard-segment-option\"\n tabindex=\"-1\"\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\n [class.ard-option-selected]=\"option.selected()\"\n [class.ard-option-highlighted]=\"option.highlighted()\"\n [ariaSelected]=\"option.selected()\"\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\n (click)=\"onItemClick(option, $event)\"\n >\n <div class=\"ard-focus-overlay\"></div>\n <div class=\"ard-button-content\">\n <span class=\"ard-option-label\">\n <ng-template #defaultOptionTemplate>\n {{ option.label() }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\n />\n </span>\n </div>\n </button>\n }\n </div>\n }\n</div>\n", styles: [".ard-segment-container{display:flex;flex-direction:column}.ard-segment-container.ard-align-left .ard-segment-option{justify-content:left}.ard-segment-container.ard-align-middle .ard-segment-option{justify-content:center}.ard-segment-container.ard-align-right .ard-segment-option{justify-content:right}.ard-segment-row{width:100%;display:flex;align-items:center}.ard-segment-row.ard-segment-row-uniform{display:grid;grid-template-columns:repeat(var(--ard-_segment-row-items),1fr)}.ard-segment-option{-webkit-user-select:none;user-select:none}.ard-option-disabled{pointer-events:none}\n"] }]
6983
7006
  }], ctorParameters: () => [{ type: undefined, decorators: [{
6984
7007
  type: Inject,
6985
7008
  args: [ARD_SEGMENT_DEFAULTS]