@ardium-ui/ui 3.5.2 → 3.5.4-alpha.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.
@@ -107,13 +107,17 @@ export class ArdiumDigitInputComponent extends _FormFieldComponentBase {
107
107
  return !this.model.isDefinedAtIndex(index);
108
108
  }
109
109
  writeValue(v) {
110
+ console.log('writeValue', v, this._wasViewInit);
110
111
  if (!this._wasViewInit) {
111
112
  this._valueBeforeViewInit = v;
113
+ console.log('returning from writeValue');
112
114
  return;
113
115
  }
116
+ console.log('calling _writeValue with value', v);
114
117
  this._writeValue(v);
115
118
  }
116
119
  _writeValue(v) {
120
+ console.log('_writeValue', v);
117
121
  return this.model.writeValue(v);
118
122
  }
119
123
  ngAfterViewInit() {
@@ -261,4 +265,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
261
265
  }] }], propDecorators: { value: [{
262
266
  type: Input
263
267
  }] } });
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"digit-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.component.ts","../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AutofillMonitor } from '@angular/cdk/text-field';\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  computed,\r\n  effect,\r\n  forwardRef,\r\n  inject,\r\n  input,\r\n  output,\r\n  signal,\r\n  viewChildren,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { Subscription } from 'rxjs';\r\nimport { _FormFieldComponentBase } from '../../_internal/form-field-component';\r\nimport { FormElementAppearance, FormElementVariant } from '../../types/theming.types';\r\nimport { ARD_DIGIT_INPUT_DEFAULTS, ArdDigitInputDefaults } from './digit-input.defaults';\r\nimport { DigitInputModel } from './digit-input.model';\r\nimport { DigitInputAutoFillParseFn, DigitInputConfig, DigitInputShape, DigitInputTransform } from './digit-input.types';\r\nimport { DigitInputModelHost } from './digit-input.utils';\r\n\r\n@Component({\r\n  selector: 'ard-digit-input',\r\n  templateUrl: './digit-input.component.html',\r\n  styleUrls: ['./digit-input.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ArdiumDigitInputComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: _FormFieldComponentBase,\r\n      useExisting: ArdiumDigitInputComponent,\r\n    },\r\n  ],\r\n})\r\nexport class ArdiumDigitInputComponent\r\n  extends _FormFieldComponentBase\r\n  implements ControlValueAccessor, DigitInputModelHost, OnInit, AfterViewInit, OnDestroy\r\n{\r\n  protected override readonly _DEFAULTS!: ArdDigitInputDefaults;\r\n  constructor(@Inject(ARD_DIGIT_INPUT_DEFAULTS) defaults: ArdDigitInputDefaults) {\r\n    super(defaults);\r\n  }\r\n\r\n  private readonly _autoFillMonitor = inject(AutofillMonitor);\r\n\r\n  //! inputs ref\r\n  readonly inputs = viewChildren<ElementRef<HTMLInputElement>>('input');\r\n\r\n  readonly inputAttrs = input<Record<string, any>>(this._DEFAULTS.inputAttrs);\r\n\r\n  private _setInputAttributes() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      const inputEl = input.nativeElement;\r\n      const attributes: Record<string, string> = {\r\n        autocorrect: 'off',\r\n        autocapitalize: 'off',\r\n        autocomplete: 'off',\r\n        ...this.inputAttrs(),\r\n      };\r\n\r\n      for (const key of Object.keys(attributes)) {\r\n        inputEl.setAttribute(key, attributes[key]);\r\n      }\r\n    }\r\n  }\r\n\r\n  //! auto-fill\r\n  readonly autoFillParseFn = input<DigitInputAutoFillParseFn>(this._DEFAULTS.autoFillParseFn);\r\n\r\n  readonly isAutofilled = signal<boolean>(false);\r\n  private readonly _wasAutofillValueRead = signal<boolean>(false);\r\n\r\n  private _autoFillSubs: Subscription[] = [];\r\n  private _subscribeToAutoFillOnInputs() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      const sub = this._autoFillMonitor.monitor(input).subscribe(event => {\r\n        this.isAutofilled.set(event.isAutofilled);\r\n      });\r\n      this._autoFillSubs.push(sub);\r\n    }\r\n  }\r\n\r\n  private _unsubscribeFromAutoFill() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      this._autoFillMonitor.stopMonitoring(input);\r\n    }\r\n    for (const sub of this._autoFillSubs) {\r\n      sub.unsubscribe();\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n    this._unsubscribeFromAutoFill();\r\n  }\r\n\r\n  //! data model\r\n  private readonly model = new DigitInputModel(this);\r\n\r\n  //! appearance\r\n  readonly appearance = input<FormElementAppearance>(this._DEFAULTS.appearance);\r\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\r\n  readonly shape = input<DigitInputShape>(this._DEFAULTS.shape);\r\n\r\n  readonly compact = input<boolean, any>(this._DEFAULTS.compact, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly ngClasses = computed((): string =>\r\n    [\r\n      `ard-appearance-${this.appearance()}`,\r\n      `ard-variant-${this.variant()}`,\r\n      `ard-shape-${this.shape()}`,\r\n      this.compact() ? 'ard-compact' : '',\r\n      this.isAutofilled() ? 'ard-autofilled' : '',\r\n    ].join(' ')\r\n  );\r\n\r\n  //! model access points\r\n  readonly config = input.required<void, DigitInputConfig>({\r\n    transform: v => this.model.setConfig(v),\r\n  });\r\n  readonly configArrayData = this.model.configArrayData;\r\n\r\n  readonly transform = input<DigitInputTransform>(this._DEFAULTS.transform);\r\n\r\n  private _oldConfigArrayDataLength = -1;\r\n  readonly configArrayDataEffect = effect(() => {\r\n    if (this.configArrayData().length === this._oldConfigArrayDataLength) return;\r\n\r\n    this._oldConfigArrayDataLength = this.configArrayData().length;\r\n    this._emitChange();\r\n  });\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this._oldConfigArrayDataLength = this.configArrayData().length;\r\n  }\r\n\r\n  isInputEmpty(index: number): boolean {\r\n    return !this.model.isDefinedAtIndex(index);\r\n  }\r\n\r\n  //! control value accessor's write value implementation\r\n  private _valueBeforeViewInit?: any;\r\n  writeValue(v: any): void {\r\n    if (!this._wasViewInit) {\r\n      this._valueBeforeViewInit = v;\r\n      return;\r\n    }\r\n    this._writeValue(v);\r\n  }\r\n  private _writeValue(v: any): boolean {\r\n    return this.model.writeValue(v);\r\n  }\r\n\r\n  private _wasViewInit = false;\r\n  ngAfterViewInit(): void {\r\n    this._wasViewInit = true;\r\n\r\n    if (this._valueBeforeViewInit) {\r\n      this._writeValue(this._valueBeforeViewInit);\r\n    }\r\n\r\n    this._setInputAttributes();\r\n    this._subscribeToAutoFillOnInputs();\r\n  }\r\n\r\n  //! value two-way binding\r\n  readonly outputAsString = input<boolean, any>(this._DEFAULTS.outputAsString, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly outputControlValueAccessorOnFinish = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  @Input()\r\n  set value(v: string | (string | null)[] | null) {\r\n    this.writeValue(v);\r\n  }\r\n  readonly valueChange = output<string | (string | null)[] | null>();\r\n\r\n  readonly stringValue = this.model.stringValue;\r\n\r\n  readonly emittableValue = computed((): string | (string | null)[] | null => {\r\n    if (this.outputAsString()) return this.model.stringValue();\r\n    return this.model.value();\r\n  });\r\n\r\n  //! event emitters\r\n  readonly finishedValue = output<string | (string | null)[] | null>();\r\n\r\n  readonly focusIndexEvent = output<number>({ alias: 'focusIndex' });\r\n  readonly blurIndexEvent = output<number>({ alias: 'blurIndex' });\r\n\r\n  //! event handlers\r\n  onPaste(event: ClipboardEvent, index: number): void {\r\n    const value = event.clipboardData?.getData('text');\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    if (!value) return;\r\n\r\n    this._handleMultiDigitChange(value, index);\r\n  }\r\n  onInput(event: Event, index: number): void {\r\n    const value = (event.target as HTMLInputElement).value;\r\n    if (this.isAutofilled()) {\r\n      if (!this._wasAutofillValueRead()) {\r\n        this._wasAutofillValueRead.set(true);\r\n        setTimeout(() => {\r\n          this._wasAutofillValueRead.set(false);\r\n\r\n          const parsedValue = this.autoFillParseFn()(value);\r\n\r\n          this._handleMultiDigitChange(parsedValue, 0);\r\n        }, 0);\r\n      }\r\n      return;\r\n    }\r\n    const wasValidCharacter = this._updateSingleInputValue(value, index);\r\n    if (!wasValidCharacter) return;\r\n    this.focusByIndex(index + 1);\r\n  }\r\n  private _handleMultiDigitChange(value: string, startIndex: number): void {\r\n    const maxLength = this.inputs().length - startIndex;\r\n    value\r\n      .slice(0, maxLength)\r\n      .split('')\r\n      .forEach((char, i) => {\r\n        this.model.resetInputValue(startIndex + i);\r\n        this.model.validateInputAndSetValue(char, startIndex + i);\r\n      });\r\n\r\n    this.focusByIndex(startIndex - 1 + Math.min(value.length, maxLength));\r\n\r\n    this._emitChange();\r\n  }\r\n  private _updateSingleInputValue(value: string, index: number): boolean {\r\n    const changeResult = this.model.validateInputAndSetValue(value, index);\r\n\r\n    if (changeResult?.wasChanged) {\r\n      this._emitChange();\r\n    }\r\n\r\n    return changeResult?.wasValidChar ?? false;\r\n  }\r\n  focusByIndex(index: number): boolean;\r\n  focusByIndex(index: number, tryFocusingNext: boolean, direction: 1 | -1): boolean;\r\n  focusByIndex(index: number, tryFocusingNext?: boolean, direction?: 1 | -1): boolean {\r\n    if (index < 0 || index >= this.inputs().length) return false;\r\n    const nextEl = this.inputs()[index]?.nativeElement;\r\n    if (!nextEl) return false;\r\n\r\n    if (nextEl.getAttribute('data-ard-static') !== null) {\r\n      return this.focusByIndex(index + (direction ?? 1));\r\n    }\r\n    nextEl.focus();\r\n    if (tryFocusingNext && direction && document.activeElement !== nextEl) {\r\n      return this.focusByIndex(index + direction);\r\n    }\r\n    return document.activeElement === nextEl;\r\n  }\r\n  //focus, blur, change\r\n  onFocusMaster(event: FocusEvent, index: number): void {\r\n    this.focusIndexEvent.emit(index);\r\n    (event.target as HTMLInputElement).setSelectionRange(0, 1);\r\n\r\n    this.onFocus(event);\r\n  }\r\n  onBlurMaster(event: FocusEvent, index: number): void {\r\n    this.blurIndexEvent.emit(index);\r\n    this.onBlur(event);\r\n  }\r\n  protected _emitChange(): void {\r\n    const v = this.emittableValue();\r\n    if (!this.outputControlValueAccessorOnFinish() || this.model.isValueFull()) this._onChangeRegistered?.(v);\r\n    this.valueChange.emit(v);\r\n    if (this.model.isValueFull()) {\r\n      this.finishedValue.emit(v);\r\n    }\r\n  }\r\n  onKeydown(event: KeyboardEvent, index: number): void {\r\n    switch (event.key) {\r\n      case 'ArrowLeft':\r\n        this.focusByIndex(index - 1, true, -1);\r\n        return;\r\n      case 'ArrowRight':\r\n        this.focusByIndex(index + 1, true, +1);\r\n        return;\r\n      case 'Home':\r\n        this.focusByIndex(0, true, 1);\r\n        return;\r\n      case 'End':\r\n        this.focusByIndex(this.inputs.length - 1, true, -1);\r\n        return;\r\n      case 'Backspace':\r\n      case 'Delete':\r\n        this._updateSingleInputValue('', index);\r\n        this.focusByIndex(index - 1, true, -1);\r\n        event.preventDefault();\r\n        return;\r\n    }\r\n  }\r\n}\r\n","<div\r\n  class=\"ard-digit-input\"\r\n  [ngClass]=\"ngClasses()\"\r\n  [class.ard-has-error]=\"hasError()\"\r\n  [class.ard-is-success]=\"isSuccess()\"\r\n>\r\n  @for (data of configArrayData(); track $index) {\r\n  <div\r\n    class=\"ard-digit-input__item\"\r\n    [class.ard-digit-input__item-with-input]=\"data.type === 'input'\"\r\n  >\r\n    @if (data.type === 'input') {\r\n    <input\r\n      #input\r\n      #focusableElement\r\n      class=\"ard-digit-input__input\"\r\n      type=\"text\"\r\n      [readonly]=\"data.readonly\"\r\n      [placeholder]=\"data.placeholder\"\r\n      [attr.tabindex]=\"tabIndex()\"\r\n      [class.ard-digit-input__input-readonly]=\"data.readonly\"\r\n      [class.ard-digit-input__input-empty]=\"isInputEmpty(data.index!)\"\r\n      (paste)=\"onPaste($event, data.index!)\"\r\n      (input)=\"onInput($event, data.index!)\"\r\n      (focus)=\"onFocusMaster($event, data.index!)\"\r\n      (blur)=\"onBlurMaster($event, data.index!)\"\r\n      (keydown)=\"onKeydown($event, data.index!)\"\r\n    />\r\n    } @else {\r\n    <div class=\"ard-digit-input__static\">\r\n      {{ data.char }}\r\n    </div>\r\n    <input\r\n      #input\r\n      type=\"text\"\r\n      class=\"ard-digit-input__static-input\"\r\n      data-ard-static\r\n      autocomplete=\"off\"\r\n      tabindex=\"-1\"\r\n      aria-hidden=\"true\"\r\n      [value]=\"data.char\"\r\n    />\r\n    }\r\n  </div>\r\n  }\r\n</div>\r\n"]}
268
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"digit-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.component.ts","../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AutofillMonitor } from '@angular/cdk/text-field';\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  computed,\r\n  effect,\r\n  forwardRef,\r\n  inject,\r\n  input,\r\n  output,\r\n  signal,\r\n  viewChildren,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { Subscription } from 'rxjs';\r\nimport { _FormFieldComponentBase } from '../../_internal/form-field-component';\r\nimport { FormElementAppearance, FormElementVariant } from '../../types/theming.types';\r\nimport { ARD_DIGIT_INPUT_DEFAULTS, ArdDigitInputDefaults } from './digit-input.defaults';\r\nimport { DigitInputModel } from './digit-input.model';\r\nimport { DigitInputAutoFillParseFn, DigitInputConfig, DigitInputShape, DigitInputTransform } from './digit-input.types';\r\nimport { DigitInputModelHost } from './digit-input.utils';\r\n\r\n@Component({\r\n  selector: 'ard-digit-input',\r\n  templateUrl: './digit-input.component.html',\r\n  styleUrls: ['./digit-input.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ArdiumDigitInputComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: _FormFieldComponentBase,\r\n      useExisting: ArdiumDigitInputComponent,\r\n    },\r\n  ],\r\n})\r\nexport class ArdiumDigitInputComponent\r\n  extends _FormFieldComponentBase\r\n  implements ControlValueAccessor, DigitInputModelHost, OnInit, AfterViewInit, OnDestroy\r\n{\r\n  protected override readonly _DEFAULTS!: ArdDigitInputDefaults;\r\n  constructor(@Inject(ARD_DIGIT_INPUT_DEFAULTS) defaults: ArdDigitInputDefaults) {\r\n    super(defaults);\r\n  }\r\n\r\n  private readonly _autoFillMonitor = inject(AutofillMonitor);\r\n\r\n  //! inputs ref\r\n  readonly inputs = viewChildren<ElementRef<HTMLInputElement>>('input');\r\n\r\n  readonly inputAttrs = input<Record<string, any>>(this._DEFAULTS.inputAttrs);\r\n\r\n  private _setInputAttributes() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      const inputEl = input.nativeElement;\r\n      const attributes: Record<string, string> = {\r\n        autocorrect: 'off',\r\n        autocapitalize: 'off',\r\n        autocomplete: 'off',\r\n        ...this.inputAttrs(),\r\n      };\r\n\r\n      for (const key of Object.keys(attributes)) {\r\n        inputEl.setAttribute(key, attributes[key]);\r\n      }\r\n    }\r\n  }\r\n\r\n  //! auto-fill\r\n  readonly autoFillParseFn = input<DigitInputAutoFillParseFn>(this._DEFAULTS.autoFillParseFn);\r\n\r\n  readonly isAutofilled = signal<boolean>(false);\r\n  private readonly _wasAutofillValueRead = signal<boolean>(false);\r\n\r\n  private _autoFillSubs: Subscription[] = [];\r\n  private _subscribeToAutoFillOnInputs() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      const sub = this._autoFillMonitor.monitor(input).subscribe(event => {\r\n        this.isAutofilled.set(event.isAutofilled);\r\n      });\r\n      this._autoFillSubs.push(sub);\r\n    }\r\n  }\r\n\r\n  private _unsubscribeFromAutoFill() {\r\n    const inputs = this.inputs();\r\n    for (const input of inputs) {\r\n      this._autoFillMonitor.stopMonitoring(input);\r\n    }\r\n    for (const sub of this._autoFillSubs) {\r\n      sub.unsubscribe();\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n    this._unsubscribeFromAutoFill();\r\n  }\r\n\r\n  //! data model\r\n  private readonly model = new DigitInputModel(this);\r\n\r\n  //! appearance\r\n  readonly appearance = input<FormElementAppearance>(this._DEFAULTS.appearance);\r\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\r\n  readonly shape = input<DigitInputShape>(this._DEFAULTS.shape);\r\n\r\n  readonly compact = input<boolean, any>(this._DEFAULTS.compact, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly ngClasses = computed((): string =>\r\n    [\r\n      `ard-appearance-${this.appearance()}`,\r\n      `ard-variant-${this.variant()}`,\r\n      `ard-shape-${this.shape()}`,\r\n      this.compact() ? 'ard-compact' : '',\r\n      this.isAutofilled() ? 'ard-autofilled' : '',\r\n    ].join(' ')\r\n  );\r\n\r\n  //! model access points\r\n  readonly config = input.required<void, DigitInputConfig>({\r\n    transform: v => this.model.setConfig(v),\r\n  });\r\n  readonly configArrayData = this.model.configArrayData;\r\n\r\n  readonly transform = input<DigitInputTransform>(this._DEFAULTS.transform);\r\n\r\n  private _oldConfigArrayDataLength = -1;\r\n  readonly configArrayDataEffect = effect(() => {\r\n    if (this.configArrayData().length === this._oldConfigArrayDataLength) return;\r\n\r\n    this._oldConfigArrayDataLength = this.configArrayData().length;\r\n    this._emitChange();\r\n  });\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this._oldConfigArrayDataLength = this.configArrayData().length;\r\n  }\r\n\r\n  isInputEmpty(index: number): boolean {\r\n    return !this.model.isDefinedAtIndex(index);\r\n  }\r\n\r\n  //! control value accessor's write value implementation\r\n  private _valueBeforeViewInit?: any;\r\n  writeValue(v: any): void {\r\n    console.log('writeValue', v, this._wasViewInit);\r\n    if (!this._wasViewInit) {\r\n      this._valueBeforeViewInit = v;\r\n      console.log('returning from writeValue');\r\n      return;\r\n    }\r\n    console.log('calling _writeValue with value', v);\r\n    this._writeValue(v);\r\n  }\r\n  private _writeValue(v: any): boolean {\r\n    console.log('_writeValue', v);\r\n    return this.model.writeValue(v);\r\n  }\r\n\r\n  private _wasViewInit = false;\r\n  ngAfterViewInit(): void {\r\n    this._wasViewInit = true;\r\n\r\n    if (this._valueBeforeViewInit) {\r\n      this._writeValue(this._valueBeforeViewInit);\r\n    }\r\n\r\n    this._setInputAttributes();\r\n    this._subscribeToAutoFillOnInputs();\r\n  }\r\n\r\n  //! value two-way binding\r\n  readonly outputAsString = input<boolean, any>(this._DEFAULTS.outputAsString, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  readonly outputControlValueAccessorOnFinish = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  @Input()\r\n  set value(v: string | (string | null)[] | null) {\r\n    this.writeValue(v);\r\n  }\r\n  readonly valueChange = output<string | (string | null)[] | null>();\r\n\r\n  readonly stringValue = this.model.stringValue;\r\n\r\n  readonly emittableValue = computed((): string | (string | null)[] | null => {\r\n    if (this.outputAsString()) return this.model.stringValue();\r\n    return this.model.value();\r\n  });\r\n\r\n  //! event emitters\r\n  readonly finishedValue = output<string | (string | null)[] | null>();\r\n\r\n  readonly focusIndexEvent = output<number>({ alias: 'focusIndex' });\r\n  readonly blurIndexEvent = output<number>({ alias: 'blurIndex' });\r\n\r\n  //! event handlers\r\n  onPaste(event: ClipboardEvent, index: number): void {\r\n    const value = event.clipboardData?.getData('text');\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    if (!value) return;\r\n\r\n    this._handleMultiDigitChange(value, index);\r\n  }\r\n  onInput(event: Event, index: number): void {\r\n    const value = (event.target as HTMLInputElement).value;\r\n    if (this.isAutofilled()) {\r\n      if (!this._wasAutofillValueRead()) {\r\n        this._wasAutofillValueRead.set(true);\r\n        setTimeout(() => {\r\n          this._wasAutofillValueRead.set(false);\r\n\r\n          const parsedValue = this.autoFillParseFn()(value);\r\n\r\n          this._handleMultiDigitChange(parsedValue, 0);\r\n        }, 0);\r\n      }\r\n      return;\r\n    }\r\n    const wasValidCharacter = this._updateSingleInputValue(value, index);\r\n    if (!wasValidCharacter) return;\r\n    this.focusByIndex(index + 1);\r\n  }\r\n  private _handleMultiDigitChange(value: string, startIndex: number): void {\r\n    const maxLength = this.inputs().length - startIndex;\r\n    value\r\n      .slice(0, maxLength)\r\n      .split('')\r\n      .forEach((char, i) => {\r\n        this.model.resetInputValue(startIndex + i);\r\n        this.model.validateInputAndSetValue(char, startIndex + i);\r\n      });\r\n\r\n    this.focusByIndex(startIndex - 1 + Math.min(value.length, maxLength));\r\n\r\n    this._emitChange();\r\n  }\r\n  private _updateSingleInputValue(value: string, index: number): boolean {\r\n    const changeResult = this.model.validateInputAndSetValue(value, index);\r\n\r\n    if (changeResult?.wasChanged) {\r\n      this._emitChange();\r\n    }\r\n\r\n    return changeResult?.wasValidChar ?? false;\r\n  }\r\n  focusByIndex(index: number): boolean;\r\n  focusByIndex(index: number, tryFocusingNext: boolean, direction: 1 | -1): boolean;\r\n  focusByIndex(index: number, tryFocusingNext?: boolean, direction?: 1 | -1): boolean {\r\n    if (index < 0 || index >= this.inputs().length) return false;\r\n    const nextEl = this.inputs()[index]?.nativeElement;\r\n    if (!nextEl) return false;\r\n\r\n    if (nextEl.getAttribute('data-ard-static') !== null) {\r\n      return this.focusByIndex(index + (direction ?? 1));\r\n    }\r\n    nextEl.focus();\r\n    if (tryFocusingNext && direction && document.activeElement !== nextEl) {\r\n      return this.focusByIndex(index + direction);\r\n    }\r\n    return document.activeElement === nextEl;\r\n  }\r\n  //focus, blur, change\r\n  onFocusMaster(event: FocusEvent, index: number): void {\r\n    this.focusIndexEvent.emit(index);\r\n    (event.target as HTMLInputElement).setSelectionRange(0, 1);\r\n\r\n    this.onFocus(event);\r\n  }\r\n  onBlurMaster(event: FocusEvent, index: number): void {\r\n    this.blurIndexEvent.emit(index);\r\n    this.onBlur(event);\r\n  }\r\n  protected _emitChange(): void {\r\n    const v = this.emittableValue();\r\n    if (!this.outputControlValueAccessorOnFinish() || this.model.isValueFull()) this._onChangeRegistered?.(v);\r\n    this.valueChange.emit(v);\r\n    if (this.model.isValueFull()) {\r\n      this.finishedValue.emit(v);\r\n    }\r\n  }\r\n  onKeydown(event: KeyboardEvent, index: number): void {\r\n    switch (event.key) {\r\n      case 'ArrowLeft':\r\n        this.focusByIndex(index - 1, true, -1);\r\n        return;\r\n      case 'ArrowRight':\r\n        this.focusByIndex(index + 1, true, +1);\r\n        return;\r\n      case 'Home':\r\n        this.focusByIndex(0, true, 1);\r\n        return;\r\n      case 'End':\r\n        this.focusByIndex(this.inputs.length - 1, true, -1);\r\n        return;\r\n      case 'Backspace':\r\n      case 'Delete':\r\n        this._updateSingleInputValue('', index);\r\n        this.focusByIndex(index - 1, true, -1);\r\n        event.preventDefault();\r\n        return;\r\n    }\r\n  }\r\n}\r\n","<div\r\n  class=\"ard-digit-input\"\r\n  [ngClass]=\"ngClasses()\"\r\n  [class.ard-has-error]=\"hasError()\"\r\n  [class.ard-is-success]=\"isSuccess()\"\r\n>\r\n  @for (data of configArrayData(); track $index) {\r\n  <div\r\n    class=\"ard-digit-input__item\"\r\n    [class.ard-digit-input__item-with-input]=\"data.type === 'input'\"\r\n  >\r\n    @if (data.type === 'input') {\r\n    <input\r\n      #input\r\n      #focusableElement\r\n      class=\"ard-digit-input__input\"\r\n      type=\"text\"\r\n      [readonly]=\"data.readonly\"\r\n      [placeholder]=\"data.placeholder\"\r\n      [attr.tabindex]=\"tabIndex()\"\r\n      [class.ard-digit-input__input-readonly]=\"data.readonly\"\r\n      [class.ard-digit-input__input-empty]=\"isInputEmpty(data.index!)\"\r\n      (paste)=\"onPaste($event, data.index!)\"\r\n      (input)=\"onInput($event, data.index!)\"\r\n      (focus)=\"onFocusMaster($event, data.index!)\"\r\n      (blur)=\"onBlurMaster($event, data.index!)\"\r\n      (keydown)=\"onKeydown($event, data.index!)\"\r\n    />\r\n    } @else {\r\n    <div class=\"ard-digit-input__static\">\r\n      {{ data.char }}\r\n    </div>\r\n    <input\r\n      #input\r\n      type=\"text\"\r\n      class=\"ard-digit-input__static-input\"\r\n      data-ard-static\r\n      autocomplete=\"off\"\r\n      tabindex=\"-1\"\r\n      aria-hidden=\"true\"\r\n      [value]=\"data.char\"\r\n    />\r\n    }\r\n  </div>\r\n  }\r\n</div>\r\n"]}
@@ -50,11 +50,13 @@ export class DigitInputModel {
50
50
  return !!this.value()?.[index];
51
51
  }
52
52
  writeValue(v) {
53
+ console.log('executing model writeValue', v, this._ardHost.outputAsString());
53
54
  if (this._ardHost.outputAsString()) {
54
55
  if (!isAnyString(v) && !isNull(v)) {
55
56
  throw new Error(`ARD-FT0040b: Trying to set <ard-digit-input>'s value to "${v}" (of type ${typeof v}), but the input uses [outputAsString]="true", and thus expects string or null.`);
56
57
  }
57
58
  const vArray = v?.split('') ?? [];
59
+ console.log('executing model writeValue - vArray', vArray, this._configArray());
58
60
  if (vArray.length > this._configArray().length) {
59
61
  console.warn(`ARD-WA0041: Value provided to <ard-digit-input> is too long. Got ${vArray.length} characters, but expected a maximum of ${this._configArray().length} characters.`);
60
62
  }
@@ -75,6 +77,7 @@ export class DigitInputModel {
75
77
  }
76
78
  _writeValue(v) {
77
79
  const isOldValueTheSame = this.value() ? this.value().every((ch, i) => ch === v?.[i]) : !v;
80
+ console.log('executing model _writeValue', v, 'current value', this.value(), isOldValueTheSame);
78
81
  if (isOldValueTheSame)
79
82
  return false;
80
83
  this.value.set(v && v.map(el => el || null));
@@ -254,4 +257,4 @@ export class DigitInputModel {
254
257
  return char;
255
258
  }
256
259
  }
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"digit-input.model.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, effect, signal } from '@angular/core';\r\nimport { coerceArrayProperty } from '@ardium-ui/devkit';\r\nimport { isAnyString, isArray, isFunction, isNull, isNumber, isRegExp } from 'simple-bool';\r\nimport {\r\n  DigitInputAcceptObject,\r\n  DigitInputConfig,\r\n  DigitInputOption,\r\n  DigitInputPrimitiveOption,\r\n  TransformType,\r\n} from './digit-input.types';\r\nimport { DigitInputConfigData, DigitInputConfigDataType, DigitInputModelHost, _sanitizeRegExpString } from './digit-input.utils';\r\n\r\nexport class DigitInputModel {\r\n  constructor(private _ardHost: DigitInputModelHost) {\r\n    //set the value array to be the same length\r\n    effect(\r\n      () => {\r\n        const configArr = this.configArrayData();\r\n        const length = configArr.length;\r\n\r\n        this.value.update(arr => {\r\n          if (!arr) arr = [];\r\n          const newArr: (string | null)[] = [];\r\n          for (let i = 0; i < length; i++) {\r\n            const curr = arr[i];\r\n            const config = configArr[i];\r\n            newArr.push(config.type === DigitInputConfigDataType.Static ? config.char! : curr ?? null);\r\n          }\r\n          return newArr;\r\n        });\r\n      },\r\n      { allowSignalWrites: true }\r\n    );\r\n  }\r\n\r\n  private readonly _configArray = signal<DigitInputOption[]>([]);\r\n\r\n  readonly configArrayData = computed<DigitInputConfigData[]>(() => {\r\n    return this._configArray().map((v, i) => {\r\n      if ('static' in v) {\r\n        return {\r\n          type: DigitInputConfigDataType.Static,\r\n          char: v.static,\r\n        } satisfies DigitInputConfigData;\r\n      }\r\n      return {\r\n        type: DigitInputConfigDataType.Input,\r\n        index: i,\r\n        readonly: v.readonly,\r\n        placeholder: v.placeholder ?? '',\r\n      } satisfies DigitInputConfigData;\r\n    });\r\n  });\r\n\r\n  readonly isConfigDefined = computed((): boolean => this._configArray().length > 0);\r\n\r\n  readonly value = signal<(string | null)[] | null>(null);\r\n\r\n  readonly stringValue = computed(\r\n    (): string =>\r\n      this.value()\r\n        ?.map(v => v ?? ' ')\r\n        .join('') ?? ''\r\n  );\r\n\r\n  readonly isValueFull = computed((): boolean => this.value()?.filter(v => v).length === this._configArray().length);\r\n\r\n  isDefinedAtIndex(index: number): boolean {\r\n    return !!this.value()?.[index];\r\n  }\r\n\r\n  writeValue(v: any): boolean {\r\n    if (this._ardHost.outputAsString()) {\r\n      if (!isAnyString(v) && !isNull(v)) {\r\n        throw new Error(\r\n          `ARD-FT0040b: Trying to set <ard-digit-input>'s value to \"${v}\" (of type ${typeof v}), but the input uses [outputAsString]=\"true\", and thus expects string or null.`\r\n        );\r\n      }\r\n      const vArray = v?.split('') ?? [];\r\n\r\n      if (vArray.length > this._configArray().length) {\r\n        console.warn(\r\n          `ARD-WA0041: Value provided to <ard-digit-input> is too long. Got ${\r\n            vArray.length\r\n          } characters, but expected a maximum of ${this._configArray().length} characters.`\r\n        );\r\n      }\r\n      return this._writeValue(vArray);\r\n    }\r\n    if (!isAnyString(v) && !isNull(v) && !isArray(v)) {\r\n      throw new Error(\r\n        `ARD-FT0041: Trying to set <ard-digit-input>'s value to \"${v}\" (of type ${typeof v}), expected string or array of characters.`\r\n      );\r\n    }\r\n    const vArray = coerceArrayProperty(v);\r\n\r\n    if (vArray.length > this._configArray().length) {\r\n      console.warn(\r\n        `ARD-WA0041: Value provided to <ard-digit-input> is too long. Got ${\r\n          vArray.length\r\n        } characters, but expected a maximum of ${this._configArray().length} characters.`\r\n      );\r\n    }\r\n    const problemIndex = vArray.findIndex(el => !isAnyString(el) || el.length > 1);\r\n    if (problemIndex !== -1) {\r\n      throw new Error(\r\n        `ARD-FT0042: Array passed to <ard-digit-input>'s value must only contain strings of length 1 or 0. Element \"${vArray[problemIndex]}\" at index ${problemIndex} does not match those requirements.`\r\n      );\r\n    }\r\n    return this._writeValue(vArray);\r\n  }\r\n  private _writeValue(v: string[] | null): boolean {\r\n    const isOldValueTheSame = this.value() ? this.value()!.every((ch, i) => ch === v?.[i]) : !v;\r\n    if (isOldValueTheSame) return false;\r\n    this.value.set(v && v.map(el => el || null));\r\n    this.validateValueAndUpdate();\r\n    this._updateInputElements();\r\n    return true;\r\n  }\r\n\r\n  private _updateInputElements() {\r\n    const v = this.value() ?? [];\r\n    let i = 0;\r\n    for (const inputEl of this._ardHost.inputs()) {\r\n      inputEl.nativeElement.value = v[i] ?? '';\r\n      i++;\r\n    }\r\n  }\r\n\r\n  //! setting config\r\n  setConfig(config: DigitInputConfig): void {\r\n    this._setConfig(config);\r\n    this.validateValueAndUpdate();\r\n  }\r\n  private _setConfig(config: DigitInputConfig): void {\r\n    //map a number to ready objects\r\n    let configAsNumber = isAnyString(config) ? Number(config) : null;\r\n    if (isNumber(config) || isNumber(configAsNumber)) {\r\n      configAsNumber = isNumber(config) ? config : configAsNumber!;\r\n      this._configArray.set(new Array(configAsNumber).fill({ accept: (str: string) => /[0-9]/.test(str) }));\r\n      return;\r\n    }\r\n    //map a string to an array\r\n    let configArr: string[] | Exclude<DigitInputConfig, number | string>;\r\n    if (isAnyString(config)) {\r\n      configArr = coerceArrayProperty(config);\r\n    } else {\r\n      configArr = config;\r\n    }\r\n    //map array to ready objects\r\n    this._configArray.set(\r\n      configArr.map((v, i) => {\r\n        if (!isAnyString(v)) {\r\n          if ('accept' in v && !isFunction(v.accept)) {\r\n            const regExp = isRegExp(v.accept) ? v.accept : new RegExp(`[${_sanitizeRegExpString(v.accept)}]`);\r\n            v.accept = str => regExp.test(str);\r\n          }\r\n          return v;\r\n        }\r\n\r\n        switch (v) {\r\n          case DigitInputPrimitiveOption.Number:\r\n            return { accept: str => /[0-9]/.test(str) };\r\n          case DigitInputPrimitiveOption.Letter:\r\n            return { accept: str => /[a-zA-Z]/.test(str) };\r\n          case DigitInputPrimitiveOption.Alphanumeric:\r\n            return { accept: str => /[0-9a-zA-Z]/.test(str) };\r\n          case DigitInputPrimitiveOption.Special:\r\n            return { accept: str => /[!@#$%^&*-_=+/\\\\.,]/.test(str) };\r\n\r\n          default:\r\n            if (configArr.length === 1) {\r\n              throw new Error(`ARD-NF0043S: <ard-digit-input>'s config is invalid. Expected number or array, got \"${v}\"`);\r\n            }\r\n            throw new Error(`ARD-NF0043B: Found invalid string \"${v}\" in <ard-digit-input>'s config at index ${i}`);\r\n        }\r\n      })\r\n    );\r\n  }\r\n\r\n  resetInputValue(index: number): void {\r\n    if (index < 0 || index > this._configArray().length) return;\r\n\r\n    const config = this._configArray()[index] as DigitInputOption;\r\n    let newValue = '';\r\n    if ('static' in config) {\r\n      newValue = config.static;\r\n    }\r\n\r\n    //get the corresponding HTML input element\r\n    const inputEl = this._ardHost.inputs()[index];\r\n    if (!inputEl) {\r\n      throw new Error(\r\n        \"ARD-IS0048: <ard-digit-input>'s value changed, but its corresponding input element could not be found. If you are reading this, you probably experienced a problem with Ardium UI. Please report this issue to the creators.\"\r\n      );\r\n    }\r\n    //update the input element and value array\r\n    inputEl.nativeElement.value = newValue;\r\n\r\n    this.value.update(arr => {\r\n      if (!arr) arr = [];\r\n      const newArr = [...arr];\r\n      newArr[index] = newValue || null;\r\n      return newArr;\r\n    });\r\n  }\r\n\r\n  //! validate against the config\r\n  validateInputAndSetValue(\r\n    input: string,\r\n    index: number\r\n  ): null | { wasChanged: boolean; wasValidChar: boolean; resultChar: string | null } {\r\n    if (index < 0 || index > this._configArray().length) return null;\r\n\r\n    let v = this.value();\r\n    //prepare the value array if does not exist\r\n    if (!v) {\r\n      this.value.set([]);\r\n    }\r\n    v = [];\r\n    //prepare the characters before the current one (to be used in validation)\r\n    const before = this.stringValue().charAt(index);\r\n\r\n    //remove the old character from the input element\r\n    if (before && input.length > 1 && input.match(before)) {\r\n      input = input.replace(before, '');\r\n    }\r\n    //use only the first or last character (error safety)\r\n    const firstChar = input.charAt(0);\r\n    const lastChar = input.charAt(input.length - 1);\r\n    input = firstChar === before ? lastChar : firstChar;\r\n\r\n    //validate and transform, if necessary\r\n    const inputChar = this._validateSingleChar(input, before, this._configArray()[index] as DigitInputAcceptObject);\r\n\r\n    //get the corresponding HTML input element\r\n    const inputEl = this._ardHost.inputs()[index];\r\n    if (!inputEl) {\r\n      throw new Error(\r\n        \"ARD-IS0048: <ard-digit-input>'s value changed, but its corresponding input element could not be found. If you are reading this, you probably experienced a problem with Ardium UI. Please report this issue to the creators.\"\r\n      );\r\n    }\r\n    //update the input element and value array\r\n    const newVal = inputChar ?? before;\r\n    inputEl.nativeElement.value = newVal ?? '';\r\n\r\n    this.value.update(arr => {\r\n      if (!arr) arr = [];\r\n      const newArr = [...arr];\r\n      newArr[index] = newVal || null;\r\n      return newArr;\r\n    });\r\n    //return changes marker and validated value\r\n    return { wasChanged: newVal !== before, wasValidChar: !isNull(inputChar), resultChar: inputChar };\r\n  }\r\n  validateValueAndUpdate(): void {\r\n    const v = this.value();\r\n    if (!v) return;\r\n\r\n    let before = '';\r\n    const newValue: (string | null)[] = [];\r\n    for (let i = 0; i < Math.min(this._configArray().length, v.length); i++) {\r\n      const char = v[i];\r\n      before += char ?? ' ';\r\n\r\n      if (!char) {\r\n        newValue.push(char);\r\n        continue;\r\n      }\r\n      const newChar = this._validateSingleChar(char, before, this._configArray()[i] as DigitInputAcceptObject);\r\n      newValue.push(newChar);\r\n    }\r\n    this.value.set(newValue);\r\n  }\r\n  private _validateSingleChar(char: string | null, before: string, config: DigitInputOption): string | null {\r\n    // return the character if it is static\r\n    if ('static' in config) return config.static;\r\n    // for peace of mind protect against modifying read-only fields\r\n    if (config.readonly) {\r\n      throw new Error(\r\n        `ARD-IS0049R: trying to set value of a <ard-digit-input>'s readonly field. This is error is fatal to the functioning of Ardium UI. Please report this issue to the creators.`\r\n      );\r\n    }\r\n    // process regex or convert string into regex\r\n    if (!isFunction(config.accept)) {\r\n      const regExp = isRegExp(config.accept) ? config.accept : new RegExp(`[${_sanitizeRegExpString(config.accept)}]`);\r\n      config.accept = str => regExp.test(str);\r\n    }\r\n    if (!char) return char;\r\n\r\n    // check if input fits the criteria\r\n    const canAccept = config.accept(char, before);\r\n    if (!canAccept) return null;\r\n\r\n    // transform if needed\r\n    const transform = config.transform ?? this._ardHost.transform();\r\n    if (transform) {\r\n      if (transform === TransformType.Lowercase) {\r\n        return char.toLowerCase();\r\n      }\r\n      if (transform === TransformType.Uppercase) {\r\n        return char.toUpperCase();\r\n      }\r\n      if (isFunction(transform)) {\r\n        return transform(char).charAt(0);\r\n      }\r\n      console.warn(\r\n        `ARD-IS0049T: <ard-digit-input>'s value validator encountered an unexpected value of the config's \"transform\" property. Ardium UI was able to handle this issue, but please report it to the creators.`\r\n      );\r\n    }\r\n    return char;\r\n  }\r\n}\r\n"]}
260
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"digit-input.model.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/inputs/digit-input/digit-input.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, effect, signal } from '@angular/core';\r\nimport { coerceArrayProperty } from '@ardium-ui/devkit';\r\nimport { isAnyString, isArray, isFunction, isNull, isNumber, isRegExp } from 'simple-bool';\r\nimport {\r\n  DigitInputAcceptObject,\r\n  DigitInputConfig,\r\n  DigitInputOption,\r\n  DigitInputPrimitiveOption,\r\n  TransformType,\r\n} from './digit-input.types';\r\nimport { DigitInputConfigData, DigitInputConfigDataType, DigitInputModelHost, _sanitizeRegExpString } from './digit-input.utils';\r\n\r\nexport class DigitInputModel {\r\n  constructor(private _ardHost: DigitInputModelHost) {\r\n    //set the value array to be the same length\r\n    effect(\r\n      () => {\r\n        const configArr = this.configArrayData();\r\n        const length = configArr.length;\r\n\r\n        this.value.update(arr => {\r\n          if (!arr) arr = [];\r\n          const newArr: (string | null)[] = [];\r\n          for (let i = 0; i < length; i++) {\r\n            const curr = arr[i];\r\n            const config = configArr[i];\r\n            newArr.push(config.type === DigitInputConfigDataType.Static ? config.char! : curr ?? null);\r\n          }\r\n          return newArr;\r\n        });\r\n      },\r\n      { allowSignalWrites: true }\r\n    );\r\n  }\r\n\r\n  private readonly _configArray = signal<DigitInputOption[]>([]);\r\n\r\n  readonly configArrayData = computed<DigitInputConfigData[]>(() => {\r\n    return this._configArray().map((v, i) => {\r\n      if ('static' in v) {\r\n        return {\r\n          type: DigitInputConfigDataType.Static,\r\n          char: v.static,\r\n        } satisfies DigitInputConfigData;\r\n      }\r\n      return {\r\n        type: DigitInputConfigDataType.Input,\r\n        index: i,\r\n        readonly: v.readonly,\r\n        placeholder: v.placeholder ?? '',\r\n      } satisfies DigitInputConfigData;\r\n    });\r\n  });\r\n\r\n  readonly isConfigDefined = computed((): boolean => this._configArray().length > 0);\r\n\r\n  readonly value = signal<(string | null)[] | null>(null);\r\n\r\n  readonly stringValue = computed(\r\n    (): string =>\r\n      this.value()\r\n        ?.map(v => v ?? ' ')\r\n        .join('') ?? ''\r\n  );\r\n\r\n  readonly isValueFull = computed((): boolean => this.value()?.filter(v => v).length === this._configArray().length);\r\n\r\n  isDefinedAtIndex(index: number): boolean {\r\n    return !!this.value()?.[index];\r\n  }\r\n\r\n  writeValue(v: any): boolean {\r\n    console.log('executing model writeValue', v, this._ardHost.outputAsString());\r\n    if (this._ardHost.outputAsString()) {\r\n      if (!isAnyString(v) && !isNull(v)) {\r\n        throw new Error(\r\n          `ARD-FT0040b: Trying to set <ard-digit-input>'s value to \"${v}\" (of type ${typeof v}), but the input uses [outputAsString]=\"true\", and thus expects string or null.`\r\n        );\r\n      }\r\n      const vArray = v?.split('') ?? [];\r\n      console.log('executing model writeValue - vArray', vArray, this._configArray());\r\n\r\n      if (vArray.length > this._configArray().length) {\r\n        console.warn(\r\n          `ARD-WA0041: Value provided to <ard-digit-input> is too long. Got ${\r\n            vArray.length\r\n          } characters, but expected a maximum of ${this._configArray().length} characters.`\r\n        );\r\n      }\r\n      return this._writeValue(vArray);\r\n    }\r\n    if (!isAnyString(v) && !isNull(v) && !isArray(v)) {\r\n      throw new Error(\r\n        `ARD-FT0041: Trying to set <ard-digit-input>'s value to \"${v}\" (of type ${typeof v}), expected string or array of characters.`\r\n      );\r\n    }\r\n    const vArray = coerceArrayProperty(v);\r\n\r\n    if (vArray.length > this._configArray().length) {\r\n      console.warn(\r\n        `ARD-WA0041: Value provided to <ard-digit-input> is too long. Got ${\r\n          vArray.length\r\n        } characters, but expected a maximum of ${this._configArray().length} characters.`\r\n      );\r\n    }\r\n    const problemIndex = vArray.findIndex(el => !isAnyString(el) || el.length > 1);\r\n    if (problemIndex !== -1) {\r\n      throw new Error(\r\n        `ARD-FT0042: Array passed to <ard-digit-input>'s value must only contain strings of length 1 or 0. Element \"${vArray[problemIndex]}\" at index ${problemIndex} does not match those requirements.`\r\n      );\r\n    }\r\n    return this._writeValue(vArray);\r\n  }\r\n  private _writeValue(v: string[] | null): boolean {\r\n    const isOldValueTheSame = this.value() ? this.value()!.every((ch, i) => ch === v?.[i]) : !v;\r\n    console.log('executing model _writeValue', v, 'current value', this.value(), isOldValueTheSame);\r\n    if (isOldValueTheSame) return false;\r\n    this.value.set(v && v.map(el => el || null));\r\n    this.validateValueAndUpdate();\r\n    this._updateInputElements();\r\n    return true;\r\n  }\r\n\r\n  private _updateInputElements() {\r\n    const v = this.value() ?? [];\r\n    let i = 0;\r\n    for (const inputEl of this._ardHost.inputs()) {\r\n      inputEl.nativeElement.value = v[i] ?? '';\r\n      i++;\r\n    }\r\n  }\r\n\r\n  //! setting config\r\n  setConfig(config: DigitInputConfig): void {\r\n    this._setConfig(config);\r\n    this.validateValueAndUpdate();\r\n  }\r\n  private _setConfig(config: DigitInputConfig): void {\r\n    //map a number to ready objects\r\n    let configAsNumber = isAnyString(config) ? Number(config) : null;\r\n    if (isNumber(config) || isNumber(configAsNumber)) {\r\n      configAsNumber = isNumber(config) ? config : configAsNumber!;\r\n      this._configArray.set(new Array(configAsNumber).fill({ accept: (str: string) => /[0-9]/.test(str) }));\r\n      return;\r\n    }\r\n    //map a string to an array\r\n    let configArr: string[] | Exclude<DigitInputConfig, number | string>;\r\n    if (isAnyString(config)) {\r\n      configArr = coerceArrayProperty(config);\r\n    } else {\r\n      configArr = config;\r\n    }\r\n    //map array to ready objects\r\n    this._configArray.set(\r\n      configArr.map((v, i) => {\r\n        if (!isAnyString(v)) {\r\n          if ('accept' in v && !isFunction(v.accept)) {\r\n            const regExp = isRegExp(v.accept) ? v.accept : new RegExp(`[${_sanitizeRegExpString(v.accept)}]`);\r\n            v.accept = str => regExp.test(str);\r\n          }\r\n          return v;\r\n        }\r\n\r\n        switch (v) {\r\n          case DigitInputPrimitiveOption.Number:\r\n            return { accept: str => /[0-9]/.test(str) };\r\n          case DigitInputPrimitiveOption.Letter:\r\n            return { accept: str => /[a-zA-Z]/.test(str) };\r\n          case DigitInputPrimitiveOption.Alphanumeric:\r\n            return { accept: str => /[0-9a-zA-Z]/.test(str) };\r\n          case DigitInputPrimitiveOption.Special:\r\n            return { accept: str => /[!@#$%^&*-_=+/\\\\.,]/.test(str) };\r\n\r\n          default:\r\n            if (configArr.length === 1) {\r\n              throw new Error(`ARD-NF0043S: <ard-digit-input>'s config is invalid. Expected number or array, got \"${v}\"`);\r\n            }\r\n            throw new Error(`ARD-NF0043B: Found invalid string \"${v}\" in <ard-digit-input>'s config at index ${i}`);\r\n        }\r\n      })\r\n    );\r\n  }\r\n\r\n  resetInputValue(index: number): void {\r\n    if (index < 0 || index > this._configArray().length) return;\r\n\r\n    const config = this._configArray()[index] as DigitInputOption;\r\n    let newValue = '';\r\n    if ('static' in config) {\r\n      newValue = config.static;\r\n    }\r\n\r\n    //get the corresponding HTML input element\r\n    const inputEl = this._ardHost.inputs()[index];\r\n    if (!inputEl) {\r\n      throw new Error(\r\n        \"ARD-IS0048: <ard-digit-input>'s value changed, but its corresponding input element could not be found. If you are reading this, you probably experienced a problem with Ardium UI. Please report this issue to the creators.\"\r\n      );\r\n    }\r\n    //update the input element and value array\r\n    inputEl.nativeElement.value = newValue;\r\n\r\n    this.value.update(arr => {\r\n      if (!arr) arr = [];\r\n      const newArr = [...arr];\r\n      newArr[index] = newValue || null;\r\n      return newArr;\r\n    });\r\n  }\r\n\r\n  //! validate against the config\r\n  validateInputAndSetValue(\r\n    input: string,\r\n    index: number\r\n  ): null | { wasChanged: boolean; wasValidChar: boolean; resultChar: string | null } {\r\n    if (index < 0 || index > this._configArray().length) return null;\r\n\r\n    let v = this.value();\r\n    //prepare the value array if does not exist\r\n    if (!v) {\r\n      this.value.set([]);\r\n    }\r\n    v = [];\r\n    //prepare the characters before the current one (to be used in validation)\r\n    const before = this.stringValue().charAt(index);\r\n\r\n    //remove the old character from the input element\r\n    if (before && input.length > 1 && input.match(before)) {\r\n      input = input.replace(before, '');\r\n    }\r\n    //use only the first or last character (error safety)\r\n    const firstChar = input.charAt(0);\r\n    const lastChar = input.charAt(input.length - 1);\r\n    input = firstChar === before ? lastChar : firstChar;\r\n\r\n    //validate and transform, if necessary\r\n    const inputChar = this._validateSingleChar(input, before, this._configArray()[index] as DigitInputAcceptObject);\r\n\r\n    //get the corresponding HTML input element\r\n    const inputEl = this._ardHost.inputs()[index];\r\n    if (!inputEl) {\r\n      throw new Error(\r\n        \"ARD-IS0048: <ard-digit-input>'s value changed, but its corresponding input element could not be found. If you are reading this, you probably experienced a problem with Ardium UI. Please report this issue to the creators.\"\r\n      );\r\n    }\r\n    //update the input element and value array\r\n    const newVal = inputChar ?? before;\r\n    inputEl.nativeElement.value = newVal ?? '';\r\n\r\n    this.value.update(arr => {\r\n      if (!arr) arr = [];\r\n      const newArr = [...arr];\r\n      newArr[index] = newVal || null;\r\n      return newArr;\r\n    });\r\n    //return changes marker and validated value\r\n    return { wasChanged: newVal !== before, wasValidChar: !isNull(inputChar), resultChar: inputChar };\r\n  }\r\n  validateValueAndUpdate(): void {\r\n    const v = this.value();\r\n    if (!v) return;\r\n\r\n    let before = '';\r\n    const newValue: (string | null)[] = [];\r\n    for (let i = 0; i < Math.min(this._configArray().length, v.length); i++) {\r\n      const char = v[i];\r\n      before += char ?? ' ';\r\n\r\n      if (!char) {\r\n        newValue.push(char);\r\n        continue;\r\n      }\r\n      const newChar = this._validateSingleChar(char, before, this._configArray()[i] as DigitInputAcceptObject);\r\n      newValue.push(newChar);\r\n    }\r\n    this.value.set(newValue);\r\n  }\r\n  private _validateSingleChar(char: string | null, before: string, config: DigitInputOption): string | null {\r\n    // return the character if it is static\r\n    if ('static' in config) return config.static;\r\n    // for peace of mind protect against modifying read-only fields\r\n    if (config.readonly) {\r\n      throw new Error(\r\n        `ARD-IS0049R: trying to set value of a <ard-digit-input>'s readonly field. This is error is fatal to the functioning of Ardium UI. Please report this issue to the creators.`\r\n      );\r\n    }\r\n    // process regex or convert string into regex\r\n    if (!isFunction(config.accept)) {\r\n      const regExp = isRegExp(config.accept) ? config.accept : new RegExp(`[${_sanitizeRegExpString(config.accept)}]`);\r\n      config.accept = str => regExp.test(str);\r\n    }\r\n    if (!char) return char;\r\n\r\n    // check if input fits the criteria\r\n    const canAccept = config.accept(char, before);\r\n    if (!canAccept) return null;\r\n\r\n    // transform if needed\r\n    const transform = config.transform ?? this._ardHost.transform();\r\n    if (transform) {\r\n      if (transform === TransformType.Lowercase) {\r\n        return char.toLowerCase();\r\n      }\r\n      if (transform === TransformType.Uppercase) {\r\n        return char.toUpperCase();\r\n      }\r\n      if (isFunction(transform)) {\r\n        return transform(char).charAt(0);\r\n      }\r\n      console.warn(\r\n        `ARD-IS0049T: <ard-digit-input>'s value validator encountered an unexpected value of the config's \"transform\" property. Ardium UI was able to handle this issue, but please report it to the creators.`\r\n      );\r\n    }\r\n    return char;\r\n  }\r\n}\r\n"]}
@@ -16,4 +16,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
16
16
  exports: [ArdiumDigitInputComponent],
17
17
  }]
18
18
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlnaXQtaW5wdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9pbnB1dHMvZGlnaXQtaW5wdXQvZGlnaXQtaW5wdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFPcEUsTUFBTSxPQUFPLHNCQUFzQjsrR0FBdEIsc0JBQXNCO2dIQUF0QixzQkFBc0IsaUJBSmxCLHlCQUF5QixhQUM5QixZQUFZLEVBQUUsV0FBVyxhQUN6Qix5QkFBeUI7Z0hBRXhCLHNCQUFzQixZQUh2QixZQUFZOzs0RkFHWCxzQkFBc0I7a0JBTGxDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMseUJBQXlCLENBQUM7b0JBQ3pDLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUM7b0JBQ3BDLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixDQUFDO2lCQUNyQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENka0F1dG9maWxsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3RleHQtZmllbGQnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBcmRpdW1EaWdpdElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9kaWdpdC1pbnB1dC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtBcmRpdW1EaWdpdElucHV0Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQ2RrQXV0b2ZpbGxdLFxuICBleHBvcnRzOiBbQXJkaXVtRGlnaXRJbnB1dENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEFyZGl1bURpZ2l0SW5wdXRNb2R1bGUge31cbiJdfQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlnaXQtaW5wdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9pbnB1dHMvZGlnaXQtaW5wdXQvZGlnaXQtaW5wdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFPcEUsTUFBTSxPQUFPLHNCQUFzQjsrR0FBdEIsc0JBQXNCO2dIQUF0QixzQkFBc0IsaUJBSmxCLHlCQUF5QixhQUM5QixZQUFZLEVBQUUsV0FBVyxhQUN6Qix5QkFBeUI7Z0hBRXhCLHNCQUFzQixZQUh2QixZQUFZOzs0RkFHWCxzQkFBc0I7a0JBTGxDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMseUJBQXlCLENBQUM7b0JBQ3pDLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUM7b0JBQ3BDLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixDQUFDO2lCQUNyQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENka0F1dG9maWxsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3RleHQtZmllbGQnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBcmRpdW1EaWdpdElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9kaWdpdC1pbnB1dC5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtBcmRpdW1EaWdpdElucHV0Q29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBDZGtBdXRvZmlsbF0sXHJcbiAgZXhwb3J0czogW0FyZGl1bURpZ2l0SW5wdXRDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXJkaXVtRGlnaXRJbnB1dE1vZHVsZSB7fVxyXG4iXX0=
@@ -213,7 +213,9 @@ class _NgModelComponentBase extends _FocusableComponentBase {
213
213
  ngOnInit() {
214
214
  this._ngControl = this._injector.get(NgControl, null);
215
215
  if (this._ngControl) {
216
- this._ngControl.valueAccessor = this;
216
+ if (!this._ngControl.valueAccessor || this && this instanceof this._ngControl.valueAccessor.constructor) {
217
+ this._ngControl.valueAccessor = this;
218
+ }
217
219
  this._hasErrorInControl.set(this._ngControl.status === 'INVALID');
218
220
  this._statusChangesSub = this._ngControl.statusChanges
219
221
  ?.pipe(map(v => v === 'INVALID'))
@@ -405,11 +407,13 @@ class DigitInputModel {
405
407
  return !!this.value()?.[index];
406
408
  }
407
409
  writeValue(v) {
410
+ console.log('executing model writeValue', v, this._ardHost.outputAsString());
408
411
  if (this._ardHost.outputAsString()) {
409
412
  if (!isAnyString(v) && !isNull(v)) {
410
413
  throw new Error(`ARD-FT0040b: Trying to set <ard-digit-input>'s value to "${v}" (of type ${typeof v}), but the input uses [outputAsString]="true", and thus expects string or null.`);
411
414
  }
412
415
  const vArray = v?.split('') ?? [];
416
+ console.log('executing model writeValue - vArray', vArray, this._configArray());
413
417
  if (vArray.length > this._configArray().length) {
414
418
  console.warn(`ARD-WA0041: Value provided to <ard-digit-input> is too long. Got ${vArray.length} characters, but expected a maximum of ${this._configArray().length} characters.`);
415
419
  }
@@ -430,6 +434,7 @@ class DigitInputModel {
430
434
  }
431
435
  _writeValue(v) {
432
436
  const isOldValueTheSame = this.value() ? this.value().every((ch, i) => ch === v?.[i]) : !v;
437
+ console.log('executing model _writeValue', v, 'current value', this.value(), isOldValueTheSame);
433
438
  if (isOldValueTheSame)
434
439
  return false;
435
440
  this.value.set(v && v.map(el => el || null));
@@ -710,13 +715,17 @@ class ArdiumDigitInputComponent extends _FormFieldComponentBase {
710
715
  return !this.model.isDefinedAtIndex(index);
711
716
  }
712
717
  writeValue(v) {
718
+ console.log('writeValue', v, this._wasViewInit);
713
719
  if (!this._wasViewInit) {
714
720
  this._valueBeforeViewInit = v;
721
+ console.log('returning from writeValue');
715
722
  return;
716
723
  }
724
+ console.log('calling _writeValue with value', v);
717
725
  this._writeValue(v);
718
726
  }
719
727
  _writeValue(v) {
728
+ console.log('_writeValue', v);
720
729
  return this.model.writeValue(v);
721
730
  }
722
731
  ngAfterViewInit() {
@@ -2871,6 +2880,10 @@ class ItemStorage {
2871
2880
  return;
2872
2881
  }
2873
2882
  const selectItemByValue = (value) => {
2883
+ if (value === null || value === undefined) {
2884
+ this.unselectItem(...this._selectedItems());
2885
+ return;
2886
+ }
2874
2887
  const item = this.findItemByValue(value);
2875
2888
  if (item) {
2876
2889
  this.selectItem(item);
@@ -6355,7 +6368,7 @@ class ArdiumCalendarComponent extends _NgModelComponentBase {
6355
6368
  const value = coerceNumberProperty(v, this._DEFAULTS.firstWeekday);
6356
6369
  if (!Number.isInteger(value)) {
6357
6370
  console.error(new Error(`ARD-NF2001A: [firstWeekday] must be a positive integer, got "${value}". Using default value instead.`));
6358
- return 1;
6371
+ return this._DEFAULTS.firstWeekday;
6359
6372
  }
6360
6373
  if (value < 0 || value > 6) {
6361
6374
  console.error(new Error(`ARD-NF2001B: [firstWeekday] must be between 0 and 6, got "${value}". Using modulo operator to adjust the value.`));
@@ -6368,7 +6381,7 @@ class ArdiumCalendarComponent extends _NgModelComponentBase {
6368
6381
  const value = coerceNumberProperty(v, this._DEFAULTS.multipleYearPageChangeModifier);
6369
6382
  if (!Number.isInteger(value) || value < 1) {
6370
6383
  console.error(new Error(`ARD-NF2002: [multipleYearPageChangeModifier] must be a positive integer, got "${value}". Using default value instead.`));
6371
- return 5;
6384
+ return this._DEFAULTS.multipleYearPageChangeModifier;
6372
6385
  }
6373
6386
  return value;
6374
6387
  },
@@ -6459,7 +6472,7 @@ class ArdiumCalendarComponent extends _NgModelComponentBase {
6459
6472
  }
6460
6473
  if (day instanceof Date)
6461
6474
  day = day.getDate();
6462
- if (day && this.isDayOutOfRange(day) || this.isDayFilteredOut()(day))
6475
+ if ((day && this.isDayOutOfRange(day)) || this.isDayFilteredOut()(day))
6463
6476
  return;
6464
6477
  this.selectedDate.set(new Date(this.activeYear(), this.activeMonth(), day, 0, 0, 0, 0));
6465
6478
  }
@@ -6745,11 +6758,23 @@ class ArdiumCalendarComponent extends _NgModelComponentBase {
6745
6758
  this._isUsingKeyboard.set(true);
6746
6759
  }
6747
6760
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumCalendarComponent, deps: [{ token: ARD_CALENDAR_DEFAULTS }], target: i0.ɵɵFactoryTarget.Component }); }
6748
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumCalendarComponent, selector: "ard-calendar", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, activeView: { classPropertyName: "activeView", publicName: "activeView", isSignal: true, isRequired: false, transformFunction: null }, activeYear: { classPropertyName: "activeYear", publicName: "activeYear", isSignal: true, isRequired: false, transformFunction: null }, activeMonth: { classPropertyName: "activeMonth", publicName: "activeMonth", isSignal: true, isRequired: false, transformFunction: null }, firstWeekday: { classPropertyName: "firstWeekday", publicName: "firstWeekday", isSignal: true, isRequired: false, transformFunction: null }, multipleYearPageChangeModifier: { classPropertyName: "multipleYearPageChangeModifier", publicName: "multipleYearPageChangeModifier", isSignal: true, isRequired: false, transformFunction: null }, autoFocus: { classPropertyName: "autoFocus", publicName: "autoFocus", isSignal: true, isRequired: false, transformFunction: null }, selectedDate: { classPropertyName: "selectedDate", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { activeView: "activeViewChange", activeYear: "activeYearChange", activeMonth: "activeMonthChange", selectedDate: "selectedChange", yearSelect: "yearSelect", monthSelect: "monthSelect" }, host: { listeners: { "document:mousemove": "onDocumentMousemove()", "document:keydown": "onDocumentKeydown()" } }, queries: [{ propertyName: "yearsViewHeaderTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "monthsViewHeaderTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "daysViewHeaderTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "floatingMonthTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "yearTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "monthTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "dayTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "weekdayTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n class=\"ard-calendar\"\r\n [ngClass]=\"ngClasses()\"\r\n>\r\n @switch (activeView()) { @case ('days') {\r\n <ard-days-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [activeMonth]=\"activeMonth()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [firstWeekday]=\"firstWeekday()\"\r\n [highlightedDay]=\"highlightedDay()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [isDayFilteredOut]=\"isDayFilteredOut()\"\r\n [daysViewHeaderTemplate]=\"daysViewHeaderTemplate()\"\r\n [floatingMonthTemplate]=\"floatingMonthTemplate()\"\r\n [weekdayTemplate]=\"weekdayTemplate()\"\r\n [dayTemplate]=\"dayTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenMonthsView)=\"onTriggerOpenMonthsView()\"\r\n (triggerOpenYearsView)=\"onTriggerOpenYearsView()\"\r\n (triggerChangeMonth)=\"changeMonth($event)\"\r\n (triggerChangeYear)=\"changeYear($event)\"\r\n (triggerHighlightDay)=\"setHighlightedDay($event)\"\r\n (triggerHighlightFirstDay)=\"highlightFirstDay()\"\r\n (triggerHighlightLastDay)=\"highlightLastDay()\"\r\n (triggerHighlightNextDay)=\"highlightNextDay($event)\"\r\n (triggerHighlightPreviousDay)=\"highlightPreviousDay($event)\"\r\n (triggerHighlightSameDayNextPage)=\"$event ? highlightSameDayNextYear() : highlightSameDayNextMonth()\"\r\n (triggerHighlightSameDayPreviousPage)=\"$event ? highlightSameDayPreviousYear() : highlightSameDayPreviousMonth()\"\r\n (triggerSelectDay)=\"selectDay($event)\"\r\n />\r\n } @case ('months') {\r\n <ard-months-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [color]=\"color()\"\r\n [activeMonth]=\"activeMonth()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [highlightedMonth]=\"highlightedMonth()\"\r\n [monthsViewHeaderTemplate]=\"monthsViewHeaderTemplate()\"\r\n [monthTemplate]=\"monthTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenDaysView)=\"onTriggerOpenDaysView()\"\r\n (triggerOpenYearsView)=\"onTriggerOpenYearsView()\"\r\n (triggeChangeYear)=\"changeYear($event)\"\r\n (triggerSelectMonth)=\"selectMonth($event)\"\r\n (triggerHighlightMonth)=\"setHighlightedMonth($event)\"\r\n (triggerHighlightFirstMonth)=\"highlightFirstMonth()\"\r\n (triggerHighlightLastMonth)=\"highlightLastMonth()\"\r\n (triggerHighlightNextMonth)=\"highlightNextMonth($event)\"\r\n (triggerHighlightPreviousMonth)=\"highlightPreviousMonth($event)\"\r\n (triggerHighlightSameMonthNextPage)=\"highlightSameMonthNextYear($event)\"\r\n (triggerHighlightSameMonthPreviousPage)=\"highlightSameMonthPreviousYear($event)\"\r\n />\r\n } @case ('years') {\r\n <ard-years-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [highlightedYear]=\"highlightedYear()\"\r\n [currentYearRangeStart]=\"currentYearRangeStart()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [yearsViewHeaderTemplate]=\"yearsViewHeaderTemplate()\"\r\n [yearTemplate]=\"yearTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenDaysView)=\"onTriggerOpenDaysView()\"\r\n (triggerOpenMonthsView)=\"onTriggerOpenMonthsView()\"\r\n (triggerSelectYear)=\"selectYear($event)\"\r\n (triggerChangeYearsViewPage)=\"changeYearsViewPage($event)\"\r\n (triggerHighlightYear)=\"setHighlightedYear($event)\"\r\n (triggerHighlightFirstYear)=\"highlightFirstYear()\"\r\n (triggerHighlightLastYear)=\"highlightLastYear()\"\r\n (triggerHighlightNextYear)=\"highlightNextYear($event)\"\r\n (triggerHighlightPreviousYear)=\"highlightPreviousYear($event)\"\r\n (triggerHighlightSameYearNextPage)=\"highlightSameYearNextPage($event)\"\r\n (triggerHighlightSameYearPreviousPage)=\"highlightSameYearPreviousPage($event)\"\r\n />\r\n } }\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: DaysViewComponent, selector: "ard-days-view", inputs: ["tabIndex", "readOnly", "disabled", "autoFocus", "_isUsingKeyboard", "activeYear", "activeMonth", "selectedDate", "min", "max", "isDayFilteredOut", "highlightedDay", "firstWeekday", "daysViewHeaderTemplate", "floatingMonthTemplate", "weekdayTemplate", "dayTemplate"], outputs: ["triggerOpenYearsView", "triggerOpenMonthsView", "triggerSelectDay", "triggerChangeMonth", "triggerChangeYear", "triggerHighlightDay", "triggerHighlightNextDay", "triggerHighlightPreviousDay", "triggerHighlightFirstDay", "triggerHighlightLastDay", "triggerHighlightSameDayPreviousPage", "triggerHighlightSameDayNextPage", "focus", "blur"] }, { kind: "component", type: MonthsViewComponent, selector: "ard-months-view", inputs: ["tabIndex", "readOnly", "disabled", "autoFocus", "_isUsingKeyboard", "color", "activeYear", "activeMonth", "selectedDate", "min", "max", "highlightedMonth", "monthsViewHeaderTemplate", "monthTemplate"], outputs: ["triggerOpenYearsView", "triggerOpenDaysView", "focus", "blur", "triggerSelectMonth", "triggeChangeYear", "triggerHighlightMonth", "triggerHighlightNextMonth", "triggerHighlightPreviousMonth", "triggerHighlightFirstMonth", "triggerHighlightLastMonth", "triggerHighlightSameMonthPreviousPage", "triggerHighlightSameMonthNextPage"] }, { kind: "component", type: YearsViewComponent, selector: "ard-years-view", inputs: ["tabIndex", "readOnly", "disabled", "autoFocus", "_isUsingKeyboard", "activeYear", "selectedDate", "min", "max", "currentYearRangeStart", "highlightedYear", "yearsViewHeaderTemplate", "yearTemplate"], outputs: ["triggerOpenMonthsView", "triggerOpenDaysView", "focus", "blur", "triggerSelectYear", "triggerChangeYearsViewPage", "triggerHighlightYear", "triggerHighlightNextYear", "triggerHighlightPreviousYear", "triggerHighlightFirstYear", "triggerHighlightLastYear", "triggerHighlightSameYearPreviousPage", "triggerHighlightSameYearNextPage"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
6761
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumCalendarComponent, selector: "ard-calendar", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, activeView: { classPropertyName: "activeView", publicName: "activeView", isSignal: true, isRequired: false, transformFunction: null }, activeYear: { classPropertyName: "activeYear", publicName: "activeYear", isSignal: true, isRequired: false, transformFunction: null }, activeMonth: { classPropertyName: "activeMonth", publicName: "activeMonth", isSignal: true, isRequired: false, transformFunction: null }, firstWeekday: { classPropertyName: "firstWeekday", publicName: "firstWeekday", isSignal: true, isRequired: false, transformFunction: null }, multipleYearPageChangeModifier: { classPropertyName: "multipleYearPageChangeModifier", publicName: "multipleYearPageChangeModifier", isSignal: true, isRequired: false, transformFunction: null }, autoFocus: { classPropertyName: "autoFocus", publicName: "autoFocus", isSignal: true, isRequired: false, transformFunction: null }, selectedDate: { classPropertyName: "selectedDate", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { activeView: "activeViewChange", activeYear: "activeYearChange", activeMonth: "activeMonthChange", selectedDate: "selectedChange", yearSelect: "yearSelect", monthSelect: "monthSelect" }, host: { listeners: { "document:mousemove": "onDocumentMousemove()", "document:keydown": "onDocumentKeydown()" } }, providers: [
6762
+ {
6763
+ provide: NG_VALUE_ACCESSOR,
6764
+ useExisting: forwardRef(() => ArdiumCalendarComponent),
6765
+ multi: true,
6766
+ },
6767
+ ], queries: [{ propertyName: "yearsViewHeaderTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "monthsViewHeaderTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "daysViewHeaderTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "floatingMonthTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "yearTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "monthTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "dayTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "weekdayTemplate", first: true, predicate: TemplateRef, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n class=\"ard-calendar\"\r\n [ngClass]=\"ngClasses()\"\r\n>\r\n @switch (activeView()) { @case ('days') {\r\n <ard-days-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [activeMonth]=\"activeMonth()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [firstWeekday]=\"firstWeekday()\"\r\n [highlightedDay]=\"highlightedDay()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [isDayFilteredOut]=\"isDayFilteredOut()\"\r\n [daysViewHeaderTemplate]=\"daysViewHeaderTemplate()\"\r\n [floatingMonthTemplate]=\"floatingMonthTemplate()\"\r\n [weekdayTemplate]=\"weekdayTemplate()\"\r\n [dayTemplate]=\"dayTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenMonthsView)=\"onTriggerOpenMonthsView()\"\r\n (triggerOpenYearsView)=\"onTriggerOpenYearsView()\"\r\n (triggerChangeMonth)=\"changeMonth($event)\"\r\n (triggerChangeYear)=\"changeYear($event)\"\r\n (triggerHighlightDay)=\"setHighlightedDay($event)\"\r\n (triggerHighlightFirstDay)=\"highlightFirstDay()\"\r\n (triggerHighlightLastDay)=\"highlightLastDay()\"\r\n (triggerHighlightNextDay)=\"highlightNextDay($event)\"\r\n (triggerHighlightPreviousDay)=\"highlightPreviousDay($event)\"\r\n (triggerHighlightSameDayNextPage)=\"$event ? highlightSameDayNextYear() : highlightSameDayNextMonth()\"\r\n (triggerHighlightSameDayPreviousPage)=\"$event ? highlightSameDayPreviousYear() : highlightSameDayPreviousMonth()\"\r\n (triggerSelectDay)=\"selectDay($event)\"\r\n />\r\n } @case ('months') {\r\n <ard-months-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [color]=\"color()\"\r\n [activeMonth]=\"activeMonth()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [highlightedMonth]=\"highlightedMonth()\"\r\n [monthsViewHeaderTemplate]=\"monthsViewHeaderTemplate()\"\r\n [monthTemplate]=\"monthTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenDaysView)=\"onTriggerOpenDaysView()\"\r\n (triggerOpenYearsView)=\"onTriggerOpenYearsView()\"\r\n (triggeChangeYear)=\"changeYear($event)\"\r\n (triggerSelectMonth)=\"selectMonth($event)\"\r\n (triggerHighlightMonth)=\"setHighlightedMonth($event)\"\r\n (triggerHighlightFirstMonth)=\"highlightFirstMonth()\"\r\n (triggerHighlightLastMonth)=\"highlightLastMonth()\"\r\n (triggerHighlightNextMonth)=\"highlightNextMonth($event)\"\r\n (triggerHighlightPreviousMonth)=\"highlightPreviousMonth($event)\"\r\n (triggerHighlightSameMonthNextPage)=\"highlightSameMonthNextYear($event)\"\r\n (triggerHighlightSameMonthPreviousPage)=\"highlightSameMonthPreviousYear($event)\"\r\n />\r\n } @case ('years') {\r\n <ard-years-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [highlightedYear]=\"highlightedYear()\"\r\n [currentYearRangeStart]=\"currentYearRangeStart()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [yearsViewHeaderTemplate]=\"yearsViewHeaderTemplate()\"\r\n [yearTemplate]=\"yearTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenDaysView)=\"onTriggerOpenDaysView()\"\r\n (triggerOpenMonthsView)=\"onTriggerOpenMonthsView()\"\r\n (triggerSelectYear)=\"selectYear($event)\"\r\n (triggerChangeYearsViewPage)=\"changeYearsViewPage($event)\"\r\n (triggerHighlightYear)=\"setHighlightedYear($event)\"\r\n (triggerHighlightFirstYear)=\"highlightFirstYear()\"\r\n (triggerHighlightLastYear)=\"highlightLastYear()\"\r\n (triggerHighlightNextYear)=\"highlightNextYear($event)\"\r\n (triggerHighlightPreviousYear)=\"highlightPreviousYear($event)\"\r\n (triggerHighlightSameYearNextPage)=\"highlightSameYearNextPage($event)\"\r\n (triggerHighlightSameYearPreviousPage)=\"highlightSameYearPreviousPage($event)\"\r\n />\r\n } }\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: DaysViewComponent, selector: "ard-days-view", inputs: ["tabIndex", "readOnly", "disabled", "autoFocus", "_isUsingKeyboard", "activeYear", "activeMonth", "selectedDate", "min", "max", "isDayFilteredOut", "highlightedDay", "firstWeekday", "daysViewHeaderTemplate", "floatingMonthTemplate", "weekdayTemplate", "dayTemplate"], outputs: ["triggerOpenYearsView", "triggerOpenMonthsView", "triggerSelectDay", "triggerChangeMonth", "triggerChangeYear", "triggerHighlightDay", "triggerHighlightNextDay", "triggerHighlightPreviousDay", "triggerHighlightFirstDay", "triggerHighlightLastDay", "triggerHighlightSameDayPreviousPage", "triggerHighlightSameDayNextPage", "focus", "blur"] }, { kind: "component", type: MonthsViewComponent, selector: "ard-months-view", inputs: ["tabIndex", "readOnly", "disabled", "autoFocus", "_isUsingKeyboard", "color", "activeYear", "activeMonth", "selectedDate", "min", "max", "highlightedMonth", "monthsViewHeaderTemplate", "monthTemplate"], outputs: ["triggerOpenYearsView", "triggerOpenDaysView", "focus", "blur", "triggerSelectMonth", "triggeChangeYear", "triggerHighlightMonth", "triggerHighlightNextMonth", "triggerHighlightPreviousMonth", "triggerHighlightFirstMonth", "triggerHighlightLastMonth", "triggerHighlightSameMonthPreviousPage", "triggerHighlightSameMonthNextPage"] }, { kind: "component", type: YearsViewComponent, selector: "ard-years-view", inputs: ["tabIndex", "readOnly", "disabled", "autoFocus", "_isUsingKeyboard", "activeYear", "selectedDate", "min", "max", "currentYearRangeStart", "highlightedYear", "yearsViewHeaderTemplate", "yearTemplate"], outputs: ["triggerOpenMonthsView", "triggerOpenDaysView", "focus", "blur", "triggerSelectYear", "triggerChangeYearsViewPage", "triggerHighlightYear", "triggerHighlightNextYear", "triggerHighlightPreviousYear", "triggerHighlightFirstYear", "triggerHighlightLastYear", "triggerHighlightSameYearPreviousPage", "triggerHighlightSameYearNextPage"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
6749
6768
  }
6750
6769
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumCalendarComponent, decorators: [{
6751
6770
  type: Component,
6752
- args: [{ selector: 'ard-calendar', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n class=\"ard-calendar\"\r\n [ngClass]=\"ngClasses()\"\r\n>\r\n @switch (activeView()) { @case ('days') {\r\n <ard-days-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [activeMonth]=\"activeMonth()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [firstWeekday]=\"firstWeekday()\"\r\n [highlightedDay]=\"highlightedDay()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [isDayFilteredOut]=\"isDayFilteredOut()\"\r\n [daysViewHeaderTemplate]=\"daysViewHeaderTemplate()\"\r\n [floatingMonthTemplate]=\"floatingMonthTemplate()\"\r\n [weekdayTemplate]=\"weekdayTemplate()\"\r\n [dayTemplate]=\"dayTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenMonthsView)=\"onTriggerOpenMonthsView()\"\r\n (triggerOpenYearsView)=\"onTriggerOpenYearsView()\"\r\n (triggerChangeMonth)=\"changeMonth($event)\"\r\n (triggerChangeYear)=\"changeYear($event)\"\r\n (triggerHighlightDay)=\"setHighlightedDay($event)\"\r\n (triggerHighlightFirstDay)=\"highlightFirstDay()\"\r\n (triggerHighlightLastDay)=\"highlightLastDay()\"\r\n (triggerHighlightNextDay)=\"highlightNextDay($event)\"\r\n (triggerHighlightPreviousDay)=\"highlightPreviousDay($event)\"\r\n (triggerHighlightSameDayNextPage)=\"$event ? highlightSameDayNextYear() : highlightSameDayNextMonth()\"\r\n (triggerHighlightSameDayPreviousPage)=\"$event ? highlightSameDayPreviousYear() : highlightSameDayPreviousMonth()\"\r\n (triggerSelectDay)=\"selectDay($event)\"\r\n />\r\n } @case ('months') {\r\n <ard-months-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [color]=\"color()\"\r\n [activeMonth]=\"activeMonth()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [highlightedMonth]=\"highlightedMonth()\"\r\n [monthsViewHeaderTemplate]=\"monthsViewHeaderTemplate()\"\r\n [monthTemplate]=\"monthTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenDaysView)=\"onTriggerOpenDaysView()\"\r\n (triggerOpenYearsView)=\"onTriggerOpenYearsView()\"\r\n (triggeChangeYear)=\"changeYear($event)\"\r\n (triggerSelectMonth)=\"selectMonth($event)\"\r\n (triggerHighlightMonth)=\"setHighlightedMonth($event)\"\r\n (triggerHighlightFirstMonth)=\"highlightFirstMonth()\"\r\n (triggerHighlightLastMonth)=\"highlightLastMonth()\"\r\n (triggerHighlightNextMonth)=\"highlightNextMonth($event)\"\r\n (triggerHighlightPreviousMonth)=\"highlightPreviousMonth($event)\"\r\n (triggerHighlightSameMonthNextPage)=\"highlightSameMonthNextYear($event)\"\r\n (triggerHighlightSameMonthPreviousPage)=\"highlightSameMonthPreviousYear($event)\"\r\n />\r\n } @case ('years') {\r\n <ard-years-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [highlightedYear]=\"highlightedYear()\"\r\n [currentYearRangeStart]=\"currentYearRangeStart()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [yearsViewHeaderTemplate]=\"yearsViewHeaderTemplate()\"\r\n [yearTemplate]=\"yearTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenDaysView)=\"onTriggerOpenDaysView()\"\r\n (triggerOpenMonthsView)=\"onTriggerOpenMonthsView()\"\r\n (triggerSelectYear)=\"selectYear($event)\"\r\n (triggerChangeYearsViewPage)=\"changeYearsViewPage($event)\"\r\n (triggerHighlightYear)=\"setHighlightedYear($event)\"\r\n (triggerHighlightFirstYear)=\"highlightFirstYear()\"\r\n (triggerHighlightLastYear)=\"highlightLastYear()\"\r\n (triggerHighlightNextYear)=\"highlightNextYear($event)\"\r\n (triggerHighlightPreviousYear)=\"highlightPreviousYear($event)\"\r\n (triggerHighlightSameYearNextPage)=\"highlightSameYearNextPage($event)\"\r\n (triggerHighlightSameYearPreviousPage)=\"highlightSameYearPreviousPage($event)\"\r\n />\r\n } }\r\n</div>\r\n" }]
6771
+ args: [{ selector: 'ard-calendar', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
6772
+ {
6773
+ provide: NG_VALUE_ACCESSOR,
6774
+ useExisting: forwardRef(() => ArdiumCalendarComponent),
6775
+ multi: true,
6776
+ },
6777
+ ], template: "<div\r\n class=\"ard-calendar\"\r\n [ngClass]=\"ngClasses()\"\r\n>\r\n @switch (activeView()) { @case ('days') {\r\n <ard-days-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [activeMonth]=\"activeMonth()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [firstWeekday]=\"firstWeekday()\"\r\n [highlightedDay]=\"highlightedDay()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [isDayFilteredOut]=\"isDayFilteredOut()\"\r\n [daysViewHeaderTemplate]=\"daysViewHeaderTemplate()\"\r\n [floatingMonthTemplate]=\"floatingMonthTemplate()\"\r\n [weekdayTemplate]=\"weekdayTemplate()\"\r\n [dayTemplate]=\"dayTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenMonthsView)=\"onTriggerOpenMonthsView()\"\r\n (triggerOpenYearsView)=\"onTriggerOpenYearsView()\"\r\n (triggerChangeMonth)=\"changeMonth($event)\"\r\n (triggerChangeYear)=\"changeYear($event)\"\r\n (triggerHighlightDay)=\"setHighlightedDay($event)\"\r\n (triggerHighlightFirstDay)=\"highlightFirstDay()\"\r\n (triggerHighlightLastDay)=\"highlightLastDay()\"\r\n (triggerHighlightNextDay)=\"highlightNextDay($event)\"\r\n (triggerHighlightPreviousDay)=\"highlightPreviousDay($event)\"\r\n (triggerHighlightSameDayNextPage)=\"$event ? highlightSameDayNextYear() : highlightSameDayNextMonth()\"\r\n (triggerHighlightSameDayPreviousPage)=\"$event ? highlightSameDayPreviousYear() : highlightSameDayPreviousMonth()\"\r\n (triggerSelectDay)=\"selectDay($event)\"\r\n />\r\n } @case ('months') {\r\n <ard-months-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [color]=\"color()\"\r\n [activeMonth]=\"activeMonth()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [highlightedMonth]=\"highlightedMonth()\"\r\n [monthsViewHeaderTemplate]=\"monthsViewHeaderTemplate()\"\r\n [monthTemplate]=\"monthTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenDaysView)=\"onTriggerOpenDaysView()\"\r\n (triggerOpenYearsView)=\"onTriggerOpenYearsView()\"\r\n (triggeChangeYear)=\"changeYear($event)\"\r\n (triggerSelectMonth)=\"selectMonth($event)\"\r\n (triggerHighlightMonth)=\"setHighlightedMonth($event)\"\r\n (triggerHighlightFirstMonth)=\"highlightFirstMonth()\"\r\n (triggerHighlightLastMonth)=\"highlightLastMonth()\"\r\n (triggerHighlightNextMonth)=\"highlightNextMonth($event)\"\r\n (triggerHighlightPreviousMonth)=\"highlightPreviousMonth($event)\"\r\n (triggerHighlightSameMonthNextPage)=\"highlightSameMonthNextYear($event)\"\r\n (triggerHighlightSameMonthPreviousPage)=\"highlightSameMonthPreviousYear($event)\"\r\n />\r\n } @case ('years') {\r\n <ard-years-view\r\n [tabIndex]=\"tabIndex()\"\r\n [readOnly]=\"readonly()\"\r\n [disabled]=\"disabled()\"\r\n [autoFocus]=\"autoFocus()\"\r\n [_isUsingKeyboard]=\"_isUsingKeyboard()\"\r\n [highlightedYear]=\"highlightedYear()\"\r\n [currentYearRangeStart]=\"currentYearRangeStart()\"\r\n [activeYear]=\"activeYear()\"\r\n [selectedDate]=\"selectedDate()\"\r\n [min]=\"min()\"\r\n [max]=\"max()\"\r\n [yearsViewHeaderTemplate]=\"yearsViewHeaderTemplate()\"\r\n [yearTemplate]=\"yearTemplate()\"\r\n (focus)=\"onFocus($event)\"\r\n (blur)=\"onBlur($event)\"\r\n (triggerOpenDaysView)=\"onTriggerOpenDaysView()\"\r\n (triggerOpenMonthsView)=\"onTriggerOpenMonthsView()\"\r\n (triggerSelectYear)=\"selectYear($event)\"\r\n (triggerChangeYearsViewPage)=\"changeYearsViewPage($event)\"\r\n (triggerHighlightYear)=\"setHighlightedYear($event)\"\r\n (triggerHighlightFirstYear)=\"highlightFirstYear()\"\r\n (triggerHighlightLastYear)=\"highlightLastYear()\"\r\n (triggerHighlightNextYear)=\"highlightNextYear($event)\"\r\n (triggerHighlightPreviousYear)=\"highlightPreviousYear($event)\"\r\n (triggerHighlightSameYearNextPage)=\"highlightSameYearNextPage($event)\"\r\n (triggerHighlightSameYearPreviousPage)=\"highlightSameYearPreviousPage($event)\"\r\n />\r\n } }\r\n</div>\r\n" }]
6753
6778
  }], ctorParameters: () => [{ type: undefined, decorators: [{
6754
6779
  type: Inject,
6755
6780
  args: [ARD_CALENDAR_DEFAULTS]
@@ -8368,6 +8393,10 @@ class SimpleItemStorage {
8368
8393
  if (!this._validateWriteValue(ngModel))
8369
8394
  return;
8370
8395
  const selectItemByValue = (value) => {
8396
+ if (value === null || value === undefined) {
8397
+ this.unselectAll();
8398
+ return;
8399
+ }
8371
8400
  const item = this.findItemByValue(value);
8372
8401
  if (item) {
8373
8402
  this.selectItem(item);