@ardium-ui/ui 2.0.6 → 2.1.0

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.
@@ -135,6 +135,8 @@ export class _SelectableListComponentBase extends _NgModelComponentBase {
135
135
  //! item selection handlers
136
136
  toggleItem(item) {
137
137
  if (item.selected()) {
138
+ if (this.singleselectable())
139
+ return;
138
140
  this.unselectItem(item);
139
141
  return;
140
142
  }
@@ -151,7 +153,8 @@ export class _SelectableListComponentBase extends _NgModelComponentBase {
151
153
  }
152
154
  unselectItem(...items) {
153
155
  const unselected = this.itemStorage.unselectItem(...items);
154
- this.removeEvent.emit(unselected);
156
+ if (unselected.length > 0)
157
+ this.removeEvent.emit(unselected);
155
158
  this._emitChange();
156
159
  }
157
160
  onMouseMove() {
@@ -277,4 +280,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
277
280
  type: HostListener,
278
281
  args: ['keydown', ['$event']]
279
282
  }] } });
280
- //# 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 {\r\n  ChangeDetectorRef,\r\n  Directive,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  computed,\r\n  input,\r\n  output,\r\n  signal\r\n} from '@angular/core';\r\nimport { ControlValueAccessor } from '@angular/forms';\r\nimport { coerceArrayProperty, coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\r\nimport { ArdOptionSimple, CompareWithFn, OptionContext } from '../types/item-storage.types';\r\nimport { Nullable } from '../types/utility.types';\r\nimport { SimpleItemStorage, SimpleItemStorageHost } from './item-storages/simple-item-storage';\r\nimport { _NgModelComponentBase } from './ngmodel-component';\r\n\r\n@Directive()\r\nexport abstract class _SelectableListComponentBase\r\n  extends _NgModelComponentBase\r\n  implements ControlValueAccessor, SimpleItemStorageHost\r\n{\r\n  //! public constants\r\n  readonly itemStorage = new SimpleItemStorage(this);\r\n  readonly htmlId = crypto.randomUUID();\r\n  readonly element!: HTMLElement;\r\n  readonly DEFAULTS = {\r\n    valueFrom: 'value',\r\n    labelFrom: 'label',\r\n    disabledFrom: 'disabled',\r\n  };\r\n\r\n  abstract readonly _componentId: string;\r\n  abstract readonly _componentName: string;\r\n\r\n  constructor(private _cd: ChangeDetectorRef) {\r\n    super();\r\n  }\r\n\r\n  //! binding-related inputs\r\n  readonly valueFrom = input<Nullable<string>>(undefined);\r\n  readonly labelFrom = input<Nullable<string>>(undefined);\r\n  readonly disabledFrom = input<Nullable<string>>(undefined);\r\n  readonly compareWith = input<Nullable<CompareWithFn>>(undefined);\r\n\r\n  //! items setter/getter\r\n  @Input()\r\n  get items(): any[] {\r\n    return this.itemStorage.items();\r\n  }\r\n  set items(value: any) {\r\n    if (!Array.isArray(value)) value = coerceArrayProperty(value);\r\n\r\n    const shouldPrintErrors = this.itemStorage.setItems(value);\r\n\r\n    if (shouldPrintErrors) {\r\n      this._printPrimitiveWarnings();\r\n    }\r\n  }\r\n  private _printPrimitiveWarnings() {\r\n    const makeWarning = (str: string): void => {\r\n      console.warn(\r\n        `ARD-WA${this._componentId} Skipped using [${str}] property bound to <ard-${this._componentName}>, as some provided items are of primitive type`\r\n      );\r\n    };\r\n    if (this.valueFrom()) {\r\n      makeWarning('valueFrom');\r\n    }\r\n    if (this.labelFrom()) {\r\n      makeWarning('labelFrom');\r\n    }\r\n    if (this.disabledFrom()) {\r\n      makeWarning('disabledFrom');\r\n    }\r\n    if (this.invertDisabled()) {\r\n      makeWarning('invertDisabled');\r\n    }\r\n  }\r\n\r\n  //! multiselectable\r\n  readonly multiselectable = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  @HostBinding('attr.multiple')\r\n  @HostBinding('class.ard-multiselect')\r\n  get _multiselectableHostAttribute() {\r\n    return this.multiselectable();\r\n  }\r\n\r\n  readonly singleselectable = computed(() => !this.multiselectable());\r\n\r\n  //! require value\r\n  readonly requireValue = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly isValueRequired = computed(() => this.requireValue() || !this.multiselectable());\r\n\r\n  @HostBinding('class.ard-require-value')\r\n  get _requireValueHostAttribute() {\r\n    return this.requireValue();\r\n  }\r\n\r\n  //! coerced properties\r\n  readonly invertDisabled = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n  readonly maxSelectedItems = input<Nullable<number>, any>(undefined, { transform: v => coerceNumberProperty(v, undefined) });\r\n\r\n  //! control value accessor\r\n  //override the writeValue and setDisabledState defined in _NgModelComponent\r\n  override setDisabledState(state: boolean): void {\r\n    this.disabled.set(state);\r\n    this._cd.markForCheck();\r\n  }\r\n  writeValue(ngModel: any[]): void {\r\n    this.itemStorage.writeValue(ngModel);\r\n    this._cd.markForCheck();\r\n  }\r\n\r\n  //! change & touch event emitters\r\n  readonly touched = signal<boolean>(false);\r\n\r\n  @HostBinding('class.ard-touched')\r\n  get _touchedHostAttribute(): boolean {\r\n    return this.touched();\r\n  }\r\n\r\n  protected _emitChange(): void {\r\n    const value = this.itemStorage.value();\r\n    this._onChangeRegistered?.(value);\r\n    this.changeEvent.emit(value);\r\n    this.valueChange.emit(value);\r\n  }\r\n  protected _onTouched(): void {\r\n    if (this.touched()) return;\r\n\r\n    this._onTouchedRegistered?.();\r\n    this.touched.set(true);\r\n  }\r\n\r\n  //! focus & blur handlers\r\n  private readonly lastBlurTimestamp = signal<Nullable<number>>(undefined);\r\n  override onFocus(event: FocusEvent): void {\r\n    super.onFocus(event);\r\n\r\n    const lbt = this.lastBlurTimestamp();\r\n    if (this.touched() || !lbt || lbt + 1 < Date.now()) return;\r\n    this.lastBlurTimestamp.set(null);\r\n\r\n    this._onTouched();\r\n  }\r\n  override onBlur(event: FocusEvent): void {\r\n    super.onBlur(event);\r\n\r\n    if (!this.touched()) this.lastBlurTimestamp.set(Date.now());\r\n  }\r\n\r\n  //! getters\r\n  readonly highlightedItems = computed<ArdOptionSimple[]>(() => this.itemStorage.highlightedItems());\r\n  readonly firstHighlightedItem = computed<Nullable<ArdOptionSimple>>(() => this.highlightedItems()?.first());\r\n  readonly isItemLimitReached = computed(() => this.itemStorage.isItemLimitReached());\r\n\r\n  //! context providers\r\n  getOptionContext(item: ArdOptionSimple): OptionContext<ArdOptionSimple> {\r\n    return {\r\n      $implicit: item,\r\n      item,\r\n      itemData: item.itemData(),\r\n    };\r\n  }\r\n\r\n  //! value input & output\r\n  @Input()\r\n  set value(newValue: any) {\r\n    if (!Array.isArray(newValue)) newValue = coerceArrayProperty(newValue);\r\n    this.writeValue(newValue);\r\n  }\r\n  readonly valueChange = output<any[]>();\r\n\r\n  //! output events\r\n  readonly changeEvent = output<any[]>({ alias: 'change' });\r\n  readonly addEvent = output<any[]>({ alias: 'add' });\r\n  readonly removeEvent = output<any[]>({ alias: 'remove' });\r\n\r\n  //! item selection handlers\r\n  toggleItem(item: ArdOptionSimple): void {\r\n    if (item.selected()) {\r\n      this.unselectItem(item);\r\n      return;\r\n    }\r\n    this.selectItem(item);\r\n  }\r\n  selectItem(...items: ArdOptionSimple[]): void {\r\n    const [selected, unselected] = this.itemStorage.selectItem(...items);\r\n\r\n    if (unselected.length > 0) this.removeEvent.emit(unselected);\r\n\r\n    if (selected.length > 0) {\r\n      this.addEvent.emit(selected);\r\n      this._emitChange();\r\n    }\r\n  }\r\n  unselectItem(...items: ArdOptionSimple[]): void {\r\n    const unselected = this.itemStorage.unselectItem(...items);\r\n\r\n    this.removeEvent.emit(unselected);\r\n    this._emitChange();\r\n  }\r\n\r\n  //! highligh-related\r\n\r\n  readonly isMouseBeingUsed = signal<boolean>(false);\r\n  @HostListener('mousemove')\r\n  onMouseMove() {\r\n    this.isMouseBeingUsed.set(true);\r\n  }\r\n  onItemMouseEnter(option: ArdOptionSimple, event: MouseEvent): void {\r\n    if (!this.isMouseBeingUsed) return;\r\n    this.itemStorage.highlightSingleItem(option);\r\n    event.stopPropagation();\r\n  }\r\n  onItemMouseLeave(option: ArdOptionSimple, event: MouseEvent): void {\r\n    if (!this.isMouseBeingUsed) return;\r\n    this.itemStorage.unhighlightItem(option);\r\n    event.stopPropagation();\r\n  }\r\n\r\n  //! click handlers\r\n  onItemClick(option: ArdOptionSimple, event: MouseEvent): void {\r\n    event.stopPropagation();\r\n    this.toggleItem(option);\r\n  }\r\n\r\n  //! key press handlers\r\n  @HostListener('keydown', ['$event'])\r\n  onKeyPress(event: KeyboardEvent): void {\r\n    switch (event.code) {\r\n      case 'Space':\r\n      case 'Enter': {\r\n        this._toggleHighlightedItems(event);\r\n        return;\r\n      }\r\n      case 'ArrowRight': {\r\n        this._highlightNext(event);\r\n        return;\r\n      }\r\n      case 'ArrowLeft': {\r\n        this._highlightPrevious(event);\r\n        return;\r\n      }\r\n      case 'Home': {\r\n        this._highlightFirst(event);\r\n        return;\r\n      }\r\n      case 'End': {\r\n        this._highlightLast(event);\r\n        return;\r\n      }\r\n      case 'KeyA': {\r\n        if (event.ctrlKey) {\r\n          this._highlightAll();\r\n          return;\r\n        }\r\n      }\r\n    }\r\n  }\r\n  private _toggleHighlightedItems(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n\r\n    const highlightedItems = this.highlightedItems();\r\n\r\n    if (highlightedItems.every(item => item.selected)) {\r\n      this.unselectItem(...highlightedItems);\r\n    } else {\r\n      this.selectItem(...highlightedItems);\r\n    }\r\n  }\r\n  private _highlightPrevious(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n    this.isMouseBeingUsed.set(false);\r\n\r\n    this.itemStorage.highlightNextItem(-1, event.shiftKey);\r\n  }\r\n  private _highlightNext(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n    this.isMouseBeingUsed.set(false);\r\n\r\n    this.itemStorage.highlightNextItem(+1, event.shiftKey);\r\n  }\r\n  private _highlightFirst(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n    this.isMouseBeingUsed.set(false);\r\n\r\n    this.itemStorage.highlightFirstItem();\r\n  }\r\n  private _highlightLast(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n    this.isMouseBeingUsed.set(false);\r\n\r\n    this.itemStorage.highlightLastItem();\r\n  }\r\n  private _highlightAll(): void {\r\n    this.itemStorage.highlightAllItems();\r\n  }\r\n}\r\n"]}
283
+ //# 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 { ChangeDetectorRef, Directive, HostBinding, HostListener, Input, computed, input, output, signal } from '@angular/core';\r\nimport { ControlValueAccessor } from '@angular/forms';\r\nimport { coerceArrayProperty, coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\r\nimport { ArdOptionSimple, CompareWithFn, OptionContext } from '../types/item-storage.types';\r\nimport { Nullable } from '../types/utility.types';\r\nimport { SimpleItemStorage, SimpleItemStorageHost } from './item-storages/simple-item-storage';\r\nimport { _NgModelComponentBase } from './ngmodel-component';\r\n\r\n@Directive()\r\nexport abstract class _SelectableListComponentBase\r\n  extends _NgModelComponentBase\r\n  implements ControlValueAccessor, SimpleItemStorageHost\r\n{\r\n  //! public constants\r\n  readonly itemStorage = new SimpleItemStorage(this);\r\n  readonly htmlId = crypto.randomUUID();\r\n  readonly element!: HTMLElement;\r\n  readonly DEFAULTS = {\r\n    valueFrom: 'value',\r\n    labelFrom: 'label',\r\n    disabledFrom: 'disabled',\r\n  };\r\n\r\n  abstract readonly _componentId: string;\r\n  abstract readonly _componentName: string;\r\n\r\n  constructor(private _cd: ChangeDetectorRef) {\r\n    super();\r\n  }\r\n\r\n  //! binding-related inputs\r\n  readonly valueFrom = input<Nullable<string>>(undefined);\r\n  readonly labelFrom = input<Nullable<string>>(undefined);\r\n  readonly disabledFrom = input<Nullable<string>>(undefined);\r\n  readonly compareWith = input<Nullable<CompareWithFn>>(undefined);\r\n\r\n  //! items setter/getter\r\n  @Input()\r\n  get items(): any[] {\r\n    return this.itemStorage.items();\r\n  }\r\n  set items(value: any) {\r\n    if (!Array.isArray(value)) value = coerceArrayProperty(value);\r\n\r\n    const shouldPrintErrors = this.itemStorage.setItems(value);\r\n\r\n    if (shouldPrintErrors) {\r\n      this._printPrimitiveWarnings();\r\n    }\r\n  }\r\n  private _printPrimitiveWarnings() {\r\n    const makeWarning = (str: string): void => {\r\n      console.warn(\r\n        `ARD-WA${this._componentId} Skipped using [${str}] property bound to <ard-${this._componentName}>, as some provided items are of primitive type`\r\n      );\r\n    };\r\n    if (this.valueFrom()) {\r\n      makeWarning('valueFrom');\r\n    }\r\n    if (this.labelFrom()) {\r\n      makeWarning('labelFrom');\r\n    }\r\n    if (this.disabledFrom()) {\r\n      makeWarning('disabledFrom');\r\n    }\r\n    if (this.invertDisabled()) {\r\n      makeWarning('invertDisabled');\r\n    }\r\n  }\r\n\r\n  //! multiselectable\r\n  readonly multiselectable = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  @HostBinding('attr.multiple')\r\n  @HostBinding('class.ard-multiselect')\r\n  get _multiselectableHostAttribute() {\r\n    return this.multiselectable();\r\n  }\r\n\r\n  readonly singleselectable = computed(() => !this.multiselectable());\r\n\r\n  //! require value\r\n  readonly requireValue = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly isValueRequired = computed(() => this.requireValue() || !this.multiselectable());\r\n\r\n  @HostBinding('class.ard-require-value')\r\n  get _requireValueHostAttribute() {\r\n    return this.requireValue();\r\n  }\r\n\r\n  //! coerced properties\r\n  readonly invertDisabled = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n  readonly maxSelectedItems = input<Nullable<number>, any>(undefined, { transform: v => coerceNumberProperty(v, undefined) });\r\n\r\n  //! control value accessor\r\n  //override the writeValue and setDisabledState defined in _NgModelComponent\r\n  override setDisabledState(state: boolean): void {\r\n    this.disabled.set(state);\r\n    this._cd.markForCheck();\r\n  }\r\n  writeValue(ngModel: any[]): void {\r\n    this.itemStorage.writeValue(ngModel);\r\n    this._cd.markForCheck();\r\n  }\r\n\r\n  //! change & touch event emitters\r\n  readonly touched = signal<boolean>(false);\r\n\r\n  @HostBinding('class.ard-touched')\r\n  get _touchedHostAttribute(): boolean {\r\n    return this.touched();\r\n  }\r\n\r\n  protected _emitChange(): void {\r\n    const value = this.itemStorage.value();\r\n    this._onChangeRegistered?.(value);\r\n    this.changeEvent.emit(value);\r\n    this.valueChange.emit(value);\r\n  }\r\n  protected _onTouched(): void {\r\n    if (this.touched()) return;\r\n\r\n    this._onTouchedRegistered?.();\r\n    this.touched.set(true);\r\n  }\r\n\r\n  //! focus & blur handlers\r\n  private readonly lastBlurTimestamp = signal<Nullable<number>>(undefined);\r\n  override onFocus(event: FocusEvent): void {\r\n    super.onFocus(event);\r\n\r\n    const lbt = this.lastBlurTimestamp();\r\n    if (this.touched() || !lbt || lbt + 1 < Date.now()) return;\r\n    this.lastBlurTimestamp.set(null);\r\n\r\n    this._onTouched();\r\n  }\r\n  override onBlur(event: FocusEvent): void {\r\n    super.onBlur(event);\r\n\r\n    if (!this.touched()) this.lastBlurTimestamp.set(Date.now());\r\n  }\r\n\r\n  //! getters\r\n  readonly highlightedItems = computed<ArdOptionSimple[]>(() => this.itemStorage.highlightedItems());\r\n  readonly firstHighlightedItem = computed<Nullable<ArdOptionSimple>>(() => this.highlightedItems()?.first());\r\n  readonly isItemLimitReached = computed(() => this.itemStorage.isItemLimitReached());\r\n\r\n  //! context providers\r\n  getOptionContext(item: ArdOptionSimple): OptionContext<ArdOptionSimple> {\r\n    return {\r\n      $implicit: item,\r\n      item,\r\n      itemData: item.itemData(),\r\n    };\r\n  }\r\n\r\n  //! value input & output\r\n  @Input()\r\n  set value(newValue: any) {\r\n    if (!Array.isArray(newValue)) newValue = coerceArrayProperty(newValue);\r\n    this.writeValue(newValue);\r\n  }\r\n  readonly valueChange = output<any[]>();\r\n\r\n  //! output events\r\n  readonly changeEvent = output<any[]>({ alias: 'change' });\r\n  readonly addEvent = output<any[]>({ alias: 'add' });\r\n  readonly removeEvent = output<any[]>({ alias: 'remove' });\r\n\r\n  //! item selection handlers\r\n  toggleItem(item: ArdOptionSimple): void {\r\n    if (item.selected()) {\r\n      if (this.singleselectable()) return;\r\n\r\n      this.unselectItem(item);\r\n      return;\r\n    }\r\n    this.selectItem(item);\r\n  }\r\n  selectItem(...items: ArdOptionSimple[]): void {\r\n    const [selected, unselected] = this.itemStorage.selectItem(...items);\r\n\r\n    if (unselected.length > 0) this.removeEvent.emit(unselected);\r\n\r\n    if (selected.length > 0) {\r\n      this.addEvent.emit(selected);\r\n      this._emitChange();\r\n    }\r\n  }\r\n  unselectItem(...items: ArdOptionSimple[]): void {\r\n    const unselected = this.itemStorage.unselectItem(...items);\r\n\r\n    if (unselected.length > 0) this.removeEvent.emit(unselected);\r\n    \r\n    this._emitChange();\r\n  }\r\n\r\n  //! highligh-related\r\n\r\n  readonly isMouseBeingUsed = signal<boolean>(false);\r\n  @HostListener('mousemove')\r\n  onMouseMove() {\r\n    this.isMouseBeingUsed.set(true);\r\n  }\r\n  onItemMouseEnter(option: ArdOptionSimple, event: MouseEvent): void {\r\n    if (!this.isMouseBeingUsed) return;\r\n    this.itemStorage.highlightSingleItem(option);\r\n    event.stopPropagation();\r\n  }\r\n  onItemMouseLeave(option: ArdOptionSimple, event: MouseEvent): void {\r\n    if (!this.isMouseBeingUsed) return;\r\n    this.itemStorage.unhighlightItem(option);\r\n    event.stopPropagation();\r\n  }\r\n\r\n  //! click handlers\r\n  onItemClick(option: ArdOptionSimple, event: MouseEvent): void {\r\n    event.stopPropagation();\r\n    this.toggleItem(option);\r\n  }\r\n\r\n  //! key press handlers\r\n  @HostListener('keydown', ['$event'])\r\n  onKeyPress(event: KeyboardEvent): void {\r\n    switch (event.code) {\r\n      case 'Space':\r\n      case 'Enter': {\r\n        this._toggleHighlightedItems(event);\r\n        return;\r\n      }\r\n      case 'ArrowRight': {\r\n        this._highlightNext(event);\r\n        return;\r\n      }\r\n      case 'ArrowLeft': {\r\n        this._highlightPrevious(event);\r\n        return;\r\n      }\r\n      case 'Home': {\r\n        this._highlightFirst(event);\r\n        return;\r\n      }\r\n      case 'End': {\r\n        this._highlightLast(event);\r\n        return;\r\n      }\r\n      case 'KeyA': {\r\n        if (event.ctrlKey) {\r\n          this._highlightAll();\r\n          return;\r\n        }\r\n      }\r\n    }\r\n  }\r\n  private _toggleHighlightedItems(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n\r\n    const highlightedItems = this.highlightedItems();\r\n\r\n    if (highlightedItems.every(item => item.selected)) {\r\n      this.unselectItem(...highlightedItems);\r\n    } else {\r\n      this.selectItem(...highlightedItems);\r\n    }\r\n  }\r\n  private _highlightPrevious(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n    this.isMouseBeingUsed.set(false);\r\n\r\n    this.itemStorage.highlightNextItem(-1, event.shiftKey);\r\n  }\r\n  private _highlightNext(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n    this.isMouseBeingUsed.set(false);\r\n\r\n    this.itemStorage.highlightNextItem(+1, event.shiftKey);\r\n  }\r\n  private _highlightFirst(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n    this.isMouseBeingUsed.set(false);\r\n\r\n    this.itemStorage.highlightFirstItem();\r\n  }\r\n  private _highlightLast(event: KeyboardEvent): void {\r\n    if (!this.isFocused) return;\r\n\r\n    event.preventDefault();\r\n    this.isMouseBeingUsed.set(false);\r\n\r\n    this.itemStorage.highlightLastItem();\r\n  }\r\n  private _highlightAll(): void {\r\n    this.itemStorage.highlightAllItems();\r\n  }\r\n}\r\n"]}
@@ -26,6 +26,7 @@ export class ArdiumSegmentComponent extends _SelectableListComponentBase {
26
26
  `ard-align-${this.align()}`,
27
27
  this.iconBased() ? 'ard-icon-based' : '',
28
28
  this.compact() ? 'ard-compact' : '',
29
+ this.itemRows().length > 1 ? 'ard-multirow' : 'ard-singlerow',
29
30
  ].join(' '));
30
31
  //! coerced properties
31
32
  this.autoFocus = input(false, { transform: v => coerceBooleanProperty(v) });
@@ -98,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
98
99
  type: Component,
99
100
  args: [{ selector: 'ard-segment', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n #focusableElement\r\n class=\"ard-segment-container\"\r\n [class.ard-disabled]=\"disabled()\"\r\n [ariaDisabled]=\"disabled()\"\r\n [ngClass]=\"ngClasses()\"\r\n [class.ard-focus-visible]=\"isFocused && !isMouseBeingUsed\"\r\n [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\r\n [attr.tabindex]=\"tabIndex()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n>\r\n @for (row of itemRows(); track $index) {\r\n <div\r\n class=\"ard-segment-row\"\r\n [class.ard-segment-row-partial]=\"row.isNotFull\"\r\n [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\r\n [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\r\n >\r\n @for (option of row.options; track $index) {\r\n <button\r\n type=\"button\"\r\n class=\"ard-segment-option\"\r\n tabindex=\"-1\"\r\n [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\r\n [class.ard-option-selected]=\"option.selected()\"\r\n [class.ard-option-highlighted]=\"option.highlighted()\"\r\n [ariaSelected]=\"option.selected()\"\r\n (mouseenter)=\"onItemMouseEnter(option, $event)\"\r\n (mouseleave)=\"onItemMouseLeave(option, $event)\"\r\n (click)=\"onItemClick(option, $event)\"\r\n >\r\n <div class=\"ard-focus-overlay\"></div>\r\n <div class=\"ard-button-content\">\r\n <span class=\"ard-option-label\">\r\n <ng-template #defaultOptionTemplate>\r\n {{ option.label() }}\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\r\n [ngTemplateOutletContext]=\"getOptionContext(option)\"\r\n />\r\n </span>\r\n </div>\r\n </button>\r\n }\r\n </div>\r\n }\r\n</div>\r\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"] }]
100
101
  }] });
101
- //# 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,iBAAiB,EACjB,QAAQ,EACR,YAAY,EACZ,KAAK,EACN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,4BAA4B,EAAE,MAAM,wCAAwC,CAAC;AACtF,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAGvD,OAAO,EAAE,iCAAiC,EAAE,MAAM,sBAAsB,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;;;AAcpE,MAAM,OAAO,sBAAuB,SAAQ,4BAA4B;IAPxE;;QAQoB,iBAAY,GAAW,KAAK,CAAC;QAC7B,mBAAc,GAAW,SAAS,CAAC;QAErD,cAAc;QACL,eAAU,GAAG,KAAK,CAAoB,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QAClE,YAAO,GAAG,KAAK,CAAiB,cAAc,CAAC,gBAAgB,CAAC,CAAC;QACjE,UAAK,GAAG,KAAK,CAAiB,cAAc,CAAC,OAAO,CAAC,CAAC;QACtD,UAAK,GAAG,KAAK,CAAmB,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAEzD,cAAS,GAAG,KAAK,CAAe,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACrF,YAAO,GAAG,KAAK,CAAe,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEnF,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;SACpC,CAAC,IAAI,CAAC,GAAG,CAAC,CACZ,CAAC;QAEF,sBAAsB;QACb,cAAS,GAAG,KAAK,CAAe,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACrF,kBAAa,GAAG,KAAK,CAAe,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEzF,gBAAW,GAAG,KAAK,CAAc,QAAQ,EAAE;YAClD,SAAS,EAAE,CAAC,CAAC,EAAE;gBACb,MAAM,QAAQ,GAAG,oBAAoB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;gBACnD,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,CAAA;KAgBH;IArDC,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;8GAlGU,sBAAsB;kGAAtB,sBAAsB,gwCAmDM,iCAAiC,uFCjF1E,80DAkDA;;2FDpBa,sBAAsB;kBAPlC,SAAS;+BACE,aAAa,iBAGR,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM","sourcesContent":["import {\r\n  AfterContentInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ViewEncapsulation,\r\n  computed,\r\n  contentChild,\r\n  input\r\n} from '@angular/core';\r\nimport { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\r\nimport { _SelectableListComponentBase } from '../_internal/selectable-list-component';\r\nimport { OneAxisAlignment } from '../types/alignment.types';\r\nimport { ComponentColor } from '../types/colors.types';\r\nimport { ArdOptionSimple } from '../types/item-storage.types';\r\nimport { SimpleItemStorageHost } from './../_internal/item-storages/simple-item-storage';\r\nimport { ArdSegmentOptionTemplateDirective } from './segment.directives';\r\nimport { SegmentAppearance, SegmentVariant } from './segment.types';\r\n\r\ninterface SegmentRow {\r\n  options: ArdOptionSimple[];\r\n  isNotFull?: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'ard-segment',\r\n  templateUrl: './segment.component.html',\r\n  styleUrls: ['./segment.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ArdiumSegmentComponent extends _SelectableListComponentBase implements SimpleItemStorageHost, AfterContentInit {\r\n  override readonly _componentId: string = '104';\r\n  override readonly _componentName: string = 'segment';\r\n\r\n  //! appearance\r\n  readonly appearance = input<SegmentAppearance>(SegmentAppearance.Outlined);\r\n  readonly variant = input<SegmentVariant>(SegmentVariant.RoundedConnected);\r\n  readonly color = input<ComponentColor>(ComponentColor.Primary);\r\n  readonly align = input<OneAxisAlignment>(OneAxisAlignment.Middle);\r\n\r\n  readonly iconBased = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n  readonly compact = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly ngClasses = computed<string>(() =>\r\n    [\r\n      `ard-appearance-${this.appearance()}`,\r\n      `ard-variant-${this.variant()}`,\r\n      `ard-color-${this.color()}`,\r\n      `ard-align-${this.align()}`,\r\n      this.iconBased() ? 'ard-icon-based' : '',\r\n      this.compact() ? 'ard-compact' : '',\r\n    ].join(' ')\r\n  );\r\n\r\n  //! coerced properties\r\n  readonly autoFocus = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n  readonly uniformWidths = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly itemsPerRow = input<number, any>(Infinity, {\r\n    transform: v => {\r\n      const newValue = coerceNumberProperty(v, Infinity);\r\n      if (newValue === 0) throw new Error(`ARD-FT1040a: Cannot set <ard-segment>'s [itemsPerRow] to 0.`);\r\n      if (newValue < 0)\r\n        throw new Error(`ARD-FT1040b: Cannot set <ard-segment>'s [itemsPerRow] to a negative value, got \"${newValue}\".`);\r\n      if (newValue % 1 !== 0) {\r\n        const roundedValue = Math.round(newValue) || 1; // round to nearest int, but never round to zero\r\n        console.warn(\r\n          new Error(\r\n            `ARD-WA1040c: Cannot set <ard-segment>'s [itemsPerRow] to a non-interger value, got \"${newValue}\". The value was rounded to \"${roundedValue}\".`\r\n          )\r\n        );\r\n        return Math.ceil(newValue);\r\n      }\r\n      return newValue;\r\n    },\r\n  });\r\n  get itemsInActualRow(): number {\r\n    return this.itemsPerRow() === Infinity ? this.items.length : this.itemsPerRow();\r\n  }\r\n\r\n  //! option template\r\n  readonly optionTemplate = contentChild(ArdSegmentOptionTemplateDirective);\r\n\r\n  //! lifecycle hooks\r\n  ngAfterContentInit(): void {\r\n    if (this.autoFocus()) {\r\n      this.focus();\r\n    }\r\n  }\r\n\r\n  //! item row getters\r\n  readonly itemRows = computed<SegmentRow[]>(() => {\r\n    const itemRows: SegmentRow[] = [];\r\n    let currentRow: ArdOptionSimple[] = [];\r\n    //get all rows\r\n    for (const item of this.items) {\r\n      //add item\r\n      currentRow.push(item);\r\n\r\n      //push if item amount reached the limit\r\n      if (this.itemsPerRow() && currentRow.length === this.itemsPerRow()) {\r\n        itemRows.push({ options: currentRow });\r\n        currentRow = [];\r\n      }\r\n    }\r\n    //push the last row if it is not empty\r\n    if (currentRow.length !== 0) {\r\n      itemRows.push({\r\n        options: currentRow,\r\n        isNotFull: Boolean(this.itemsPerRow()),\r\n      });\r\n    }\r\n    return itemRows;\r\n  })\r\n\r\n  //! focus handler override\r\n  override onFocus(event: FocusEvent): void {\r\n    super.onFocus(event);\r\n\r\n    if (this.itemStorage.isAnyItemHighlighted()) return;\r\n\r\n    this.itemStorage.highlightFirstItem();\r\n  }\r\n\r\n  override onBlur(event: FocusEvent): void {\r\n    super.onBlur(event);\r\n\r\n    this.itemStorage.unhighlightAll();\r\n  }\r\n}\r\n","<div\r\n  #focusableElement\r\n  class=\"ard-segment-container\"\r\n  [class.ard-disabled]=\"disabled()\"\r\n  [ariaDisabled]=\"disabled()\"\r\n  [ngClass]=\"ngClasses()\"\r\n  [class.ard-focus-visible]=\"isFocused && !isMouseBeingUsed\"\r\n  [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\r\n  [attr.tabindex]=\"tabIndex()\"\r\n  (focus)=\"onFocus($event)\"\r\n  (blur)=\"onBlur($event)\"\r\n>\r\n  @for (row of itemRows(); track $index) {\r\n  <div\r\n    class=\"ard-segment-row\"\r\n    [class.ard-segment-row-partial]=\"row.isNotFull\"\r\n    [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\r\n    [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\r\n  >\r\n    @for (option of row.options; track $index) {\r\n    <button\r\n      type=\"button\"\r\n      class=\"ard-segment-option\"\r\n      tabindex=\"-1\"\r\n      [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\r\n      [class.ard-option-selected]=\"option.selected()\"\r\n      [class.ard-option-highlighted]=\"option.highlighted()\"\r\n      [ariaSelected]=\"option.selected()\"\r\n      (mouseenter)=\"onItemMouseEnter(option, $event)\"\r\n      (mouseleave)=\"onItemMouseLeave(option, $event)\"\r\n      (click)=\"onItemClick(option, $event)\"\r\n    >\r\n      <div class=\"ard-focus-overlay\"></div>\r\n      <div class=\"ard-button-content\">\r\n        <span class=\"ard-option-label\">\r\n          <ng-template #defaultOptionTemplate>\r\n            {{ option.label() }}\r\n          </ng-template>\r\n\r\n          <ng-template\r\n            [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\r\n            [ngTemplateOutletContext]=\"getOptionContext(option)\"\r\n          />\r\n        </span>\r\n      </div>\r\n    </button>\r\n    }\r\n  </div>\r\n  }\r\n</div>\r\n"]}
102
+ //# 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 {\r\n  AfterContentInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ViewEncapsulation,\r\n  computed,\r\n  contentChild,\r\n  input\r\n} from '@angular/core';\r\nimport { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\r\nimport { _SelectableListComponentBase } from '../_internal/selectable-list-component';\r\nimport { OneAxisAlignment } from '../types/alignment.types';\r\nimport { ComponentColor } from '../types/colors.types';\r\nimport { ArdOptionSimple } from '../types/item-storage.types';\r\nimport { SimpleItemStorageHost } from './../_internal/item-storages/simple-item-storage';\r\nimport { ArdSegmentOptionTemplateDirective } from './segment.directives';\r\nimport { SegmentAppearance, SegmentVariant } from './segment.types';\r\n\r\ninterface SegmentRow {\r\n  options: ArdOptionSimple[];\r\n  isNotFull?: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'ard-segment',\r\n  templateUrl: './segment.component.html',\r\n  styleUrls: ['./segment.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ArdiumSegmentComponent extends _SelectableListComponentBase implements SimpleItemStorageHost, AfterContentInit {\r\n  override readonly _componentId: string = '104';\r\n  override readonly _componentName: string = 'segment';\r\n\r\n  //! appearance\r\n  readonly appearance = input<SegmentAppearance>(SegmentAppearance.Outlined);\r\n  readonly variant = input<SegmentVariant>(SegmentVariant.RoundedConnected);\r\n  readonly color = input<ComponentColor>(ComponentColor.Primary);\r\n  readonly align = input<OneAxisAlignment>(OneAxisAlignment.Middle);\r\n\r\n  readonly iconBased = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n  readonly compact = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly ngClasses = computed<string>(() =>\r\n    [\r\n      `ard-appearance-${this.appearance()}`,\r\n      `ard-variant-${this.variant()}`,\r\n      `ard-color-${this.color()}`,\r\n      `ard-align-${this.align()}`,\r\n      this.iconBased() ? 'ard-icon-based' : '',\r\n      this.compact() ? 'ard-compact' : '',\r\n      this.itemRows().length > 1 ? 'ard-multirow' : 'ard-singlerow',\r\n    ].join(' ')\r\n  );\r\n\r\n  //! coerced properties\r\n  readonly autoFocus = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n  readonly uniformWidths = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly itemsPerRow = input<number, any>(Infinity, {\r\n    transform: v => {\r\n      const newValue = coerceNumberProperty(v, Infinity);\r\n      if (newValue === 0) throw new Error(`ARD-FT1040a: Cannot set <ard-segment>'s [itemsPerRow] to 0.`);\r\n      if (newValue < 0)\r\n        throw new Error(`ARD-FT1040b: Cannot set <ard-segment>'s [itemsPerRow] to a negative value, got \"${newValue}\".`);\r\n      if (newValue % 1 !== 0) {\r\n        const roundedValue = Math.round(newValue) || 1; // round to nearest int, but never round to zero\r\n        console.warn(\r\n          new Error(\r\n            `ARD-WA1040c: Cannot set <ard-segment>'s [itemsPerRow] to a non-interger value, got \"${newValue}\". The value was rounded to \"${roundedValue}\".`\r\n          )\r\n        );\r\n        return Math.ceil(newValue);\r\n      }\r\n      return newValue;\r\n    },\r\n  });\r\n  get itemsInActualRow(): number {\r\n    return this.itemsPerRow() === Infinity ? this.items.length : this.itemsPerRow();\r\n  }\r\n\r\n  //! option template\r\n  readonly optionTemplate = contentChild(ArdSegmentOptionTemplateDirective);\r\n\r\n  //! lifecycle hooks\r\n  ngAfterContentInit(): void {\r\n    if (this.autoFocus()) {\r\n      this.focus();\r\n    }\r\n  }\r\n\r\n  //! item row getters\r\n  readonly itemRows = computed<SegmentRow[]>(() => {\r\n    const itemRows: SegmentRow[] = [];\r\n    let currentRow: ArdOptionSimple[] = [];\r\n    //get all rows\r\n    for (const item of this.items) {\r\n      //add item\r\n      currentRow.push(item);\r\n\r\n      //push if item amount reached the limit\r\n      if (this.itemsPerRow() && currentRow.length === this.itemsPerRow()) {\r\n        itemRows.push({ options: currentRow });\r\n        currentRow = [];\r\n      }\r\n    }\r\n    //push the last row if it is not empty\r\n    if (currentRow.length !== 0) {\r\n      itemRows.push({\r\n        options: currentRow,\r\n        isNotFull: Boolean(this.itemsPerRow()),\r\n      });\r\n    }\r\n    return itemRows;\r\n  });\r\n\r\n  //! focus handler override\r\n  override onFocus(event: FocusEvent): void {\r\n    super.onFocus(event);\r\n\r\n    if (this.itemStorage.isAnyItemHighlighted()) return;\r\n\r\n    this.itemStorage.highlightFirstItem();\r\n  }\r\n\r\n  override onBlur(event: FocusEvent): void {\r\n    super.onBlur(event);\r\n\r\n    this.itemStorage.unhighlightAll();\r\n  }\r\n}\r\n","<div\r\n  #focusableElement\r\n  class=\"ard-segment-container\"\r\n  [class.ard-disabled]=\"disabled()\"\r\n  [ariaDisabled]=\"disabled()\"\r\n  [ngClass]=\"ngClasses()\"\r\n  [class.ard-focus-visible]=\"isFocused && !isMouseBeingUsed\"\r\n  [class.ard-using-keyboard]=\"!isMouseBeingUsed\"\r\n  [attr.tabindex]=\"tabIndex()\"\r\n  (focus)=\"onFocus($event)\"\r\n  (blur)=\"onBlur($event)\"\r\n>\r\n  @for (row of itemRows(); track $index) {\r\n  <div\r\n    class=\"ard-segment-row\"\r\n    [class.ard-segment-row-partial]=\"row.isNotFull\"\r\n    [class.ard-segment-row-uniform]=\"uniformWidths() || itemsPerRow() < items.length\"\r\n    [style]=\"{ '--ard-_segment-row-items': itemsInActualRow }\"\r\n  >\r\n    @for (option of row.options; track $index) {\r\n    <button\r\n      type=\"button\"\r\n      class=\"ard-segment-option\"\r\n      tabindex=\"-1\"\r\n      [class.ard-option-disabled]=\"option.disabled() || (isItemLimitReached() && !option.selected())\"\r\n      [class.ard-option-selected]=\"option.selected()\"\r\n      [class.ard-option-highlighted]=\"option.highlighted()\"\r\n      [ariaSelected]=\"option.selected()\"\r\n      (mouseenter)=\"onItemMouseEnter(option, $event)\"\r\n      (mouseleave)=\"onItemMouseLeave(option, $event)\"\r\n      (click)=\"onItemClick(option, $event)\"\r\n    >\r\n      <div class=\"ard-focus-overlay\"></div>\r\n      <div class=\"ard-button-content\">\r\n        <span class=\"ard-option-label\">\r\n          <ng-template #defaultOptionTemplate>\r\n            {{ option.label() }}\r\n          </ng-template>\r\n\r\n          <ng-template\r\n            [ngTemplateOutlet]=\"optionTemplate()?.template || defaultOptionTemplate\"\r\n            [ngTemplateOutletContext]=\"getOptionContext(option)\"\r\n          />\r\n        </span>\r\n      </div>\r\n    </button>\r\n    }\r\n  </div>\r\n  }\r\n</div>\r\n"]}
@@ -3,10 +3,11 @@ export const SegmentVariant = {
3
3
  ...FormElementVariant,
4
4
  RoundedConnected: 'rounded-connected',
5
5
  SharpConnected: 'sharp-connected',
6
+ PillConnected: 'pill-connected',
6
7
  };
7
8
  export const SegmentAppearance = {
8
9
  ...FormElementAppearance,
9
10
  FilledStrong: 'filled-strong',
10
11
  OutlinedStrong: 'outlined-strong',
11
12
  };
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VnbWVudC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvc2VnbWVudC9zZWdtZW50LnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRW5GLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixHQUFHLGtCQUFrQjtJQUNyQixnQkFBZ0IsRUFBRSxtQkFBbUI7SUFDckMsY0FBYyxFQUFFLGlCQUFpQjtDQUN6QixDQUFDO0FBR1gsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUc7SUFDL0IsR0FBRyxxQkFBcUI7SUFDeEIsWUFBWSxFQUFFLGVBQWU7SUFDN0IsY0FBYyxFQUFFLGlCQUFpQjtDQUN6QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybUVsZW1lbnRBcHBlYXJhbmNlLCBGb3JtRWxlbWVudFZhcmlhbnQgfSBmcm9tICcuLi90eXBlcy90aGVtaW5nLnR5cGVzJztcblxuZXhwb3J0IGNvbnN0IFNlZ21lbnRWYXJpYW50ID0ge1xuICAuLi5Gb3JtRWxlbWVudFZhcmlhbnQsXG4gIFJvdW5kZWRDb25uZWN0ZWQ6ICdyb3VuZGVkLWNvbm5lY3RlZCcsXG4gIFNoYXJwQ29ubmVjdGVkOiAnc2hhcnAtY29ubmVjdGVkJyxcbn0gYXMgY29uc3Q7XG5leHBvcnQgdHlwZSBTZWdtZW50VmFyaWFudCA9ICh0eXBlb2YgU2VnbWVudFZhcmlhbnQpW2tleW9mIHR5cGVvZiBTZWdtZW50VmFyaWFudF07XG5cbmV4cG9ydCBjb25zdCBTZWdtZW50QXBwZWFyYW5jZSA9IHtcbiAgLi4uRm9ybUVsZW1lbnRBcHBlYXJhbmNlLFxuICBGaWxsZWRTdHJvbmc6ICdmaWxsZWQtc3Ryb25nJyxcbiAgT3V0bGluZWRTdHJvbmc6ICdvdXRsaW5lZC1zdHJvbmcnLFxufSBhcyBjb25zdDtcbmV4cG9ydCB0eXBlIFNlZ21lbnRBcHBlYXJhbmNlID0gKHR5cGVvZiBTZWdtZW50QXBwZWFyYW5jZSlba2V5b2YgdHlwZW9mIFNlZ21lbnRBcHBlYXJhbmNlXTtcbiJdfQ==
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VnbWVudC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvc2VnbWVudC9zZWdtZW50LnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRW5GLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixHQUFHLGtCQUFrQjtJQUNyQixnQkFBZ0IsRUFBRSxtQkFBbUI7SUFDckMsY0FBYyxFQUFFLGlCQUFpQjtJQUNqQyxhQUFhLEVBQUUsZ0JBQWdCO0NBQ3ZCLENBQUM7QUFHWCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRztJQUMvQixHQUFHLHFCQUFxQjtJQUN4QixZQUFZLEVBQUUsZUFBZTtJQUM3QixjQUFjLEVBQUUsaUJBQWlCO0NBQ3pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JtRWxlbWVudEFwcGVhcmFuY2UsIEZvcm1FbGVtZW50VmFyaWFudCB9IGZyb20gJy4uL3R5cGVzL3RoZW1pbmcudHlwZXMnO1xuXG5leHBvcnQgY29uc3QgU2VnbWVudFZhcmlhbnQgPSB7XG4gIC4uLkZvcm1FbGVtZW50VmFyaWFudCxcbiAgUm91bmRlZENvbm5lY3RlZDogJ3JvdW5kZWQtY29ubmVjdGVkJyxcbiAgU2hhcnBDb25uZWN0ZWQ6ICdzaGFycC1jb25uZWN0ZWQnLFxuICBQaWxsQ29ubmVjdGVkOiAncGlsbC1jb25uZWN0ZWQnLFxufSBhcyBjb25zdDtcbmV4cG9ydCB0eXBlIFNlZ21lbnRWYXJpYW50ID0gKHR5cGVvZiBTZWdtZW50VmFyaWFudClba2V5b2YgdHlwZW9mIFNlZ21lbnRWYXJpYW50XTtcblxuZXhwb3J0IGNvbnN0IFNlZ21lbnRBcHBlYXJhbmNlID0ge1xuICAuLi5Gb3JtRWxlbWVudEFwcGVhcmFuY2UsXG4gIEZpbGxlZFN0cm9uZzogJ2ZpbGxlZC1zdHJvbmcnLFxuICBPdXRsaW5lZFN0cm9uZzogJ291dGxpbmVkLXN0cm9uZycsXG59IGFzIGNvbnN0O1xuZXhwb3J0IHR5cGUgU2VnbWVudEFwcGVhcmFuY2UgPSAodHlwZW9mIFNlZ21lbnRBcHBlYXJhbmNlKVtrZXlvZiB0eXBlb2YgU2VnbWVudEFwcGVhcmFuY2VdO1xuIl19
@@ -6077,6 +6077,8 @@ class _SelectableListComponentBase extends _NgModelComponentBase {
6077
6077
  //! item selection handlers
6078
6078
  toggleItem(item) {
6079
6079
  if (item.selected()) {
6080
+ if (this.singleselectable())
6081
+ return;
6080
6082
  this.unselectItem(item);
6081
6083
  return;
6082
6084
  }
@@ -6093,7 +6095,8 @@ class _SelectableListComponentBase extends _NgModelComponentBase {
6093
6095
  }
6094
6096
  unselectItem(...items) {
6095
6097
  const unselected = this.itemStorage.unselectItem(...items);
6096
- this.removeEvent.emit(unselected);
6098
+ if (unselected.length > 0)
6099
+ this.removeEvent.emit(unselected);
6097
6100
  this._emitChange();
6098
6101
  }
6099
6102
  onMouseMove() {
@@ -6236,6 +6239,7 @@ const SegmentVariant = {
6236
6239
  ...FormElementVariant,
6237
6240
  RoundedConnected: 'rounded-connected',
6238
6241
  SharpConnected: 'sharp-connected',
6242
+ PillConnected: 'pill-connected',
6239
6243
  };
6240
6244
  const SegmentAppearance = {
6241
6245
  ...FormElementAppearance,
@@ -6262,6 +6266,7 @@ class ArdiumSegmentComponent extends _SelectableListComponentBase {
6262
6266
  `ard-align-${this.align()}`,
6263
6267
  this.iconBased() ? 'ard-icon-based' : '',
6264
6268
  this.compact() ? 'ard-compact' : '',
6269
+ this.itemRows().length > 1 ? 'ard-multirow' : 'ard-singlerow',
6265
6270
  ].join(' '));
6266
6271
  //! coerced properties
6267
6272
  this.autoFocus = input(false, { transform: v => coerceBooleanProperty(v) });