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

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.
@@ -32,7 +32,6 @@ export class _FocusableComponentBase extends _DisablableComponentBase {
32
32
  * Whether the component is currently focused.
33
33
  */
34
34
  this.isFocused = signal(false);
35
- this.wasTouched = signal(false);
36
35
  }
37
36
  /**
38
37
  * Focuses the correct element in the component.
@@ -71,7 +70,6 @@ export class _FocusableComponentBase extends _DisablableComponentBase {
71
70
  * @param event The focus event to emit.
72
71
  */
73
72
  onBlur(event) {
74
- this.wasTouched.set(true);
75
73
  this.isFocused.set(false);
76
74
  this.blurEvent.emit(event);
77
75
  }
@@ -84,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
84
82
  type: ViewChildren,
85
83
  args: ['focusableElement']
86
84
  }] } });
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXNhYmxlLWNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvX2ludGVybmFsL2ZvY3VzYWJsZS1jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLE1BQU0sRUFBYSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hILE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSw0QkFBNEIsRUFBZ0MsTUFBTSx3QkFBd0IsQ0FBQzs7QUFLOUgsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQWdDO0lBQ3RFLEdBQUcsNEJBQTRCO0lBQy9CLFFBQVEsRUFBRSxDQUFDO0NBQ1osQ0FBQztBQUdGLE1BQU0sT0FBZ0IsdUJBQXdCLFNBQVEsd0JBQXdCO0lBRDlFOztRQWlDRSxZQUFZO1FBQ1o7O1dBRUc7UUFDTSxhQUFRLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNyRSxjQUFTLEdBQUcsS0FBSyxDQUFjLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFO1lBQy9ELEtBQUssRUFBRSxVQUFVO1lBQ2pCLFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLG9CQUFvQixDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDM0MsQ0FBQyxDQUFDO1FBRUgsVUFBVTtRQUNWOztXQUVHO1FBQ00sZUFBVSxHQUFHLE1BQU0sQ0FBYSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQzdEOztXQUVHO1FBQ00sY0FBUyxHQUFHLE1BQU0sQ0FBYSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO1FBRTNELHdCQUF3QjtRQUN4Qjs7V0FFRztRQUNNLGNBQVMsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7UUFFbkMsZUFBVSxHQUFHLE1BQU0sQ0FBVSxLQUFLLENBQUMsQ0FBQztLQW1COUM7SUF0RUM7O09BRUc7SUFDSSxLQUFLO1FBQ1YsSUFBSSxDQUFDLGlCQUFpQixFQUFFLEtBQUssRUFBRSxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDdkQsQ0FBQztJQUNEOztPQUVHO0lBQ0ksVUFBVTtRQUNmLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNmLENBQUM7SUFDRDs7T0FFRztJQUNJLFNBQVM7UUFDZCxJQUFJLENBQUMsaUJBQWlCLEVBQUUsSUFBSSxFQUFFLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN0RCxDQUFDO0lBQ0Q7O09BRUc7SUFDSSxJQUFJO1FBQ1QsSUFBSSxDQUFDLGlCQUFpQixFQUFFLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBOEJEOzs7T0FHRztJQUNILE9BQU8sQ0FBQyxLQUFpQjtRQUN2QixJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBQ0Q7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLEtBQWlCO1FBQ3RCLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFCLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzFCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzdCLENBQUM7K0dBNUVtQix1QkFBdUI7bUdBQXZCLHVCQUF1Qjs7NEZBQXZCLHVCQUF1QjtrQkFENUMsU0FBUzs4QkFNUyxpQkFBaUI7c0JBRGpDLFlBQVk7dUJBQUMsa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29tcHV0ZWQsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgaW5wdXQsIG91dHB1dCwgUXVlcnlMaXN0LCBzaWduYWwsIFZpZXdDaGlsZHJlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBjb2VyY2VOdW1iZXJQcm9wZXJ0eSB9IGZyb20gJ0BhcmRpdW0tdWkvZGV2a2l0JztcclxuaW1wb3J0IHsgX0Rpc2FibGFibGVDb21wb25lbnRCYXNlLCBfZGlzYWJsYWJsZUNvbXBvbmVudERlZmF1bHRzLCBfRGlzYWJsYWJsZUNvbXBvbmVudERlZmF1bHRzIH0gZnJvbSAnLi9kaXNhYmxhYmxlLWNvbXBvbmVudCc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIF9Gb2N1c2FibGVDb21wb25lbnREZWZhdWx0cyBleHRlbmRzIF9EaXNhYmxhYmxlQ29tcG9uZW50RGVmYXVsdHMge1xyXG4gIHRhYkluZGV4OiBudW1iZXI7XHJcbn1cclxuZXhwb3J0IGNvbnN0IF9mb2N1c2FibGVDb21wb25lbnREZWZhdWx0czogX0ZvY3VzYWJsZUNvbXBvbmVudERlZmF1bHRzID0ge1xyXG4gIC4uLl9kaXNhYmxhYmxlQ29tcG9uZW50RGVmYXVsdHMsXHJcbiAgdGFiSW5kZXg6IDAsXHJcbn07XHJcblxyXG5ARGlyZWN0aXZlKClcclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIF9Gb2N1c2FibGVDb21wb25lbnRCYXNlIGV4dGVuZHMgX0Rpc2FibGFibGVDb21wb25lbnRCYXNlIHtcclxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVhZG9ubHkgX0RFRkFVTFRTITogX0ZvY3VzYWJsZUNvbXBvbmVudERlZmF1bHRzO1xyXG5cclxuICAvLyEgbWFrZSB0aGUgY29tcG9uZW50IGZvY3VzYWJsZSBwcm9ncmFtbWF0aWNhbGx5XHJcbiAgQFZpZXdDaGlsZHJlbignZm9jdXNhYmxlRWxlbWVudCcpXHJcbiAgcHJpdmF0ZSByZWFkb25seSBfZm9jdXNhYmxlRWxlbWVudCE6IFF1ZXJ5TGlzdDxFbGVtZW50UmVmPEhUTUxFbGVtZW50Pj47XHJcblxyXG4gIC8qKlxyXG4gICAqIEZvY3VzZXMgdGhlIGNvcnJlY3QgZWxlbWVudCBpbiB0aGUgY29tcG9uZW50LlxyXG4gICAqL1xyXG4gIHB1YmxpYyBmb2N1cygpOiB2b2lkIHtcclxuICAgIHRoaXMuX2ZvY3VzYWJsZUVsZW1lbnQ/LmZpcnN0Py5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XHJcbiAgfVxyXG4gIC8qKlxyXG4gICAqIEZvY3VzZXMgdGhlIGZpcnN0IG9mIGFsbCBhdmFpbGFibGUgZWxlbWVudHMgaW4gdGhlIGNvbXBvbmVudC5cclxuICAgKi9cclxuICBwdWJsaWMgZm9jdXNGaXJzdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuZm9jdXMoKTtcclxuICB9XHJcbiAgLyoqXHJcbiAgICogRm9jdXNlcyB0aGUgbGFzdCBvZiBhbGwgYXZhaWxhYmxlIGVsZW1lbnRzIGluIHRoZSBjb21wb25lbnQuXHJcbiAgICovXHJcbiAgcHVibGljIGZvY3VzTGFzdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuX2ZvY3VzYWJsZUVsZW1lbnQ/Lmxhc3Q/Lm5hdGl2ZUVsZW1lbnQuZm9jdXMoKTtcclxuICB9XHJcbiAgLyoqXHJcbiAgICogQmx1cnMgYWxsIGZvY3VzYWJsZSBlbGVtZW50cyBpbiB0aGUgY29tcG9uZW50LlxyXG4gICAqL1xyXG4gIHB1YmxpYyBibHVyKCk6IHZvaWQge1xyXG4gICAgdGhpcy5fZm9jdXNhYmxlRWxlbWVudD8uZm9yRWFjaChlbCA9PiBlbC5uYXRpdmVFbGVtZW50LmJsdXIoKSk7XHJcbiAgfVxyXG5cclxuICAvLyEgdGFiaW5kZXhcclxuICAvKipcclxuICAgKiBUaGUgY29tcG9uZW50J3Mgb3ZlcmFsbCB0YWIgaW5kZXguIElmIHRoZSBjb21wb25lbnQgaXMgZGlzYWJsZWQsIGl0IGlzIGFsd2F5cyBgLTFgLiBDb2VyY2libGUgaW50byBhIG51bWJlciwgZGVmYXVsdHMgdG8gYDBgLlxyXG4gICAqL1xyXG4gIHJlYWRvbmx5IHRhYkluZGV4ID0gY29tcHV0ZWQoKCkgPT4gKHRoaXMuZGlzYWJsZWQoKSA/IC0xIDogdGhpcy5fdGFiSW5kZXgoKSkpO1xyXG4gIHJlYWRvbmx5IF90YWJJbmRleCA9IGlucHV0PG51bWJlciwgYW55Pih0aGlzLl9ERUZBVUxUUy50YWJJbmRleCwge1xyXG4gICAgYWxpYXM6ICd0YWJJbmRleCcsXHJcbiAgICB0cmFuc2Zvcm06IHYgPT4gY29lcmNlTnVtYmVyUHJvcGVydHkodiwgMCksXHJcbiAgfSk7XHJcblxyXG4gIC8vISBldmVudHNcclxuICAvKipcclxuICAgKiBUaGUgZXZlbnQgZW1pdHRlciByZXNwb25zaWJsZSBmb3IgZmlyaW5nIGBmb2N1c2AgZXZlbnRzLlxyXG4gICAqL1xyXG4gIHJlYWRvbmx5IGZvY3VzRXZlbnQgPSBvdXRwdXQ8Rm9jdXNFdmVudD4oeyBhbGlhczogJ2ZvY3VzJyB9KTtcclxuICAvKipcclxuICAgKiBUaGUgZXZlbnQgZW1pdHRlciByZXNwb25zaWJsZSBmb3IgZmlyaW5nIGBibHVyYCBldmVudHMuXHJcbiAgICovXHJcbiAgcmVhZG9ubHkgYmx1ckV2ZW50ID0gb3V0cHV0PEZvY3VzRXZlbnQ+KHsgYWxpYXM6ICdibHVyJyB9KTtcclxuXHJcbiAgLy8hIGZvY3VzIGV2ZW50IGhhbmRsZXJzXHJcbiAgLyoqXHJcbiAgICogV2hldGhlciB0aGUgY29tcG9uZW50IGlzIGN1cnJlbnRseSBmb2N1c2VkLlxyXG4gICAqL1xyXG4gIHJlYWRvbmx5IGlzRm9jdXNlZCA9IHNpZ25hbDxib29sZWFuPihmYWxzZSk7XHJcblxyXG4gIHJlYWRvbmx5IHdhc1RvdWNoZWQgPSBzaWduYWw8Ym9vbGVhbj4oZmFsc2UpO1xyXG5cclxuICAvKipcclxuICAgKiBGdW5jdGlvbiB0byBoYW5kbGUgd2hlbiBhbiBlbGVtZW50IGlzIGZvY3VzZWQuIFNldHMgYGlzRm9jdXNlZGAgYW5kIGZpcmVzIHRoZSBgZm9jdXNgIGV2ZW50LlxyXG4gICAqIEBwYXJhbSBldmVudCBUaGUgZm9jdXMgZXZlbnQgdG8gZW1pdC5cclxuICAgKi9cclxuICBvbkZvY3VzKGV2ZW50OiBGb2N1c0V2ZW50KSB7XHJcbiAgICB0aGlzLmlzRm9jdXNlZC5zZXQodHJ1ZSk7XHJcbiAgICB0aGlzLmZvY3VzRXZlbnQuZW1pdChldmVudCk7XHJcbiAgfVxyXG4gIC8qKlxyXG4gICAqIEZ1bmN0aW9uIHRvIGhhbmRsZSB3aGVuIGFuIGVsZW1lbnQgaXMgYmx1cnJlZC4gU2V0cyBgaXNGb2N1c2VkYCBhbmQgZmlyZXMgdGhlIGBibHVyYCBldmVudC5cclxuICAgKiBAcGFyYW0gZXZlbnQgVGhlIGZvY3VzIGV2ZW50IHRvIGVtaXQuXHJcbiAgICovXHJcbiAgb25CbHVyKGV2ZW50OiBGb2N1c0V2ZW50KSB7XHJcbiAgICB0aGlzLndhc1RvdWNoZWQuc2V0KHRydWUpO1xyXG4gICAgdGhpcy5pc0ZvY3VzZWQuc2V0KGZhbHNlKTtcclxuICAgIHRoaXMuYmx1ckV2ZW50LmVtaXQoZXZlbnQpO1xyXG4gIH1cclxufVxyXG4iXX0=
85
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXNhYmxlLWNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvX2ludGVybmFsL2ZvY3VzYWJsZS1jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLE1BQU0sRUFBYSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hILE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSw0QkFBNEIsRUFBZ0MsTUFBTSx3QkFBd0IsQ0FBQzs7QUFLOUgsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQWdDO0lBQ3RFLEdBQUcsNEJBQTRCO0lBQy9CLFFBQVEsRUFBRSxDQUFDO0NBQ1osQ0FBQztBQUdGLE1BQU0sT0FBZ0IsdUJBQXdCLFNBQVEsd0JBQXdCO0lBRDlFOztRQWlDRSxZQUFZO1FBQ1o7O1dBRUc7UUFDTSxhQUFRLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNyRSxjQUFTLEdBQUcsS0FBSyxDQUFjLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFO1lBQy9ELEtBQUssRUFBRSxVQUFVO1lBQ2pCLFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLG9CQUFvQixDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDM0MsQ0FBQyxDQUFDO1FBRUgsVUFBVTtRQUNWOztXQUVHO1FBQ00sZUFBVSxHQUFHLE1BQU0sQ0FBYSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQzdEOztXQUVHO1FBQ00sY0FBUyxHQUFHLE1BQU0sQ0FBYSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO1FBRTNELHdCQUF3QjtRQUN4Qjs7V0FFRztRQUNNLGNBQVMsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7S0FrQjdDO0lBbkVDOztPQUVHO0lBQ0ksS0FBSztRQUNWLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxLQUFLLEVBQUUsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3ZELENBQUM7SUFDRDs7T0FFRztJQUNJLFVBQVU7UUFDZixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDZixDQUFDO0lBQ0Q7O09BRUc7SUFDSSxTQUFTO1FBQ2QsSUFBSSxDQUFDLGlCQUFpQixFQUFFLElBQUksRUFBRSxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDdEQsQ0FBQztJQUNEOztPQUVHO0lBQ0ksSUFBSTtRQUNULElBQUksQ0FBQyxpQkFBaUIsRUFBRSxPQUFPLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7SUFDakUsQ0FBQztJQTRCRDs7O09BR0c7SUFDSCxPQUFPLENBQUMsS0FBaUI7UUFDdkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDekIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUNEOzs7T0FHRztJQUNILE1BQU0sQ0FBQyxLQUFpQjtRQUN0QixJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMxQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM3QixDQUFDOytHQXpFbUIsdUJBQXVCO21HQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBRDVDLFNBQVM7OEJBTVMsaUJBQWlCO3NCQURqQyxZQUFZO3VCQUFDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbXB1dGVkLCBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIGlucHV0LCBvdXRwdXQsIFF1ZXJ5TGlzdCwgc2lnbmFsLCBWaWV3Q2hpbGRyZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgY29lcmNlTnVtYmVyUHJvcGVydHkgfSBmcm9tICdAYXJkaXVtLXVpL2RldmtpdCc7XHJcbmltcG9ydCB7IF9EaXNhYmxhYmxlQ29tcG9uZW50QmFzZSwgX2Rpc2FibGFibGVDb21wb25lbnREZWZhdWx0cywgX0Rpc2FibGFibGVDb21wb25lbnREZWZhdWx0cyB9IGZyb20gJy4vZGlzYWJsYWJsZS1jb21wb25lbnQnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBfRm9jdXNhYmxlQ29tcG9uZW50RGVmYXVsdHMgZXh0ZW5kcyBfRGlzYWJsYWJsZUNvbXBvbmVudERlZmF1bHRzIHtcclxuICB0YWJJbmRleDogbnVtYmVyO1xyXG59XHJcbmV4cG9ydCBjb25zdCBfZm9jdXNhYmxlQ29tcG9uZW50RGVmYXVsdHM6IF9Gb2N1c2FibGVDb21wb25lbnREZWZhdWx0cyA9IHtcclxuICAuLi5fZGlzYWJsYWJsZUNvbXBvbmVudERlZmF1bHRzLFxyXG4gIHRhYkluZGV4OiAwLFxyXG59O1xyXG5cclxuQERpcmVjdGl2ZSgpXHJcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBfRm9jdXNhYmxlQ29tcG9uZW50QmFzZSBleHRlbmRzIF9EaXNhYmxhYmxlQ29tcG9uZW50QmFzZSB7XHJcbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlYWRvbmx5IF9ERUZBVUxUUyE6IF9Gb2N1c2FibGVDb21wb25lbnREZWZhdWx0cztcclxuXHJcbiAgLy8hIG1ha2UgdGhlIGNvbXBvbmVudCBmb2N1c2FibGUgcHJvZ3JhbW1hdGljYWxseVxyXG4gIEBWaWV3Q2hpbGRyZW4oJ2ZvY3VzYWJsZUVsZW1lbnQnKVxyXG4gIHByaXZhdGUgcmVhZG9ubHkgX2ZvY3VzYWJsZUVsZW1lbnQhOiBRdWVyeUxpc3Q8RWxlbWVudFJlZjxIVE1MRWxlbWVudD4+O1xyXG5cclxuICAvKipcclxuICAgKiBGb2N1c2VzIHRoZSBjb3JyZWN0IGVsZW1lbnQgaW4gdGhlIGNvbXBvbmVudC5cclxuICAgKi9cclxuICBwdWJsaWMgZm9jdXMoKTogdm9pZCB7XHJcbiAgICB0aGlzLl9mb2N1c2FibGVFbGVtZW50Py5maXJzdD8ubmF0aXZlRWxlbWVudC5mb2N1cygpO1xyXG4gIH1cclxuICAvKipcclxuICAgKiBGb2N1c2VzIHRoZSBmaXJzdCBvZiBhbGwgYXZhaWxhYmxlIGVsZW1lbnRzIGluIHRoZSBjb21wb25lbnQuXHJcbiAgICovXHJcbiAgcHVibGljIGZvY3VzRmlyc3QoKTogdm9pZCB7XHJcbiAgICB0aGlzLmZvY3VzKCk7XHJcbiAgfVxyXG4gIC8qKlxyXG4gICAqIEZvY3VzZXMgdGhlIGxhc3Qgb2YgYWxsIGF2YWlsYWJsZSBlbGVtZW50cyBpbiB0aGUgY29tcG9uZW50LlxyXG4gICAqL1xyXG4gIHB1YmxpYyBmb2N1c0xhc3QoKTogdm9pZCB7XHJcbiAgICB0aGlzLl9mb2N1c2FibGVFbGVtZW50Py5sYXN0Py5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XHJcbiAgfVxyXG4gIC8qKlxyXG4gICAqIEJsdXJzIGFsbCBmb2N1c2FibGUgZWxlbWVudHMgaW4gdGhlIGNvbXBvbmVudC5cclxuICAgKi9cclxuICBwdWJsaWMgYmx1cigpOiB2b2lkIHtcclxuICAgIHRoaXMuX2ZvY3VzYWJsZUVsZW1lbnQ/LmZvckVhY2goZWwgPT4gZWwubmF0aXZlRWxlbWVudC5ibHVyKCkpO1xyXG4gIH1cclxuXHJcbiAgLy8hIHRhYmluZGV4XHJcbiAgLyoqXHJcbiAgICogVGhlIGNvbXBvbmVudCdzIG92ZXJhbGwgdGFiIGluZGV4LiBJZiB0aGUgY29tcG9uZW50IGlzIGRpc2FibGVkLCBpdCBpcyBhbHdheXMgYC0xYC4gQ29lcmNpYmxlIGludG8gYSBudW1iZXIsIGRlZmF1bHRzIHRvIGAwYC5cclxuICAgKi9cclxuICByZWFkb25seSB0YWJJbmRleCA9IGNvbXB1dGVkKCgpID0+ICh0aGlzLmRpc2FibGVkKCkgPyAtMSA6IHRoaXMuX3RhYkluZGV4KCkpKTtcclxuICByZWFkb25seSBfdGFiSW5kZXggPSBpbnB1dDxudW1iZXIsIGFueT4odGhpcy5fREVGQVVMVFMudGFiSW5kZXgsIHtcclxuICAgIGFsaWFzOiAndGFiSW5kZXgnLFxyXG4gICAgdHJhbnNmb3JtOiB2ID0+IGNvZXJjZU51bWJlclByb3BlcnR5KHYsIDApLFxyXG4gIH0pO1xyXG5cclxuICAvLyEgZXZlbnRzXHJcbiAgLyoqXHJcbiAgICogVGhlIGV2ZW50IGVtaXR0ZXIgcmVzcG9uc2libGUgZm9yIGZpcmluZyBgZm9jdXNgIGV2ZW50cy5cclxuICAgKi9cclxuICByZWFkb25seSBmb2N1c0V2ZW50ID0gb3V0cHV0PEZvY3VzRXZlbnQ+KHsgYWxpYXM6ICdmb2N1cycgfSk7XHJcbiAgLyoqXHJcbiAgICogVGhlIGV2ZW50IGVtaXR0ZXIgcmVzcG9uc2libGUgZm9yIGZpcmluZyBgYmx1cmAgZXZlbnRzLlxyXG4gICAqL1xyXG4gIHJlYWRvbmx5IGJsdXJFdmVudCA9IG91dHB1dDxGb2N1c0V2ZW50Pih7IGFsaWFzOiAnYmx1cicgfSk7XHJcblxyXG4gIC8vISBmb2N1cyBldmVudCBoYW5kbGVyc1xyXG4gIC8qKlxyXG4gICAqIFdoZXRoZXIgdGhlIGNvbXBvbmVudCBpcyBjdXJyZW50bHkgZm9jdXNlZC5cclxuICAgKi9cclxuICByZWFkb25seSBpc0ZvY3VzZWQgPSBzaWduYWw8Ym9vbGVhbj4oZmFsc2UpO1xyXG5cclxuICAvKipcclxuICAgKiBGdW5jdGlvbiB0byBoYW5kbGUgd2hlbiBhbiBlbGVtZW50IGlzIGZvY3VzZWQuIFNldHMgYGlzRm9jdXNlZGAgYW5kIGZpcmVzIHRoZSBgZm9jdXNgIGV2ZW50LlxyXG4gICAqIEBwYXJhbSBldmVudCBUaGUgZm9jdXMgZXZlbnQgdG8gZW1pdC5cclxuICAgKi9cclxuICBvbkZvY3VzKGV2ZW50OiBGb2N1c0V2ZW50KSB7XHJcbiAgICB0aGlzLmlzRm9jdXNlZC5zZXQodHJ1ZSk7XHJcbiAgICB0aGlzLmZvY3VzRXZlbnQuZW1pdChldmVudCk7XHJcbiAgfVxyXG4gIC8qKlxyXG4gICAqIEZ1bmN0aW9uIHRvIGhhbmRsZSB3aGVuIGFuIGVsZW1lbnQgaXMgYmx1cnJlZC4gU2V0cyBgaXNGb2N1c2VkYCBhbmQgZmlyZXMgdGhlIGBibHVyYCBldmVudC5cclxuICAgKiBAcGFyYW0gZXZlbnQgVGhlIGZvY3VzIGV2ZW50IHRvIGVtaXQuXHJcbiAgICovXHJcbiAgb25CbHVyKGV2ZW50OiBGb2N1c0V2ZW50KSB7XHJcbiAgICB0aGlzLmlzRm9jdXNlZC5zZXQoZmFsc2UpO1xyXG4gICAgdGhpcy5ibHVyRXZlbnQuZW1pdChldmVudCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -18,6 +18,9 @@ export const _ngModelComponentDefaults = {
18
18
  export class _NgModelComponentBase extends _FocusableComponentBase {
19
19
  constructor() {
20
20
  super(...arguments);
21
+ //! event handlers
22
+ this.wasTouched = signal(false);
23
+ this._shouldEmitTouched = false;
21
24
  //! form field related
22
25
  this._injector = inject(Injector);
23
26
  this._ngControl = null;
@@ -50,10 +53,19 @@ export class _NgModelComponentBase extends _FocusableComponentBase {
50
53
  setDisabledState(isDisabled) {
51
54
  this.disabled.set(isDisabled);
52
55
  }
53
- //! event handlers
56
+ onFocus(event) {
57
+ super.onFocus(event);
58
+ this._shouldEmitTouched = false;
59
+ }
54
60
  onBlur(event) {
61
+ this._shouldEmitTouched = true;
55
62
  super.onBlur(event);
56
- this._onTouchedRegistered?.();
63
+ setTimeout(() => {
64
+ if (!this._shouldEmitTouched)
65
+ return;
66
+ this.wasTouched.set(true);
67
+ this._onTouchedRegistered?.();
68
+ }, 0);
57
69
  }
58
70
  ngOnInit() {
59
71
  this._ngControl = this._injector.get(NgControl, null);
@@ -83,4 +95,4 @@ export class _NgModelComponentBase extends _FocusableComponentBase {
83
95
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: _NgModelComponentBase, decorators: [{
84
96
  type: Directive
85
97
  }] });
86
- //# 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  override onBlur(event: FocusEvent) {\r\n    super.onBlur(event);\r\n    this._onTouchedRegistered?.();\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      this._ngControl.valueAccessor = this;\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"]}
98
+ //# 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      this._ngControl.valueAccessor = this;\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"]}
@@ -95,20 +95,17 @@ export class ArdiumDigitInputComponent extends _FormFieldComponentBase {
95
95
  this.focusByIndex(index - 1 + Math.min(value.length, maxLength));
96
96
  }
97
97
  onInput(event, index) {
98
- const wasChanged = this._updateSingleInputValue(event.target.value, index);
99
- if (!wasChanged)
100
- return;
98
+ this._updateSingleInputValue(event.target.value, index);
101
99
  this.focusByIndex(index + 1);
102
100
  }
103
101
  _updateSingleInputValue(value, index) {
104
102
  const changeResult = this.model.validateInputAndSetValue(value, index);
105
103
  if (!changeResult?.wasChanged)
106
- return false;
104
+ return;
107
105
  this._emitChange();
108
106
  if (this.model.isValueFull()) {
109
107
  this.blur();
110
108
  }
111
- return true;
112
109
  }
113
110
  focusByIndex(index, tryFocusingNext, direction) {
114
111
  if (index < 0 || index >= this.inputs().length)
@@ -194,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
194
191
  }] }], propDecorators: { value: [{
195
192
  type: Input
196
193
  }] } });
197
- //# 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 {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  Input,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  computed,\r\n  effect,\r\n  forwardRef,\r\n  input,\r\n  output,\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 { _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 { DigitInputConfig, DigitInputShape } 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\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  //! inputs ref\r\n  readonly inputs = viewChildren<ElementRef<HTMLInputElement>>('input');\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    ].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  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\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    const maxLength = this.inputs().length - index;\r\n    value\r\n      .slice(0, maxLength)\r\n      .split('')\r\n      .forEach((char, i) => {\r\n        this.model.validateInputAndSetValue(char, index + i);\r\n      });\r\n    this.focusByIndex(index - 1 + Math.min(value.length, maxLength));\r\n  }\r\n  onInput(event: Event, index: number): void {\r\n    const wasChanged = this._updateSingleInputValue((event.target as HTMLInputElement).value, index);\r\n    if (!wasChanged) return;\r\n    this.focusByIndex(index + 1);\r\n  }\r\n  private _updateSingleInputValue(value: string, index: number): boolean {\r\n    const changeResult = this.model.validateInputAndSetValue(value, index);\r\n    if (!changeResult?.wasChanged) return false;\r\n\r\n    this._emitChange();\r\n\r\n    if (this.model.isValueFull()) {\r\n      this.blur();\r\n    }\r\n    return true;\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    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    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      autocomplete=\"off\"\r\n      [readonly]=\"data.readonly\"\r\n      [placeholder]=\"data.placeholder\"\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    }\r\n  </div>\r\n  }\r\n</div>\r\n"]}
194
+ //# 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 {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  Inject,\r\n  Input,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  computed,\r\n  effect,\r\n  forwardRef,\r\n  input,\r\n  output,\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 { _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 { DigitInputConfig, DigitInputShape } 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\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  //! inputs ref\r\n  readonly inputs = viewChildren<ElementRef<HTMLInputElement>>('input');\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    ].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  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\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    const maxLength = this.inputs().length - index;\r\n    value\r\n      .slice(0, maxLength)\r\n      .split('')\r\n      .forEach((char, i) => {\r\n        this.model.validateInputAndSetValue(char, index + i);\r\n      });\r\n    this.focusByIndex(index - 1 + Math.min(value.length, maxLength));\r\n  }\r\n  onInput(event: Event, index: number): void {\r\n    this._updateSingleInputValue((event.target as HTMLInputElement).value, index);\r\n    this.focusByIndex(index + 1);\r\n  }\r\n  private _updateSingleInputValue(value: string, index: number): void {\r\n    const changeResult = this.model.validateInputAndSetValue(value, index);\r\n    if (!changeResult?.wasChanged) return;\r\n\r\n    this._emitChange();\r\n\r\n    if (this.model.isValueFull()) {\r\n      this.blur();\r\n    }\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    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    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      autocomplete=\"off\"\r\n      [readonly]=\"data.readonly\"\r\n      [placeholder]=\"data.placeholder\"\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    }\r\n  </div>\r\n  }\r\n</div>\r\n"]}
@@ -97,7 +97,6 @@ class _FocusableComponentBase extends _DisablableComponentBase {
97
97
  * Whether the component is currently focused.
98
98
  */
99
99
  this.isFocused = signal(false);
100
- this.wasTouched = signal(false);
101
100
  }
102
101
  /**
103
102
  * Focuses the correct element in the component.
@@ -136,7 +135,6 @@ class _FocusableComponentBase extends _DisablableComponentBase {
136
135
  * @param event The focus event to emit.
137
136
  */
138
137
  onBlur(event) {
139
- this.wasTouched.set(true);
140
138
  this.isFocused.set(false);
141
139
  this.blurEvent.emit(event);
142
140
  }
@@ -162,6 +160,9 @@ const _ngModelComponentDefaults = {
162
160
  class _NgModelComponentBase extends _FocusableComponentBase {
163
161
  constructor() {
164
162
  super(...arguments);
163
+ //! event handlers
164
+ this.wasTouched = signal(false);
165
+ this._shouldEmitTouched = false;
165
166
  //! form field related
166
167
  this._injector = inject(Injector);
167
168
  this._ngControl = null;
@@ -194,10 +195,19 @@ class _NgModelComponentBase extends _FocusableComponentBase {
194
195
  setDisabledState(isDisabled) {
195
196
  this.disabled.set(isDisabled);
196
197
  }
197
- //! event handlers
198
+ onFocus(event) {
199
+ super.onFocus(event);
200
+ this._shouldEmitTouched = false;
201
+ }
198
202
  onBlur(event) {
203
+ this._shouldEmitTouched = true;
199
204
  super.onBlur(event);
200
- this._onTouchedRegistered?.();
205
+ setTimeout(() => {
206
+ if (!this._shouldEmitTouched)
207
+ return;
208
+ this.wasTouched.set(true);
209
+ this._onTouchedRegistered?.();
210
+ }, 0);
201
211
  }
202
212
  ngOnInit() {
203
213
  this._ngControl = this._injector.get(NgControl, null);
@@ -650,20 +660,17 @@ class ArdiumDigitInputComponent extends _FormFieldComponentBase {
650
660
  this.focusByIndex(index - 1 + Math.min(value.length, maxLength));
651
661
  }
652
662
  onInput(event, index) {
653
- const wasChanged = this._updateSingleInputValue(event.target.value, index);
654
- if (!wasChanged)
655
- return;
663
+ this._updateSingleInputValue(event.target.value, index);
656
664
  this.focusByIndex(index + 1);
657
665
  }
658
666
  _updateSingleInputValue(value, index) {
659
667
  const changeResult = this.model.validateInputAndSetValue(value, index);
660
668
  if (!changeResult?.wasChanged)
661
- return false;
669
+ return;
662
670
  this._emitChange();
663
671
  if (this.model.isValueFull()) {
664
672
  this.blur();
665
673
  }
666
- return true;
667
674
  }
668
675
  focusByIndex(index, tryFocusingNext, direction) {
669
676
  if (index < 0 || index >= this.inputs().length)