@ardium-ui/ui 3.5.3 → 3.5.4-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -70,7 +70,7 @@ export class _NgModelComponentBase extends _FocusableComponentBase {
70
70
  ngOnInit() {
71
71
  this._ngControl = this._injector.get(NgControl, null);
72
72
  if (this._ngControl) {
73
- if (!this._ngControl.valueAccessor || this instanceof this._ngControl.valueAccessor.constructor) {
73
+ if (!this._ngControl.valueAccessor || this && this instanceof this._ngControl.valueAccessor.constructor) {
74
74
  this._ngControl.valueAccessor = this;
75
75
  }
76
76
  this._hasErrorInControl.set(this._ngControl.status === 'INVALID');
@@ -97,4 +97,4 @@ export class _NgModelComponentBase extends _FocusableComponentBase {
97
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: _NgModelComponentBase, decorators: [{
98
98
  type: Directive
99
99
  }] });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngmodel-component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/_internal/ngmodel-component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  Directive,\r\n  inject,\r\n  Injector,\r\n  input,\r\n  OnDestroy,\r\n  OnInit,\r\n  runInInjectionContext,\r\n  Signal,\r\n  signal,\r\n} from '@angular/core';\r\nimport { toObservable } from '@angular/core/rxjs-interop';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { map, Subscription } from 'rxjs';\r\nimport { TakeChance as Random } from 'take-chance';\r\nimport { _FocusableComponentBase, _focusableComponentDefaults, _FocusableComponentDefaults } from './focusable-component';\r\n\r\nexport interface _NgModelComponentDefaults extends _FocusableComponentDefaults {\r\n  required: boolean | undefined;\r\n}\r\n\r\nexport const _ngModelComponentDefaults: _NgModelComponentDefaults = {\r\n  ..._focusableComponentDefaults,\r\n  required: undefined,\r\n};\r\n\r\n/**\r\n * Common code for components which implement the ControlValueAccessor.\r\n *\r\n * **Warning**: `writeValue` function should be implemented on the child component!\r\n */\r\n@Directive()\r\nexport abstract class _NgModelComponentBase extends _FocusableComponentBase implements ControlValueAccessor, OnInit, OnDestroy {\r\n  protected override readonly _DEFAULTS!: _NgModelComponentDefaults;\r\n\r\n  //! control value accessor\r\n  protected _onChangeRegistered!: (_: any) => void;\r\n  protected _onTouchedRegistered!: () => void;\r\n  /**\r\n   * Registers a function to handle touched state. Required by ControlValueAccessor.\r\n   * @param fn The function to register.\r\n   */\r\n  registerOnTouched(fn: () => void): void {\r\n    this._onTouchedRegistered = fn;\r\n  }\r\n  /**\r\n   * Registers a function to handle value change. Required by ControlValueAccessor.\r\n   * @param fn The function to register.\r\n   */\r\n  registerOnChange(fn: (_: any) => void): void {\r\n    this._onChangeRegistered = fn;\r\n  }\r\n  /**\r\n   * Sets the component's disabled state. Required by ControlValueAccessor.\r\n   * @param isDisabled the new disabled state.\r\n   */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled.set(isDisabled);\r\n  }\r\n\r\n  /**\r\n   * Writes the a new value into the component. Required by ControlValueAccessor.\r\n   * @abstract\r\n   * @param v The new value to write.\r\n   */\r\n  abstract writeValue(v: any): void; //* abstract\r\n\r\n  /**\r\n   * Writes the a new value into the component. Required by ControlValueAccessor.\r\n   * @abstract\r\n   * @param v The new value to write.\r\n   */\r\n  protected abstract _emitChange(): void; //* abstract\r\n\r\n  //! event handlers\r\n  readonly wasTouched = signal<boolean>(false);\r\n\r\n  override onFocus(event: FocusEvent): void {\r\n    super.onFocus(event);\r\n    this._shouldEmitTouched = false;\r\n  }\r\n\r\n  private _shouldEmitTouched = false;\r\n  override onBlur(event: FocusEvent) {\r\n    this._shouldEmitTouched = true;\r\n    super.onBlur(event);\r\n\r\n    setTimeout(() => {\r\n      if (!this._shouldEmitTouched) return;\r\n      this.wasTouched.set(true);\r\n      this._onTouchedRegistered?.();\r\n    }, 0);\r\n  }\r\n\r\n  //! form field related\r\n  protected readonly _injector = inject(Injector);\r\n\r\n  private _statusChangesSub?: Subscription;\r\n  ngOnInit(): void {\r\n    this._ngControl = this._injector.get(NgControl, null);\r\n\r\n    if (this._ngControl) {\r\n      if (!this._ngControl.valueAccessor || this instanceof (this._ngControl.valueAccessor as any).constructor) {\r\n        this._ngControl.valueAccessor = this;\r\n      }\r\n\r\n      this._hasErrorInControl.set(this._ngControl.status === 'INVALID');\r\n\r\n      this._statusChangesSub = this._ngControl.statusChanges\r\n        ?.pipe(map(v => v === 'INVALID'))\r\n        .subscribe(v => this._hasErrorInControl.set(v));\r\n\r\n      if (!this._ngControl.control) return;\r\n\r\n      runInInjectionContext(this._injector, () => {\r\n        // do not read the next line of code if you are easily frightened\r\n        // I'm not proud of this part, but it had to be done. God please forgive me\r\n        // I didn't find any other feasible way to detect when the control changes its touched state\r\n        // so it had to be hacked like this\r\n        toObservable((this._ngControl?.control as any | undefined)?.touchedReactive as Signal<boolean>)?.subscribe(v =>\r\n          this.wasTouched.set(v)\r\n        );\r\n      });\r\n    }\r\n  }\r\n  protected _ngControl: NgControl | null = null;\r\n\r\n  readonly htmlId = input<string>(Random.id());\r\n\r\n  readonly _hasError = input<boolean | undefined, any>(undefined, {\r\n    transform: v => coerceBooleanProperty(v),\r\n    alias: 'hasError',\r\n  });\r\n  private readonly _hasErrorInControl = signal<boolean>(false);\r\n  readonly hasError = computed<boolean>(() => this._hasError() ?? (this.wasTouched() && this._hasErrorInControl()));\r\n\r\n  ngOnDestroy(): void {\r\n    this._statusChangesSub?.unsubscribe();\r\n  }\r\n}\r\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngmodel-component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/_internal/ngmodel-component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  Directive,\r\n  inject,\r\n  Injector,\r\n  input,\r\n  OnDestroy,\r\n  OnInit,\r\n  runInInjectionContext,\r\n  Signal,\r\n  signal,\r\n} from '@angular/core';\r\nimport { toObservable } from '@angular/core/rxjs-interop';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\r\nimport { map, Subscription } from 'rxjs';\r\nimport { TakeChance as Random } from 'take-chance';\r\nimport { _FocusableComponentBase, _focusableComponentDefaults, _FocusableComponentDefaults } from './focusable-component';\r\n\r\nexport interface _NgModelComponentDefaults extends _FocusableComponentDefaults {\r\n  required: boolean | undefined;\r\n}\r\n\r\nexport const _ngModelComponentDefaults: _NgModelComponentDefaults = {\r\n  ..._focusableComponentDefaults,\r\n  required: undefined,\r\n};\r\n\r\n/**\r\n * Common code for components which implement the ControlValueAccessor.\r\n *\r\n * **Warning**: `writeValue` function should be implemented on the child component!\r\n */\r\n@Directive()\r\nexport abstract class _NgModelComponentBase extends _FocusableComponentBase implements ControlValueAccessor, OnInit, OnDestroy {\r\n  protected override readonly _DEFAULTS!: _NgModelComponentDefaults;\r\n\r\n  //! control value accessor\r\n  protected _onChangeRegistered!: (_: any) => void;\r\n  protected _onTouchedRegistered!: () => void;\r\n  /**\r\n   * Registers a function to handle touched state. Required by ControlValueAccessor.\r\n   * @param fn The function to register.\r\n   */\r\n  registerOnTouched(fn: () => void): void {\r\n    this._onTouchedRegistered = fn;\r\n  }\r\n  /**\r\n   * Registers a function to handle value change. Required by ControlValueAccessor.\r\n   * @param fn The function to register.\r\n   */\r\n  registerOnChange(fn: (_: any) => void): void {\r\n    this._onChangeRegistered = fn;\r\n  }\r\n  /**\r\n   * Sets the component's disabled state. Required by ControlValueAccessor.\r\n   * @param isDisabled the new disabled state.\r\n   */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled.set(isDisabled);\r\n  }\r\n\r\n  /**\r\n   * Writes the a new value into the component. Required by ControlValueAccessor.\r\n   * @abstract\r\n   * @param v The new value to write.\r\n   */\r\n  abstract writeValue(v: any): void; //* abstract\r\n\r\n  /**\r\n   * Writes the a new value into the component. Required by ControlValueAccessor.\r\n   * @abstract\r\n   * @param v The new value to write.\r\n   */\r\n  protected abstract _emitChange(): void; //* abstract\r\n\r\n  //! event handlers\r\n  readonly wasTouched = signal<boolean>(false);\r\n\r\n  override onFocus(event: FocusEvent): void {\r\n    super.onFocus(event);\r\n    this._shouldEmitTouched = false;\r\n  }\r\n\r\n  private _shouldEmitTouched = false;\r\n  override onBlur(event: FocusEvent) {\r\n    this._shouldEmitTouched = true;\r\n    super.onBlur(event);\r\n\r\n    setTimeout(() => {\r\n      if (!this._shouldEmitTouched) return;\r\n      this.wasTouched.set(true);\r\n      this._onTouchedRegistered?.();\r\n    }, 0);\r\n  }\r\n\r\n  //! form field related\r\n  protected readonly _injector = inject(Injector);\r\n\r\n  private _statusChangesSub?: Subscription;\r\n  ngOnInit(): void {\r\n    this._ngControl = this._injector.get(NgControl, null);\r\n\r\n    if (this._ngControl) {\r\n      if (!this._ngControl.valueAccessor || this && this instanceof (this._ngControl.valueAccessor as any).constructor) {\r\n        this._ngControl.valueAccessor = this;\r\n      }\r\n\r\n      this._hasErrorInControl.set(this._ngControl.status === 'INVALID');\r\n\r\n      this._statusChangesSub = this._ngControl.statusChanges\r\n        ?.pipe(map(v => v === 'INVALID'))\r\n        .subscribe(v => this._hasErrorInControl.set(v));\r\n\r\n      if (!this._ngControl.control) return;\r\n\r\n      runInInjectionContext(this._injector, () => {\r\n        // do not read the next line of code if you are easily frightened\r\n        // I'm not proud of this part, but it had to be done. God please forgive me\r\n        // I didn't find any other feasible way to detect when the control changes its touched state\r\n        // so it had to be hacked like this\r\n        toObservable((this._ngControl?.control as any | undefined)?.touchedReactive as Signal<boolean>)?.subscribe(v =>\r\n          this.wasTouched.set(v)\r\n        );\r\n      });\r\n    }\r\n  }\r\n  protected _ngControl: NgControl | null = null;\r\n\r\n  readonly htmlId = input<string>(Random.id());\r\n\r\n  readonly _hasError = input<boolean | undefined, any>(undefined, {\r\n    transform: v => coerceBooleanProperty(v),\r\n    alias: 'hasError',\r\n  });\r\n  private readonly _hasErrorInControl = signal<boolean>(false);\r\n  readonly hasError = computed<boolean>(() => this._hasError() ?? (this.wasTouched() && this._hasErrorInControl()));\r\n\r\n  ngOnDestroy(): void {\r\n    this._statusChangesSub?.unsubscribe();\r\n  }\r\n}\r\n"]}
@@ -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
  }
@@ -74,7 +76,8 @@ export class DigitInputModel {
74
76
  return this._writeValue(vArray);
75
77
  }
76
78
  _writeValue(v) {
77
- const isOldValueTheSame = this.value() ? this.value().every((ch, i) => ch === v?.[i]) : !v;
79
+ const isOldValueTheSame = this.value()?.length ? this.value().every((ch, i) => ch === v?.[i]) : !v?.length;
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()?.length ? this.value()!.every((ch, i) => ch === v?.[i]) : !v?.length;\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"]}
@@ -213,7 +213,7 @@ class _NgModelComponentBase extends _FocusableComponentBase {
213
213
  ngOnInit() {
214
214
  this._ngControl = this._injector.get(NgControl, null);
215
215
  if (this._ngControl) {
216
- if (!this._ngControl.valueAccessor || this instanceof this._ngControl.valueAccessor.constructor) {
216
+ if (!this._ngControl.valueAccessor || this && this instanceof this._ngControl.valueAccessor.constructor) {
217
217
  this._ngControl.valueAccessor = this;
218
218
  }
219
219
  this._hasErrorInControl.set(this._ngControl.status === 'INVALID');
@@ -407,11 +407,13 @@ class DigitInputModel {
407
407
  return !!this.value()?.[index];
408
408
  }
409
409
  writeValue(v) {
410
+ console.log('executing model writeValue', v, this._ardHost.outputAsString());
410
411
  if (this._ardHost.outputAsString()) {
411
412
  if (!isAnyString(v) && !isNull(v)) {
412
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.`);
413
414
  }
414
415
  const vArray = v?.split('') ?? [];
416
+ console.log('executing model writeValue - vArray', vArray, this._configArray());
415
417
  if (vArray.length > this._configArray().length) {
416
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.`);
417
419
  }
@@ -431,7 +433,8 @@ class DigitInputModel {
431
433
  return this._writeValue(vArray);
432
434
  }
433
435
  _writeValue(v) {
434
- const isOldValueTheSame = this.value() ? this.value().every((ch, i) => ch === v?.[i]) : !v;
436
+ const isOldValueTheSame = this.value()?.length ? this.value().every((ch, i) => ch === v?.[i]) : !v?.length;
437
+ console.log('executing model _writeValue', v, 'current value', this.value(), isOldValueTheSame);
435
438
  if (isOldValueTheSame)
436
439
  return false;
437
440
  this.value.set(v && v.map(el => el || null));
@@ -712,13 +715,17 @@ class ArdiumDigitInputComponent extends _FormFieldComponentBase {
712
715
  return !this.model.isDefinedAtIndex(index);
713
716
  }
714
717
  writeValue(v) {
718
+ console.log('writeValue', v, this._wasViewInit);
715
719
  if (!this._wasViewInit) {
716
720
  this._valueBeforeViewInit = v;
721
+ console.log('returning from writeValue');
717
722
  return;
718
723
  }
724
+ console.log('calling _writeValue with value', v);
719
725
  this._writeValue(v);
720
726
  }
721
727
  _writeValue(v) {
728
+ console.log('_writeValue', v);
722
729
  return this.model.writeValue(v);
723
730
  }
724
731
  ngAfterViewInit() {