@ardium-ui/ui 3.2.7 → 3.3.0-alpha1

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.
Files changed (103) hide show
  1. package/esm2022/lib/_internal/boolean-component.mjs +1 -1
  2. package/esm2022/lib/_internal/focusable-component.mjs +2 -2
  3. package/esm2022/lib/_internal/form-field-component.mjs +55 -0
  4. package/esm2022/lib/_internal/item-storages/dropdown-item-storage.mjs +4 -1
  5. package/esm2022/lib/_internal/ngmodel-component.mjs +5 -2
  6. package/esm2022/lib/_internal/public-api.mjs +2 -0
  7. package/esm2022/lib/checkbox/checkbox.component.mjs +1 -1
  8. package/esm2022/lib/file-inputs/file-input/file-input.component.mjs +1 -1
  9. package/esm2022/lib/form-field/error/error.component.mjs +17 -0
  10. package/esm2022/lib/form-field/error/error.directive.mjs +17 -0
  11. package/esm2022/lib/form-field/form-field.component.mjs +36 -0
  12. package/esm2022/lib/form-field/form-field.defaults.mjs +14 -0
  13. package/esm2022/lib/form-field/form-field.module.mjs +23 -0
  14. package/esm2022/lib/form-field/hint/hint.component.mjs +17 -0
  15. package/esm2022/lib/form-field/hint/hint.directive.mjs +30 -0
  16. package/esm2022/lib/form-field/index.mjs +8 -0
  17. package/esm2022/lib/form-field/label/label.component.mjs +21 -0
  18. package/esm2022/lib/form-field-frame/form-field-frame.component.mjs +4 -2
  19. package/esm2022/lib/inputs/_simple-input-base.mjs +4 -4
  20. package/esm2022/lib/inputs/digit-input/digit-input.component.mjs +28 -11
  21. package/esm2022/lib/inputs/digit-input/digit-input.defaults.mjs +3 -3
  22. package/esm2022/lib/inputs/digit-input/digit-input.model.mjs +5 -3
  23. package/esm2022/lib/inputs/digit-input/digit-input.types.mjs +1 -1
  24. package/esm2022/lib/inputs/digit-input/digit-input.utils.mjs +1 -1
  25. package/esm2022/lib/inputs/hex-input/hex-input.component.mjs +13 -5
  26. package/esm2022/lib/inputs/hex-input/hex-input.defaults.mjs +3 -3
  27. package/esm2022/lib/inputs/input/input.component.mjs +12 -3
  28. package/esm2022/lib/inputs/number-input/number-input.component.mjs +15 -7
  29. package/esm2022/lib/inputs/number-input/number-input.defaults.mjs +3 -3
  30. package/esm2022/lib/inputs/password-input/password-input.component.mjs +15 -5
  31. package/esm2022/lib/inputs/password-input/password-input.defaults.mjs +3 -3
  32. package/esm2022/lib/inputs/simple-input/simple-input.component.mjs +12 -3
  33. package/esm2022/lib/inputs/simple-input/simple-input.defaults.mjs +3 -3
  34. package/esm2022/lib/select/select.component.mjs +16 -8
  35. package/esm2022/lib/select/select.defaults.mjs +3 -3
  36. package/esm2022/lib/slide-toggle/slide-toggle.component.mjs +1 -1
  37. package/esm2022/lib/table-pagination/table-pagination.component.mjs +1 -1
  38. package/esm2022/public-api.mjs +3 -1
  39. package/fesm2022/ardium-ui-ui.mjs +315 -49
  40. package/fesm2022/ardium-ui-ui.mjs.map +1 -1
  41. package/lib/_internal/focusable-component.d.ts +2 -2
  42. package/lib/_internal/form-field-component.d.ts +29 -0
  43. package/lib/_internal/ngmodel-component.d.ts +1 -0
  44. package/lib/_internal/public-api.d.ts +3 -0
  45. package/lib/form-field/error/error.component.d.ts +6 -0
  46. package/lib/form-field/error/error.directive.d.ts +5 -0
  47. package/lib/form-field/form-field.component.d.ts +19 -0
  48. package/lib/form-field/form-field.defaults.d.ts +7 -0
  49. package/lib/form-field/form-field.module.d.ts +13 -0
  50. package/lib/form-field/hint/hint.component.d.ts +6 -0
  51. package/lib/form-field/hint/hint.directive.d.ts +8 -0
  52. package/lib/form-field/index.d.ts +7 -0
  53. package/lib/form-field/label/label.component.d.ts +8 -0
  54. package/lib/form-field-frame/form-field-frame.component.d.ts +2 -1
  55. package/lib/inputs/_simple-input-base.d.ts +3 -3
  56. package/lib/inputs/digit-input/digit-input.component.d.ts +6 -4
  57. package/lib/inputs/digit-input/digit-input.defaults.d.ts +2 -2
  58. package/lib/inputs/digit-input/digit-input.model.d.ts +4 -1
  59. package/lib/inputs/digit-input/digit-input.types.d.ts +1 -0
  60. package/lib/inputs/digit-input/digit-input.utils.d.ts +1 -0
  61. package/lib/inputs/hex-input/hex-input.component.d.ts +2 -2
  62. package/lib/inputs/hex-input/hex-input.defaults.d.ts +2 -2
  63. package/lib/inputs/number-input/number-input.component.d.ts +2 -2
  64. package/lib/inputs/number-input/number-input.defaults.d.ts +2 -2
  65. package/lib/inputs/password-input/password-input.component.d.ts +2 -2
  66. package/lib/inputs/password-input/password-input.defaults.d.ts +2 -2
  67. package/lib/select/select.component.d.ts +3 -4
  68. package/lib/select/select.defaults.d.ts +2 -2
  69. package/package.json +1 -1
  70. package/prebuilt-themes/default/chips.css.map +1 -1
  71. package/prebuilt-themes/default/core.css +1 -1
  72. package/prebuilt-themes/default/form-field-frame.css +16 -5
  73. package/prebuilt-themes/default/form-field-frame.css.map +1 -1
  74. package/prebuilt-themes/default/form-field.css +33 -0
  75. package/prebuilt-themes/default/form-field.css.map +1 -0
  76. package/prebuilt-themes/default/inputs/color-input.css +0 -1
  77. package/prebuilt-themes/default/inputs/color-input.css.map +1 -1
  78. package/prebuilt-themes/default/inputs/digit-input.css +61 -5
  79. package/prebuilt-themes/default/inputs/digit-input.css.map +1 -1
  80. package/prebuilt-themes/default/inputs/file-input.css +0 -1
  81. package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
  82. package/prebuilt-themes/default/inputs/hex-input.css +0 -1
  83. package/prebuilt-themes/default/inputs/hex-input.css.map +1 -1
  84. package/prebuilt-themes/default/inputs/input.css +0 -1
  85. package/prebuilt-themes/default/inputs/input.css.map +1 -1
  86. package/prebuilt-themes/default/inputs/number-input.css +30 -18
  87. package/prebuilt-themes/default/inputs/number-input.css.map +1 -1
  88. package/prebuilt-themes/default/inputs/password-input.css +0 -1
  89. package/prebuilt-themes/default/inputs/password-input.css.map +1 -1
  90. package/prebuilt-themes/default/inputs/search-bar.css +0 -1
  91. package/prebuilt-themes/default/inputs/search-bar.css.map +1 -1
  92. package/prebuilt-themes/default/inputs/simple-input.css +0 -1
  93. package/prebuilt-themes/default/inputs/simple-input.css.map +1 -1
  94. package/prebuilt-themes/default/segment.css +15 -1
  95. package/prebuilt-themes/default/segment.css.map +1 -1
  96. package/public-api.d.ts +2 -0
  97. package/themes/default/_mixins.scss +81 -64
  98. package/themes/default/core.scss +99 -99
  99. package/themes/default/form-field-frame.scss +75 -78
  100. package/themes/default/form-field.scss +39 -0
  101. package/themes/default/inputs/_shared.scss +50 -51
  102. package/themes/default/inputs/digit-input.scss +90 -56
  103. package/themes/default/inputs/number-input.scss +131 -121
@@ -0,0 +1,36 @@
1
+ import { ChangeDetectionStrategy, Component, computed, contentChild, contentChildren, inject, ViewEncapsulation } from '@angular/core';
2
+ import { _FormFieldComponentBase } from '../_internal/form-field-component';
3
+ import { SimpleOneAxisAlignment } from './../types/alignment.types';
4
+ import { ArdiumErrorDirective } from './error/error.directive';
5
+ import { ARD_FORM_FIELD_DEFAULTS } from './form-field.defaults';
6
+ import { ArdiumHintDirective } from './hint/hint.directive';
7
+ import { ArdiumLabelComponent } from './label/label.component';
8
+ import * as i0 from "@angular/core";
9
+ export class ArdiumFormFieldComponent {
10
+ constructor() {
11
+ this._DEFAULTS = inject(ARD_FORM_FIELD_DEFAULTS);
12
+ this.alignLabelToLeftByDefault = this._DEFAULTS.defaultHintAlign === SimpleOneAxisAlignment.Left;
13
+ this.control = contentChild(_FormFieldComponentBase);
14
+ this.controlId = computed(() => this.control()?.htmlId());
15
+ this.label = contentChild(ArdiumLabelComponent);
16
+ this.hints = contentChildren(ArdiumHintDirective);
17
+ // readonly leftHints = computed<ArdiumHintDirective[]>(() => this.hints().filter(v => v.left() && !v.right()));
18
+ // readonly rightHints = computed<ArdiumHintDirective[]>(() => this.hints().filter(v => !v.left() && v.right()));
19
+ this.errors = contentChildren(ArdiumErrorDirective);
20
+ // readonly leftErrors = computed<ArdiumErrorDirective[]>(() => this.errors().filter(v => v.left() && !v.right()));
21
+ // readonly rightErrors = computed<ArdiumErrorDirective[]>(() => this.errors().filter(v => !v.left() && v.right()));
22
+ this.hasAnyError = computed(() => this.errors()?.length > 0);
23
+ }
24
+ ngOnInit() {
25
+ if (!this.control()) {
26
+ throw new Error(`ARD-FT5110: Form field component requires any control (input) to be present within the element. Found none.`);
27
+ }
28
+ }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumFormFieldComponent, selector: "ard-form-field", queries: [{ propertyName: "control", first: true, predicate: _FormFieldComponentBase, descendants: true, isSignal: true }, { propertyName: "label", first: true, predicate: ArdiumLabelComponent, descendants: true, isSignal: true }, { propertyName: "hints", predicate: ArdiumHintDirective, isSignal: true }, { propertyName: "errors", predicate: ArdiumErrorDirective, isSignal: true }], ngImport: i0, template: "<div class=\"ard-form-field\" [class.ard-form-field__with-error]=\"control()?.hasError()\">\r\n <label\r\n class=\"ard-label\"\r\n [attr.for]=\"controlId()\"\r\n >\r\n <ng-content select=\"ard-label, [ard-label]\" />\r\n </label>\r\n <div class=\"ard-form-field__input\">\r\n <ng-content />\r\n </div>\r\n <div\r\n class=\"ard-form-field__hints\"\r\n [class.ard-form-field__hints-default-left]=\"alignLabelToLeftByDefault\"\r\n >\r\n @if (hasAnyError()) {\r\n <div class=\"ard-form-field__error\">\r\n <ng-content select=\"ard-error, [ard-error]\" />\r\n </div>\r\n } @else {\r\n <div class=\"ard-form-field__hints-left\">\r\n <div class=\"ard-form-field__default-hint\">\r\n <ng-content select=\"ard-hint:not([left]):not([right]), [ard-hint]:not([left]):not([right])\" />\r\n </div>\r\n <ng-content select=\"ard-hint[left], [ard-hint][left]\" />\r\n </div>\r\n <div class=\"ard-form-field__hints-right\">\r\n <div class=\"ard-form-field__default-hint\">\r\n <ng-content select=\"ard-hint:not([left]):not([right]), [ard-hint]:not([left]):not([right])\" />\r\n </div>\r\n <ng-content select=\"ard-hint[right], [ard-hint][right]\" />\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".ard-form-field__hints{display:flex;justify-content:space-between}.ard-form-field__hints>*{display:flex;flex-direction:column}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
31
+ }
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFormFieldComponent, decorators: [{
33
+ type: Component,
34
+ args: [{ selector: 'ard-form-field', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ard-form-field\" [class.ard-form-field__with-error]=\"control()?.hasError()\">\r\n <label\r\n class=\"ard-label\"\r\n [attr.for]=\"controlId()\"\r\n >\r\n <ng-content select=\"ard-label, [ard-label]\" />\r\n </label>\r\n <div class=\"ard-form-field__input\">\r\n <ng-content />\r\n </div>\r\n <div\r\n class=\"ard-form-field__hints\"\r\n [class.ard-form-field__hints-default-left]=\"alignLabelToLeftByDefault\"\r\n >\r\n @if (hasAnyError()) {\r\n <div class=\"ard-form-field__error\">\r\n <ng-content select=\"ard-error, [ard-error]\" />\r\n </div>\r\n } @else {\r\n <div class=\"ard-form-field__hints-left\">\r\n <div class=\"ard-form-field__default-hint\">\r\n <ng-content select=\"ard-hint:not([left]):not([right]), [ard-hint]:not([left]):not([right])\" />\r\n </div>\r\n <ng-content select=\"ard-hint[left], [ard-hint][left]\" />\r\n </div>\r\n <div class=\"ard-form-field__hints-right\">\r\n <div class=\"ard-form-field__default-hint\">\r\n <ng-content select=\"ard-hint:not([left]):not([right]), [ard-hint]:not([left]):not([right])\" />\r\n </div>\r\n <ng-content select=\"ard-hint[right], [ard-hint][right]\" />\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".ard-form-field__hints{display:flex;justify-content:space-between}.ard-form-field__hints>*{display:flex;flex-direction:column}\n"] }]
35
+ }] });
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQvZm9ybS1maWVsZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQvZm9ybS1maWVsZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxRQUFRLEVBQ1IsWUFBWSxFQUNaLGVBQWUsRUFDZixNQUFNLEVBRU4saUJBQWlCLEVBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQy9ELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQVMvRCxNQUFNLE9BQU8sd0JBQXdCO0lBUHJDO1FBUXFCLGNBQVMsR0FBRyxNQUFNLENBQUMsdUJBQXVCLENBQUMsQ0FBQztRQUUvQyw4QkFBeUIsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGdCQUFnQixLQUFLLHNCQUFzQixDQUFDLElBQUksQ0FBQztRQUVuRyxZQUFPLEdBQUcsWUFBWSxDQUEwQix1QkFBdUIsQ0FBQyxDQUFDO1FBQ3pFLGNBQVMsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7UUFFckQsVUFBSyxHQUFHLFlBQVksQ0FBdUIsb0JBQW9CLENBQUMsQ0FBQztRQUVqRSxVQUFLLEdBQUcsZUFBZSxDQUFzQixtQkFBbUIsQ0FBQyxDQUFDO1FBQzNFLGdIQUFnSDtRQUNoSCxpSEFBaUg7UUFFeEcsV0FBTSxHQUFHLGVBQWUsQ0FBdUIsb0JBQW9CLENBQUMsQ0FBQztRQUM5RSxtSEFBbUg7UUFDbkgsb0hBQW9IO1FBRTNHLGdCQUFXLEdBQUcsUUFBUSxDQUFVLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUM7S0FTM0U7SUFQQyxRQUFRO1FBQ04sSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDO1lBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQ2IsNkdBQTZHLENBQzlHLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQzsrR0ExQlUsd0JBQXdCO21HQUF4Qix3QkFBd0IsMkZBS3NCLHVCQUF1Qix3RkFHNUIsb0JBQW9CLDJFQUVsQixtQkFBbUIseURBSWpCLG9CQUFvQiw2Q0N0QzlFLDZ2Q0FrQ0E7OzRGRFZhLHdCQUF3QjtrQkFQcEMsU0FBUzsrQkFDRSxnQkFBZ0IsaUJBR1gsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgQ29tcG9uZW50LFxyXG4gIGNvbXB1dGVkLFxyXG4gIGNvbnRlbnRDaGlsZCxcclxuICBjb250ZW50Q2hpbGRyZW4sXHJcbiAgaW5qZWN0LFxyXG4gIE9uSW5pdCxcclxuICBWaWV3RW5jYXBzdWxhdGlvblxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBfRm9ybUZpZWxkQ29tcG9uZW50QmFzZSB9IGZyb20gJy4uL19pbnRlcm5hbC9mb3JtLWZpZWxkLWNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFNpbXBsZU9uZUF4aXNBbGlnbm1lbnQgfSBmcm9tICcuLy4uL3R5cGVzL2FsaWdubWVudC50eXBlcyc7XHJcbmltcG9ydCB7IEFyZGl1bUVycm9yRGlyZWN0aXZlIH0gZnJvbSAnLi9lcnJvci9lcnJvci5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBBUkRfRk9STV9GSUVMRF9ERUZBVUxUUyB9IGZyb20gJy4vZm9ybS1maWVsZC5kZWZhdWx0cyc7XHJcbmltcG9ydCB7IEFyZGl1bUhpbnREaXJlY3RpdmUgfSBmcm9tICcuL2hpbnQvaGludC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBBcmRpdW1MYWJlbENvbXBvbmVudCB9IGZyb20gJy4vbGFiZWwvbGFiZWwuY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXJkLWZvcm0tZmllbGQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9mb3JtLWZpZWxkLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vZm9ybS1maWVsZC5jb21wb25lbnQuc2NzcycsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFyZGl1bUZvcm1GaWVsZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IF9ERUZBVUxUUyA9IGluamVjdChBUkRfRk9STV9GSUVMRF9ERUZBVUxUUyk7XHJcblxyXG4gIHB1YmxpYyByZWFkb25seSBhbGlnbkxhYmVsVG9MZWZ0QnlEZWZhdWx0ID0gdGhpcy5fREVGQVVMVFMuZGVmYXVsdEhpbnRBbGlnbiA9PT0gU2ltcGxlT25lQXhpc0FsaWdubWVudC5MZWZ0O1xyXG5cclxuICByZWFkb25seSBjb250cm9sID0gY29udGVudENoaWxkPF9Gb3JtRmllbGRDb21wb25lbnRCYXNlPihfRm9ybUZpZWxkQ29tcG9uZW50QmFzZSk7XHJcbiAgcmVhZG9ubHkgY29udHJvbElkID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5jb250cm9sKCk/Lmh0bWxJZCgpKTtcclxuXHJcbiAgcmVhZG9ubHkgbGFiZWwgPSBjb250ZW50Q2hpbGQ8QXJkaXVtTGFiZWxDb21wb25lbnQ+KEFyZGl1bUxhYmVsQ29tcG9uZW50KTtcclxuXHJcbiAgcmVhZG9ubHkgaGludHMgPSBjb250ZW50Q2hpbGRyZW48QXJkaXVtSGludERpcmVjdGl2ZT4oQXJkaXVtSGludERpcmVjdGl2ZSk7XHJcbiAgLy8gcmVhZG9ubHkgbGVmdEhpbnRzID0gY29tcHV0ZWQ8QXJkaXVtSGludERpcmVjdGl2ZVtdPigoKSA9PiB0aGlzLmhpbnRzKCkuZmlsdGVyKHYgPT4gdi5sZWZ0KCkgJiYgIXYucmlnaHQoKSkpO1xyXG4gIC8vIHJlYWRvbmx5IHJpZ2h0SGludHMgPSBjb21wdXRlZDxBcmRpdW1IaW50RGlyZWN0aXZlW10+KCgpID0+IHRoaXMuaGludHMoKS5maWx0ZXIodiA9PiAhdi5sZWZ0KCkgJiYgdi5yaWdodCgpKSk7XHJcblxyXG4gIHJlYWRvbmx5IGVycm9ycyA9IGNvbnRlbnRDaGlsZHJlbjxBcmRpdW1FcnJvckRpcmVjdGl2ZT4oQXJkaXVtRXJyb3JEaXJlY3RpdmUpO1xyXG4gIC8vIHJlYWRvbmx5IGxlZnRFcnJvcnMgPSBjb21wdXRlZDxBcmRpdW1FcnJvckRpcmVjdGl2ZVtdPigoKSA9PiB0aGlzLmVycm9ycygpLmZpbHRlcih2ID0+IHYubGVmdCgpICYmICF2LnJpZ2h0KCkpKTtcclxuICAvLyByZWFkb25seSByaWdodEVycm9ycyA9IGNvbXB1dGVkPEFyZGl1bUVycm9yRGlyZWN0aXZlW10+KCgpID0+IHRoaXMuZXJyb3JzKCkuZmlsdGVyKHYgPT4gIXYubGVmdCgpICYmIHYucmlnaHQoKSkpO1xyXG5cclxuICByZWFkb25seSBoYXNBbnlFcnJvciA9IGNvbXB1dGVkPGJvb2xlYW4+KCgpID0+IHRoaXMuZXJyb3JzKCk/Lmxlbmd0aCA+IDApO1xyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIGlmICghdGhpcy5jb250cm9sKCkpIHtcclxuICAgICAgdGhyb3cgbmV3IEVycm9yKFxyXG4gICAgICAgIGBBUkQtRlQ1MTEwOiBGb3JtIGZpZWxkIGNvbXBvbmVudCByZXF1aXJlcyBhbnkgY29udHJvbCAoaW5wdXQpIHRvIGJlIHByZXNlbnQgd2l0aGluIHRoZSBlbGVtZW50LiBGb3VuZCBub25lLmBcclxuICAgICAgKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImFyZC1mb3JtLWZpZWxkXCIgW2NsYXNzLmFyZC1mb3JtLWZpZWxkX193aXRoLWVycm9yXT1cImNvbnRyb2woKT8uaGFzRXJyb3IoKVwiPlxyXG4gIDxsYWJlbFxyXG4gICAgY2xhc3M9XCJhcmQtbGFiZWxcIlxyXG4gICAgW2F0dHIuZm9yXT1cImNvbnRyb2xJZCgpXCJcclxuICA+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJhcmQtbGFiZWwsIFthcmQtbGFiZWxdXCIgLz5cclxuICA8L2xhYmVsPlxyXG4gIDxkaXYgY2xhc3M9XCJhcmQtZm9ybS1maWVsZF9faW5wdXRcIj5cclxuICAgIDxuZy1jb250ZW50IC8+XHJcbiAgPC9kaXY+XHJcbiAgPGRpdlxyXG4gICAgY2xhc3M9XCJhcmQtZm9ybS1maWVsZF9faGludHNcIlxyXG4gICAgW2NsYXNzLmFyZC1mb3JtLWZpZWxkX19oaW50cy1kZWZhdWx0LWxlZnRdPVwiYWxpZ25MYWJlbFRvTGVmdEJ5RGVmYXVsdFwiXHJcbiAgPlxyXG4gICAgQGlmIChoYXNBbnlFcnJvcigpKSB7XHJcbiAgICA8ZGl2IGNsYXNzPVwiYXJkLWZvcm0tZmllbGRfX2Vycm9yXCI+XHJcbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImFyZC1lcnJvciwgW2FyZC1lcnJvcl1cIiAvPlxyXG4gICAgPC9kaXY+XHJcbiAgICB9IEBlbHNlIHtcclxuICAgIDxkaXYgY2xhc3M9XCJhcmQtZm9ybS1maWVsZF9faGludHMtbGVmdFwiPlxyXG4gICAgICA8ZGl2IGNsYXNzPVwiYXJkLWZvcm0tZmllbGRfX2RlZmF1bHQtaGludFwiPlxyXG4gICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImFyZC1oaW50Om5vdChbbGVmdF0pOm5vdChbcmlnaHRdKSwgW2FyZC1oaW50XTpub3QoW2xlZnRdKTpub3QoW3JpZ2h0XSlcIiAvPlxyXG4gICAgICA8L2Rpdj5cclxuICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXJkLWhpbnRbbGVmdF0sIFthcmQtaGludF1bbGVmdF1cIiAvPlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiYXJkLWZvcm0tZmllbGRfX2hpbnRzLXJpZ2h0XCI+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJhcmQtZm9ybS1maWVsZF9fZGVmYXVsdC1oaW50XCI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXJkLWhpbnQ6bm90KFtsZWZ0XSk6bm90KFtyaWdodF0pLCBbYXJkLWhpbnRdOm5vdChbbGVmdF0pOm5vdChbcmlnaHRdKVwiIC8+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJhcmQtaGludFtyaWdodF0sIFthcmQtaGludF1bcmlnaHRdXCIgLz5cclxuICAgIDwvZGl2PlxyXG4gICAgfVxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
@@ -0,0 +1,14 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ import { SimpleOneAxisAlignment } from './../types/alignment.types';
3
+ const _formFieldDefaults = {
4
+ defaultHintAlign: SimpleOneAxisAlignment.Left,
5
+ };
6
+ export const ARD_FORM_FIELD_DEFAULTS = new InjectionToken('ard-form-field-defaults', {
7
+ factory: () => ({
8
+ ..._formFieldDefaults,
9
+ }),
10
+ });
11
+ export function provideFormFieldDefaults(config) {
12
+ return { provide: ARD_FORM_FIELD_DEFAULTS, useValue: { ..._formFieldDefaults, ...config } };
13
+ }
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC5kZWZhdWx0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvZm9ybS1maWVsZC9mb3JtLWZpZWxkLmRlZmF1bHRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQVksTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFNcEUsTUFBTSxrQkFBa0IsR0FBeUI7SUFDL0MsZ0JBQWdCLEVBQUUsc0JBQXNCLENBQUMsSUFBSTtDQUM5QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxjQUFjLENBQXVCLHlCQUF5QixFQUFFO0lBQ3pHLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQ2QsR0FBRyxrQkFBa0I7S0FDdEIsQ0FBQztDQUNILENBQUMsQ0FBQztBQUVILE1BQU0sVUFBVSx3QkFBd0IsQ0FBQyxNQUFxQztJQUM1RSxPQUFPLEVBQUUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFFBQVEsRUFBRSxFQUFFLEdBQUcsa0JBQWtCLEVBQUUsR0FBRyxNQUFNLEVBQUUsRUFBRSxDQUFDO0FBQzlGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgUHJvdmlkZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2ltcGxlT25lQXhpc0FsaWdubWVudCB9IGZyb20gJy4vLi4vdHlwZXMvYWxpZ25tZW50LnR5cGVzJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQXJkRm9ybUZpZWxkRGVmYXVsdHMge1xyXG4gIGRlZmF1bHRIaW50QWxpZ246IFNpbXBsZU9uZUF4aXNBbGlnbm1lbnQ7XHJcbn1cclxuXHJcbmNvbnN0IF9mb3JtRmllbGREZWZhdWx0czogQXJkRm9ybUZpZWxkRGVmYXVsdHMgPSB7XHJcbiAgZGVmYXVsdEhpbnRBbGlnbjogU2ltcGxlT25lQXhpc0FsaWdubWVudC5MZWZ0LFxyXG59O1xyXG5cclxuZXhwb3J0IGNvbnN0IEFSRF9GT1JNX0ZJRUxEX0RFRkFVTFRTID0gbmV3IEluamVjdGlvblRva2VuPEFyZEZvcm1GaWVsZERlZmF1bHRzPignYXJkLWZvcm0tZmllbGQtZGVmYXVsdHMnLCB7XHJcbiAgZmFjdG9yeTogKCkgPT4gKHtcclxuICAgIC4uLl9mb3JtRmllbGREZWZhdWx0cyxcclxuICB9KSxcclxufSk7XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZUZvcm1GaWVsZERlZmF1bHRzKGNvbmZpZzogUGFydGlhbDxBcmRGb3JtRmllbGREZWZhdWx0cz4pOiBQcm92aWRlciB7XHJcbiAgcmV0dXJuIHsgcHJvdmlkZTogQVJEX0ZPUk1fRklFTERfREVGQVVMVFMsIHVzZVZhbHVlOiB7IC4uLl9mb3JtRmllbGREZWZhdWx0cywgLi4uY29uZmlnIH0gfTtcclxufVxyXG4iXX0=
@@ -0,0 +1,23 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { ArdiumErrorComponent } from './error/error.component';
4
+ import { ArdiumErrorDirective } from './error/error.directive';
5
+ import { ArdiumFormFieldComponent } from './form-field.component';
6
+ import { ArdiumHintComponent } from './hint/hint.component';
7
+ import { ArdiumHintDirective } from './hint/hint.directive';
8
+ import { ArdiumLabelComponent } from './label/label.component';
9
+ import * as i0 from "@angular/core";
10
+ export class ArdiumFormFieldModule {
11
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFormFieldModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
12
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFormFieldModule, declarations: [ArdiumFormFieldComponent, ArdiumLabelComponent, ArdiumHintComponent, ArdiumErrorComponent], imports: [CommonModule, ArdiumHintDirective, ArdiumErrorDirective], exports: [ArdiumFormFieldComponent, ArdiumLabelComponent, ArdiumHintComponent, ArdiumErrorComponent] }); }
13
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFormFieldModule, imports: [CommonModule] }); }
14
+ }
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFormFieldModule, decorators: [{
16
+ type: NgModule,
17
+ args: [{
18
+ declarations: [ArdiumFormFieldComponent, ArdiumLabelComponent, ArdiumHintComponent, ArdiumErrorComponent],
19
+ imports: [CommonModule, ArdiumHintDirective, ArdiumErrorDirective],
20
+ exports: [ArdiumFormFieldComponent, ArdiumLabelComponent, ArdiumHintComponent, ArdiumErrorComponent],
21
+ }]
22
+ }] });
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQvZm9ybS1maWVsZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDL0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDNUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDNUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBTy9ELE1BQU0sT0FBTyxxQkFBcUI7K0dBQXJCLHFCQUFxQjtnSEFBckIscUJBQXFCLGlCQUpqQix3QkFBd0IsRUFBRSxvQkFBb0IsRUFBRSxtQkFBbUIsRUFBRSxvQkFBb0IsYUFDOUYsWUFBWSxFQUFFLG1CQUFtQixFQUFFLG9CQUFvQixhQUN2RCx3QkFBd0IsRUFBRSxvQkFBb0IsRUFBRSxtQkFBbUIsRUFBRSxvQkFBb0I7Z0hBRXhGLHFCQUFxQixZQUh0QixZQUFZOzs0RkFHWCxxQkFBcUI7a0JBTGpDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsd0JBQXdCLEVBQUUsb0JBQW9CLEVBQUUsbUJBQW1CLEVBQUUsb0JBQW9CLENBQUM7b0JBQ3pHLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxtQkFBbUIsRUFBRSxvQkFBb0IsQ0FBQztvQkFDbEUsT0FBTyxFQUFFLENBQUMsd0JBQXdCLEVBQUUsb0JBQW9CLEVBQUUsbUJBQW1CLEVBQUUsb0JBQW9CLENBQUM7aUJBQ3JHIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQXJkaXVtRXJyb3JDb21wb25lbnQgfSBmcm9tICcuL2Vycm9yL2Vycm9yLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFyZGl1bUVycm9yRGlyZWN0aXZlIH0gZnJvbSAnLi9lcnJvci9lcnJvci5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBBcmRpdW1Gb3JtRmllbGRDb21wb25lbnQgfSBmcm9tICcuL2Zvcm0tZmllbGQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQXJkaXVtSGludENvbXBvbmVudCB9IGZyb20gJy4vaGludC9oaW50LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFyZGl1bUhpbnREaXJlY3RpdmUgfSBmcm9tICcuL2hpbnQvaGludC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBBcmRpdW1MYWJlbENvbXBvbmVudCB9IGZyb20gJy4vbGFiZWwvbGFiZWwuY29tcG9uZW50JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbQXJkaXVtRm9ybUZpZWxkQ29tcG9uZW50LCBBcmRpdW1MYWJlbENvbXBvbmVudCwgQXJkaXVtSGludENvbXBvbmVudCwgQXJkaXVtRXJyb3JDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEFyZGl1bUhpbnREaXJlY3RpdmUsIEFyZGl1bUVycm9yRGlyZWN0aXZlXSxcclxuICBleHBvcnRzOiBbQXJkaXVtRm9ybUZpZWxkQ29tcG9uZW50LCBBcmRpdW1MYWJlbENvbXBvbmVudCwgQXJkaXVtSGludENvbXBvbmVudCwgQXJkaXVtRXJyb3JDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXJkaXVtRm9ybUZpZWxkTW9kdWxlIHt9XHJcbiJdfQ==
@@ -0,0 +1,17 @@
1
+ import { Component } from '@angular/core';
2
+ import { ArdiumHintDirective } from './hint.directive';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./hint.directive";
5
+ export class ArdiumHintComponent {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumHintComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
7
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ArdiumHintComponent, selector: "ard-hint", hostDirectives: [{ directive: i1.ArdiumHintDirective, inputs: ["left", "left", "right", "right"] }], ngImport: i0, template: '<ng-content />', isInline: true }); }
8
+ }
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumHintComponent, decorators: [{
10
+ type: Component,
11
+ args: [{
12
+ selector: 'ard-hint',
13
+ template: '<ng-content />',
14
+ hostDirectives: [{ directive: ArdiumHintDirective, inputs: ['left', 'right'] }],
15
+ }]
16
+ }] });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGludC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQvaGludC9oaW50LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7QUFPdkQsTUFBTSxPQUFPLG1CQUFtQjsrR0FBbkIsbUJBQW1CO21HQUFuQixtQkFBbUIscUpBSHBCLGdCQUFnQjs7NEZBR2YsbUJBQW1CO2tCQUwvQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxVQUFVO29CQUNwQixRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixjQUFjLEVBQUUsQ0FBQyxFQUFFLFNBQVMsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLEVBQUUsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLEVBQUUsQ0FBQztpQkFDaEYiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQXJkaXVtSGludERpcmVjdGl2ZSB9IGZyb20gJy4vaGludC5kaXJlY3RpdmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcmQtaGludCcsXHJcbiAgdGVtcGxhdGU6ICc8bmctY29udGVudCAvPicsXHJcbiAgaG9zdERpcmVjdGl2ZXM6IFt7IGRpcmVjdGl2ZTogQXJkaXVtSGludERpcmVjdGl2ZSwgaW5wdXRzOiBbJ2xlZnQnLCAncmlnaHQnXSB9XSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFyZGl1bUhpbnRDb21wb25lbnQge31cclxuIl19
@@ -0,0 +1,30 @@
1
+ import { Directive, effect, input } from '@angular/core';
2
+ import { coerceBooleanProperty } from '@ardium-ui/devkit';
3
+ import * as i0 from "@angular/core";
4
+ export class ArdiumHintDirective {
5
+ constructor() {
6
+ this.left = input(false, { transform: v => coerceBooleanProperty(v) });
7
+ this.right = input(false, { transform: v => coerceBooleanProperty(v) });
8
+ effect(() => {
9
+ if (this.left() && this.right()) {
10
+ console.error(`ARD-NF5130: Cannot align a form field hint to both left and right.`);
11
+ }
12
+ });
13
+ }
14
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumHintDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
15
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: ArdiumHintDirective, isStandalone: true, selector: "[ard-hint]", inputs: { left: { classPropertyName: "left", publicName: "left", isSignal: true, isRequired: false, transformFunction: null }, right: { classPropertyName: "right", publicName: "right", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.ard-hint": "true", "class.ard-hint-default": "!left() && !right()", "class.ard-hint-left": "left() && !right()", "class.ard-hint-right": "!left() && right()" } }, ngImport: i0 }); }
16
+ }
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumHintDirective, decorators: [{
18
+ type: Directive,
19
+ args: [{
20
+ selector: '[ard-hint]',
21
+ standalone: true,
22
+ host: {
23
+ '[class.ard-hint]': 'true',
24
+ '[class.ard-hint-default]': '!left() && !right()',
25
+ '[class.ard-hint-left]': 'left() && !right()',
26
+ '[class.ard-hint-right]': '!left() && right()',
27
+ },
28
+ }]
29
+ }], ctorParameters: () => [] });
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGludC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQvaGludC9oaW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBWTFELE1BQU0sT0FBTyxtQkFBbUI7SUFJOUI7UUFIUyxTQUFJLEdBQUcsS0FBSyxDQUFlLEtBQUssRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNoRixVQUFLLEdBQUcsS0FBSyxDQUFlLEtBQUssRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUd4RixNQUFNLENBQUMsR0FBRyxFQUFFO1lBQ1YsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUM7Z0JBQ2hDLE9BQU8sQ0FBQyxLQUFLLENBQUMsb0VBQW9FLENBQUMsQ0FBQztZQUN0RixDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOytHQVZVLG1CQUFtQjttR0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQVYvQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxZQUFZO29CQUN0QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNKLGtCQUFrQixFQUFFLE1BQU07d0JBQzFCLDBCQUEwQixFQUFFLHFCQUFxQjt3QkFDakQsdUJBQXVCLEVBQUUsb0JBQW9CO3dCQUM3Qyx3QkFBd0IsRUFBRSxvQkFBb0I7cUJBQy9DO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBlZmZlY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJ0BhcmRpdW0tdWkvZGV2a2l0JztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW2FyZC1oaW50XScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBob3N0OiB7XHJcbiAgICAnW2NsYXNzLmFyZC1oaW50XSc6ICd0cnVlJyxcclxuICAgICdbY2xhc3MuYXJkLWhpbnQtZGVmYXVsdF0nOiAnIWxlZnQoKSAmJiAhcmlnaHQoKScsXHJcbiAgICAnW2NsYXNzLmFyZC1oaW50LWxlZnRdJzogJ2xlZnQoKSAmJiAhcmlnaHQoKScsXHJcbiAgICAnW2NsYXNzLmFyZC1oaW50LXJpZ2h0XSc6ICchbGVmdCgpICYmIHJpZ2h0KCknLFxyXG4gIH0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBcmRpdW1IaW50RGlyZWN0aXZlIHtcclxuICByZWFkb25seSBsZWZ0ID0gaW5wdXQ8Ym9vbGVhbiwgYW55PihmYWxzZSwgeyB0cmFuc2Zvcm06IHYgPT4gY29lcmNlQm9vbGVhblByb3BlcnR5KHYpIH0pO1xyXG4gIHJlYWRvbmx5IHJpZ2h0ID0gaW5wdXQ8Ym9vbGVhbiwgYW55PihmYWxzZSwgeyB0cmFuc2Zvcm06IHYgPT4gY29lcmNlQm9vbGVhblByb3BlcnR5KHYpIH0pO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIGVmZmVjdCgoKSA9PiB7XHJcbiAgICAgIGlmICh0aGlzLmxlZnQoKSAmJiB0aGlzLnJpZ2h0KCkpIHtcclxuICAgICAgICBjb25zb2xlLmVycm9yKGBBUkQtTkY1MTMwOiBDYW5ub3QgYWxpZ24gYSBmb3JtIGZpZWxkIGhpbnQgdG8gYm90aCBsZWZ0IGFuZCByaWdodC5gKTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -0,0 +1,8 @@
1
+ export * from './error/error.component';
2
+ export * from './error/error.directive';
3
+ export * from './form-field.component';
4
+ export * from './form-field.module';
5
+ export * from './hint/hint.component';
6
+ export * from './hint/hint.directive';
7
+ export * from './label/label.component';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZXJyb3IvZXJyb3IuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9lcnJvci9lcnJvci5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0tZmllbGQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9mb3JtLWZpZWxkLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vaGludC9oaW50LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vaGludC9oaW50LmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGFiZWwvbGFiZWwuY29tcG9uZW50JztcclxuXHJcbiJdfQ==
@@ -0,0 +1,21 @@
1
+ import { Component, effect, input } from '@angular/core';
2
+ import { coerceBooleanProperty } from '@ardium-ui/devkit';
3
+ import * as i0 from "@angular/core";
4
+ export class ArdiumLabelComponent {
5
+ constructor() {
6
+ this.required = input(false, { transform: v => coerceBooleanProperty(v) });
7
+ this.optional = input(false, { transform: v => coerceBooleanProperty(v) });
8
+ effect(() => {
9
+ if (this.required() && this.optional()) {
10
+ console.error(`ARD-NF5110: Cannot set a form field label to be both required and optional.`);
11
+ }
12
+ });
13
+ }
14
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
15
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: ArdiumLabelComponent, selector: "ard-label", inputs: { required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, optional: { classPropertyName: "optional", publicName: "optional", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div\r\n class=\"ard-label-text\"\r\n [class.ard-label-optional]=\"optional()\"\r\n [class.ard-label-required]=\"required()\"\r\n>\r\n <ng-content />\r\n</div>\r\n" }); }
16
+ }
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumLabelComponent, decorators: [{
18
+ type: Component,
19
+ args: [{ selector: 'ard-label', template: "<div\r\n class=\"ard-label-text\"\r\n [class.ard-label-optional]=\"optional()\"\r\n [class.ard-label-required]=\"required()\"\r\n>\r\n <ng-content />\r\n</div>\r\n" }]
20
+ }], ctorParameters: () => [] });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9mb3JtLWZpZWxkL2xhYmVsL2xhYmVsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvZm9ybS1maWVsZC9sYWJlbC9sYWJlbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBTTFELE1BQU0sT0FBTyxvQkFBb0I7SUFJL0I7UUFIUyxhQUFRLEdBQUcsS0FBSyxDQUFlLEtBQUssRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNwRixhQUFRLEdBQUcsS0FBSyxDQUFlLEtBQUssRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUczRixNQUFNLENBQUMsR0FBRyxFQUFFO1lBQ1YsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7Z0JBQ3ZDLE9BQU8sQ0FBQyxLQUFLLENBQUMsNkVBQTZFLENBQUMsQ0FBQztZQUMvRixDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOytHQVZVLG9CQUFvQjttR0FBcEIsb0JBQW9CLCtUQ1BqQyx5S0FPQTs7NEZEQWEsb0JBQW9CO2tCQUpoQyxTQUFTOytCQUNFLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGVmZmVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgY29lcmNlQm9vbGVhblByb3BlcnR5IH0gZnJvbSAnQGFyZGl1bS11aS9kZXZraXQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcmQtbGFiZWwnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9sYWJlbC5jb21wb25lbnQuaHRtbCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBcmRpdW1MYWJlbENvbXBvbmVudCB7XHJcbiAgcmVhZG9ubHkgcmVxdWlyZWQgPSBpbnB1dDxib29sZWFuLCBhbnk+KGZhbHNlLCB7IHRyYW5zZm9ybTogdiA9PiBjb2VyY2VCb29sZWFuUHJvcGVydHkodikgfSk7XHJcbiAgcmVhZG9ubHkgb3B0aW9uYWwgPSBpbnB1dDxib29sZWFuLCBhbnk+KGZhbHNlLCB7IHRyYW5zZm9ybTogdiA9PiBjb2VyY2VCb29sZWFuUHJvcGVydHkodikgfSk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgZWZmZWN0KCgpID0+IHtcclxuICAgICAgaWYgKHRoaXMucmVxdWlyZWQoKSAmJiB0aGlzLm9wdGlvbmFsKCkpIHtcclxuICAgICAgICBjb25zb2xlLmVycm9yKGBBUkQtTkY1MTEwOiBDYW5ub3Qgc2V0IGEgZm9ybSBmaWVsZCBsYWJlbCB0byBiZSBib3RoIHJlcXVpcmVkIGFuZCBvcHRpb25hbC5gKTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXZcclxuICBjbGFzcz1cImFyZC1sYWJlbC10ZXh0XCJcclxuICBbY2xhc3MuYXJkLWxhYmVsLW9wdGlvbmFsXT1cIm9wdGlvbmFsKClcIlxyXG4gIFtjbGFzcy5hcmQtbGFiZWwtcmVxdWlyZWRdPVwicmVxdWlyZWQoKVwiXHJcbj5cclxuICA8bmctY29udGVudCAvPlxyXG48L2Rpdj5cclxuIl19
@@ -9,6 +9,7 @@ import * as i1 from "@angular/common";
9
9
  export class ArdiumFormFieldFrameComponent extends _FocusableComponentBase {
10
10
  constructor(defaults) {
11
11
  super(defaults);
12
+ this.hasError = input(false, { transform: v => coerceBooleanProperty(v) });
12
13
  //! focused state
13
14
  this.isFocused = false;
14
15
  //! appearance
@@ -28,6 +29,7 @@ export class ArdiumFormFieldFrameComponent extends _FocusableComponentBase {
28
29
  `ard-appearance-${this.appearance()}`,
29
30
  `ard-variant-${this.variant()}`,
30
31
  this.compact() ? 'ard-compact' : '',
32
+ this.hasError() ? 'ard-has-error' : '',
31
33
  this.isFocused ? 'ard-focused' : 'ard-unfocused',
32
34
  ].join(' '));
33
35
  //! prefix & suffix
@@ -37,7 +39,7 @@ export class ArdiumFormFieldFrameComponent extends _FocusableComponentBase {
37
39
  this.suffixTemplate = contentChild(ArdFormFieldSuffixTemplateDirective);
38
40
  }
39
41
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFormFieldFrameComponent, deps: [{ token: ARD_FORM_FIELD_FRAME_DEFAULTS }], target: i0.ɵɵFactoryTarget.Component }); }
40
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumFormFieldFrameComponent, selector: "ard-form-field-frame", inputs: { isFocused: { classPropertyName: "isFocused", publicName: "isFocused", isSignal: false, isRequired: false, transformFunction: null }, appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, prefixTemplateInput: { classPropertyName: "prefixTemplateInput", publicName: "prefixTemplate", isSignal: true, isRequired: false, transformFunction: null }, suffixTemplateInput: { classPropertyName: "suffixTemplateInput", publicName: "suffixTemplate", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "prefixTemplate", first: true, predicate: ArdFormFieldPrefixTemplateDirective, descendants: true, isSignal: true }, { propertyName: "suffixTemplate", first: true, predicate: ArdFormFieldSuffixTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\n class=\"ard-form-field-frame\"\n [ngClass]=\"ngClasses()\"\n>\n <div class=\"ard-form-field-overlay\"></div>\n @if (prefixTemplateInput() ?? prefixTemplate()) {\n <div class=\"ard-form-field-prefix-container\">\n <ng-template [ngTemplateOutlet]=\"prefixTemplateInput() ?? prefixTemplate()?.template ?? null\"></ng-template>\n </div>\n }\n <div class=\"ard-form-field-content-container\">\n <ng-content></ng-content>\n </div>\n @if (suffixTemplateInput() ?? suffixTemplate()) {\n <div class=\"ard-form-field-suffix-container\">\n <ng-template [ngTemplateOutlet]=\"suffixTemplateInput() ?? suffixTemplate()?.template ?? null\"></ng-template>\n </div>\n }\n</div>\n", styles: [".ard-form-field-frame{position:relative}.ard-form-field-overlay{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumFormFieldFrameComponent, selector: "ard-form-field-frame", inputs: { hasError: { classPropertyName: "hasError", publicName: "hasError", isSignal: true, isRequired: false, transformFunction: null }, isFocused: { classPropertyName: "isFocused", publicName: "isFocused", isSignal: false, isRequired: false, transformFunction: null }, appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, prefixTemplateInput: { classPropertyName: "prefixTemplateInput", publicName: "prefixTemplate", isSignal: true, isRequired: false, transformFunction: null }, suffixTemplateInput: { classPropertyName: "suffixTemplateInput", publicName: "suffixTemplate", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "prefixTemplate", first: true, predicate: ArdFormFieldPrefixTemplateDirective, descendants: true, isSignal: true }, { propertyName: "suffixTemplate", first: true, predicate: ArdFormFieldSuffixTemplateDirective, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\n class=\"ard-form-field-frame\"\n [ngClass]=\"ngClasses()\"\n>\n <div class=\"ard-form-field-overlay\"></div>\n @if (prefixTemplateInput() ?? prefixTemplate()) {\n <div class=\"ard-form-field-prefix-container\">\n <ng-template [ngTemplateOutlet]=\"prefixTemplateInput() ?? prefixTemplate()?.template ?? null\"></ng-template>\n </div>\n }\n <div class=\"ard-form-field-content-container\">\n <ng-content></ng-content>\n </div>\n @if (suffixTemplateInput() ?? suffixTemplate()) {\n <div class=\"ard-form-field-suffix-container\">\n <ng-template [ngTemplateOutlet]=\"suffixTemplateInput() ?? suffixTemplate()?.template ?? null\"></ng-template>\n </div>\n }\n</div>\n", styles: [".ard-form-field-frame{position:relative}.ard-form-field-overlay{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
41
43
  }
42
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumFormFieldFrameComponent, decorators: [{
43
45
  type: Component,
@@ -48,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
48
50
  }] }], propDecorators: { isFocused: [{
49
51
  type: Input
50
52
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC1mcmFtZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQtZnJhbWUvZm9ybS1maWVsZC1mcmFtZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQtZnJhbWUvZm9ybS1maWVsZC1mcmFtZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEVBQ04sS0FBSyxFQUVMLGlCQUFpQixFQUNqQixRQUFRLEVBQ1IsWUFBWSxFQUNaLEtBQUssR0FDTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMzRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUVuRixPQUFPLEVBQUUsNkJBQTZCLEVBQTZCLE1BQU0sNkJBQTZCLENBQUM7QUFDdkcsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sK0JBQStCLENBQUM7OztBQVN6SCxNQUFNLE9BQU8sNkJBQThCLFNBQVEsdUJBQXVCO0lBRXhFLFlBQW1ELFFBQW1DO1FBQ3BGLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUdsQixpQkFBaUI7UUFDQyxjQUFTLEdBQUcsS0FBSyxDQUFDO1FBRXBDLGNBQWM7UUFDZDs7V0FFRztRQUNNLGVBQVUsR0FBRyxLQUFLLENBQXdCLHFCQUFxQixDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ25GOztXQUVHO1FBQ00sWUFBTyxHQUFHLEtBQUssQ0FBcUIsa0JBQWtCLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFekU7O1dBRUc7UUFDTSxZQUFPLEdBQUcsS0FBSyxDQUFlLEtBQUssRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUVuRixjQUFTLEdBQUcsUUFBUSxDQUFTLEdBQUcsRUFBRSxDQUN6QztZQUNFLGtCQUFrQixJQUFJLENBQUMsVUFBVSxFQUFFLEVBQUU7WUFDckMsZUFBZSxJQUFJLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDL0IsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDbkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxlQUFlO1NBQ2pELENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUNaLENBQUM7UUFFRixtQkFBbUI7UUFDVix3QkFBbUIsR0FBRyxLQUFLLENBQTZCLFNBQVMsRUFBRSxFQUFFLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7UUFDaEcsd0JBQW1CLEdBQUcsS0FBSyxDQUE2QixTQUFTLEVBQUUsRUFBRSxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBQ2hHLG1CQUFjLEdBQUcsWUFBWSxDQUFDLG1DQUFtQyxDQUFDLENBQUM7UUFDbkUsbUJBQWMsR0FBRyxZQUFZLENBQUMsbUNBQW1DLENBQUMsQ0FBQztJQWpDNUUsQ0FBQzsrR0FKVSw2QkFBNkIsa0JBRXBCLDZCQUE2QjttR0FGdEMsNkJBQTZCLHM3QkFvQ0QsbUNBQW1DLGlHQUNuQyxtQ0FBbUMsdUZDOUQ1RSxpc0JBbUJBOzs0RkRNYSw2QkFBNkI7a0JBUHpDLFNBQVM7K0JBQ0Usc0JBQXNCLGlCQUdqQixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNOzswQkFJbEMsTUFBTTsyQkFBQyw2QkFBNkI7eUNBSy9CLFNBQVM7c0JBQTFCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBJbmplY3QsXG4gIElucHV0LFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG4gIGNvbXB1dGVkLFxuICBjb250ZW50Q2hpbGQsXG4gIGlucHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJ0BhcmRpdW0tdWkvZGV2a2l0JztcbmltcG9ydCB7IF9Gb2N1c2FibGVDb21wb25lbnRCYXNlIH0gZnJvbSAnLi4vX2ludGVybmFsL2ZvY3VzYWJsZS1jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9ybUVsZW1lbnRBcHBlYXJhbmNlLCBGb3JtRWxlbWVudFZhcmlhbnQgfSBmcm9tICcuLi90eXBlcy90aGVtaW5nLnR5cGVzJztcbmltcG9ydCB7IE51bGxhYmxlIH0gZnJvbSAnLi4vdHlwZXMvdXRpbGl0eS50eXBlcyc7XG5pbXBvcnQgeyBBUkRfRk9STV9GSUVMRF9GUkFNRV9ERUZBVUxUUywgQXJkRm9ybUZpZWxkRnJhbWVEZWZhdWx0cyB9IGZyb20gJy4vZm9ybS1maWVsZC1mcmFtZS5kZWZhdWx0cyc7XG5pbXBvcnQgeyBBcmRGb3JtRmllbGRQcmVmaXhUZW1wbGF0ZURpcmVjdGl2ZSwgQXJkRm9ybUZpZWxkU3VmZml4VGVtcGxhdGVEaXJlY3RpdmUgfSBmcm9tICcuL2Zvcm0tZmllbGQtZnJhbWUuZGlyZWN0aXZlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FyZC1mb3JtLWZpZWxkLWZyYW1lJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Zvcm0tZmllbGQtZnJhbWUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9mb3JtLWZpZWxkLWZyYW1lLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBBcmRpdW1Gb3JtRmllbGRGcmFtZUNvbXBvbmVudCBleHRlbmRzIF9Gb2N1c2FibGVDb21wb25lbnRCYXNlIHtcbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlYWRvbmx5IF9ERUZBVUxUUyE6IEFyZEZvcm1GaWVsZEZyYW1lRGVmYXVsdHM7XG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoQVJEX0ZPUk1fRklFTERfRlJBTUVfREVGQVVMVFMpIGRlZmF1bHRzOiBBcmRGb3JtRmllbGRGcmFtZURlZmF1bHRzKSB7XG4gICAgc3VwZXIoZGVmYXVsdHMpO1xuICB9XG5cbiAgLy8hIGZvY3VzZWQgc3RhdGVcbiAgQElucHV0KCkgb3ZlcnJpZGUgaXNGb2N1c2VkID0gZmFsc2U7XG5cbiAgLy8hIGFwcGVhcmFuY2VcbiAgLyoqXG4gICAqIFRoZSBhcHBlYXJhbmNlIG9mIHRoZSBjb21wb25lbnQsIGFrYSB0aGUgc3R5bGluZy5cbiAgICovXG4gIHJlYWRvbmx5IGFwcGVhcmFuY2UgPSBpbnB1dDxGb3JtRWxlbWVudEFwcGVhcmFuY2U+KEZvcm1FbGVtZW50QXBwZWFyYW5jZS5PdXRsaW5lZCk7XG4gIC8qKlxuICAgKiBUaGUgdmFyaWFudCBvZiB0aGUgY29tcG9uZW50LCBha2EgdGhlIHNoYXBlLlxuICAgKi9cbiAgcmVhZG9ubHkgdmFyaWFudCA9IGlucHV0PEZvcm1FbGVtZW50VmFyaWFudD4oRm9ybUVsZW1lbnRWYXJpYW50LlJvdW5kZWQpO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIHVzZSB0aGUgY29tcGFjdCBzdHlsaW5nIG9yIG5vdC5cbiAgICovXG4gIHJlYWRvbmx5IGNvbXBhY3QgPSBpbnB1dDxib29sZWFuLCBhbnk+KGZhbHNlLCB7IHRyYW5zZm9ybTogdiA9PiBjb2VyY2VCb29sZWFuUHJvcGVydHkodikgfSk7XG5cbiAgcmVhZG9ubHkgbmdDbGFzc2VzID0gY29tcHV0ZWQ8c3RyaW5nPigoKSA9PlxuICAgIFtcbiAgICAgIGBhcmQtYXBwZWFyYW5jZS0ke3RoaXMuYXBwZWFyYW5jZSgpfWAsXG4gICAgICBgYXJkLXZhcmlhbnQtJHt0aGlzLnZhcmlhbnQoKX1gLFxuICAgICAgdGhpcy5jb21wYWN0KCkgPyAnYXJkLWNvbXBhY3QnIDogJycsXG4gICAgICB0aGlzLmlzRm9jdXNlZCA/ICdhcmQtZm9jdXNlZCcgOiAnYXJkLXVuZm9jdXNlZCcsXG4gICAgXS5qb2luKCcgJylcbiAgKTtcblxuICAvLyEgcHJlZml4ICYgc3VmZml4XG4gIHJlYWRvbmx5IHByZWZpeFRlbXBsYXRlSW5wdXQgPSBpbnB1dDxOdWxsYWJsZTxUZW1wbGF0ZVJlZjxhbnk+Pj4odW5kZWZpbmVkLCB7IGFsaWFzOiAncHJlZml4VGVtcGxhdGUnIH0pO1xuICByZWFkb25seSBzdWZmaXhUZW1wbGF0ZUlucHV0ID0gaW5wdXQ8TnVsbGFibGU8VGVtcGxhdGVSZWY8YW55Pj4+KHVuZGVmaW5lZCwgeyBhbGlhczogJ3N1ZmZpeFRlbXBsYXRlJyB9KTtcbiAgcmVhZG9ubHkgcHJlZml4VGVtcGxhdGUgPSBjb250ZW50Q2hpbGQoQXJkRm9ybUZpZWxkUHJlZml4VGVtcGxhdGVEaXJlY3RpdmUpO1xuICByZWFkb25seSBzdWZmaXhUZW1wbGF0ZSA9IGNvbnRlbnRDaGlsZChBcmRGb3JtRmllbGRTdWZmaXhUZW1wbGF0ZURpcmVjdGl2ZSk7XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwiYXJkLWZvcm0tZmllbGQtZnJhbWVcIlxuICBbbmdDbGFzc109XCJuZ0NsYXNzZXMoKVwiXG4+XG4gIDxkaXYgY2xhc3M9XCJhcmQtZm9ybS1maWVsZC1vdmVybGF5XCI+PC9kaXY+XG4gIEBpZiAocHJlZml4VGVtcGxhdGVJbnB1dCgpID8/IHByZWZpeFRlbXBsYXRlKCkpIHtcbiAgICA8ZGl2IGNsYXNzPVwiYXJkLWZvcm0tZmllbGQtcHJlZml4LWNvbnRhaW5lclwiPlxuICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cInByZWZpeFRlbXBsYXRlSW5wdXQoKSA/PyBwcmVmaXhUZW1wbGF0ZSgpPy50ZW1wbGF0ZSA/PyBudWxsXCI+PC9uZy10ZW1wbGF0ZT5cbiAgICA8L2Rpdj5cbiAgfVxuICA8ZGl2IGNsYXNzPVwiYXJkLWZvcm0tZmllbGQtY29udGVudC1jb250YWluZXJcIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuICBAaWYgKHN1ZmZpeFRlbXBsYXRlSW5wdXQoKSA/PyBzdWZmaXhUZW1wbGF0ZSgpKSB7XG4gICAgPGRpdiBjbGFzcz1cImFyZC1mb3JtLWZpZWxkLXN1ZmZpeC1jb250YWluZXJcIj5cbiAgICAgIDxuZy10ZW1wbGF0ZSBbbmdUZW1wbGF0ZU91dGxldF09XCJzdWZmaXhUZW1wbGF0ZUlucHV0KCkgPz8gc3VmZml4VGVtcGxhdGUoKT8udGVtcGxhdGUgPz8gbnVsbFwiPjwvbmctdGVtcGxhdGU+XG4gICAgPC9kaXY+XG4gIH1cbjwvZGl2PlxuIl19
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC1mcmFtZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQtZnJhbWUvZm9ybS1maWVsZC1mcmFtZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2Zvcm0tZmllbGQtZnJhbWUvZm9ybS1maWVsZC1mcmFtZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEVBQ04sS0FBSyxFQUVMLGlCQUFpQixFQUNqQixRQUFRLEVBQ1IsWUFBWSxFQUNaLEtBQUssR0FDTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMzRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUVuRixPQUFPLEVBQUUsNkJBQTZCLEVBQTZCLE1BQU0sNkJBQTZCLENBQUM7QUFDdkcsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sK0JBQStCLENBQUM7OztBQVN6SCxNQUFNLE9BQU8sNkJBQThCLFNBQVEsdUJBQXVCO0lBRXhFLFlBQW1ELFFBQW1DO1FBQ3BGLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUdULGFBQVEsR0FBRyxLQUFLLENBQWUsS0FBSyxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMscUJBQXFCLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBRTdGLGlCQUFpQjtRQUNDLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFFcEMsY0FBYztRQUNkOztXQUVHO1FBQ00sZUFBVSxHQUFHLEtBQUssQ0FBd0IscUJBQXFCLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDbkY7O1dBRUc7UUFDTSxZQUFPLEdBQUcsS0FBSyxDQUFxQixrQkFBa0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUV6RTs7V0FFRztRQUNNLFlBQU8sR0FBRyxLQUFLLENBQWUsS0FBSyxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMscUJBQXFCLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBRW5GLGNBQVMsR0FBRyxRQUFRLENBQVMsR0FBRyxFQUFFLENBQ3pDO1lBQ0Usa0JBQWtCLElBQUksQ0FBQyxVQUFVLEVBQUUsRUFBRTtZQUNyQyxlQUFlLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRTtZQUMvQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNuQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUN0QyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLGVBQWU7U0FDakQsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQ1osQ0FBQztRQUVGLG1CQUFtQjtRQUNWLHdCQUFtQixHQUFHLEtBQUssQ0FBNkIsU0FBUyxFQUFFLEVBQUUsS0FBSyxFQUFFLGdCQUFnQixFQUFFLENBQUMsQ0FBQztRQUNoRyx3QkFBbUIsR0FBRyxLQUFLLENBQTZCLFNBQVMsRUFBRSxFQUFFLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7UUFDaEcsbUJBQWMsR0FBRyxZQUFZLENBQUMsbUNBQW1DLENBQUMsQ0FBQztRQUNuRSxtQkFBYyxHQUFHLFlBQVksQ0FBQyxtQ0FBbUMsQ0FBQyxDQUFDO0lBcEM1RSxDQUFDOytHQUpVLDZCQUE2QixrQkFFcEIsNkJBQTZCO21HQUZ0Qyw2QkFBNkIsdWpDQXVDRCxtQ0FBbUMsaUdBQ25DLG1DQUFtQyx1RkNqRTVFLGlzQkFtQkE7OzRGRE1hLDZCQUE2QjtrQkFQekMsU0FBUzsrQkFDRSxzQkFBc0IsaUJBR2pCLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU07OzBCQUlsQyxNQUFNOzJCQUFDLDZCQUE2Qjt5Q0FPL0IsU0FBUztzQkFBMUIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgQ29tcG9uZW50LFxyXG4gIEluamVjdCxcclxuICBJbnB1dCxcclxuICBUZW1wbGF0ZVJlZixcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxuICBjb21wdXRlZCxcclxuICBjb250ZW50Q2hpbGQsXHJcbiAgaW5wdXQsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJ0BhcmRpdW0tdWkvZGV2a2l0JztcclxuaW1wb3J0IHsgX0ZvY3VzYWJsZUNvbXBvbmVudEJhc2UgfSBmcm9tICcuLi9faW50ZXJuYWwvZm9jdXNhYmxlLWNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZvcm1FbGVtZW50QXBwZWFyYW5jZSwgRm9ybUVsZW1lbnRWYXJpYW50IH0gZnJvbSAnLi4vdHlwZXMvdGhlbWluZy50eXBlcyc7XHJcbmltcG9ydCB7IE51bGxhYmxlIH0gZnJvbSAnLi4vdHlwZXMvdXRpbGl0eS50eXBlcyc7XHJcbmltcG9ydCB7IEFSRF9GT1JNX0ZJRUxEX0ZSQU1FX0RFRkFVTFRTLCBBcmRGb3JtRmllbGRGcmFtZURlZmF1bHRzIH0gZnJvbSAnLi9mb3JtLWZpZWxkLWZyYW1lLmRlZmF1bHRzJztcclxuaW1wb3J0IHsgQXJkRm9ybUZpZWxkUHJlZml4VGVtcGxhdGVEaXJlY3RpdmUsIEFyZEZvcm1GaWVsZFN1ZmZpeFRlbXBsYXRlRGlyZWN0aXZlIH0gZnJvbSAnLi9mb3JtLWZpZWxkLWZyYW1lLmRpcmVjdGl2ZXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcmQtZm9ybS1maWVsZC1mcmFtZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2Zvcm0tZmllbGQtZnJhbWUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2Zvcm0tZmllbGQtZnJhbWUuY29tcG9uZW50LnNjc3MnXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXJkaXVtRm9ybUZpZWxkRnJhbWVDb21wb25lbnQgZXh0ZW5kcyBfRm9jdXNhYmxlQ29tcG9uZW50QmFzZSB7XHJcbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlYWRvbmx5IF9ERUZBVUxUUyE6IEFyZEZvcm1GaWVsZEZyYW1lRGVmYXVsdHM7XHJcbiAgY29uc3RydWN0b3IoQEluamVjdChBUkRfRk9STV9GSUVMRF9GUkFNRV9ERUZBVUxUUykgZGVmYXVsdHM6IEFyZEZvcm1GaWVsZEZyYW1lRGVmYXVsdHMpIHtcclxuICAgIHN1cGVyKGRlZmF1bHRzKTtcclxuICB9XHJcblxyXG4gIHJlYWRvbmx5IGhhc0Vycm9yID0gaW5wdXQ8Ym9vbGVhbiwgYW55PihmYWxzZSwgeyB0cmFuc2Zvcm06IHYgPT4gY29lcmNlQm9vbGVhblByb3BlcnR5KHYpIH0pO1xyXG5cclxuICAvLyEgZm9jdXNlZCBzdGF0ZVxyXG4gIEBJbnB1dCgpIG92ZXJyaWRlIGlzRm9jdXNlZCA9IGZhbHNlO1xyXG5cclxuICAvLyEgYXBwZWFyYW5jZVxyXG4gIC8qKlxyXG4gICAqIFRoZSBhcHBlYXJhbmNlIG9mIHRoZSBjb21wb25lbnQsIGFrYSB0aGUgc3R5bGluZy5cclxuICAgKi9cclxuICByZWFkb25seSBhcHBlYXJhbmNlID0gaW5wdXQ8Rm9ybUVsZW1lbnRBcHBlYXJhbmNlPihGb3JtRWxlbWVudEFwcGVhcmFuY2UuT3V0bGluZWQpO1xyXG4gIC8qKlxyXG4gICAqIFRoZSB2YXJpYW50IG9mIHRoZSBjb21wb25lbnQsIGFrYSB0aGUgc2hhcGUuXHJcbiAgICovXHJcbiAgcmVhZG9ubHkgdmFyaWFudCA9IGlucHV0PEZvcm1FbGVtZW50VmFyaWFudD4oRm9ybUVsZW1lbnRWYXJpYW50LlJvdW5kZWQpO1xyXG5cclxuICAvKipcclxuICAgKiBXaGV0aGVyIHRvIHVzZSB0aGUgY29tcGFjdCBzdHlsaW5nIG9yIG5vdC5cclxuICAgKi9cclxuICByZWFkb25seSBjb21wYWN0ID0gaW5wdXQ8Ym9vbGVhbiwgYW55PihmYWxzZSwgeyB0cmFuc2Zvcm06IHYgPT4gY29lcmNlQm9vbGVhblByb3BlcnR5KHYpIH0pO1xyXG5cclxuICByZWFkb25seSBuZ0NsYXNzZXMgPSBjb21wdXRlZDxzdHJpbmc+KCgpID0+XHJcbiAgICBbXHJcbiAgICAgIGBhcmQtYXBwZWFyYW5jZS0ke3RoaXMuYXBwZWFyYW5jZSgpfWAsXHJcbiAgICAgIGBhcmQtdmFyaWFudC0ke3RoaXMudmFyaWFudCgpfWAsXHJcbiAgICAgIHRoaXMuY29tcGFjdCgpID8gJ2FyZC1jb21wYWN0JyA6ICcnLFxyXG4gICAgICB0aGlzLmhhc0Vycm9yKCkgPyAnYXJkLWhhcy1lcnJvcicgOiAnJyxcclxuICAgICAgdGhpcy5pc0ZvY3VzZWQgPyAnYXJkLWZvY3VzZWQnIDogJ2FyZC11bmZvY3VzZWQnLFxyXG4gICAgXS5qb2luKCcgJylcclxuICApO1xyXG5cclxuICAvLyEgcHJlZml4ICYgc3VmZml4XHJcbiAgcmVhZG9ubHkgcHJlZml4VGVtcGxhdGVJbnB1dCA9IGlucHV0PE51bGxhYmxlPFRlbXBsYXRlUmVmPGFueT4+Pih1bmRlZmluZWQsIHsgYWxpYXM6ICdwcmVmaXhUZW1wbGF0ZScgfSk7XHJcbiAgcmVhZG9ubHkgc3VmZml4VGVtcGxhdGVJbnB1dCA9IGlucHV0PE51bGxhYmxlPFRlbXBsYXRlUmVmPGFueT4+Pih1bmRlZmluZWQsIHsgYWxpYXM6ICdzdWZmaXhUZW1wbGF0ZScgfSk7XHJcbiAgcmVhZG9ubHkgcHJlZml4VGVtcGxhdGUgPSBjb250ZW50Q2hpbGQoQXJkRm9ybUZpZWxkUHJlZml4VGVtcGxhdGVEaXJlY3RpdmUpO1xyXG4gIHJlYWRvbmx5IHN1ZmZpeFRlbXBsYXRlID0gY29udGVudENoaWxkKEFyZEZvcm1GaWVsZFN1ZmZpeFRlbXBsYXRlRGlyZWN0aXZlKTtcclxufVxyXG4iLCI8ZGl2XG4gIGNsYXNzPVwiYXJkLWZvcm0tZmllbGQtZnJhbWVcIlxuICBbbmdDbGFzc109XCJuZ0NsYXNzZXMoKVwiXG4+XG4gIDxkaXYgY2xhc3M9XCJhcmQtZm9ybS1maWVsZC1vdmVybGF5XCI+PC9kaXY+XG4gIEBpZiAocHJlZml4VGVtcGxhdGVJbnB1dCgpID8/IHByZWZpeFRlbXBsYXRlKCkpIHtcbiAgICA8ZGl2IGNsYXNzPVwiYXJkLWZvcm0tZmllbGQtcHJlZml4LWNvbnRhaW5lclwiPlxuICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cInByZWZpeFRlbXBsYXRlSW5wdXQoKSA/PyBwcmVmaXhUZW1wbGF0ZSgpPy50ZW1wbGF0ZSA/PyBudWxsXCI+PC9uZy10ZW1wbGF0ZT5cbiAgICA8L2Rpdj5cbiAgfVxuICA8ZGl2IGNsYXNzPVwiYXJkLWZvcm0tZmllbGQtY29udGVudC1jb250YWluZXJcIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuICBAaWYgKHN1ZmZpeFRlbXBsYXRlSW5wdXQoKSA/PyBzdWZmaXhUZW1wbGF0ZSgpKSB7XG4gICAgPGRpdiBjbGFzcz1cImFyZC1mb3JtLWZpZWxkLXN1ZmZpeC1jb250YWluZXJcIj5cbiAgICAgIDxuZy10ZW1wbGF0ZSBbbmdUZW1wbGF0ZU91dGxldF09XCJzdWZmaXhUZW1wbGF0ZUlucHV0KCkgPz8gc3VmZml4VGVtcGxhdGUoKT8udGVtcGxhdGUgPz8gbnVsbFwiPjwvbmctdGVtcGxhdGU+XG4gICAgPC9kaXY+XG4gIH1cbjwvZGl2PlxuIl19
@@ -1,12 +1,12 @@
1
1
  import { computed, Directive, input, Input, output, viewChild } from '@angular/core';
2
2
  import { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';
3
- import { _NgModelComponentBase, _ngModelComponentDefaults } from '../_internal/ngmodel-component';
3
+ import { _FormFieldComponentBase, _formFieldComponentDefaults } from '../_internal/form-field-component';
4
4
  import { SimpleOneAxisAlignment } from './../types/alignment.types';
5
5
  import { FormElementAppearance, FormElementVariant } from './../types/theming.types';
6
6
  import { SimpleInputModel } from './input-utils';
7
7
  import * as i0 from "@angular/core";
8
8
  export const _simpleInputComponentDefaults = {
9
- ..._ngModelComponentDefaults,
9
+ ..._formFieldComponentDefaults,
10
10
  appearance: FormElementAppearance.Outlined,
11
11
  variant: FormElementVariant.Rounded,
12
12
  compact: false,
@@ -17,7 +17,7 @@ export const _simpleInputComponentDefaults = {
17
17
  inputAttrs: {},
18
18
  maxLength: undefined,
19
19
  };
20
- export class _SimpleInputComponentBase extends _NgModelComponentBase {
20
+ export class _SimpleInputComponentBase extends _FormFieldComponentBase {
21
21
  constructor() {
22
22
  super(...arguments);
23
23
  //! input view
@@ -150,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
150
150
  }], propDecorators: { value: [{
151
151
  type: Input
152
152
  }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"_simple-input-base.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/inputs/_simple-input-base.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,QAAQ,EAAE,SAAS,EAAc,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAChH,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,qBAAqB,EAA6B,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC7H,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAErF,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;;AAcjD,MAAM,CAAC,MAAM,6BAA6B,GAAkC;IAC1E,GAAG,yBAAyB;IAC5B,UAAU,EAAE,qBAAqB,CAAC,QAAQ;IAC1C,OAAO,EAAE,kBAAkB,CAAC,OAAO;IACnC,OAAO,EAAE,KAAK;IACd,WAAW,EAAE,EAAE;IACf,SAAS,EAAE,sBAAsB,CAAC,IAAI;IACtC,SAAS,EAAE,KAAK;IAChB,gBAAgB,EAAE,OAAO;IACzB,UAAU,EAAE,EAAE;IACd,SAAS,EAAE,SAAS;CACrB,CAAC;AAGF,MAAM,OAAgB,yBAA0B,SAAQ,qBAAqB;IAD7E;;QAIE,cAAc;QACL,gBAAW,GAAG,SAAS,CAA+B,WAAW,CAAC,CAAC;QAEzD,eAAU,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACnD,iBAAY,GAAG,KAAK,CAAC;QAWpB,gBAAW,GAAG,KAAK,CAAS,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACxD,YAAO,GAAG,KAAK,CAAmB,SAAS,CAAC,CAAC;QAC7C,qBAAgB,GAAG,KAAK,CAAS,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QASlE,6BAAwB,GAAG,QAAQ,CAAU,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC,CAAC;QAErH,cAAc;QACL,eAAU,GAAG,KAAK,CAAwB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACrE,YAAO,GAAG,KAAK,CAAqB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC5D,cAAS,GAAG,KAAK,CAAyB,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAEpE,YAAO,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEpG,cAAS,GAAG,QAAQ,CAAC,GAAW,EAAE,CACzC;YACE,kBAAkB,IAAI,CAAC,UAAU,EAAE,EAAE;YACrC,eAAe,IAAI,CAAC,OAAO,EAAE,EAAE;YAC/B,kBAAkB,IAAI,CAAC,SAAS,EAAE,EAAE;YACpC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE;SACxC,CAAC,IAAI,CAAC,GAAG,CAAC,CACZ,CAAC;QAEF,gBAAgB;QACP,eAAU,GAAG,KAAK,CAAsB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAE5E,oCAAoC;QAC3B,cAAS,GAAG,KAAK,CAAwB,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE;YAC1E,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;SAClE,CAAC,CAAC;QAEH,sCAAsC;QAC7B,cAAS,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAMjH,yBAAyB;QACf,qBAAgB,GAAmB,IAAI,CAAC;QAYzC,gBAAW,GAAG,MAAM,EAAiB,CAAC;QAE/C,kBAAkB;QACT,eAAU,GAAG,MAAM,CAAgB,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;QACvD,gBAAW,GAAG,MAAM,CAAgB,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;QACzD,eAAU,GAAG,MAAM,CAAa,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;QA2B7D,eAAe;QACN,0BAAqB,GAAG,QAAQ,CACvC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC,CAC/E,CAAC;KAwCH;IA/IC,eAAe;QACb,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,eAAe;QACf,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACvC,OAAO,IAAI,CAAC,gBAAgB,CAAC;QAC/B,CAAC;IACH,CAAC;IA2CD,uDAAuD;IACvD,UAAU,CAAC,CAAM;QACf,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC;IAGD,IACI,KAAK,CAAC,CAAgB;QACxB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;YAC1B,OAAO;QACT,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IACD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IACjC,CAAC;IAQD,kBAAkB;IAClB,OAAO,CAAC,MAAc;QACpB,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAC3D,IAAI,CAAC,eAAe;YAAE,OAAO;QAC7B,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IACS,UAAU;QAClB,IAAI,CAAC,mBAAmB,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IACD,qBAAqB;IACrB,aAAa,CAAC,KAAiB;QAC7B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACtB,CAAC;IACD,YAAY,CAAC,KAAiB;QAC5B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;IACD,QAAQ,CAAC,KAAY;QACnB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IACS,WAAW;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC,CAAC;IACjD,CAAC;IAKD,kBAAkB,CAAC,KAAiB;QAClC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED,cAAc;IACd,MAAM,CAAC,KAAqB;QAC1B,IACE,IAAI,CAAC,KAAK;YACV,2CAA2C;YAC3C,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,cAAc,KAAK,CAAC;gBACtD,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,YAAY,KAAK,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC;gBAClG,iBAAiB;gBACjB,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,cAAc,KAAK,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,YAAY,CAAC,EACtG,CAAC;YACD,KAAK,CAAC,aAAa,EAAE,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YACvD,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;IACD,WAAW;IACD,mBAAmB;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAG,CAAC,aAAa,CAAC;QAChD,MAAM,UAAU,GAA2B;YACzC,IAAI,EAAE,MAAM;YACZ,WAAW,EAAE,KAAK;YAClB,cAAc,EAAE,KAAK;YACrB,YAAY,EAAE,KAAK;YACnB,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACjC,GAAG,IAAI,CAAC,UAAU,EAAE;SACrB,CAAC;QAEF,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC1C,KAAK,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;+GAtJmB,yBAAyB;mGAAzB,yBAAyB;;4FAAzB,yBAAyB;kBAD9C,SAAS;8BAmEJ,KAAK;sBADR,KAAK","sourcesContent":["import { AfterViewInit, computed, Directive, ElementRef, input, Input, output, viewChild } from '@angular/core';\nimport { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\nimport { _NgModelComponentBase, _NgModelComponentDefaults, _ngModelComponentDefaults } from '../_internal/ngmodel-component';\nimport { SimpleOneAxisAlignment } from './../types/alignment.types';\nimport { FormElementAppearance, FormElementVariant } from './../types/theming.types';\nimport { Nullable } from './../types/utility.types';\nimport { SimpleInputModel } from './input-utils';\n\nexport interface _SimpleInputComponentDefaults extends _NgModelComponentDefaults {\n  appearance: FormElementAppearance;\n  variant: FormElementVariant;\n  compact: boolean;\n  placeholder: string;\n  alignText: SimpleOneAxisAlignment;\n  clearable: boolean;\n  clearButtonTitle: string;\n  inputAttrs: Record<string, any>;\n  maxLength: Nullable<number>;\n}\n\nexport const _simpleInputComponentDefaults: _SimpleInputComponentDefaults = {\n  ..._ngModelComponentDefaults,\n  appearance: FormElementAppearance.Outlined,\n  variant: FormElementVariant.Rounded,\n  compact: false,\n  placeholder: '',\n  alignText: SimpleOneAxisAlignment.Left,\n  clearable: false,\n  clearButtonTitle: 'Clear',\n  inputAttrs: {},\n  maxLength: undefined,\n};\n\n@Directive()\nexport abstract class _SimpleInputComponentBase extends _NgModelComponentBase implements AfterViewInit {\n  protected override readonly _DEFAULTS!: _SimpleInputComponentDefaults;\n\n  //! input view\n  readonly textInputEl = viewChild<ElementRef<HTMLInputElement>>('textInput');\n\n  protected readonly inputModel = new SimpleInputModel(this);\n  private _wasViewInit = false;\n  ngAfterViewInit(): void {\n    this._wasViewInit = true;\n    this._setInputAttributes();\n    //set the value\n    if (this._valueBeforeInit) {\n      this.writeValue(this._valueBeforeInit);\n      delete this._valueBeforeInit;\n    }\n  }\n\n  readonly placeholder = input<string>(this._DEFAULTS.placeholder);\n  readonly inputId = input<Nullable<string>>(undefined);\n  readonly clearButtonTitle = input<string>(this._DEFAULTS.clearButtonTitle);\n\n  //! prefix & suffix\n  abstract readonly prefixTemplate: any;\n  abstract readonly suffixTemplate: any;\n\n  //! placeholder\n  abstract readonly placeholderTemplate: any;\n\n  readonly shouldDisplayPlaceholder = computed<boolean>(() => Boolean(this.placeholder()) && !this.inputModel.value());\n\n  //! appearance\n  readonly appearance = input<FormElementAppearance>(this._DEFAULTS.appearance);\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\n  readonly alignText = input<SimpleOneAxisAlignment>(this._DEFAULTS.alignText);\n\n  readonly compact = input<boolean, any>(this._DEFAULTS.compact, { transform: v => coerceBooleanProperty(v) });\n\n  readonly ngClasses = computed((): string =>\n    [\n      `ard-appearance-${this.appearance()}`,\n      `ard-variant-${this.variant()}`,\n      `ard-text-align-${this.alignText()}`,\n      this.compact() ? 'ard-compact' : '',\n      this.clearable() ? 'ard-clearable' : '',\n    ].join(' ')\n  );\n\n  //! other inputs\n  readonly inputAttrs = input<Record<string, any>>(this._DEFAULTS.inputAttrs);\n\n  //! number attribute setters/getters\n  readonly maxLength = input<Nullable<number>, any>(this._DEFAULTS.maxLength, {\n    transform: v => coerceNumberProperty(v, this._DEFAULTS.maxLength),\n  });\n\n  //! no-value attribute setters/getters\n  readonly clearable = input<boolean, any>(this._DEFAULTS.clearable, { transform: v => coerceBooleanProperty(v) });\n\n  //! control value accessor's write value implementation\n  writeValue(v: any) {\n    this.inputModel.writeValue(v);\n  }\n  //! value two-way binding\n  protected _valueBeforeInit?: string | null = null;\n  @Input()\n  set value(v: string | null) {\n    if (!this._wasViewInit) {\n      this._valueBeforeInit = v;\n      return;\n    }\n    this.writeValue(v);\n  }\n  get value(): string | null {\n    return this.inputModel.value();\n  }\n  readonly valueChange = output<string | null>();\n\n  //! event emitters\n  readonly inputEvent = output<string | null>({ alias: 'input' });\n  readonly changeEvent = output<string | null>({ alias: 'change' });\n  readonly clearEvent = output<MouseEvent>({ alias: 'clear' });\n\n  //! event handlers\n  onInput(newVal: string): void {\n    const valueHasChanged = this.inputModel.writeValue(newVal);\n    if (!valueHasChanged) return;\n    this._emitInput();\n  }\n  protected _emitInput(): void {\n    this._onChangeRegistered?.(this.value);\n    this.inputEvent.emit(this.value);\n    this.valueChange.emit(this.value);\n  }\n  //focus, blur, change\n  onFocusMaster(event: FocusEvent): void {\n    this.onFocus(event);\n  }\n  onBlurMaster(event: FocusEvent): void {\n    this.onBlur(event);\n  }\n  onChange(event: Event): void {\n    event.stopPropagation();\n    this._emitChange();\n  }\n  protected _emitChange(): void {\n    this.changeEvent.emit(this.inputModel.value());\n  }\n  // clear button\n  readonly shouldShowClearButton = computed<boolean>(\n    () => this.clearable() && !this.disabled() && Boolean(this.inputModel.value())\n  );\n  onClearButtonClick(event: MouseEvent): void {\n    event.stopPropagation();\n    this.inputModel.clear();\n    this._emitChange();\n    this._emitInput();\n    this.clearEvent.emit(event);\n    this.focus();\n  }\n\n  //! copy event\n  onCopy(event: ClipboardEvent): void {\n    if (\n      this.value &&\n      //does the selection cover the entire input\n      ((this.textInputEl()?.nativeElement.selectionStart === 0 &&\n        this.textInputEl()?.nativeElement.selectionEnd === this.textInputEl()?.nativeElement.value.length) ||\n        //or is zero-wide\n        this.textInputEl()?.nativeElement.selectionStart === this.textInputEl()?.nativeElement.selectionEnd)\n    ) {\n      event.clipboardData?.setData('text/plain', this.value);\n      event.preventDefault();\n    }\n  }\n  //! helpers\n  protected _setInputAttributes() {\n    const input = this.textInputEl()!.nativeElement;\n    const attributes: Record<string, string> = {\n      type: 'text',\n      autocorrect: 'off',\n      autocapitalize: 'off',\n      autocomplete: 'off',\n      tabindex: String(this.tabIndex()),\n      ...this.inputAttrs(),\n    };\n\n    for (const key of Object.keys(attributes)) {\n      input.setAttribute(key, String(attributes[key]));\n    }\n  }\n}\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"_simple-input-base.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/inputs/_simple-input-base.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,QAAQ,EAAE,SAAS,EAAc,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAChH,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,uBAAuB,EAA+B,2BAA2B,EAAE,MAAM,mCAAmC,CAAC;AACtI,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAErF,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;;AAcjD,MAAM,CAAC,MAAM,6BAA6B,GAAkC;IAC1E,GAAG,2BAA2B;IAC9B,UAAU,EAAE,qBAAqB,CAAC,QAAQ;IAC1C,OAAO,EAAE,kBAAkB,CAAC,OAAO;IACnC,OAAO,EAAE,KAAK;IACd,WAAW,EAAE,EAAE;IACf,SAAS,EAAE,sBAAsB,CAAC,IAAI;IACtC,SAAS,EAAE,KAAK;IAChB,gBAAgB,EAAE,OAAO;IACzB,UAAU,EAAE,EAAE;IACd,SAAS,EAAE,SAAS;CACrB,CAAC;AAGF,MAAM,OAAgB,yBAA0B,SAAQ,uBAAuB;IAD/E;;QAIE,cAAc;QACL,gBAAW,GAAG,SAAS,CAA+B,WAAW,CAAC,CAAC;QAEzD,eAAU,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACnD,iBAAY,GAAG,KAAK,CAAC;QAWpB,gBAAW,GAAG,KAAK,CAAS,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACxD,YAAO,GAAG,KAAK,CAAmB,SAAS,CAAC,CAAC;QAC7C,qBAAgB,GAAG,KAAK,CAAS,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QASlE,6BAAwB,GAAG,QAAQ,CAAU,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC,CAAC;QAErH,cAAc;QACL,eAAU,GAAG,KAAK,CAAwB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACrE,YAAO,GAAG,KAAK,CAAqB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC5D,cAAS,GAAG,KAAK,CAAyB,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAEpE,YAAO,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEpG,cAAS,GAAG,QAAQ,CAAC,GAAW,EAAE,CACzC;YACE,kBAAkB,IAAI,CAAC,UAAU,EAAE,EAAE;YACrC,eAAe,IAAI,CAAC,OAAO,EAAE,EAAE;YAC/B,kBAAkB,IAAI,CAAC,SAAS,EAAE,EAAE;YACpC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE;SACxC,CAAC,IAAI,CAAC,GAAG,CAAC,CACZ,CAAC;QAEF,gBAAgB;QACP,eAAU,GAAG,KAAK,CAAsB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAE5E,oCAAoC;QAC3B,cAAS,GAAG,KAAK,CAAwB,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE;YAC1E,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;SAClE,CAAC,CAAC;QAEH,sCAAsC;QAC7B,cAAS,GAAG,KAAK,CAAe,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAMjH,yBAAyB;QACf,qBAAgB,GAAmB,IAAI,CAAC;QAYzC,gBAAW,GAAG,MAAM,EAAiB,CAAC;QAE/C,kBAAkB;QACT,eAAU,GAAG,MAAM,CAAgB,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;QACvD,gBAAW,GAAG,MAAM,CAAgB,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;QACzD,eAAU,GAAG,MAAM,CAAa,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;QA2B7D,eAAe;QACN,0BAAqB,GAAG,QAAQ,CACvC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC,CAC/E,CAAC;KAwCH;IA/IC,eAAe;QACb,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,eAAe;QACf,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACvC,OAAO,IAAI,CAAC,gBAAgB,CAAC;QAC/B,CAAC;IACH,CAAC;IA2CD,uDAAuD;IACvD,UAAU,CAAC,CAAM;QACf,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC;IAGD,IACI,KAAK,CAAC,CAAgB;QACxB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;YAC1B,OAAO;QACT,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IACD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IACjC,CAAC;IAQD,kBAAkB;IAClB,OAAO,CAAC,MAAc;QACpB,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAC3D,IAAI,CAAC,eAAe;YAAE,OAAO;QAC7B,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IACS,UAAU;QAClB,IAAI,CAAC,mBAAmB,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IACD,qBAAqB;IACrB,aAAa,CAAC,KAAiB;QAC7B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACtB,CAAC;IACD,YAAY,CAAC,KAAiB;QAC5B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;IACD,QAAQ,CAAC,KAAY;QACnB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IACS,WAAW;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC,CAAC;IACjD,CAAC;IAKD,kBAAkB,CAAC,KAAiB;QAClC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED,cAAc;IACd,MAAM,CAAC,KAAqB;QAC1B,IACE,IAAI,CAAC,KAAK;YACV,2CAA2C;YAC3C,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,cAAc,KAAK,CAAC;gBACtD,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,YAAY,KAAK,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC;gBAClG,iBAAiB;gBACjB,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,cAAc,KAAK,IAAI,CAAC,WAAW,EAAE,EAAE,aAAa,CAAC,YAAY,CAAC,EACtG,CAAC;YACD,KAAK,CAAC,aAAa,EAAE,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YACvD,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;IACD,WAAW;IACD,mBAAmB;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAG,CAAC,aAAa,CAAC;QAChD,MAAM,UAAU,GAA2B;YACzC,IAAI,EAAE,MAAM;YACZ,WAAW,EAAE,KAAK;YAClB,cAAc,EAAE,KAAK;YACrB,YAAY,EAAE,KAAK;YACnB,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACjC,GAAG,IAAI,CAAC,UAAU,EAAE;SACrB,CAAC;QAEF,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC1C,KAAK,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;+GAtJmB,yBAAyB;mGAAzB,yBAAyB;;4FAAzB,yBAAyB;kBAD9C,SAAS;8BAmEJ,KAAK;sBADR,KAAK","sourcesContent":["import { AfterViewInit, computed, Directive, ElementRef, input, Input, output, viewChild } from '@angular/core';\r\nimport { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\r\nimport { _FormFieldComponentBase, _FormFieldComponentDefaults, _formFieldComponentDefaults } from '../_internal/form-field-component';\r\nimport { SimpleOneAxisAlignment } from './../types/alignment.types';\r\nimport { FormElementAppearance, FormElementVariant } from './../types/theming.types';\r\nimport { Nullable } from './../types/utility.types';\r\nimport { SimpleInputModel } from './input-utils';\r\n\r\nexport interface _SimpleInputComponentDefaults extends _FormFieldComponentDefaults {\r\n  appearance: FormElementAppearance;\r\n  variant: FormElementVariant;\r\n  compact: boolean;\r\n  placeholder: string;\r\n  alignText: SimpleOneAxisAlignment;\r\n  clearable: boolean;\r\n  clearButtonTitle: string;\r\n  inputAttrs: Record<string, any>;\r\n  maxLength: Nullable<number>;\r\n}\r\n\r\nexport const _simpleInputComponentDefaults: _SimpleInputComponentDefaults = {\r\n  ..._formFieldComponentDefaults,\r\n  appearance: FormElementAppearance.Outlined,\r\n  variant: FormElementVariant.Rounded,\r\n  compact: false,\r\n  placeholder: '',\r\n  alignText: SimpleOneAxisAlignment.Left,\r\n  clearable: false,\r\n  clearButtonTitle: 'Clear',\r\n  inputAttrs: {},\r\n  maxLength: undefined,\r\n};\r\n\r\n@Directive()\r\nexport abstract class _SimpleInputComponentBase extends _FormFieldComponentBase implements AfterViewInit {\r\n  protected override readonly _DEFAULTS!: _SimpleInputComponentDefaults;\r\n\r\n  //! input view\r\n  readonly textInputEl = viewChild<ElementRef<HTMLInputElement>>('textInput');\r\n\r\n  protected readonly inputModel = new SimpleInputModel(this);\r\n  private _wasViewInit = false;\r\n  ngAfterViewInit(): void {\r\n    this._wasViewInit = true;\r\n    this._setInputAttributes();\r\n    //set the value\r\n    if (this._valueBeforeInit) {\r\n      this.writeValue(this._valueBeforeInit);\r\n      delete this._valueBeforeInit;\r\n    }\r\n  }\r\n\r\n  readonly placeholder = input<string>(this._DEFAULTS.placeholder);\r\n  readonly inputId = input<Nullable<string>>(undefined);\r\n  readonly clearButtonTitle = input<string>(this._DEFAULTS.clearButtonTitle);\r\n\r\n  //! prefix & suffix\r\n  abstract readonly prefixTemplate: any;\r\n  abstract readonly suffixTemplate: any;\r\n\r\n  //! placeholder\r\n  abstract readonly placeholderTemplate: any;\r\n\r\n  readonly shouldDisplayPlaceholder = computed<boolean>(() => Boolean(this.placeholder()) && !this.inputModel.value());\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 alignText = input<SimpleOneAxisAlignment>(this._DEFAULTS.alignText);\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-text-align-${this.alignText()}`,\r\n      this.compact() ? 'ard-compact' : '',\r\n      this.clearable() ? 'ard-clearable' : '',\r\n    ].join(' ')\r\n  );\r\n\r\n  //! other inputs\r\n  readonly inputAttrs = input<Record<string, any>>(this._DEFAULTS.inputAttrs);\r\n\r\n  //! number attribute setters/getters\r\n  readonly maxLength = input<Nullable<number>, any>(this._DEFAULTS.maxLength, {\r\n    transform: v => coerceNumberProperty(v, this._DEFAULTS.maxLength),\r\n  });\r\n\r\n  //! no-value attribute setters/getters\r\n  readonly clearable = input<boolean, any>(this._DEFAULTS.clearable, { transform: v => coerceBooleanProperty(v) });\r\n\r\n  //! control value accessor's write value implementation\r\n  writeValue(v: any) {\r\n    this.inputModel.writeValue(v);\r\n  }\r\n  //! value two-way binding\r\n  protected _valueBeforeInit?: string | null = null;\r\n  @Input()\r\n  set value(v: string | null) {\r\n    if (!this._wasViewInit) {\r\n      this._valueBeforeInit = v;\r\n      return;\r\n    }\r\n    this.writeValue(v);\r\n  }\r\n  get value(): string | null {\r\n    return this.inputModel.value();\r\n  }\r\n  readonly valueChange = output<string | null>();\r\n\r\n  //! event emitters\r\n  readonly inputEvent = output<string | null>({ alias: 'input' });\r\n  readonly changeEvent = output<string | null>({ alias: 'change' });\r\n  readonly clearEvent = output<MouseEvent>({ alias: 'clear' });\r\n\r\n  //! event handlers\r\n  onInput(newVal: string): void {\r\n    const valueHasChanged = this.inputModel.writeValue(newVal);\r\n    if (!valueHasChanged) return;\r\n    this._emitInput();\r\n  }\r\n  protected _emitInput(): void {\r\n    this._onChangeRegistered?.(this.value);\r\n    this.inputEvent.emit(this.value);\r\n    this.valueChange.emit(this.value);\r\n  }\r\n  //focus, blur, change\r\n  onFocusMaster(event: FocusEvent): void {\r\n    this.onFocus(event);\r\n  }\r\n  onBlurMaster(event: FocusEvent): void {\r\n    this.onBlur(event);\r\n  }\r\n  onChange(event: Event): void {\r\n    event.stopPropagation();\r\n    this._emitChange();\r\n  }\r\n  protected _emitChange(): void {\r\n    this.changeEvent.emit(this.inputModel.value());\r\n  }\r\n  // clear button\r\n  readonly shouldShowClearButton = computed<boolean>(\r\n    () => this.clearable() && !this.disabled() && Boolean(this.inputModel.value())\r\n  );\r\n  onClearButtonClick(event: MouseEvent): void {\r\n    event.stopPropagation();\r\n    this.inputModel.clear();\r\n    this._emitChange();\r\n    this._emitInput();\r\n    this.clearEvent.emit(event);\r\n    this.focus();\r\n  }\r\n\r\n  //! copy event\r\n  onCopy(event: ClipboardEvent): void {\r\n    if (\r\n      this.value &&\r\n      //does the selection cover the entire input\r\n      ((this.textInputEl()?.nativeElement.selectionStart === 0 &&\r\n        this.textInputEl()?.nativeElement.selectionEnd === this.textInputEl()?.nativeElement.value.length) ||\r\n        //or is zero-wide\r\n        this.textInputEl()?.nativeElement.selectionStart === this.textInputEl()?.nativeElement.selectionEnd)\r\n    ) {\r\n      event.clipboardData?.setData('text/plain', this.value);\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  //! helpers\r\n  protected _setInputAttributes() {\r\n    const input = this.textInputEl()!.nativeElement;\r\n    const attributes: Record<string, string> = {\r\n      type: 'text',\r\n      autocorrect: 'off',\r\n      autocapitalize: 'off',\r\n      autocomplete: 'off',\r\n      tabindex: String(this.tabIndex()),\r\n      ...this.inputAttrs(),\r\n    };\r\n\r\n    for (const key of Object.keys(attributes)) {\r\n      input.setAttribute(key, String(attributes[key]));\r\n    }\r\n  }\r\n}\r\n"]}
@@ -1,12 +1,12 @@
1
1
  import { ChangeDetectionStrategy, Component, Inject, Input, ViewEncapsulation, computed, effect, forwardRef, input, output, viewChildren, } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { coerceBooleanProperty } from '@ardium-ui/devkit';
4
- import { _NgModelComponentBase } from '../../_internal/ngmodel-component';
4
+ import { _FormFieldComponentBase } from '../../_internal/form-field-component';
5
5
  import { ARD_DIGIT_INPUT_DEFAULTS } from './digit-input.defaults';
6
6
  import { DigitInputModel } from './digit-input.model';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/common";
9
- export class ArdiumDigitInputComponent extends _NgModelComponentBase {
9
+ export class ArdiumDigitInputComponent extends _FormFieldComponentBase {
10
10
  constructor(defaults) {
11
11
  super(defaults);
12
12
  //! inputs ref
@@ -38,6 +38,7 @@ export class ArdiumDigitInputComponent extends _NgModelComponentBase {
38
38
  });
39
39
  //! value two-way binding
40
40
  this.outputAsString = input(this._DEFAULTS.outputAsString, { transform: v => coerceBooleanProperty(v) });
41
+ this.outputControlValueAccessorOnFinish = input(false, { transform: v => coerceBooleanProperty(v) });
41
42
  this.valueChange = output();
42
43
  this.stringValue = this.model.stringValue;
43
44
  this.emittableValue = computed(() => {
@@ -50,6 +51,10 @@ export class ArdiumDigitInputComponent extends _NgModelComponentBase {
50
51
  this.focusIndexEvent = output({ alias: 'focusIndex' });
51
52
  this.blurIndexEvent = output({ alias: 'blurIndex' });
52
53
  }
54
+ ngOnInit() {
55
+ super.ngOnInit();
56
+ this._oldConfigArrayDataLength = this.configArrayData().length;
57
+ }
53
58
  isInputEmpty(index) {
54
59
  return !this.model.isDefinedAtIndex(index);
55
60
  }
@@ -80,17 +85,20 @@ export class ArdiumDigitInputComponent extends _NgModelComponentBase {
80
85
  this.focusByIndex(index - 1 + Math.min(value.length, maxLength));
81
86
  }
82
87
  onInput(event, index) {
83
- this._updateSingleInputValue(event.target.value, index);
88
+ const wasChanged = this._updateSingleInputValue(event.target.value, index);
89
+ if (!wasChanged)
90
+ return;
84
91
  this.focusByIndex(index + 1);
85
92
  }
86
93
  _updateSingleInputValue(value, index) {
87
- const valueChanged = this.model.validateInputAndSetValue(value, index);
88
- if (!valueChanged || !valueChanged[0])
89
- return;
94
+ const changeResult = this.model.validateInputAndSetValue(value, index);
95
+ if (!changeResult?.wasChanged)
96
+ return false;
90
97
  this._emitChange();
91
98
  if (this.model.isValueFull()) {
92
99
  this.blur();
93
100
  }
101
+ return true;
94
102
  }
95
103
  focusByIndex(index, tryFocusingNext, direction) {
96
104
  if (index < 0 || index >= this.inputs().length)
@@ -115,7 +123,8 @@ export class ArdiumDigitInputComponent extends _NgModelComponentBase {
115
123
  }
116
124
  _emitChange() {
117
125
  const v = this.emittableValue();
118
- this._onChangeRegistered?.(v);
126
+ if (!this.outputControlValueAccessorOnFinish() || this.model.isValueFull())
127
+ this._onChangeRegistered?.(v);
119
128
  this.valueChange.emit(v);
120
129
  if (this.model.isValueFull()) {
121
130
  this.finishedValue.emit(v);
@@ -144,13 +153,17 @@ export class ArdiumDigitInputComponent extends _NgModelComponentBase {
144
153
  }
145
154
  }
146
155
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumDigitInputComponent, deps: [{ token: ARD_DIGIT_INPUT_DEFAULTS }], target: i0.ɵɵFactoryTarget.Component }); }
147
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumDigitInputComponent, selector: "ard-digit-input", inputs: { appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, shape: { classPropertyName: "shape", publicName: "shape", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, outputAsString: { classPropertyName: "outputAsString", publicName: "outputAsString", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { valueChange: "valueChange", finishedValue: "finishedValue", focusIndexEvent: "focusIndex", blurIndexEvent: "blurIndex" }, providers: [
156
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ArdiumDigitInputComponent, selector: "ard-digit-input", inputs: { appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, shape: { classPropertyName: "shape", publicName: "shape", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, outputAsString: { classPropertyName: "outputAsString", publicName: "outputAsString", isSignal: true, isRequired: false, transformFunction: null }, outputControlValueAccessorOnFinish: { classPropertyName: "outputControlValueAccessorOnFinish", publicName: "outputControlValueAccessorOnFinish", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { valueChange: "valueChange", finishedValue: "finishedValue", focusIndexEvent: "focusIndex", blurIndexEvent: "blurIndex" }, providers: [
148
157
  {
149
158
  provide: NG_VALUE_ACCESSOR,
150
159
  useExisting: forwardRef(() => ArdiumDigitInputComponent),
151
160
  multi: true,
152
161
  },
153
- ], viewQueries: [{ propertyName: "inputs", predicate: ["input"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\n class=\"ard-digit-input\"\n [ngClass]=\"ngClasses()\"\n>\n @for (data of configArrayData(); track $index) {\n <div class=\"ard-digit-input__item\">\n @if (data.type === 'input') {\n <input\n #input\n #focusableElement\n class=\"ard-digit-input__input\"\n type=\"text\"\n autocomplete=\"off\"\n [readonly]=\"data.readonly\"\n [class.ard-digit-input__input-readonly]=\"data.readonly\"\n [class.ard-digit-input__input-empty]=\"isInputEmpty(data.index!)\"\n (paste)=\"onPaste($event, data.index!)\"\n (input)=\"onInput($event, data.index!)\"\n (focus)=\"onFocusMaster($event, data.index!)\"\n (blur)=\"onBlurMaster($event, data.index!)\"\n (keydown)=\"onKeydown($event, data.index!)\"\n />\n } @else {\n <div class=\"ard-digit-input__static\">\n {{ data.char }}\n </div>\n }\n </div>\n }\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
162
+ {
163
+ provide: _FormFieldComponentBase,
164
+ useExisting: ArdiumDigitInputComponent,
165
+ },
166
+ ], viewQueries: [{ propertyName: "inputs", predicate: ["input"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n class=\"ard-digit-input\"\r\n [ngClass]=\"ngClasses()\"\r\n [class.ard-has-error]=\"hasError()\"\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", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
154
167
  }
155
168
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ArdiumDigitInputComponent, decorators: [{
156
169
  type: Component,
@@ -160,11 +173,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
160
173
  useExisting: forwardRef(() => ArdiumDigitInputComponent),
161
174
  multi: true,
162
175
  },
163
- ], template: "<div\n class=\"ard-digit-input\"\n [ngClass]=\"ngClasses()\"\n>\n @for (data of configArrayData(); track $index) {\n <div class=\"ard-digit-input__item\">\n @if (data.type === 'input') {\n <input\n #input\n #focusableElement\n class=\"ard-digit-input__input\"\n type=\"text\"\n autocomplete=\"off\"\n [readonly]=\"data.readonly\"\n [class.ard-digit-input__input-readonly]=\"data.readonly\"\n [class.ard-digit-input__input-empty]=\"isInputEmpty(data.index!)\"\n (paste)=\"onPaste($event, data.index!)\"\n (input)=\"onInput($event, data.index!)\"\n (focus)=\"onFocusMaster($event, data.index!)\"\n (blur)=\"onBlurMaster($event, data.index!)\"\n (keydown)=\"onKeydown($event, data.index!)\"\n />\n } @else {\n <div class=\"ard-digit-input__static\">\n {{ data.char }}\n </div>\n }\n </div>\n }\n</div>\n" }]
176
+ {
177
+ provide: _FormFieldComponentBase,
178
+ useExisting: ArdiumDigitInputComponent,
179
+ },
180
+ ], template: "<div\r\n class=\"ard-digit-input\"\r\n [ngClass]=\"ngClasses()\"\r\n [class.ard-has-error]=\"hasError()\"\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" }]
164
181
  }], ctorParameters: () => [{ type: undefined, decorators: [{
165
182
  type: Inject,
166
183
  args: [ARD_DIGIT_INPUT_DEFAULTS]
167
184
  }] }], propDecorators: { value: [{
168
185
  type: Input
169
186
  }] } });
170
- //# 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 {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  ViewEncapsulation,\n  computed,\n  effect,\n  forwardRef,\n  input,\n  output,\n  viewChildren,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { coerceBooleanProperty } from '@ardium-ui/devkit';\nimport { _NgModelComponentBase } from '../../_internal/ngmodel-component';\nimport { FormElementAppearance, FormElementVariant } from '../../types/theming.types';\nimport { ARD_DIGIT_INPUT_DEFAULTS, ArdDigitInputDefaults } from './digit-input.defaults';\nimport { DigitInputModel } from './digit-input.model';\nimport { DigitInputConfig, DigitInputShape } from './digit-input.types';\nimport { DigitInputModelHost } from './digit-input.utils';\n\n@Component({\n  selector: 'ard-digit-input',\n  templateUrl: './digit-input.component.html',\n  styleUrls: ['./digit-input.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ArdiumDigitInputComponent),\n      multi: true,\n    },\n  ],\n})\nexport class ArdiumDigitInputComponent extends _NgModelComponentBase implements ControlValueAccessor, DigitInputModelHost {\n  protected override readonly _DEFAULTS!: ArdDigitInputDefaults;\n  constructor(@Inject(ARD_DIGIT_INPUT_DEFAULTS) defaults: ArdDigitInputDefaults) {\n    super(defaults);\n  }\n\n  //! inputs ref\n  readonly inputs = viewChildren<ElementRef<HTMLInputElement>>('input');\n\n  //! data model\n  private readonly model = new DigitInputModel(this);\n\n  //! appearance\n  readonly appearance = input<FormElementAppearance>(this._DEFAULTS.appearance);\n  readonly variant = input<FormElementVariant>(this._DEFAULTS.variant);\n  readonly shape = input<DigitInputShape>(this._DEFAULTS.shape);\n\n  readonly compact = input<boolean, any>(this._DEFAULTS.compact, { transform: v => coerceBooleanProperty(v) });\n\n  readonly ngClasses = computed((): string =>\n    [\n      `ard-appearance-${this.appearance()}`,\n      `ard-variant-${this.variant()}`,\n      `ard-shape-${this.shape()}`,\n      this.compact() ? 'ard-compact' : '',\n    ].join(' ')\n  );\n\n  //! model access points\n  readonly config = input.required<void, DigitInputConfig>({\n    transform: v => this.model.setConfig(v),\n  });\n  readonly configArrayData = this.model.configArrayData;\n\n  private _oldConfigArrayDataLength = -1;\n  readonly configArrayDataEffect = effect(() => {\n    if (this.configArrayData().length === this._oldConfigArrayDataLength) return;\n\n    this._oldConfigArrayDataLength = this.configArrayData().length;\n    this._emitChange();\n  });\n\n  isInputEmpty(index: number): boolean {\n    return !this.model.isDefinedAtIndex(index);\n  }\n\n  //! control value accessor's write value implementation\n  writeValue(v: any): void {\n    this._writeValue(v);\n  }\n  private _writeValue(v: any): boolean {\n    return this.model.writeValue(v);\n  }\n\n  //! value two-way binding\n  readonly outputAsString = input<boolean, any>(this._DEFAULTS.outputAsString, { transform: v => coerceBooleanProperty(v) });\n\n  @Input()\n  set value(v: string | (string | null)[] | null) {\n    this.writeValue(v);\n  }\n  readonly valueChange = output<string | (string | null)[] | null>();\n\n  readonly stringValue = this.model.stringValue;\n\n  readonly emittableValue = computed((): string | (string | null)[] | null => {\n    if (this.outputAsString()) return this.model.stringValue();\n    return this.model.value();\n  });\n\n  //! event emitters\n  readonly finishedValue = output<string | (string | null)[] | null>();\n\n  readonly focusIndexEvent = output<number>({ alias: 'focusIndex' });\n  readonly blurIndexEvent = output<number>({ alias: 'blurIndex' });\n\n  //! event handlers\n  onPaste(event: ClipboardEvent, index: number): void {\n    const value = event.clipboardData?.getData('text');\n    event.stopPropagation();\n    event.preventDefault();\n    if (!value) return;\n\n    const maxLength = this.inputs().length - index;\n    value\n      .slice(0, maxLength)\n      .split('')\n      .forEach((char, i) => {\n        this.model.validateInputAndSetValue(char, index + i);\n      });\n    this.focusByIndex(index - 1 + Math.min(value.length, maxLength));\n  }\n  onInput(event: Event, index: number): void {\n    this._updateSingleInputValue((event.target as HTMLInputElement).value, index);\n    this.focusByIndex(index + 1);\n  }\n  private _updateSingleInputValue(value: string, index: number): void {\n    const valueChanged = this.model.validateInputAndSetValue(value, index);\n    if (!valueChanged || !valueChanged[0]) return;\n\n    this._emitChange();\n\n    if (this.model.isValueFull()) {\n      this.blur();\n    }\n  }\n  focusByIndex(index: number): boolean;\n  focusByIndex(index: number, tryFocusingNext: boolean, direction: 1 | -1): boolean;\n  focusByIndex(index: number, tryFocusingNext?: boolean, direction?: 1 | -1): boolean {\n    if (index < 0 || index >= this.inputs().length) return false;\n    const nextEl = this.inputs()[index]?.nativeElement;\n    if (!nextEl) return false;\n\n    nextEl.focus();\n    if (tryFocusingNext && direction && document.activeElement !== nextEl) {\n      return this.focusByIndex(index + direction);\n    }\n    return document.activeElement === nextEl;\n  }\n  //focus, blur, change\n  onFocusMaster(event: FocusEvent, index: number): void {\n    this.focusIndexEvent.emit(index);\n    this.onFocus(event);\n  }\n  onBlurMaster(event: FocusEvent, index: number): void {\n    this.blurIndexEvent.emit(index);\n    this.onBlur(event);\n  }\n  protected _emitChange(): void {\n    const v = this.emittableValue();\n    this._onChangeRegistered?.(v);\n    this.valueChange.emit(v);\n    if (this.model.isValueFull()) {\n      this.finishedValue.emit(v);\n    }\n  }\n  onKeydown(event: KeyboardEvent, index: number): void {\n    switch (event.key) {\n      case 'ArrowLeft':\n        this.focusByIndex(index - 1, true, -1);\n        return;\n      case 'ArrowRight':\n        this.focusByIndex(index + 1, true, +1);\n        return;\n      case 'Home':\n        this.focusByIndex(0, true, 1);\n        return;\n      case 'End':\n        this.focusByIndex(this.inputs.length - 1, true, -1);\n        return;\n      case 'Backspace':\n      case 'Delete':\n        this._updateSingleInputValue('', index);\n        this.focusByIndex(index - 1, true, -1);\n        event.preventDefault();\n        return;\n    }\n  }\n}\n","<div\n  class=\"ard-digit-input\"\n  [ngClass]=\"ngClasses()\"\n>\n  @for (data of configArrayData(); track $index) {\n    <div class=\"ard-digit-input__item\">\n      @if (data.type === 'input') {\n        <input\n          #input\n          #focusableElement\n          class=\"ard-digit-input__input\"\n          type=\"text\"\n          autocomplete=\"off\"\n          [readonly]=\"data.readonly\"\n          [class.ard-digit-input__input-readonly]=\"data.readonly\"\n          [class.ard-digit-input__input-empty]=\"isInputEmpty(data.index!)\"\n          (paste)=\"onPaste($event, data.index!)\"\n          (input)=\"onInput($event, data.index!)\"\n          (focus)=\"onFocusMaster($event, data.index!)\"\n          (blur)=\"onBlurMaster($event, data.index!)\"\n          (keydown)=\"onKeydown($event, data.index!)\"\n        />\n      } @else {\n        <div class=\"ard-digit-input__static\">\n          {{ data.char }}\n        </div>\n      }\n    </div>\n  }\n</div>\n"]}
187
+ //# 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  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\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  writeValue(v: any): void {\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  //! 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>\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"]}