@energycap/components 0.42.0 → 0.42.2-ECAP-26676-readonly-attribute-suppresses-help-popovers-on-checkboxes.20250122-1358

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 (41) hide show
  1. package/esm2022/lib/components.module.mjs +10 -5
  2. package/esm2022/lib/controls/calendar/calendar-item.component.mjs +46 -14
  3. package/esm2022/lib/controls/calendar/calendar.component.mjs +169 -121
  4. package/esm2022/lib/controls/calendar/calendar.types.mjs +2 -4
  5. package/esm2022/lib/controls/checkbox/checkbox.component.mjs +2 -2
  6. package/esm2022/lib/controls/date-input/date-input-selection-strategies/date-input-selection-strategy-base.mjs +57 -0
  7. package/esm2022/lib/controls/date-input/date-input-selection-strategies/day-selection-strategy.mjs +62 -0
  8. package/esm2022/lib/controls/date-input/date-input-selection-strategies/last-28-days-selection-strategy.mjs +100 -0
  9. package/esm2022/lib/controls/date-input/date-input-selection-strategies/last-7-days-selection-strategy.mjs +101 -0
  10. package/esm2022/lib/controls/date-input/date-input-selection-strategies/month-selection-strategy.mjs +76 -0
  11. package/esm2022/lib/controls/date-input/date-input-selection-strategies/quarter-selection-strategy.mjs +79 -0
  12. package/esm2022/lib/controls/date-input/date-input-selection-strategies/range-selection-strategy.mjs +210 -0
  13. package/esm2022/lib/controls/date-input/date-input-selection-strategies/year-selection-strategy.mjs +81 -0
  14. package/esm2022/lib/controls/date-input/date-input.component.mjs +322 -113
  15. package/esm2022/lib/controls/date-input/date-input.types.mjs +44 -0
  16. package/esm2022/lib/controls/file-upload/file-upload.component.mjs +1 -1
  17. package/esm2022/lib/controls/form-control/form-control.component.mjs +6 -12
  18. package/esm2022/lib/core/date-time-helper.mjs +10 -2
  19. package/esm2022/lib/shared/directives/keyboard-nav-container/keyboard-nav-container.directive.mjs +100 -0
  20. package/esm2022/public-api.mjs +63 -61
  21. package/fesm2022/energycap-components.mjs +1668 -509
  22. package/fesm2022/energycap-components.mjs.map +1 -1
  23. package/lib/components.module.d.ts +9 -8
  24. package/lib/controls/calendar/calendar-item.component.d.ts +11 -6
  25. package/lib/controls/calendar/calendar.component.d.ts +21 -23
  26. package/lib/controls/calendar/calendar.types.d.ts +11 -7
  27. package/lib/controls/date-input/date-input-selection-strategies/date-input-selection-strategy-base.d.ts +42 -0
  28. package/lib/controls/date-input/date-input-selection-strategies/day-selection-strategy.d.ts +21 -0
  29. package/lib/controls/date-input/date-input-selection-strategies/last-28-days-selection-strategy.d.ts +21 -0
  30. package/lib/controls/date-input/date-input-selection-strategies/last-7-days-selection-strategy.d.ts +21 -0
  31. package/lib/controls/date-input/date-input-selection-strategies/month-selection-strategy.d.ts +18 -0
  32. package/lib/controls/date-input/date-input-selection-strategies/quarter-selection-strategy.d.ts +18 -0
  33. package/lib/controls/date-input/date-input-selection-strategies/range-selection-strategy.d.ts +21 -0
  34. package/lib/controls/date-input/date-input-selection-strategies/year-selection-strategy.d.ts +20 -0
  35. package/lib/controls/date-input/date-input.component.d.ts +63 -28
  36. package/lib/controls/date-input/date-input.types.d.ts +62 -0
  37. package/lib/controls/form-control/form-control.component.d.ts +4 -6
  38. package/lib/shared/directives/keyboard-nav-container/keyboard-nav-container.directive.d.ts +23 -0
  39. package/package.json +1 -1
  40. package/public-api.d.ts +62 -60
  41. package/src/assets/locales/en_US.json +9 -1
@@ -0,0 +1,44 @@
1
+ import { Injectable } from "@angular/core";
2
+ import { DaySelectionStrategy } from "./date-input-selection-strategies/day-selection-strategy";
3
+ import { Last28DaysSelectionStrategy } from "./date-input-selection-strategies/last-28-days-selection-strategy";
4
+ import { Last7DaysSelectionStrategy } from "./date-input-selection-strategies/last-7-days-selection-strategy";
5
+ import { MonthSelectionStrategy } from "./date-input-selection-strategies/month-selection-strategy";
6
+ import { QuarterSelectionStrategy } from "./date-input-selection-strategies/quarter-selection-strategy";
7
+ import { RangeSelectionStrategy } from "./date-input-selection-strategies/range-selection-strategy";
8
+ import { YearSelectionStrategy } from "./date-input-selection-strategies/year-selection-strategy";
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../shared/display/pipes/date-display.pipe";
11
+ export var DateInput;
12
+ (function (DateInput) {
13
+ function isSelectionSingleDate(selection) {
14
+ return selection instanceof Date;
15
+ }
16
+ DateInput.isSelectionSingleDate = isSelectionSingleDate;
17
+ function isSelectionRange(selection) {
18
+ return !!selection && !isSelectionSingleDate(selection);
19
+ }
20
+ DateInput.isSelectionRange = isSelectionRange;
21
+ class SelectionStrategies {
22
+ constructor(dateDisplayPipe) {
23
+ this.dateDisplayPipe = dateDisplayPipe;
24
+ this._range = new RangeSelectionStrategy();
25
+ this._day = new DaySelectionStrategy(this.dateDisplayPipe);
26
+ this._last7Days = new Last7DaysSelectionStrategy(this._range);
27
+ this._last28Days = new Last28DaysSelectionStrategy(this._range);
28
+ this._month = new MonthSelectionStrategy();
29
+ this._quarter = new QuarterSelectionStrategy();
30
+ this._year = new YearSelectionStrategy();
31
+ }
32
+ get range() { return this._range; }
33
+ get day() { return this._day; }
34
+ get last7Days() { return this._last7Days; }
35
+ get last28Days() { return this._last28Days; }
36
+ get month() { return this._month; }
37
+ get quarter() { return this._quarter; }
38
+ get year() { return this._year; }
39
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectionStrategies, deps: [{ token: i1.DateDisplayPipe }], target: i0.ɵɵFactoryTarget.Injectable }); }
40
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectionStrategies }); }
41
+ }
42
+ DateInput.SelectionStrategies = SelectionStrategies;
43
+ })(DateInput || (DateInput = {}));
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1pbnB1dC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9jb250cm9scy9kYXRlLWlucHV0L2RhdGUtaW5wdXQudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUkzQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwREFBMEQsQ0FBQztBQUNoRyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxtRUFBbUUsQ0FBQztBQUNoSCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUM5RyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQztBQUNwRyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQztBQUN4RyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQztBQUNwRyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyREFBMkQsQ0FBQzs7O0FBRWxHLE1BQU0sS0FBVyxTQUFTLENBa0V6QjtBQWxFRCxXQUFpQixTQUFTO0lBY3hCLFNBQWdCLHFCQUFxQixDQUFDLFNBQTRCO1FBQ2hFLE9BQU8sU0FBUyxZQUFZLElBQUksQ0FBQztJQUNuQyxDQUFDO0lBRmUsK0JBQXFCLHdCQUVwQyxDQUFBO0lBRUQsU0FBZ0IsZ0JBQWdCLENBQUMsU0FBNEI7UUFDM0QsT0FBTyxDQUFDLENBQUMsU0FBUyxJQUFJLENBQUMscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUZlLDBCQUFnQixtQkFFL0IsQ0FBQTtJQW1CRCxNQUNhLG1CQUFtQjtRQUM5QixZQUNVLGVBQWdDO1lBQWhDLG9CQUFlLEdBQWYsZUFBZSxDQUFpQjtZQUdsQyxXQUFNLEdBQUcsSUFBSSxzQkFBc0IsRUFBRSxDQUFDO1lBR3RDLFNBQUksR0FBRyxJQUFJLG9CQUFvQixDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztZQUd0RCxlQUFVLEdBQUcsSUFBSSwwQkFBMEIsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7WUFHekQsZ0JBQVcsR0FBRyxJQUFJLDJCQUEyQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUczRCxXQUFNLEdBQUcsSUFBSSxzQkFBc0IsRUFBRSxDQUFDO1lBR3RDLGFBQVEsR0FBRyxJQUFJLHdCQUF3QixFQUFFLENBQUM7WUFHM0MsVUFBSyxHQUFHLElBQUkscUJBQXFCLEVBQUUsQ0FBQztRQXBCdkMsQ0FBQztRQUdMLElBQVcsS0FBSyxLQUFLLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFHMUMsSUFBVyxHQUFHLEtBQUssT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUd0QyxJQUFXLFNBQVMsS0FBSyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBR2xELElBQVcsVUFBVSxLQUFLLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7UUFHcEQsSUFBVyxLQUFLLEtBQUssT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUcxQyxJQUFXLE9BQU8sS0FBSyxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1FBRzlDLElBQVcsSUFBSSxLQUFLLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7bUhBeEI3QixtQkFBbUI7dUhBQW5CLG1CQUFtQjs7SUFBbkIsNkJBQW1CLHNCQXlCL0IsQ0FBQTtBQUNILENBQUMsRUFsRWdCLFNBQVMsS0FBVCxTQUFTLFFBa0V6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBGb3JtQ29udHJvbCwgRm9ybUdyb3VwIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7IERhdGVEaXNwbGF5UGlwZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvZGlzcGxheS9waXBlcy9kYXRlLWRpc3BsYXkucGlwZVwiO1xyXG5pbXBvcnQgeyBEYXRlSW5wdXRTZWxlY3Rpb25TdHJhdGVneUJhc2UgfSBmcm9tIFwiLi9kYXRlLWlucHV0LXNlbGVjdGlvbi1zdHJhdGVnaWVzL2RhdGUtaW5wdXQtc2VsZWN0aW9uLXN0cmF0ZWd5LWJhc2VcIjtcclxuaW1wb3J0IHsgRGF5U2VsZWN0aW9uU3RyYXRlZ3kgfSBmcm9tIFwiLi9kYXRlLWlucHV0LXNlbGVjdGlvbi1zdHJhdGVnaWVzL2RheS1zZWxlY3Rpb24tc3RyYXRlZ3lcIjtcclxuaW1wb3J0IHsgTGFzdDI4RGF5c1NlbGVjdGlvblN0cmF0ZWd5IH0gZnJvbSBcIi4vZGF0ZS1pbnB1dC1zZWxlY3Rpb24tc3RyYXRlZ2llcy9sYXN0LTI4LWRheXMtc2VsZWN0aW9uLXN0cmF0ZWd5XCI7XHJcbmltcG9ydCB7IExhc3Q3RGF5c1NlbGVjdGlvblN0cmF0ZWd5IH0gZnJvbSBcIi4vZGF0ZS1pbnB1dC1zZWxlY3Rpb24tc3RyYXRlZ2llcy9sYXN0LTctZGF5cy1zZWxlY3Rpb24tc3RyYXRlZ3lcIjtcclxuaW1wb3J0IHsgTW9udGhTZWxlY3Rpb25TdHJhdGVneSB9IGZyb20gXCIuL2RhdGUtaW5wdXQtc2VsZWN0aW9uLXN0cmF0ZWdpZXMvbW9udGgtc2VsZWN0aW9uLXN0cmF0ZWd5XCI7XHJcbmltcG9ydCB7IFF1YXJ0ZXJTZWxlY3Rpb25TdHJhdGVneSB9IGZyb20gXCIuL2RhdGUtaW5wdXQtc2VsZWN0aW9uLXN0cmF0ZWdpZXMvcXVhcnRlci1zZWxlY3Rpb24tc3RyYXRlZ3lcIjtcclxuaW1wb3J0IHsgUmFuZ2VTZWxlY3Rpb25TdHJhdGVneSB9IGZyb20gXCIuL2RhdGUtaW5wdXQtc2VsZWN0aW9uLXN0cmF0ZWdpZXMvcmFuZ2Utc2VsZWN0aW9uLXN0cmF0ZWd5XCI7XHJcbmltcG9ydCB7IFllYXJTZWxlY3Rpb25TdHJhdGVneSB9IGZyb20gXCIuL2RhdGUtaW5wdXQtc2VsZWN0aW9uLXN0cmF0ZWdpZXMveWVhci1zZWxlY3Rpb24tc3RyYXRlZ3lcIjtcclxuXHJcbmV4cG9ydCBuYW1lc3BhY2UgRGF0ZUlucHV0IHtcclxuICBleHBvcnQgdHlwZSBGb3JtTW9kZWwgPSBGb3JtQ29udHJvbDxTZWxlY3Rpb24gfCBudWxsPjtcclxuXHJcbiAgZXhwb3J0IHR5cGUgVGV4dGJveEdyb3VwID0gRm9ybUdyb3VwPHtcclxuICAgIHRleHRib3g6IEZvcm1Db250cm9sPHN0cmluZyB8IG51bGw+O1xyXG4gICAgdGV4dGJveDI6IEZvcm1Db250cm9sPHN0cmluZyB8IG51bGw+O1xyXG4gIH0+O1xyXG5cclxuICBleHBvcnQgdHlwZSBSYW5nZSA9IHsgc3RhcnQ6IERhdGUgfCBudWxsOyBlbmQ6IERhdGUgfCBudWxsIH07XHJcblxyXG4gIGV4cG9ydCB0eXBlIFNlbGVjdGlvbiA9IERhdGUgfCBSYW5nZTtcclxuXHJcbiAgZXhwb3J0IHR5cGUgU2VsZWN0aW9uTW9kZSA9ICdkYXknIHwgJ2xhc3Q3RGF5cycgfCAnbGFzdDI4RGF5cycgfCAnbW9udGgnIHwgJ3F1YXJ0ZXInIHwgJ3llYXInIHwgJ3JhbmdlJztcclxuXHJcbiAgZXhwb3J0IGZ1bmN0aW9uIGlzU2VsZWN0aW9uU2luZ2xlRGF0ZShzZWxlY3Rpb24/OiBTZWxlY3Rpb24gfCBudWxsKTogc2VsZWN0aW9uIGlzIERhdGUge1xyXG4gICAgcmV0dXJuIHNlbGVjdGlvbiBpbnN0YW5jZW9mIERhdGU7XHJcbiAgfVxyXG5cclxuICBleHBvcnQgZnVuY3Rpb24gaXNTZWxlY3Rpb25SYW5nZShzZWxlY3Rpb24/OiBTZWxlY3Rpb24gfCBudWxsKTogc2VsZWN0aW9uIGlzIFJhbmdlIHtcclxuICAgIHJldHVybiAhIXNlbGVjdGlvbiAmJiAhaXNTZWxlY3Rpb25TaW5nbGVEYXRlKHNlbGVjdGlvbik7XHJcbiAgfVxyXG5cclxuICBleHBvcnQgdHlwZSBQYXJzaW5nT3B0aW9ucyA9IHtcclxuICAgIC8qKlxyXG4gICAgICogV2hlbiBjb25maWd1cmVkLCB0aGUgcGFyc2VyIHdpbGwgc2hpZnQgdGhlIHBhcnNlZCBkYXRlIHRvIHRoZSBjdXJyZW50IHllYXIgaWYgdGhlIGRhdGUgaXMgYmVsb3cgdGhpcyBkYXRlLlxyXG4gICAgICogVGhpcyBpcyB1c2VkIHRvIHByZXZlbnQgdGhlIGNhbGVuZGFycyBmcm9tIHNob3dpbmcgdW5oZWxwZnVsIGRhdGVzIGluIHRoZSBkaXN0YW50IHBhc3QgYmVmb3JlIHRoZSB1c2VyIGZpbmlzaGVzIHR5cGluZyBpbiB0aGUgZGF0ZS5cclxuICAgICAqL1xyXG4gICAgc2hpZnRUb0N1cnJlbnRZZWFySWZCZWxvdz86IERhdGU7XHJcbiAgICAvKipcclxuICAgICAqIFdoZW4gdHJ1ZSwgdGhlIHJhbmdlIHNlbGVjdGlvbiBtb2RlcyAocmFuZ2UsIGxhc3Q3RGF5cywgbGFzdDI4RGF5cykgd2lsbCBrZXkgb2ZmIG9mIHRoZSBlbmQgZGF0ZSBzdHJpbmcgdG8gZGV0ZXJtaW5lIHRoZSBzZWxlY3Rpb24gcmFuZ2UuXHJcbiAgICAgKi9cclxuICAgIHBhcnNlRnJvbUVuZD86IGJvb2xlYW47XHJcbiAgICAvKipcclxuICAgICAqIFN0b3BzIHRoZSBwYXJzZXIgZnJvbSBhdXRvbWF0aWNhbGx5IGNvbXBsZXRpbmcgdGhlIGRhdGUgcmFuZ2Ugd2hlbiB0aGVyZSBpcyBvbmx5IGEgc3RhcnQgb3IgYW4gZW5kIGRhdGUuXHJcbiAgICAgKiBPbmx5IGFwcGxpY2FibGUgdG8gdGhlIGZpeGVkIGxlbmd0aCByYW5nZSBzZWxlY3Rpb24gbW9kZXMgKGxhc3Q3RGF5cywgbGFzdDI4RGF5cykuXHJcbiAgICAgKi9cclxuICAgIHByZXZlbnRBdXRvQ29tcGxldGU/OiBib29sZWFuO1xyXG4gIH07XHJcblxyXG4gIEBJbmplY3RhYmxlKClcclxuICBleHBvcnQgY2xhc3MgU2VsZWN0aW9uU3RyYXRlZ2llcyBpbXBsZW1lbnRzIFJlY29yZDxTZWxlY3Rpb25Nb2RlLCBEYXRlSW5wdXRTZWxlY3Rpb25TdHJhdGVneUJhc2U+IHtcclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICBwcml2YXRlIGRhdGVEaXNwbGF5UGlwZTogRGF0ZURpc3BsYXlQaXBlXHJcbiAgICApIHsgfVxyXG4gICAgXHJcbiAgICBwcml2YXRlIF9yYW5nZSA9IG5ldyBSYW5nZVNlbGVjdGlvblN0cmF0ZWd5KCk7XHJcbiAgICBwdWJsaWMgZ2V0IHJhbmdlKCkgeyByZXR1cm4gdGhpcy5fcmFuZ2U7IH1cclxuICAgIFxyXG4gICAgcHJpdmF0ZSBfZGF5ID0gbmV3IERheVNlbGVjdGlvblN0cmF0ZWd5KHRoaXMuZGF0ZURpc3BsYXlQaXBlKTtcclxuICAgIHB1YmxpYyBnZXQgZGF5KCkgeyByZXR1cm4gdGhpcy5fZGF5OyB9XHJcbiAgXHJcbiAgICBwcml2YXRlIF9sYXN0N0RheXMgPSBuZXcgTGFzdDdEYXlzU2VsZWN0aW9uU3RyYXRlZ3kodGhpcy5fcmFuZ2UpO1xyXG4gICAgcHVibGljIGdldCBsYXN0N0RheXMoKSB7IHJldHVybiB0aGlzLl9sYXN0N0RheXM7IH1cclxuICBcclxuICAgIHByaXZhdGUgX2xhc3QyOERheXMgPSBuZXcgTGFzdDI4RGF5c1NlbGVjdGlvblN0cmF0ZWd5KHRoaXMuX3JhbmdlKTtcclxuICAgIHB1YmxpYyBnZXQgbGFzdDI4RGF5cygpIHsgcmV0dXJuIHRoaXMuX2xhc3QyOERheXM7IH1cclxuICBcclxuICAgIHByaXZhdGUgX21vbnRoID0gbmV3IE1vbnRoU2VsZWN0aW9uU3RyYXRlZ3koKTtcclxuICAgIHB1YmxpYyBnZXQgbW9udGgoKSB7IHJldHVybiB0aGlzLl9tb250aDsgfVxyXG4gIFxyXG4gICAgcHJpdmF0ZSBfcXVhcnRlciA9IG5ldyBRdWFydGVyU2VsZWN0aW9uU3RyYXRlZ3koKTtcclxuICAgIHB1YmxpYyBnZXQgcXVhcnRlcigpIHsgcmV0dXJuIHRoaXMuX3F1YXJ0ZXI7IH1cclxuICBcclxuICAgIHB1YmxpYyBfeWVhciA9IG5ldyBZZWFyU2VsZWN0aW9uU3RyYXRlZ3koKTtcclxuICAgIHB1YmxpYyBnZXQgeWVhcigpIHsgcmV0dXJuIHRoaXMuX3llYXI7IH1cclxuICB9XHJcbn1cclxuIl19
@@ -225,7 +225,7 @@ export class FileUploadComponent extends FormControlBase {
225
225
  }
226
226
  }
227
227
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FileUploadComponent, deps: [{ token: i1.ValidationMessageService }, { token: i2.FormGroupHelper }], target: i0.ɵɵFactoryTarget.Component }); }
228
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FileUploadComponent, selector: "ec-file-upload", inputs: { formModel: "formModel", placeholder: "placeholder", fileType: "fileType", fileOutput: "fileOutput", customExtensions: "customExtensions", onFileSelected: "onFileSelected", onMultipleFilesSelected: "onMultipleFilesSelected", displayType: "displayType", buttonLabel: "buttonLabel", buttonType: "buttonType", multiSelect: "multiSelect", validateBeforeUpload: "validateBeforeUpload" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ec-form-group [label]=\"label\"\r\n [formGroup]=\"formModel\"\r\n [helpPopover]=\"helpPopover\"\r\n [helpPopoverPosition]=\"helpPopoverPosition\"\r\n class=\"mb-0\">\r\n <div class=\"d-flex control-group\">\r\n <div class=\"d-flex flex-grow position-relative\">\r\n <input #fileInput\r\n id=\"{{inputId}}_input\"\r\n type=\"file\"\r\n tabindex=\"-1\"\r\n [attr.accept]=\"fileTypeAccept\"\r\n (change)=\"fileChange($event.target.files)\"\r\n [class.has-value]=\"displayType === 'file' ? formModel?.get('name').value : undefined\"\r\n [attr.multiple]=\"multiSelect ? 'multiple' : undefined\">\r\n <ec-form-control *ngIf=\"displayType === 'file'\"\r\n id=\"{{inputId}}_formControl\"\r\n class=\"text-truncate\"\r\n [required]=\"required\"\r\n [pending]=\"pending || formModel?.pending\">\r\n <input id=\"{{inputId}}_name\"\r\n [formControl]=\"formModel?.get('name')\"\r\n type=\"text\"\r\n [placeholder]=\"placeholder\"\r\n [tabindex]=\"-1\">\r\n </ec-form-control>\r\n </div>\r\n <ec-button *ngIf=\"displayType === 'file'\"\r\n #browseBtn\r\n id=\"{{inputId}}_browseBtn\"\r\n (clicked)=\"fileInput.click()\"\r\n type=\"secondary\"\r\n [tabindex]=\"tabindex\"\r\n [disabled]=\"formModel?.get('name').disabled\"\r\n label=\"Browse\"\r\n [autofocus]=\"autofocus\">\r\n </ec-button>\r\n </div>\r\n <ec-button *ngIf=\"displayType === 'button'\"\r\n id=\"{{inputId}}_btn\"\r\n [pending]=\"pending\"\r\n [type]=\"buttonType\"\r\n [label]=\"buttonLabel ?? 'Browse_TC' | translate\"\r\n (clicked)=\"fileInput.click()\"\r\n style=\"width: 100%;\">\r\n </ec-button>\r\n</ec-form-group>", styles: [":host{display:block;margin-bottom:1rem}ec-form-control{margin-bottom:0}ec-form-control ::ng-deep>.ec-focus-ring{display:none!important}input[type=file]{opacity:0;display:block;position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;cursor:pointer}input[type=file].has-value{width:calc(100% - 1.5rem)}ec-button{--ec-button-border-color-secondary: var(--ec-form-control-border-color);--ec-button-color-icon-secondary: var(--ec-color-icon)}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i5.ButtonComponent, selector: "ec-button", inputs: ["id", "disabled", "icon", "label", "badge", "tabindex", "type", "pending", "pendingIcon", "customTemplate", "isSubmit", "autofocus"], outputs: ["clicked"] }, { kind: "component", type: i6.FormControlComponent, selector: "ec-form-control", inputs: ["id", "icon", "actionIcon", "showClear", "formModel", "autofocus", "pending", "required", "readonly"], outputs: ["actionClicked", "actionKeydown"] }, { kind: "component", type: i7.FormGroupComponent, selector: "ec-form-group", inputs: ["id", "label", "formGroup", "labelPosition", "overrideValidationError", "hideValidationMessage", "helpPopover", "helpPopoverPosition"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
228
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FileUploadComponent, selector: "ec-file-upload", inputs: { formModel: "formModel", placeholder: "placeholder", fileType: "fileType", fileOutput: "fileOutput", customExtensions: "customExtensions", onFileSelected: "onFileSelected", onMultipleFilesSelected: "onMultipleFilesSelected", displayType: "displayType", buttonLabel: "buttonLabel", buttonType: "buttonType", multiSelect: "multiSelect", validateBeforeUpload: "validateBeforeUpload" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ec-form-group [label]=\"label\"\r\n [formGroup]=\"formModel\"\r\n [helpPopover]=\"helpPopover\"\r\n [helpPopoverPosition]=\"helpPopoverPosition\"\r\n class=\"mb-0\">\r\n <div class=\"d-flex control-group\">\r\n <div class=\"d-flex flex-grow position-relative\">\r\n <input #fileInput\r\n id=\"{{inputId}}_input\"\r\n type=\"file\"\r\n tabindex=\"-1\"\r\n [attr.accept]=\"fileTypeAccept\"\r\n (change)=\"fileChange($event.target.files)\"\r\n [class.has-value]=\"displayType === 'file' ? formModel?.get('name').value : undefined\"\r\n [attr.multiple]=\"multiSelect ? 'multiple' : undefined\">\r\n <ec-form-control *ngIf=\"displayType === 'file'\"\r\n id=\"{{inputId}}_formControl\"\r\n class=\"text-truncate\"\r\n [required]=\"required\"\r\n [pending]=\"pending || formModel?.pending\">\r\n <input id=\"{{inputId}}_name\"\r\n [formControl]=\"formModel?.get('name')\"\r\n type=\"text\"\r\n [placeholder]=\"placeholder\"\r\n [tabindex]=\"-1\">\r\n </ec-form-control>\r\n </div>\r\n <ec-button *ngIf=\"displayType === 'file'\"\r\n #browseBtn\r\n id=\"{{inputId}}_browseBtn\"\r\n (clicked)=\"fileInput.click()\"\r\n type=\"secondary\"\r\n [tabindex]=\"tabindex\"\r\n [disabled]=\"formModel?.get('name').disabled\"\r\n label=\"Browse\"\r\n [autofocus]=\"autofocus\">\r\n </ec-button>\r\n </div>\r\n <ec-button *ngIf=\"displayType === 'button'\"\r\n id=\"{{inputId}}_btn\"\r\n [pending]=\"pending\"\r\n [type]=\"buttonType\"\r\n [label]=\"buttonLabel ?? 'Browse_TC' | translate\"\r\n (clicked)=\"fileInput.click()\"\r\n style=\"width: 100%;\">\r\n </ec-button>\r\n</ec-form-group>", styles: [":host{display:block;margin-bottom:1rem}ec-form-control{margin-bottom:0}ec-form-control ::ng-deep>.ec-focus-ring{display:none!important}input[type=file]{opacity:0;display:block;position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;cursor:pointer}input[type=file].has-value{width:calc(100% - 1.5rem)}ec-button{--ec-button-border-color-secondary: var(--ec-form-control-border-color);--ec-button-color-icon-secondary: var(--ec-color-icon)}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i5.ButtonComponent, selector: "ec-button", inputs: ["id", "disabled", "icon", "label", "badge", "tabindex", "type", "pending", "pendingIcon", "customTemplate", "isSubmit", "autofocus"], outputs: ["clicked"] }, { kind: "component", type: i6.FormControlComponent, selector: "ec-form-control", inputs: ["id", "icon", "actionIcon", "showClear", "formModel", "autofocus", "pending", "required", "readonly"], outputs: ["actionClicked"] }, { kind: "component", type: i7.FormGroupComponent, selector: "ec-form-group", inputs: ["id", "label", "formGroup", "labelPosition", "overrideValidationError", "hideValidationMessage", "helpPopover", "helpPopoverPosition"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
229
229
  }
230
230
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FileUploadComponent, decorators: [{
231
231
  type: Component,
@@ -9,6 +9,9 @@ export class FormControlComponent {
9
9
  ;
10
10
  get disabled() { return this._formModel?.disabled == true; }
11
11
  ;
12
+ get _formModel() {
13
+ return this.formModelInput || this.formControlDirective;
14
+ }
12
15
  constructor(el) {
13
16
  this.el = el;
14
17
  this.id = '';
@@ -18,15 +21,8 @@ export class FormControlComponent {
18
21
  this.required = false;
19
22
  this.readonly = false;
20
23
  this.actionClicked = new EventEmitter();
21
- this.actionKeydown = new EventEmitter();
22
- }
23
- ngOnChanges(changes) {
24
- if (changes.formModelInput) {
25
- this._formModel = this.formModelInput || this.formControlDirective;
26
- }
27
24
  }
28
25
  ngAfterViewInit() {
29
- this._formModel = this.formModelInput || this.formControlDirective;
30
26
  if (!this._formModel) {
31
27
  console.error('Missing [formModel] input or [formControl] directive on ec-form-control content.');
32
28
  }
@@ -48,11 +44,11 @@ export class FormControlComponent {
48
44
  this._formModel?.reset();
49
45
  }
50
46
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormControlComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
51
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormControlComponent, selector: "ec-form-control", inputs: { id: "id", icon: "icon", actionIcon: "actionIcon", showClear: "showClear", formModelInput: ["formModel", "formModelInput"], autofocus: "autofocus", pending: "pending", required: "required", readonly: "readonly" }, outputs: { actionClicked: "actionClicked", actionKeydown: "actionKeydown" }, host: { listeners: { "click": "onClick()" }, properties: { "class.is-pending": "this.pending", "class.is-required": "this.required", "class.is-readonly": "this.readonly", "class.is-empty": "this.empty", "class.is-invalid": "this.invalid", "class.is-disabled": "this.disabled" } }, queries: [{ propertyName: "formControlDirective", first: true, predicate: FormControlDirective, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-content></ng-content>\r\n<i id=\"{{id + '_icon'}}\" class=\"ec-form-control-icon ec-icon {{icon}}\"></i>\r\n<i id=\"{{id + '_loading'}}\" class=\"ec-form-control-icon ec-icon icon-loading\"></i>\r\n<i id=\"{{id + '_required'}}\" class=\"ec-form-control-icon ec-icon icon-required\"></i>\r\n<i id=\"{{id + '_invalid'}}\" class=\"ec-form-control-icon ec-icon icon-invalid\"></i>\r\n<button *ngIf=\"showClear\"\r\n id=\"{{id + '_clear'}}\"\r\n [attr.disabled]=\"disabled || undefined\"\r\n class=\"ec-form-control-clear\"\r\n (click)=\"clear()\">\r\n <i class=\"ec-icon icon-cancel\"></i>\r\n</button>\r\n<button *ngIf=\"actionIcon\"\r\n id=\"{{id + '_action'}}\"\r\n [attr.disabled]=\"disabled || undefined\"\r\n class=\"ec-form-control-action\"\r\n (click)=\"actionClicked.emit($event)\"\r\n (keydown)=\"actionKeydown.emit($event)\">\r\n <i class=\"ec-icon {{actionIcon}}\"></i>\r\n</button>\r\n<div class=\"ec-focus-ring\"></div>", styles: ["ec-form-control{background-color:var(--ec-form-control-background-color);background-clip:padding-box;border:1px solid var(--ec-form-control-border-color);border-radius:var(--ec-border-radius);padding:0 .5rem;position:relative;color:var(--ec-form-control-color);display:flex;font-size:var(--ec-form-control-font-size);min-height:2rem;width:100%}ec-form-control>input,ec-form-control>select,ec-form-control>textarea,ec-form-control>div[contenteditable=true]{color:inherit;flex:1 1;min-width:0;border:0;background-color:transparent;order:2}ec-form-control>input::selection,ec-form-control>select::selection,ec-form-control>textarea::selection,ec-form-control>div[contenteditable=true]::selection{background-color:var(--ec-form-control-background-color-selection);color:var(--ec-form-control-color-selection)}ec-form-control>input::-webkit-input-placeholder,ec-form-control>select::-webkit-input-placeholder,ec-form-control>textarea::-webkit-input-placeholder,ec-form-control>div[contenteditable=true]::-webkit-input-placeholder{color:var(--ec-form-control-color-placeholder)}ec-form-control>input::-moz-placeholder,ec-form-control>select::-moz-placeholder,ec-form-control>textarea::-moz-placeholder,ec-form-control>div[contenteditable=true]::-moz-placeholder{color:var(--ec-form-control-color-placeholder);opacity:1}ec-form-control>input:-ms-input-placeholder,ec-form-control>select:-ms-input-placeholder,ec-form-control>textarea:-ms-input-placeholder,ec-form-control>div[contenteditable=true]:-ms-input-placeholder{color:var(--ec-form-control-color-placeholder)}ec-form-control>input:-moz-placeholder,ec-form-control>select:-moz-placeholder,ec-form-control>textarea:-moz-placeholder,ec-form-control>div[contenteditable=true]:-moz-placeholder{color:var(--ec-form-control-color-placeholder);opacity:1}ec-form-control>input:focus,ec-form-control>select:focus,ec-form-control>textarea:focus,ec-form-control>div[contenteditable=true]:focus{outline:none}ec-form-control>input:focus~.ec-focus-ring,ec-form-control>select:focus~.ec-focus-ring,ec-form-control>textarea:focus~.ec-focus-ring,ec-form-control>div[contenteditable=true]:focus~.ec-focus-ring{display:block}ec-form-control>input,ec-form-control>textarea,ec-form-control>select,ec-form-control>div[contenteditable=true],ec-form-control .ec-form-control-prefix,ec-form-control .ec-form-control-suffix{padding:calc((1.875rem - var(--ec-font-size-body) * 1.25) / 2) 0;line-height:1.25;font-size:inherit}ec-form-control>textarea{resize:none;padding:.3125rem 0}ec-form-control .ec-form-control-icon{margin-top:.4375rem;margin-right:.25rem;order:1}ec-form-control .ec-form-control-icon:not([class*=icon-]){display:none}ec-form-control .icon-required,ec-form-control .icon-invalid{color:var(--ec-form-control-border-color-invalid)}ec-form-control .ec-form-control-clear,ec-form-control .ec-form-control-action{font-size:var(--ec-font-size-action);height:2rem;line-height:1.25rem;padding:.3125rem .5rem;border-radius:var(--ec-border-radius);display:flex;cursor:pointer;flex:none;height:1.875rem;width:2rem;order:3;background-color:transparent;border:0;border-radius:0;display:inline-flex;align-items:center;justify-content:center;outline:none}ec-form-control .ec-form-control-clear .label,ec-form-control .ec-form-control-action .label{display:flex;align-items:center;justify-content:center;white-space:nowrap;flex:auto}ec-form-control .ec-form-control-clear .ec-icon,ec-form-control .ec-form-control-action .ec-icon{flex:none}ec-form-control .ec-form-control-clear .ec-icon+.label,ec-form-control .ec-form-control-action .ec-icon+.label{flex:none;margin-left:.25rem}ec-form-control .ec-form-control-clear.has-badge,ec-form-control .ec-form-control-action.has-badge{padding-right:.0625rem}ec-form-control .ec-form-control-clear:focus,ec-form-control .ec-form-control-action:focus{outline:none;position:relative;z-index:1}ec-form-control .ec-form-control-clear:disabled,ec-form-control .ec-form-control-action:disabled{background-color:var(--ec-background-color-disabled);border:1px solid var(--ec-form-control-border-color-disabled);color:var(--ec-color-disabled-dark);opacity:var(--ec-form-control-opacity-disabled);cursor:default}ec-form-control .ec-form-control-clear:disabled,ec-form-control .ec-form-control-action:disabled{border:0;background-color:transparent;border-color:transparent}ec-form-control .ec-form-control-clear:last-of-type,ec-form-control .ec-form-control-action:last-of-type{margin-right:-.5rem}ec-form-control .ec-form-control-clear:hover:not(:disabled),ec-form-control .ec-form-control-action:hover:not(:disabled){cursor:pointer;background-color:var(--ec-background-color-hover)}ec-form-control .ec-form-control-clear:active:not(:disabled),ec-form-control .ec-form-control-action:active:not(:disabled){background-color:var(--ec-background-color-selected);font-weight:700}ec-form-control .ec-form-control-clear:focus:not(:disabled),ec-form-control .ec-form-control-action:focus:not(:disabled){box-shadow:var(--ec-button-box-shadow-active, 0 0 0 2px var(--ec-border-color-focus))}ec-form-control button:last-of-type{border-top-right-radius:calc(var(--ec-form-control-border-radius) - .0625rem);border-bottom-right-radius:calc(var(--ec-form-control-border-radius) - .0625rem)}ec-form-control .ec-form-control-clear{width:1.5rem}ec-form-control .ec-form-control-prefix,ec-form-control .ec-form-control-suffix{color:var(--ec-color-secondary-dark);flex:none;cursor:default}ec-form-control .ec-form-control-prefix{margin-right:.125rem;order:2}ec-form-control .ec-form-control-suffix{margin-left:.125rem;order:3}ec-form-control .ec-focus-ring{position:absolute;inset:-1px;border:.125rem solid var(--ec-color-interactive);pointer-events:none;display:none;border-radius:var(--ec-form-control-border-radius);z-index:1}ec-form-control.is-pending .icon-invalid,ec-form-control.is-pending .icon-required{display:none}ec-form-control.is-invalid{border-color:var(--ec-form-control-border-color-invalid);background-color:var(--ec-form-control-background-color-invalid)}ec-form-control.is-invalid .icon-required{display:none}ec-form-control.is-empty .ec-form-control-clear{display:none}ec-form-control.is-required.is-empty .ec-form-control-icon:first-of-type{display:none}ec-form-control:not(.is-pending) .icon-loading{display:none}ec-form-control:not(.is-required) .icon-required,ec-form-control:not(.is-empty) .icon-required{display:none}ec-form-control:not(.is-invalid) .icon-invalid{display:none}ec-form-control.is-readonly,ec-form-control.is-disabled{background-color:var(--ec-form-control-background-color-disabled)}ec-form-control.is-readonly .icon-loading,ec-form-control.is-readonly .icon-invalid,ec-form-control.is-readonly .icon-required,ec-form-control.is-readonly .ec-form-control-clear,ec-form-control.is-disabled .icon-loading,ec-form-control.is-disabled .icon-invalid,ec-form-control.is-disabled .icon-required,ec-form-control.is-disabled .ec-form-control-clear{display:none}ec-form-control.is-readonly{border-color:var(--ec-form-control-border-color-readonly);color:var(--ec-form-control-color-readonly)}ec-form-control.is-readonly .ec-form-control-action{display:none}ec-form-control.is-disabled:not(.is-readonly){color:var(--ec-form-control-color-disabled);opacity:.6}ec-form-control.is-disabled:not(.is-readonly) .ec-form-control-prefix,ec-form-control.is-disabled:not(.is-readonly) .ec-form-control-suffix{color:inherit}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
47
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormControlComponent, selector: "ec-form-control", inputs: { id: "id", icon: "icon", actionIcon: "actionIcon", showClear: "showClear", formModelInput: ["formModel", "formModelInput"], autofocus: "autofocus", pending: "pending", required: "required", readonly: "readonly" }, outputs: { actionClicked: "actionClicked" }, host: { listeners: { "click": "onClick()" }, properties: { "class.is-pending": "this.pending", "class.is-required": "this.required", "class.is-readonly": "this.readonly", "class.is-empty": "this.empty", "class.is-invalid": "this.invalid", "class.is-disabled": "this.disabled" } }, queries: [{ propertyName: "formControlDirective", first: true, predicate: FormControlDirective, descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n<i id=\"{{id + '_icon'}}\" class=\"ec-form-control-icon ec-icon {{icon}}\"></i>\r\n<i id=\"{{id + '_loading'}}\" class=\"ec-form-control-icon ec-icon icon-loading\"></i>\r\n<i id=\"{{id + '_required'}}\" class=\"ec-form-control-icon ec-icon icon-required\"></i>\r\n<i id=\"{{id + '_invalid'}}\" class=\"ec-form-control-icon ec-icon icon-invalid\"></i>\r\n<button *ngIf=\"showClear\"\r\n id=\"{{id + '_clear'}}\"\r\n [attr.disabled]=\"disabled || undefined\"\r\n class=\"ec-form-control-clear\"\r\n (click)=\"clear()\">\r\n <i class=\"ec-icon icon-cancel\"></i>\r\n</button>\r\n<button *ngIf=\"actionIcon\"\r\n id=\"{{id + '_action'}}\"\r\n [attr.disabled]=\"disabled || undefined\"\r\n class=\"ec-form-control-action\"\r\n (click)=\"actionClicked.emit($event)\">\r\n <i class=\"ec-icon {{actionIcon}}\"></i>\r\n</button>\r\n<div class=\"ec-focus-ring\"></div>\r\n", styles: ["ec-form-control{background-color:var(--ec-form-control-background-color);background-clip:padding-box;border:1px solid var(--ec-form-control-border-color);border-radius:var(--ec-border-radius);padding:0 .5rem;position:relative;color:var(--ec-form-control-color);display:flex;font-size:var(--ec-form-control-font-size);min-height:2rem;width:100%}ec-form-control>input,ec-form-control>select,ec-form-control>textarea,ec-form-control>div[contenteditable=true]{color:inherit;flex:1 1;min-width:0;border:0;background-color:transparent;order:2}ec-form-control>input::selection,ec-form-control>select::selection,ec-form-control>textarea::selection,ec-form-control>div[contenteditable=true]::selection{background-color:var(--ec-form-control-background-color-selection);color:var(--ec-form-control-color-selection)}ec-form-control>input::-webkit-input-placeholder,ec-form-control>select::-webkit-input-placeholder,ec-form-control>textarea::-webkit-input-placeholder,ec-form-control>div[contenteditable=true]::-webkit-input-placeholder{color:var(--ec-form-control-color-placeholder)}ec-form-control>input::-moz-placeholder,ec-form-control>select::-moz-placeholder,ec-form-control>textarea::-moz-placeholder,ec-form-control>div[contenteditable=true]::-moz-placeholder{color:var(--ec-form-control-color-placeholder);opacity:1}ec-form-control>input:-ms-input-placeholder,ec-form-control>select:-ms-input-placeholder,ec-form-control>textarea:-ms-input-placeholder,ec-form-control>div[contenteditable=true]:-ms-input-placeholder{color:var(--ec-form-control-color-placeholder)}ec-form-control>input:-moz-placeholder,ec-form-control>select:-moz-placeholder,ec-form-control>textarea:-moz-placeholder,ec-form-control>div[contenteditable=true]:-moz-placeholder{color:var(--ec-form-control-color-placeholder);opacity:1}ec-form-control>input:focus,ec-form-control>select:focus,ec-form-control>textarea:focus,ec-form-control>div[contenteditable=true]:focus{outline:none}ec-form-control>input:focus~.ec-focus-ring,ec-form-control>select:focus~.ec-focus-ring,ec-form-control>textarea:focus~.ec-focus-ring,ec-form-control>div[contenteditable=true]:focus~.ec-focus-ring{display:block}ec-form-control>input,ec-form-control>textarea,ec-form-control>select,ec-form-control>div[contenteditable=true],ec-form-control .ec-form-control-prefix,ec-form-control .ec-form-control-suffix{padding:calc((1.875rem - var(--ec-font-size-body) * 1.25) / 2) 0;line-height:1.25;font-size:inherit}ec-form-control>textarea{resize:none;padding:.3125rem 0}ec-form-control .ec-form-control-icon{margin-top:.4375rem;margin-right:.25rem;order:1}ec-form-control .ec-form-control-icon:not([class*=icon-]){display:none}ec-form-control .icon-required,ec-form-control .icon-invalid{color:var(--ec-form-control-border-color-invalid)}ec-form-control .ec-form-control-clear,ec-form-control .ec-form-control-action{font-size:var(--ec-font-size-action);height:2rem;line-height:1.25rem;padding:.3125rem .5rem;border-radius:var(--ec-border-radius);display:flex;cursor:pointer;flex:none;height:1.875rem;width:2rem;order:3;background-color:transparent;border:0;border-radius:0;display:inline-flex;align-items:center;justify-content:center;outline:none}ec-form-control .ec-form-control-clear .label,ec-form-control .ec-form-control-action .label{display:flex;align-items:center;justify-content:center;white-space:nowrap;flex:auto}ec-form-control .ec-form-control-clear .ec-icon,ec-form-control .ec-form-control-action .ec-icon{flex:none}ec-form-control .ec-form-control-clear .ec-icon+.label,ec-form-control .ec-form-control-action .ec-icon+.label{flex:none;margin-left:.25rem}ec-form-control .ec-form-control-clear.has-badge,ec-form-control .ec-form-control-action.has-badge{padding-right:.0625rem}ec-form-control .ec-form-control-clear:focus,ec-form-control .ec-form-control-action:focus{outline:none;position:relative;z-index:1}ec-form-control .ec-form-control-clear:disabled,ec-form-control .ec-form-control-action:disabled{background-color:var(--ec-background-color-disabled);border:1px solid var(--ec-form-control-border-color-disabled);color:var(--ec-color-disabled-dark);opacity:var(--ec-form-control-opacity-disabled);cursor:default}ec-form-control .ec-form-control-clear:disabled,ec-form-control .ec-form-control-action:disabled{border:0;background-color:transparent;border-color:transparent}ec-form-control .ec-form-control-clear:last-of-type,ec-form-control .ec-form-control-action:last-of-type{margin-right:-.5rem}ec-form-control .ec-form-control-clear:hover:not(:disabled),ec-form-control .ec-form-control-action:hover:not(:disabled){cursor:pointer;background-color:var(--ec-background-color-hover)}ec-form-control .ec-form-control-clear:active:not(:disabled),ec-form-control .ec-form-control-action:active:not(:disabled){background-color:var(--ec-background-color-selected);font-weight:700}ec-form-control .ec-form-control-clear:focus:not(:disabled),ec-form-control .ec-form-control-action:focus:not(:disabled){box-shadow:var(--ec-button-box-shadow-active, 0 0 0 2px var(--ec-border-color-focus))}ec-form-control button:last-of-type{border-top-right-radius:calc(var(--ec-form-control-border-radius) - .0625rem);border-bottom-right-radius:calc(var(--ec-form-control-border-radius) - .0625rem)}ec-form-control .ec-form-control-clear{width:1.5rem}ec-form-control .ec-form-control-prefix,ec-form-control .ec-form-control-suffix{color:var(--ec-color-secondary-dark);flex:none;cursor:default}ec-form-control .ec-form-control-prefix{margin-right:.125rem;order:2}ec-form-control .ec-form-control-suffix{margin-left:.125rem;order:3}ec-form-control .ec-focus-ring{position:absolute;inset:-1px;border:.125rem solid var(--ec-color-interactive);pointer-events:none;display:none;border-radius:var(--ec-form-control-border-radius);z-index:1}ec-form-control.is-pending .icon-invalid,ec-form-control.is-pending .icon-required{display:none}ec-form-control.is-invalid{border-color:var(--ec-form-control-border-color-invalid);background-color:var(--ec-form-control-background-color-invalid)}ec-form-control.is-invalid .icon-required{display:none}ec-form-control.is-empty .ec-form-control-clear{display:none}ec-form-control.is-required.is-empty .ec-form-control-icon:first-of-type{display:none}ec-form-control:not(.is-pending) .icon-loading{display:none}ec-form-control:not(.is-required) .icon-required,ec-form-control:not(.is-empty) .icon-required{display:none}ec-form-control:not(.is-invalid) .icon-invalid{display:none}ec-form-control.is-readonly,ec-form-control.is-disabled{background-color:var(--ec-form-control-background-color-disabled)}ec-form-control.is-readonly .icon-loading,ec-form-control.is-readonly .icon-invalid,ec-form-control.is-readonly .icon-required,ec-form-control.is-readonly .ec-form-control-clear,ec-form-control.is-disabled .icon-loading,ec-form-control.is-disabled .icon-invalid,ec-form-control.is-disabled .icon-required,ec-form-control.is-disabled .ec-form-control-clear{display:none}ec-form-control.is-readonly{border-color:var(--ec-form-control-border-color-readonly);color:var(--ec-form-control-color-readonly)}ec-form-control.is-readonly .ec-form-control-action{display:none}ec-form-control.is-disabled:not(.is-readonly){color:var(--ec-form-control-color-disabled);opacity:.6}ec-form-control.is-disabled:not(.is-readonly) .ec-form-control-prefix,ec-form-control.is-disabled:not(.is-readonly) .ec-form-control-suffix{color:inherit}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
52
48
  }
53
49
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormControlComponent, decorators: [{
54
50
  type: Component,
55
- args: [{ selector: 'ec-form-control', encapsulation: ViewEncapsulation.None, template: "<ng-content></ng-content>\r\n<i id=\"{{id + '_icon'}}\" class=\"ec-form-control-icon ec-icon {{icon}}\"></i>\r\n<i id=\"{{id + '_loading'}}\" class=\"ec-form-control-icon ec-icon icon-loading\"></i>\r\n<i id=\"{{id + '_required'}}\" class=\"ec-form-control-icon ec-icon icon-required\"></i>\r\n<i id=\"{{id + '_invalid'}}\" class=\"ec-form-control-icon ec-icon icon-invalid\"></i>\r\n<button *ngIf=\"showClear\"\r\n id=\"{{id + '_clear'}}\"\r\n [attr.disabled]=\"disabled || undefined\"\r\n class=\"ec-form-control-clear\"\r\n (click)=\"clear()\">\r\n <i class=\"ec-icon icon-cancel\"></i>\r\n</button>\r\n<button *ngIf=\"actionIcon\"\r\n id=\"{{id + '_action'}}\"\r\n [attr.disabled]=\"disabled || undefined\"\r\n class=\"ec-form-control-action\"\r\n (click)=\"actionClicked.emit($event)\"\r\n (keydown)=\"actionKeydown.emit($event)\">\r\n <i class=\"ec-icon {{actionIcon}}\"></i>\r\n</button>\r\n<div class=\"ec-focus-ring\"></div>", styles: ["ec-form-control{background-color:var(--ec-form-control-background-color);background-clip:padding-box;border:1px solid var(--ec-form-control-border-color);border-radius:var(--ec-border-radius);padding:0 .5rem;position:relative;color:var(--ec-form-control-color);display:flex;font-size:var(--ec-form-control-font-size);min-height:2rem;width:100%}ec-form-control>input,ec-form-control>select,ec-form-control>textarea,ec-form-control>div[contenteditable=true]{color:inherit;flex:1 1;min-width:0;border:0;background-color:transparent;order:2}ec-form-control>input::selection,ec-form-control>select::selection,ec-form-control>textarea::selection,ec-form-control>div[contenteditable=true]::selection{background-color:var(--ec-form-control-background-color-selection);color:var(--ec-form-control-color-selection)}ec-form-control>input::-webkit-input-placeholder,ec-form-control>select::-webkit-input-placeholder,ec-form-control>textarea::-webkit-input-placeholder,ec-form-control>div[contenteditable=true]::-webkit-input-placeholder{color:var(--ec-form-control-color-placeholder)}ec-form-control>input::-moz-placeholder,ec-form-control>select::-moz-placeholder,ec-form-control>textarea::-moz-placeholder,ec-form-control>div[contenteditable=true]::-moz-placeholder{color:var(--ec-form-control-color-placeholder);opacity:1}ec-form-control>input:-ms-input-placeholder,ec-form-control>select:-ms-input-placeholder,ec-form-control>textarea:-ms-input-placeholder,ec-form-control>div[contenteditable=true]:-ms-input-placeholder{color:var(--ec-form-control-color-placeholder)}ec-form-control>input:-moz-placeholder,ec-form-control>select:-moz-placeholder,ec-form-control>textarea:-moz-placeholder,ec-form-control>div[contenteditable=true]:-moz-placeholder{color:var(--ec-form-control-color-placeholder);opacity:1}ec-form-control>input:focus,ec-form-control>select:focus,ec-form-control>textarea:focus,ec-form-control>div[contenteditable=true]:focus{outline:none}ec-form-control>input:focus~.ec-focus-ring,ec-form-control>select:focus~.ec-focus-ring,ec-form-control>textarea:focus~.ec-focus-ring,ec-form-control>div[contenteditable=true]:focus~.ec-focus-ring{display:block}ec-form-control>input,ec-form-control>textarea,ec-form-control>select,ec-form-control>div[contenteditable=true],ec-form-control .ec-form-control-prefix,ec-form-control .ec-form-control-suffix{padding:calc((1.875rem - var(--ec-font-size-body) * 1.25) / 2) 0;line-height:1.25;font-size:inherit}ec-form-control>textarea{resize:none;padding:.3125rem 0}ec-form-control .ec-form-control-icon{margin-top:.4375rem;margin-right:.25rem;order:1}ec-form-control .ec-form-control-icon:not([class*=icon-]){display:none}ec-form-control .icon-required,ec-form-control .icon-invalid{color:var(--ec-form-control-border-color-invalid)}ec-form-control .ec-form-control-clear,ec-form-control .ec-form-control-action{font-size:var(--ec-font-size-action);height:2rem;line-height:1.25rem;padding:.3125rem .5rem;border-radius:var(--ec-border-radius);display:flex;cursor:pointer;flex:none;height:1.875rem;width:2rem;order:3;background-color:transparent;border:0;border-radius:0;display:inline-flex;align-items:center;justify-content:center;outline:none}ec-form-control .ec-form-control-clear .label,ec-form-control .ec-form-control-action .label{display:flex;align-items:center;justify-content:center;white-space:nowrap;flex:auto}ec-form-control .ec-form-control-clear .ec-icon,ec-form-control .ec-form-control-action .ec-icon{flex:none}ec-form-control .ec-form-control-clear .ec-icon+.label,ec-form-control .ec-form-control-action .ec-icon+.label{flex:none;margin-left:.25rem}ec-form-control .ec-form-control-clear.has-badge,ec-form-control .ec-form-control-action.has-badge{padding-right:.0625rem}ec-form-control .ec-form-control-clear:focus,ec-form-control .ec-form-control-action:focus{outline:none;position:relative;z-index:1}ec-form-control .ec-form-control-clear:disabled,ec-form-control .ec-form-control-action:disabled{background-color:var(--ec-background-color-disabled);border:1px solid var(--ec-form-control-border-color-disabled);color:var(--ec-color-disabled-dark);opacity:var(--ec-form-control-opacity-disabled);cursor:default}ec-form-control .ec-form-control-clear:disabled,ec-form-control .ec-form-control-action:disabled{border:0;background-color:transparent;border-color:transparent}ec-form-control .ec-form-control-clear:last-of-type,ec-form-control .ec-form-control-action:last-of-type{margin-right:-.5rem}ec-form-control .ec-form-control-clear:hover:not(:disabled),ec-form-control .ec-form-control-action:hover:not(:disabled){cursor:pointer;background-color:var(--ec-background-color-hover)}ec-form-control .ec-form-control-clear:active:not(:disabled),ec-form-control .ec-form-control-action:active:not(:disabled){background-color:var(--ec-background-color-selected);font-weight:700}ec-form-control .ec-form-control-clear:focus:not(:disabled),ec-form-control .ec-form-control-action:focus:not(:disabled){box-shadow:var(--ec-button-box-shadow-active, 0 0 0 2px var(--ec-border-color-focus))}ec-form-control button:last-of-type{border-top-right-radius:calc(var(--ec-form-control-border-radius) - .0625rem);border-bottom-right-radius:calc(var(--ec-form-control-border-radius) - .0625rem)}ec-form-control .ec-form-control-clear{width:1.5rem}ec-form-control .ec-form-control-prefix,ec-form-control .ec-form-control-suffix{color:var(--ec-color-secondary-dark);flex:none;cursor:default}ec-form-control .ec-form-control-prefix{margin-right:.125rem;order:2}ec-form-control .ec-form-control-suffix{margin-left:.125rem;order:3}ec-form-control .ec-focus-ring{position:absolute;inset:-1px;border:.125rem solid var(--ec-color-interactive);pointer-events:none;display:none;border-radius:var(--ec-form-control-border-radius);z-index:1}ec-form-control.is-pending .icon-invalid,ec-form-control.is-pending .icon-required{display:none}ec-form-control.is-invalid{border-color:var(--ec-form-control-border-color-invalid);background-color:var(--ec-form-control-background-color-invalid)}ec-form-control.is-invalid .icon-required{display:none}ec-form-control.is-empty .ec-form-control-clear{display:none}ec-form-control.is-required.is-empty .ec-form-control-icon:first-of-type{display:none}ec-form-control:not(.is-pending) .icon-loading{display:none}ec-form-control:not(.is-required) .icon-required,ec-form-control:not(.is-empty) .icon-required{display:none}ec-form-control:not(.is-invalid) .icon-invalid{display:none}ec-form-control.is-readonly,ec-form-control.is-disabled{background-color:var(--ec-form-control-background-color-disabled)}ec-form-control.is-readonly .icon-loading,ec-form-control.is-readonly .icon-invalid,ec-form-control.is-readonly .icon-required,ec-form-control.is-readonly .ec-form-control-clear,ec-form-control.is-disabled .icon-loading,ec-form-control.is-disabled .icon-invalid,ec-form-control.is-disabled .icon-required,ec-form-control.is-disabled .ec-form-control-clear{display:none}ec-form-control.is-readonly{border-color:var(--ec-form-control-border-color-readonly);color:var(--ec-form-control-color-readonly)}ec-form-control.is-readonly .ec-form-control-action{display:none}ec-form-control.is-disabled:not(.is-readonly){color:var(--ec-form-control-color-disabled);opacity:.6}ec-form-control.is-disabled:not(.is-readonly) .ec-form-control-prefix,ec-form-control.is-disabled:not(.is-readonly) .ec-form-control-suffix{color:inherit}\n"] }]
51
+ args: [{ selector: 'ec-form-control', encapsulation: ViewEncapsulation.None, template: "<ng-content></ng-content>\r\n<i id=\"{{id + '_icon'}}\" class=\"ec-form-control-icon ec-icon {{icon}}\"></i>\r\n<i id=\"{{id + '_loading'}}\" class=\"ec-form-control-icon ec-icon icon-loading\"></i>\r\n<i id=\"{{id + '_required'}}\" class=\"ec-form-control-icon ec-icon icon-required\"></i>\r\n<i id=\"{{id + '_invalid'}}\" class=\"ec-form-control-icon ec-icon icon-invalid\"></i>\r\n<button *ngIf=\"showClear\"\r\n id=\"{{id + '_clear'}}\"\r\n [attr.disabled]=\"disabled || undefined\"\r\n class=\"ec-form-control-clear\"\r\n (click)=\"clear()\">\r\n <i class=\"ec-icon icon-cancel\"></i>\r\n</button>\r\n<button *ngIf=\"actionIcon\"\r\n id=\"{{id + '_action'}}\"\r\n [attr.disabled]=\"disabled || undefined\"\r\n class=\"ec-form-control-action\"\r\n (click)=\"actionClicked.emit($event)\">\r\n <i class=\"ec-icon {{actionIcon}}\"></i>\r\n</button>\r\n<div class=\"ec-focus-ring\"></div>\r\n", styles: ["ec-form-control{background-color:var(--ec-form-control-background-color);background-clip:padding-box;border:1px solid var(--ec-form-control-border-color);border-radius:var(--ec-border-radius);padding:0 .5rem;position:relative;color:var(--ec-form-control-color);display:flex;font-size:var(--ec-form-control-font-size);min-height:2rem;width:100%}ec-form-control>input,ec-form-control>select,ec-form-control>textarea,ec-form-control>div[contenteditable=true]{color:inherit;flex:1 1;min-width:0;border:0;background-color:transparent;order:2}ec-form-control>input::selection,ec-form-control>select::selection,ec-form-control>textarea::selection,ec-form-control>div[contenteditable=true]::selection{background-color:var(--ec-form-control-background-color-selection);color:var(--ec-form-control-color-selection)}ec-form-control>input::-webkit-input-placeholder,ec-form-control>select::-webkit-input-placeholder,ec-form-control>textarea::-webkit-input-placeholder,ec-form-control>div[contenteditable=true]::-webkit-input-placeholder{color:var(--ec-form-control-color-placeholder)}ec-form-control>input::-moz-placeholder,ec-form-control>select::-moz-placeholder,ec-form-control>textarea::-moz-placeholder,ec-form-control>div[contenteditable=true]::-moz-placeholder{color:var(--ec-form-control-color-placeholder);opacity:1}ec-form-control>input:-ms-input-placeholder,ec-form-control>select:-ms-input-placeholder,ec-form-control>textarea:-ms-input-placeholder,ec-form-control>div[contenteditable=true]:-ms-input-placeholder{color:var(--ec-form-control-color-placeholder)}ec-form-control>input:-moz-placeholder,ec-form-control>select:-moz-placeholder,ec-form-control>textarea:-moz-placeholder,ec-form-control>div[contenteditable=true]:-moz-placeholder{color:var(--ec-form-control-color-placeholder);opacity:1}ec-form-control>input:focus,ec-form-control>select:focus,ec-form-control>textarea:focus,ec-form-control>div[contenteditable=true]:focus{outline:none}ec-form-control>input:focus~.ec-focus-ring,ec-form-control>select:focus~.ec-focus-ring,ec-form-control>textarea:focus~.ec-focus-ring,ec-form-control>div[contenteditable=true]:focus~.ec-focus-ring{display:block}ec-form-control>input,ec-form-control>textarea,ec-form-control>select,ec-form-control>div[contenteditable=true],ec-form-control .ec-form-control-prefix,ec-form-control .ec-form-control-suffix{padding:calc((1.875rem - var(--ec-font-size-body) * 1.25) / 2) 0;line-height:1.25;font-size:inherit}ec-form-control>textarea{resize:none;padding:.3125rem 0}ec-form-control .ec-form-control-icon{margin-top:.4375rem;margin-right:.25rem;order:1}ec-form-control .ec-form-control-icon:not([class*=icon-]){display:none}ec-form-control .icon-required,ec-form-control .icon-invalid{color:var(--ec-form-control-border-color-invalid)}ec-form-control .ec-form-control-clear,ec-form-control .ec-form-control-action{font-size:var(--ec-font-size-action);height:2rem;line-height:1.25rem;padding:.3125rem .5rem;border-radius:var(--ec-border-radius);display:flex;cursor:pointer;flex:none;height:1.875rem;width:2rem;order:3;background-color:transparent;border:0;border-radius:0;display:inline-flex;align-items:center;justify-content:center;outline:none}ec-form-control .ec-form-control-clear .label,ec-form-control .ec-form-control-action .label{display:flex;align-items:center;justify-content:center;white-space:nowrap;flex:auto}ec-form-control .ec-form-control-clear .ec-icon,ec-form-control .ec-form-control-action .ec-icon{flex:none}ec-form-control .ec-form-control-clear .ec-icon+.label,ec-form-control .ec-form-control-action .ec-icon+.label{flex:none;margin-left:.25rem}ec-form-control .ec-form-control-clear.has-badge,ec-form-control .ec-form-control-action.has-badge{padding-right:.0625rem}ec-form-control .ec-form-control-clear:focus,ec-form-control .ec-form-control-action:focus{outline:none;position:relative;z-index:1}ec-form-control .ec-form-control-clear:disabled,ec-form-control .ec-form-control-action:disabled{background-color:var(--ec-background-color-disabled);border:1px solid var(--ec-form-control-border-color-disabled);color:var(--ec-color-disabled-dark);opacity:var(--ec-form-control-opacity-disabled);cursor:default}ec-form-control .ec-form-control-clear:disabled,ec-form-control .ec-form-control-action:disabled{border:0;background-color:transparent;border-color:transparent}ec-form-control .ec-form-control-clear:last-of-type,ec-form-control .ec-form-control-action:last-of-type{margin-right:-.5rem}ec-form-control .ec-form-control-clear:hover:not(:disabled),ec-form-control .ec-form-control-action:hover:not(:disabled){cursor:pointer;background-color:var(--ec-background-color-hover)}ec-form-control .ec-form-control-clear:active:not(:disabled),ec-form-control .ec-form-control-action:active:not(:disabled){background-color:var(--ec-background-color-selected);font-weight:700}ec-form-control .ec-form-control-clear:focus:not(:disabled),ec-form-control .ec-form-control-action:focus:not(:disabled){box-shadow:var(--ec-button-box-shadow-active, 0 0 0 2px var(--ec-border-color-focus))}ec-form-control button:last-of-type{border-top-right-radius:calc(var(--ec-form-control-border-radius) - .0625rem);border-bottom-right-radius:calc(var(--ec-form-control-border-radius) - .0625rem)}ec-form-control .ec-form-control-clear{width:1.5rem}ec-form-control .ec-form-control-prefix,ec-form-control .ec-form-control-suffix{color:var(--ec-color-secondary-dark);flex:none;cursor:default}ec-form-control .ec-form-control-prefix{margin-right:.125rem;order:2}ec-form-control .ec-form-control-suffix{margin-left:.125rem;order:3}ec-form-control .ec-focus-ring{position:absolute;inset:-1px;border:.125rem solid var(--ec-color-interactive);pointer-events:none;display:none;border-radius:var(--ec-form-control-border-radius);z-index:1}ec-form-control.is-pending .icon-invalid,ec-form-control.is-pending .icon-required{display:none}ec-form-control.is-invalid{border-color:var(--ec-form-control-border-color-invalid);background-color:var(--ec-form-control-background-color-invalid)}ec-form-control.is-invalid .icon-required{display:none}ec-form-control.is-empty .ec-form-control-clear{display:none}ec-form-control.is-required.is-empty .ec-form-control-icon:first-of-type{display:none}ec-form-control:not(.is-pending) .icon-loading{display:none}ec-form-control:not(.is-required) .icon-required,ec-form-control:not(.is-empty) .icon-required{display:none}ec-form-control:not(.is-invalid) .icon-invalid{display:none}ec-form-control.is-readonly,ec-form-control.is-disabled{background-color:var(--ec-form-control-background-color-disabled)}ec-form-control.is-readonly .icon-loading,ec-form-control.is-readonly .icon-invalid,ec-form-control.is-readonly .icon-required,ec-form-control.is-readonly .ec-form-control-clear,ec-form-control.is-disabled .icon-loading,ec-form-control.is-disabled .icon-invalid,ec-form-control.is-disabled .icon-required,ec-form-control.is-disabled .ec-form-control-clear{display:none}ec-form-control.is-readonly{border-color:var(--ec-form-control-border-color-readonly);color:var(--ec-form-control-color-readonly)}ec-form-control.is-readonly .ec-form-control-action{display:none}ec-form-control.is-disabled:not(.is-readonly){color:var(--ec-form-control-color-disabled);opacity:.6}ec-form-control.is-disabled:not(.is-readonly) .ec-form-control-prefix,ec-form-control.is-disabled:not(.is-readonly) .ec-form-control-suffix{color:inherit}\n"] }]
56
52
  }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { formControlDirective: [{
57
53
  type: ContentChild,
58
54
  args: [FormControlDirective]
@@ -95,10 +91,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
95
91
  args: ['class.is-disabled']
96
92
  }], actionClicked: [{
97
93
  type: Output
98
- }], actionKeydown: [{
99
- type: Output
100
94
  }], onClick: [{
101
95
  type: HostListener,
102
96
  args: ['click']
103
97
  }] } });
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-control.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/controls/form-control/form-control.component.ts","../../../../../../projects/components/src/lib/controls/form-control/form-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ContentChild, ElementRef, EventEmitter, HostBinding, HostListener, Input, OnChanges, Output, SimpleChanges, ViewEncapsulation } from '@angular/core';\r\nimport { AbstractControl, FormControlDirective } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'ec-form-control',\r\n  templateUrl: './form-control.component.html',\r\n  styleUrls: ['./form-control.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class FormControlComponent implements OnChanges, AfterViewInit{\r\n  @ContentChild(FormControlDirective) formControlDirective?: AbstractControl;\r\n  \r\n  @Input() public id: string = '';\r\n  @Input() icon?: string;\r\n  @Input() actionIcon?: string;\r\n  @Input() showClear = true;\r\n  @Input('formModel') formModelInput?: AbstractControl;\r\n  @Input() autofocus = false;\r\n  \r\n  @Input() @HostBinding('class.is-pending') pending = false;\r\n  @Input() @HostBinding('class.is-required') required = false;\r\n  @Input() @HostBinding('class.is-readonly') readonly = false;\r\n  \r\n  @HostBinding('class.is-empty') get empty():boolean { return !this._formModel?.value && this._formModel?.value !== 0};\r\n  @HostBinding('class.is-invalid') get invalid(): boolean { return this._formModel?.touched == true && this._formModel.invalid == true};\r\n  @HostBinding('class.is-disabled') get disabled(): boolean { return this._formModel?.disabled == true };\r\n  \r\n  @Output() actionClicked: EventEmitter<Event> = new EventEmitter<Event>();\r\n  @Output() actionKeydown: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\r\n\r\n  private _formModel?: AbstractControl;\r\n\r\n  constructor(private el: ElementRef) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.formModelInput) {\r\n      this._formModel = this.formModelInput || this.formControlDirective;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this._formModel = this.formModelInput || this.formControlDirective;\r\n    \r\n    if (!this._formModel) {\r\n      console.error('Missing [formModel] input or [formControl] directive on ec-form-control content.');\r\n    }\r\n\r\n    if (this.autofocus) {\r\n      this.focus();\r\n    }\r\n  }\r\n\r\n  @HostListener('click')\r\n  onClick() {\r\n    this.focus();\r\n  }\r\n\r\n  focus() {\r\n    const el = this.el.nativeElement as HTMLElement;\r\n    const inputs = el.querySelectorAll<HTMLElement>('input, textarea, select');\r\n    if (inputs.length) {\r\n      inputs.item(0).focus();\r\n    }\r\n  }\r\n\r\n  clear() {\r\n    this._formModel?.reset();\r\n  }\r\n}","<ng-content></ng-content>\r\n<i id=\"{{id + '_icon'}}\" class=\"ec-form-control-icon ec-icon {{icon}}\"></i>\r\n<i id=\"{{id + '_loading'}}\" class=\"ec-form-control-icon ec-icon icon-loading\"></i>\r\n<i id=\"{{id + '_required'}}\" class=\"ec-form-control-icon ec-icon icon-required\"></i>\r\n<i id=\"{{id + '_invalid'}}\" class=\"ec-form-control-icon ec-icon icon-invalid\"></i>\r\n<button *ngIf=\"showClear\"\r\n        id=\"{{id + '_clear'}}\"\r\n        [attr.disabled]=\"disabled || undefined\"\r\n        class=\"ec-form-control-clear\"\r\n        (click)=\"clear()\">\r\n  <i class=\"ec-icon icon-cancel\"></i>\r\n</button>\r\n<button *ngIf=\"actionIcon\"\r\n        id=\"{{id + '_action'}}\"\r\n        [attr.disabled]=\"disabled || undefined\"\r\n        class=\"ec-form-control-action\"\r\n        (click)=\"actionClicked.emit($event)\"\r\n        (keydown)=\"actionKeydown.emit($event)\">\r\n  <i class=\"ec-icon {{actionIcon}}\"></i>\r\n</button>\r\n<div class=\"ec-focus-ring\"></div>"]}
98
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9jb250cm9scy9mb3JtLWNvbnRyb2wvZm9ybS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9jb250cm9scy9mb3JtLWNvbnRyb2wvZm9ybS1jb250cm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsU0FBUyxFQUFFLFlBQVksRUFBYyxZQUFZLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlKLE9BQU8sRUFBbUIsb0JBQW9CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBUXZFLE1BQU0sT0FBTyxvQkFBb0I7SUFjL0IsSUFBbUMsS0FBSyxLQUFhLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssS0FBSyxDQUFDLENBQUEsQ0FBQSxDQUFDO0lBQUEsQ0FBQztJQUNySCxJQUFxQyxPQUFPLEtBQWMsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLE9BQU8sSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFBLENBQUEsQ0FBQztJQUFBLENBQUM7SUFDdEksSUFBc0MsUUFBUSxLQUFjLE9BQU8sSUFBSSxDQUFDLFVBQVUsRUFBRSxRQUFRLElBQUksSUFBSSxDQUFBLENBQUMsQ0FBQztJQUFBLENBQUM7SUFJdkcsSUFBWSxVQUFVO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUMsb0JBQW9CLENBQUM7SUFDMUQsQ0FBQztJQUVELFlBQW9CLEVBQWM7UUFBZCxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBckJsQixPQUFFLEdBQVcsRUFBRSxDQUFDO1FBR3ZCLGNBQVMsR0FBRyxJQUFJLENBQUM7UUFFakIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUVlLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFDZixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFNbEQsa0JBQWEsR0FBd0IsSUFBSSxZQUFZLEVBQVMsQ0FBQztJQU1uQyxDQUFDO0lBRXZDLGVBQWU7UUFDYixJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3JCLE9BQU8sQ0FBQyxLQUFLLENBQUMsa0ZBQWtGLENBQUMsQ0FBQztRQUNwRyxDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2YsQ0FBQztJQUNILENBQUM7SUFHRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ2YsQ0FBQztJQUVELEtBQUs7UUFDSCxNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQTRCLENBQUM7UUFDaEQsTUFBTSxNQUFNLEdBQUcsRUFBRSxDQUFDLGdCQUFnQixDQUFjLHlCQUF5QixDQUFDLENBQUM7UUFDM0UsSUFBSSxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDbEIsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN6QixDQUFDO0lBQ0gsQ0FBQztJQUVELEtBQUs7UUFDSCxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssRUFBRSxDQUFDO0lBQzNCLENBQUM7K0dBbkRVLG9CQUFvQjttR0FBcEIsb0JBQW9CLDhvQkFDakIsb0JBQW9CLGdEQ1ZwQyx3N0JBb0JBOzs0RkRYYSxvQkFBb0I7a0JBTmhDLFNBQVM7K0JBQ0UsaUJBQWlCLGlCQUdaLGlCQUFpQixDQUFDLElBQUk7K0VBR0Qsb0JBQW9CO3NCQUF2RCxZQUFZO3VCQUFDLG9CQUFvQjtnQkFFbEIsRUFBRTtzQkFBakIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNjLGNBQWM7c0JBQWpDLEtBQUs7dUJBQUMsV0FBVztnQkFDVCxTQUFTO3NCQUFqQixLQUFLO2dCQUVvQyxPQUFPO3NCQUFoRCxLQUFLOztzQkFBSSxXQUFXO3VCQUFDLGtCQUFrQjtnQkFDRyxRQUFRO3NCQUFsRCxLQUFLOztzQkFBSSxXQUFXO3VCQUFDLG1CQUFtQjtnQkFDRSxRQUFRO3NCQUFsRCxLQUFLOztzQkFBSSxXQUFXO3VCQUFDLG1CQUFtQjtnQkFFTixLQUFLO3NCQUF2QyxXQUFXO3VCQUFDLGdCQUFnQjtnQkFDUSxPQUFPO3NCQUEzQyxXQUFXO3VCQUFDLGtCQUFrQjtnQkFDTyxRQUFRO3NCQUE3QyxXQUFXO3VCQUFDLG1CQUFtQjtnQkFFdEIsYUFBYTtzQkFBdEIsTUFBTTtnQkFtQlAsT0FBTztzQkFETixZQUFZO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBDb21wb25lbnQsIENvbnRlbnRDaGlsZCwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSG9zdExpc3RlbmVyLCBJbnB1dCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wsIEZvcm1Db250cm9sRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdlYy1mb3JtLWNvbnRyb2wnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9mb3JtLWNvbnRyb2wuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2Zvcm0tY29udHJvbC5jb21wb25lbnQuc2NzcyddLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIEZvcm1Db250cm9sQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XHJcbiAgQENvbnRlbnRDaGlsZChGb3JtQ29udHJvbERpcmVjdGl2ZSkgZm9ybUNvbnRyb2xEaXJlY3RpdmU/OiBBYnN0cmFjdENvbnRyb2w7XHJcbiAgXHJcbiAgQElucHV0KCkgcHVibGljIGlkOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSBpY29uPzogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGFjdGlvbkljb24/OiBzdHJpbmc7XHJcbiAgQElucHV0KCkgc2hvd0NsZWFyID0gdHJ1ZTtcclxuICBASW5wdXQoJ2Zvcm1Nb2RlbCcpIGZvcm1Nb2RlbElucHV0PzogQWJzdHJhY3RDb250cm9sO1xyXG4gIEBJbnB1dCgpIGF1dG9mb2N1cyA9IGZhbHNlO1xyXG4gIFxyXG4gIEBJbnB1dCgpIEBIb3N0QmluZGluZygnY2xhc3MuaXMtcGVuZGluZycpIHBlbmRpbmcgPSBmYWxzZTtcclxuICBASW5wdXQoKSBASG9zdEJpbmRpbmcoJ2NsYXNzLmlzLXJlcXVpcmVkJykgcmVxdWlyZWQgPSBmYWxzZTtcclxuICBASW5wdXQoKSBASG9zdEJpbmRpbmcoJ2NsYXNzLmlzLXJlYWRvbmx5JykgcmVhZG9ubHkgPSBmYWxzZTtcclxuICBcclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmlzLWVtcHR5JykgZ2V0IGVtcHR5KCk6Ym9vbGVhbiB7IHJldHVybiAhdGhpcy5fZm9ybU1vZGVsPy52YWx1ZSAmJiB0aGlzLl9mb3JtTW9kZWw/LnZhbHVlICE9PSAwfTtcclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmlzLWludmFsaWQnKSBnZXQgaW52YWxpZCgpOiBib29sZWFuIHsgcmV0dXJuIHRoaXMuX2Zvcm1Nb2RlbD8udG91Y2hlZCA9PSB0cnVlICYmIHRoaXMuX2Zvcm1Nb2RlbC5pbnZhbGlkID09IHRydWV9O1xyXG4gIEBIb3N0QmluZGluZygnY2xhc3MuaXMtZGlzYWJsZWQnKSBnZXQgZGlzYWJsZWQoKTogYm9vbGVhbiB7IHJldHVybiB0aGlzLl9mb3JtTW9kZWw/LmRpc2FibGVkID09IHRydWUgfTtcclxuICBcclxuICBAT3V0cHV0KCkgYWN0aW9uQ2xpY2tlZDogRXZlbnRFbWl0dGVyPEV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXI8RXZlbnQ+KCk7XHJcblxyXG4gIHByaXZhdGUgZ2V0IF9mb3JtTW9kZWwoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5mb3JtTW9kZWxJbnB1dCB8fCB0aGlzLmZvcm1Db250cm9sRGlyZWN0aXZlO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZikgeyB9XHJcblxyXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcclxuICAgIGlmICghdGhpcy5fZm9ybU1vZGVsKSB7XHJcbiAgICAgIGNvbnNvbGUuZXJyb3IoJ01pc3NpbmcgW2Zvcm1Nb2RlbF0gaW5wdXQgb3IgW2Zvcm1Db250cm9sXSBkaXJlY3RpdmUgb24gZWMtZm9ybS1jb250cm9sIGNvbnRlbnQuJyk7XHJcbiAgICB9XHJcblxyXG4gICAgaWYgKHRoaXMuYXV0b2ZvY3VzKSB7XHJcbiAgICAgIHRoaXMuZm9jdXMoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJylcclxuICBvbkNsaWNrKCkge1xyXG4gICAgdGhpcy5mb2N1cygpO1xyXG4gIH1cclxuXHJcbiAgZm9jdXMoKSB7XHJcbiAgICBjb25zdCBlbCA9IHRoaXMuZWwubmF0aXZlRWxlbWVudCBhcyBIVE1MRWxlbWVudDtcclxuICAgIGNvbnN0IGlucHV0cyA9IGVsLnF1ZXJ5U2VsZWN0b3JBbGw8SFRNTEVsZW1lbnQ+KCdpbnB1dCwgdGV4dGFyZWEsIHNlbGVjdCcpO1xyXG4gICAgaWYgKGlucHV0cy5sZW5ndGgpIHtcclxuICAgICAgaW5wdXRzLml0ZW0oMCkuZm9jdXMoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGNsZWFyKCkge1xyXG4gICAgdGhpcy5fZm9ybU1vZGVsPy5yZXNldCgpO1xyXG4gIH1cclxufVxyXG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbjxpIGlkPVwie3tpZCArICdfaWNvbid9fVwiIGNsYXNzPVwiZWMtZm9ybS1jb250cm9sLWljb24gZWMtaWNvbiB7e2ljb259fVwiPjwvaT5cclxuPGkgaWQ9XCJ7e2lkICsgJ19sb2FkaW5nJ319XCIgY2xhc3M9XCJlYy1mb3JtLWNvbnRyb2wtaWNvbiBlYy1pY29uIGljb24tbG9hZGluZ1wiPjwvaT5cclxuPGkgaWQ9XCJ7e2lkICsgJ19yZXF1aXJlZCd9fVwiIGNsYXNzPVwiZWMtZm9ybS1jb250cm9sLWljb24gZWMtaWNvbiBpY29uLXJlcXVpcmVkXCI+PC9pPlxyXG48aSBpZD1cInt7aWQgKyAnX2ludmFsaWQnfX1cIiBjbGFzcz1cImVjLWZvcm0tY29udHJvbC1pY29uIGVjLWljb24gaWNvbi1pbnZhbGlkXCI+PC9pPlxyXG48YnV0dG9uICpuZ0lmPVwic2hvd0NsZWFyXCJcclxuICAgICAgICBpZD1cInt7aWQgKyAnX2NsZWFyJ319XCJcclxuICAgICAgICBbYXR0ci5kaXNhYmxlZF09XCJkaXNhYmxlZCB8fCB1bmRlZmluZWRcIlxyXG4gICAgICAgIGNsYXNzPVwiZWMtZm9ybS1jb250cm9sLWNsZWFyXCJcclxuICAgICAgICAoY2xpY2spPVwiY2xlYXIoKVwiPlxyXG4gIDxpIGNsYXNzPVwiZWMtaWNvbiBpY29uLWNhbmNlbFwiPjwvaT5cclxuPC9idXR0b24+XHJcbjxidXR0b24gKm5nSWY9XCJhY3Rpb25JY29uXCJcclxuICAgICAgICBpZD1cInt7aWQgKyAnX2FjdGlvbid9fVwiXHJcbiAgICAgICAgW2F0dHIuZGlzYWJsZWRdPVwiZGlzYWJsZWQgfHwgdW5kZWZpbmVkXCJcclxuICAgICAgICBjbGFzcz1cImVjLWZvcm0tY29udHJvbC1hY3Rpb25cIlxyXG4gICAgICAgIChjbGljayk9XCJhY3Rpb25DbGlja2VkLmVtaXQoJGV2ZW50KVwiPlxyXG4gIDxpIGNsYXNzPVwiZWMtaWNvbiB7e2FjdGlvbkljb259fVwiPjwvaT5cclxuPC9idXR0b24+XHJcbjxkaXYgY2xhc3M9XCJlYy1mb2N1cy1yaW5nXCI+PC9kaXY+XHJcbiJdfQ==
@@ -111,6 +111,8 @@ export class DateTimeHelper {
111
111
  * This is not an exhaustive list of formats, but it should cover most common formats.
112
112
  */
113
113
  static { this.momentMedAndLongDateFormats = [
114
+ 'DD MMM',
115
+ 'MMM DD',
114
116
  'DD MMM YY',
115
117
  'DD MMM YYYY',
116
118
  'DD MMMM YYYY',
@@ -118,7 +120,13 @@ export class DateTimeHelper {
118
120
  'MMM D, YYYY',
119
121
  'MMM DD, YYYY',
120
122
  'MMMM D, YYYY',
121
- 'MMMM DD, YYYY'
123
+ 'MMMM DD, YYYY',
124
+ 'MMM YY',
125
+ 'MMM YYYY',
126
+ 'MMMM YYYY',
127
+ 'MMM, YY',
128
+ 'MMM, YYYY',
129
+ 'MMMM, YYYY',
122
130
  ]; }
123
131
  /**
124
132
  * Format to display the time portion of a datetime
@@ -217,4 +225,4 @@ export class DateTimeHelper {
217
225
  }
218
226
  }
219
227
  }
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-helper.js","sourceRoot":"","sources":["../../../../../projects/components/src/lib/core/date-time-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import moment from 'moment';\r\n\r\ntype DateFormatMap = { [format: string]: string[] };\r\n\r\n/**\r\n * Helper class that provides common date constants and helpful date functions\r\n */\r\nexport class DateTimeHelper {\r\n\r\n    ///////////////////////////////////////////////////////\r\n    // CONSTANTS\r\n    ///////////////////////////////////////////////////////\r\n\r\n    public static beginningOfTime: Date = new Date(1899,11,31);\r\n     \r\n    /** 3000-01-01 */\r\n    public static endOfTime: Date = new Date(3000, 0, 1);\r\n\r\n    /** 3000-01-01 UTC */\r\n    public static endOfTimeUTC: Date = moment.utc('3000-01-01').toDate();\r\n\r\n    /** Default effective date for new AccountMeter relationships: 2010-01-01 */\r\n    public static defaultAccountMeterEffectiveDate: Date = new Date(2010, 0, 1);\r\n\r\n    /** The default date that a newly created account becomes effective: 2010-01-01 */\r\n    public static defaultAccountServiceEffectiveDate: Date = new Date(2010, 0, 1);\r\n\r\n    /** Minimum date for all datepickers: 1980-01-01 */\r\n    public static minDatePickerDate: Date = new Date(1980, 0, 1);\r\n\r\n    /** Maximum date for all datepickers: 3000-01-01 11:59:59 PM to allow for local time offset working in for 3000-01-01 dates, which we store in the db to represent \"end of time\" */\r\n    public static maxDatePickerDate: Date = new Date(3000,0,1,23,59,59);\r\n\r\n    /** Timestamp formats */\r\n    public static defaultDateFormat: string = \"yyyy-MM-dd\";\r\n    public static defaultTimeFormat: string = \"HH:mm:ss\";\r\n    public static defaultTimestampFormat: string = `${DateTimeHelper.defaultDateFormat} ${DateTimeHelper.defaultTimeFormat}`;\r\n\r\n    /** List of valid bill import date formats\r\n     *  Warning! Do not use these for actual formatting of dates\r\n     */\r\n    public static billImportFormatDateFormats = [\r\n        { label: \"mm/dd/yyyy\", value: \"mm/dd/yyyy\" }, { label: \"Month dd yyyy\", value: \"Month dd yyyy\" }, \r\n        { label: \"dd/mm/yyyy\", value: \"dd/mm/yyyy\" }, { label: \"dd Month yyyy\", value: \"dd Month yyyy\" }, { label: \"yyyymmdd\", value: \"yyyymmdd\" }];\r\n\r\n    /**\r\n     * User input formats that we will parse into a date\r\n     * when the users date format preference has month before day\r\n     */\r\n    public static monthFirstParseFormats: string[] = [\r\n        \"yyyy/MM/dd\",\r\n        \"MM/dd/yyyy\",\r\n        \"MMddyyyy\",\r\n        \"MM/dd/yy\",\r\n        \"MMddyy\",\r\n        \"MM/dd\",\r\n        \"yyyy.MM.dd\",\r\n        \"MM.dd.yyyy\",\r\n        \"MM.dd.yy\",\r\n        \"MM.dd\",\r\n        \"yyyy-MM-dd\",\r\n        \"MM-dd-yyyy\",\r\n        \"MM-dd-yy\",\r\n        \"MM-dd\",\r\n        \"yyyyMMdd\"\r\n    ];\r\n\r\n    /**\r\n     * User input formats that we will parse into a date\r\n     * when the users date format preference has month before day.\r\n     * To be used with moment.js. Moment ignores non-alphanumeric characters\r\n     * so dates like 2020/09/10 will be parsed the same as 2020-09-10\r\n     */\r\n    public static momentMonthFirstParseFormats: string[] = [\r\n        'M-D',\r\n        'MM-DD',\r\n        'M-D-YY',\r\n        'MM-DD-YY',\r\n        'MMDDYYYY',\r\n        'YYYYMMDD',\r\n        'YYYY-MM-DD',\r\n        'MM-DD-YYYY'\r\n    ];\r\n\r\n    /**\r\n     * User input formats that we will parse into a date\r\n     * when the users date format preference has day before month\r\n     */\r\n    public static dateFirstParseFormats: string[] = [\r\n        \"yyyy/dd/MM\",\r\n        \"dd/MM/yyyy\",\r\n        \"ddMMyyyy\",\r\n        \"dd/MM/yy\",\r\n        \"ddMMyy\",\r\n        \"dd/MM\",\r\n        \"yyyy.dd.MM\",\r\n        \"dd.MM.yyyy\",\r\n        \"dd.MM.yy\",\r\n        \"dd.MM\",\r\n        \"yyyy-dd-MM\",\r\n        \"dd-MM-yyyy\",\r\n        \"dd-MM-yy\",\r\n        \"dd-MM\",\r\n        \"yyyyDDmm\"\r\n    ];\r\n\r\n    /**\r\n     * User input formats that we will parse into a date\r\n     * when the users date format preference has day before month.\r\n     * To be used with moment.js. Moment ignores non-alphanumeric characters\r\n     * so dates like 2020/09/10 will be parsed the same as 2020-09-10\r\n     */\r\n    public static momentDateFirstParseFormats: string[] = [\r\n        'D-M',\r\n        'DD-MM',\r\n        'D-M-YY',\r\n        'DD-MM-YY',\r\n        'DDMMYYYY',\r\n        'YYYYMMDD',\r\n        'YYYY-MM-DD',\r\n        'DD-MM-YYYY'\r\n    ];\r\n\r\n    /**\r\n     * Formats used to parse dates that are in the medium or long format by moment js.\r\n     * These are shared by date-first and month-first date formats. The date can't be\r\n     * parsed differently based on the date preference since the month is not numeric.\r\n     * This is not an exhaustive list of formats, but it should cover most common formats.\r\n     */\r\n    public static momentMedAndLongDateFormats: string[] = [\r\n        'DD MMM YY',\r\n        'DD MMM YYYY',\r\n        'DD MMMM YYYY',\r\n        'MMM D, YY',\r\n        'MMM D, YYYY',\r\n        'MMM DD, YYYY',\r\n        'MMMM D, YYYY',\r\n        'MMMM DD, YYYY'\r\n    ];\r\n\r\n    /**\r\n     * Format to display the time portion of a datetime\r\n     */\r\n    public static timeFormat: string = 'HH:mm:ss';\r\n\r\n    ///////////////////////////////////////////////////////\r\n    // METHODS\r\n    ///////////////////////////////////////////////////////\r\n\r\n    /**\r\n     * Return true if @see date is equal to the @see endOfTime\r\n     */\r\n    public static isEndOfTime(date: Date | moment.Moment | string, timeZoneOffset: boolean = false): boolean {\r\n        const endOfTime = timeZoneOffset ? this.endOfTimeUTC : this.endOfTime;\r\n        return this.isSameDay(date, endOfTime);\r\n    }\r\n\r\n\r\n    /**\r\n     * Compare two dates and return true if they represent the same year, month, and day (time is ignored).\r\n     */\r\n    public static isSameDay(date1: Date | moment.Moment | string, date2: Date | moment.Moment | string): boolean {\r\n        return moment(date1).isSame(moment(date2), 'day');\r\n    }\r\n\r\n    /**\r\n     * Get the parse formats based on the given date format. If no date format is\r\n     * given, or we don't recognize the format, return the month first parse formats.\r\n     * \r\n     */\r\n    public static getParseFormats(dateFormat?: string | null): string[] {\r\n        let map: DateFormatMap = {\r\n            'MM/DD/YYYY': this.monthFirstParseFormats,\r\n            'MM-DD-YYYY': this.monthFirstParseFormats,\r\n            'DD/MM/YYYY': this.dateFirstParseFormats,\r\n            'DD-MM-YYYY': this.dateFirstParseFormats,\r\n            'YYYY/MM/DD': this.monthFirstParseFormats,\r\n            'YYYY-MM-DD': this.monthFirstParseFormats\r\n        };\r\n\r\n        return dateFormat ? map[dateFormat] : this.monthFirstParseFormats;\r\n    }\r\n\r\n    /**\r\n     * Get the moment parse formats based on the given date format. If no date format is\r\n     * given, or we don't recognize the format, return the month first parse formats.\r\n     */\r\n    public static getMomentParseFormats(dateFormat?: string | null): string[] {\r\n        let map: DateFormatMap = {\r\n            'MM/DD/YYYY': [...this.momentMonthFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'MM-DD-YYYY': [...this.momentMonthFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'DD/MM/YYYY': [...this.momentDateFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'DD-MM-YYYY': [...this.momentDateFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'YYYY/MM/DD': [...this.momentMonthFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'YYYY-MM-DD': [...this.momentMonthFirstParseFormats, ...this.momentMedAndLongDateFormats]\r\n        };\r\n\r\n        return dateFormat ? map[dateFormat] : this.momentMonthFirstParseFormats;\r\n    }\r\n\r\n\r\n\r\n    /**\r\n     * Get relationship start date (favoring date in partialFormState if exists)\r\n     * * return default account-meter effective date if no start date found\r\n     * \r\n     */\r\n    public static getAccountMeterStartDate(partialFormState: any, accountMeter: { startDate: Date | null | undefined }): Date {\r\n        let startDate = partialFormState.effectiveFrom || accountMeter.startDate;\r\n        return startDate ? new Date(startDate) : DateTimeHelper.defaultAccountMeterEffectiveDate;\r\n    }\r\n\r\n    \r\n    /**\r\n     * Get relationship end date (favoring date in partialFormState if exists)\r\n     * * return null if no stored date or end date is 1/1/3000\r\n     */\r\n    public static getAccountMeterEndDate(partialFormState: any, accountMeter: { endDate: Date | null | undefined }): Date | null {\r\n        let endDate = partialFormState.effectiveTo || accountMeter.endDate;\r\n        if (endDate && !DateTimeHelper.isEndOfTime(endDate)) {\r\n            return new Date(endDate);\r\n        }\r\n        return null;\r\n    }\r\n    \r\n    public static isDateBetween(\r\n        date: Date, \r\n        startDate?: Date | null, \r\n        endDate?: Date | null, \r\n        includeStart?: boolean, \r\n        includeEnd?: boolean\r\n    ):boolean {\r\n        let inclusivity: '()' | '[)' | '(]' | '[]' = '()';\r\n        if (includeStart && includeEnd ) {\r\n            inclusivity = '[]';\r\n        } else if (includeStart) {\r\n            inclusivity = '[)';\r\n        } else if (includeEnd) {\r\n            inclusivity = '(]';\r\n        }\r\n\r\n        // If a start date is not provide, we'll use our beginning of time instead\r\n        startDate = startDate || this.beginningOfTime;\r\n\r\n        // If an end date is not provided, we'll use our end of time instead\r\n        endDate = endDate || this.endOfTime;\r\n\r\n        return moment(date).isBetween(startDate, endDate, 'day', inclusivity);\r\n    }\r\n\r\n    public static stringToDate(dateString: string | null | undefined): Date | null | undefined {\r\n      if (dateString === null || dateString === undefined) {\r\n        return dateString;\r\n      } else {\r\n        return moment(dateString).toDate();\r\n      }      \r\n    }\r\n}"]}
228
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-helper.js","sourceRoot":"","sources":["../../../../../projects/components/src/lib/core/date-time-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import moment from 'moment';\r\n\r\ntype DateFormatMap = { [format: string]: string[] };\r\n\r\n/**\r\n * Helper class that provides common date constants and helpful date functions\r\n */\r\nexport class DateTimeHelper {\r\n\r\n    ///////////////////////////////////////////////////////\r\n    // CONSTANTS\r\n    ///////////////////////////////////////////////////////\r\n\r\n    public static beginningOfTime: Date = new Date(1899,11,31);\r\n     \r\n    /** 3000-01-01 */\r\n    public static endOfTime: Date = new Date(3000, 0, 1);\r\n\r\n    /** 3000-01-01 UTC */\r\n    public static endOfTimeUTC: Date = moment.utc('3000-01-01').toDate();\r\n\r\n    /** Default effective date for new AccountMeter relationships: 2010-01-01 */\r\n    public static defaultAccountMeterEffectiveDate: Date = new Date(2010, 0, 1);\r\n\r\n    /** The default date that a newly created account becomes effective: 2010-01-01 */\r\n    public static defaultAccountServiceEffectiveDate: Date = new Date(2010, 0, 1);\r\n\r\n    /** Minimum date for all datepickers: 1980-01-01 */\r\n    public static minDatePickerDate: Date = new Date(1980, 0, 1);\r\n\r\n    /** Maximum date for all datepickers: 3000-01-01 11:59:59 PM to allow for local time offset working in for 3000-01-01 dates, which we store in the db to represent \"end of time\" */\r\n    public static maxDatePickerDate: Date = new Date(3000,0,1,23,59,59);\r\n\r\n    /** Timestamp formats */\r\n    public static defaultDateFormat: string = \"yyyy-MM-dd\";\r\n    public static defaultTimeFormat: string = \"HH:mm:ss\";\r\n    public static defaultTimestampFormat: string = `${DateTimeHelper.defaultDateFormat} ${DateTimeHelper.defaultTimeFormat}`;\r\n\r\n    /** List of valid bill import date formats\r\n     *  Warning! Do not use these for actual formatting of dates\r\n     */\r\n    public static billImportFormatDateFormats = [\r\n        { label: \"mm/dd/yyyy\", value: \"mm/dd/yyyy\" }, { label: \"Month dd yyyy\", value: \"Month dd yyyy\" }, \r\n        { label: \"dd/mm/yyyy\", value: \"dd/mm/yyyy\" }, { label: \"dd Month yyyy\", value: \"dd Month yyyy\" }, { label: \"yyyymmdd\", value: \"yyyymmdd\" }];\r\n\r\n    /**\r\n     * User input formats that we will parse into a date\r\n     * when the users date format preference has month before day\r\n     */\r\n    public static monthFirstParseFormats: string[] = [\r\n        \"yyyy/MM/dd\",\r\n        \"MM/dd/yyyy\",\r\n        \"MMddyyyy\",\r\n        \"MM/dd/yy\",\r\n        \"MMddyy\",\r\n        \"MM/dd\",\r\n        \"yyyy.MM.dd\",\r\n        \"MM.dd.yyyy\",\r\n        \"MM.dd.yy\",\r\n        \"MM.dd\",\r\n        \"yyyy-MM-dd\",\r\n        \"MM-dd-yyyy\",\r\n        \"MM-dd-yy\",\r\n        \"MM-dd\",\r\n        \"yyyyMMdd\"\r\n    ];\r\n\r\n    /**\r\n     * User input formats that we will parse into a date\r\n     * when the users date format preference has month before day.\r\n     * To be used with moment.js. Moment ignores non-alphanumeric characters\r\n     * so dates like 2020/09/10 will be parsed the same as 2020-09-10\r\n     */\r\n    public static momentMonthFirstParseFormats: string[] = [\r\n        'M-D',\r\n        'MM-DD',\r\n        'M-D-YY',\r\n        'MM-DD-YY',\r\n        'MMDDYYYY',\r\n        'YYYYMMDD',\r\n        'YYYY-MM-DD',\r\n        'MM-DD-YYYY'\r\n    ];\r\n\r\n    /**\r\n     * User input formats that we will parse into a date\r\n     * when the users date format preference has day before month\r\n     */\r\n    public static dateFirstParseFormats: string[] = [\r\n        \"yyyy/dd/MM\",\r\n        \"dd/MM/yyyy\",\r\n        \"ddMMyyyy\",\r\n        \"dd/MM/yy\",\r\n        \"ddMMyy\",\r\n        \"dd/MM\",\r\n        \"yyyy.dd.MM\",\r\n        \"dd.MM.yyyy\",\r\n        \"dd.MM.yy\",\r\n        \"dd.MM\",\r\n        \"yyyy-dd-MM\",\r\n        \"dd-MM-yyyy\",\r\n        \"dd-MM-yy\",\r\n        \"dd-MM\",\r\n        \"yyyyDDmm\"\r\n    ];\r\n\r\n    /**\r\n     * User input formats that we will parse into a date\r\n     * when the users date format preference has day before month.\r\n     * To be used with moment.js. Moment ignores non-alphanumeric characters\r\n     * so dates like 2020/09/10 will be parsed the same as 2020-09-10\r\n     */\r\n    public static momentDateFirstParseFormats: string[] = [\r\n        'D-M',\r\n        'DD-MM',\r\n        'D-M-YY',\r\n        'DD-MM-YY',\r\n        'DDMMYYYY',\r\n        'YYYYMMDD',\r\n        'YYYY-MM-DD',\r\n        'DD-MM-YYYY'\r\n    ];\r\n\r\n    /**\r\n     * Formats used to parse dates that are in the medium or long format by moment js.\r\n     * These are shared by date-first and month-first date formats. The date can't be\r\n     * parsed differently based on the date preference since the month is not numeric.\r\n     * This is not an exhaustive list of formats, but it should cover most common formats.\r\n     */\r\n    public static momentMedAndLongDateFormats: string[] = [\r\n        'DD MMM',\r\n        'MMM DD',\r\n        'DD MMM YY',\r\n        'DD MMM YYYY',\r\n        'DD MMMM YYYY',\r\n        'MMM D, YY',\r\n        'MMM D, YYYY',\r\n        'MMM DD, YYYY',\r\n        'MMMM D, YYYY',\r\n        'MMMM DD, YYYY',\r\n        'MMM YY',\r\n        'MMM YYYY',\r\n        'MMMM YYYY',\r\n        'MMM, YY',\r\n        'MMM, YYYY',\r\n        'MMMM, YYYY',\r\n    ];\r\n\r\n    /**\r\n     * Format to display the time portion of a datetime\r\n     */\r\n    public static timeFormat: string = 'HH:mm:ss';\r\n\r\n    ///////////////////////////////////////////////////////\r\n    // METHODS\r\n    ///////////////////////////////////////////////////////\r\n\r\n    /**\r\n     * Return true if @see date is equal to the @see endOfTime\r\n     */\r\n    public static isEndOfTime(date: Date | moment.Moment | string, timeZoneOffset: boolean = false): boolean {\r\n        const endOfTime = timeZoneOffset ? this.endOfTimeUTC : this.endOfTime;\r\n        return this.isSameDay(date, endOfTime);\r\n    }\r\n\r\n\r\n    /**\r\n     * Compare two dates and return true if they represent the same year, month, and day (time is ignored).\r\n     */\r\n    public static isSameDay(date1: Date | moment.Moment | string, date2: Date | moment.Moment | string): boolean {\r\n        return moment(date1).isSame(moment(date2), 'day');\r\n    }\r\n\r\n    /**\r\n     * Get the parse formats based on the given date format. If no date format is\r\n     * given, or we don't recognize the format, return the month first parse formats.\r\n     * \r\n     */\r\n    public static getParseFormats(dateFormat?: string | null): string[] {\r\n        let map: DateFormatMap = {\r\n            'MM/DD/YYYY': this.monthFirstParseFormats,\r\n            'MM-DD-YYYY': this.monthFirstParseFormats,\r\n            'DD/MM/YYYY': this.dateFirstParseFormats,\r\n            'DD-MM-YYYY': this.dateFirstParseFormats,\r\n            'YYYY/MM/DD': this.monthFirstParseFormats,\r\n            'YYYY-MM-DD': this.monthFirstParseFormats\r\n        };\r\n\r\n        return dateFormat ? map[dateFormat] : this.monthFirstParseFormats;\r\n    }\r\n\r\n    /**\r\n     * Get the moment parse formats based on the given date format. If no date format is\r\n     * given, or we don't recognize the format, return the month first parse formats.\r\n     */\r\n    public static getMomentParseFormats(dateFormat?: string | null): string[] {\r\n        let map: DateFormatMap = {\r\n            'MM/DD/YYYY': [...this.momentMonthFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'MM-DD-YYYY': [...this.momentMonthFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'DD/MM/YYYY': [...this.momentDateFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'DD-MM-YYYY': [...this.momentDateFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'YYYY/MM/DD': [...this.momentMonthFirstParseFormats, ...this.momentMedAndLongDateFormats],\r\n            'YYYY-MM-DD': [...this.momentMonthFirstParseFormats, ...this.momentMedAndLongDateFormats]\r\n        };\r\n\r\n        return dateFormat ? map[dateFormat] : this.momentMonthFirstParseFormats;\r\n    }\r\n\r\n\r\n\r\n    /**\r\n     * Get relationship start date (favoring date in partialFormState if exists)\r\n     * * return default account-meter effective date if no start date found\r\n     * \r\n     */\r\n    public static getAccountMeterStartDate(partialFormState: any, accountMeter: { startDate: Date | null | undefined }): Date {\r\n        let startDate = partialFormState.effectiveFrom || accountMeter.startDate;\r\n        return startDate ? new Date(startDate) : DateTimeHelper.defaultAccountMeterEffectiveDate;\r\n    }\r\n\r\n    \r\n    /**\r\n     * Get relationship end date (favoring date in partialFormState if exists)\r\n     * * return null if no stored date or end date is 1/1/3000\r\n     */\r\n    public static getAccountMeterEndDate(partialFormState: any, accountMeter: { endDate: Date | null | undefined }): Date | null {\r\n        let endDate = partialFormState.effectiveTo || accountMeter.endDate;\r\n        if (endDate && !DateTimeHelper.isEndOfTime(endDate)) {\r\n            return new Date(endDate);\r\n        }\r\n        return null;\r\n    }\r\n    \r\n    public static isDateBetween(\r\n        date: Date, \r\n        startDate?: Date | null, \r\n        endDate?: Date | null, \r\n        includeStart?: boolean, \r\n        includeEnd?: boolean\r\n    ):boolean {\r\n        let inclusivity: '()' | '[)' | '(]' | '[]' = '()';\r\n        if (includeStart && includeEnd ) {\r\n            inclusivity = '[]';\r\n        } else if (includeStart) {\r\n            inclusivity = '[)';\r\n        } else if (includeEnd) {\r\n            inclusivity = '(]';\r\n        }\r\n\r\n        // If a start date is not provide, we'll use our beginning of time instead\r\n        startDate = startDate || this.beginningOfTime;\r\n\r\n        // If an end date is not provided, we'll use our end of time instead\r\n        endDate = endDate || this.endOfTime;\r\n\r\n        return moment(date).isBetween(startDate, endDate, 'day', inclusivity);\r\n    }\r\n\r\n    public static stringToDate(dateString: string | null | undefined): Date | null | undefined {\r\n      if (dateString === null || dateString === undefined) {\r\n        return dateString;\r\n      } else {\r\n        return moment(dateString).toDate();\r\n      }      \r\n    }\r\n}"]}
@@ -0,0 +1,100 @@
1
+ import { DOCUMENT } from '@angular/common';
2
+ import { Directive, EventEmitter, Inject, Input, Output } from '@angular/core';
3
+ import { fromEvent, Subject } from 'rxjs';
4
+ import { takeUntil } from 'rxjs/operators';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/cdk/a11y";
7
+ /**
8
+ * A basic helper directive to determine when focus leaves the host element.
9
+ *
10
+ * NOTE: This directive utilizes hidden anchor elements. These will disrupt tab order for elements
11
+ * within a form. It is recommended to only use this directive when you need to redirect focus when
12
+ * focus leaves a container. Also make sure this directive is disabled when the focus out events
13
+ * are not needed to avoid keyboard nav problems.
14
+ */
15
+ export class KeyboardNavContainerDirective {
16
+ constructor(hostEl, _document, interactivityChecker) {
17
+ this.hostEl = hostEl;
18
+ this._document = _document;
19
+ this.interactivityChecker = interactivityChecker;
20
+ this.enabled = true;
21
+ this.focusOutStart = new EventEmitter();
22
+ this.focusOutEnd = new EventEmitter();
23
+ this.destroyed = new Subject();
24
+ // Create the start and end anchors.
25
+ this.startAnchor = this._document.createElement('div');
26
+ this.endAnchor = this._document.createElement('div');
27
+ // Hide the anchors from screen readers.
28
+ this.startAnchor.setAttribute('aria-hidden', 'true');
29
+ this.endAnchor.setAttribute('aria-hidden', 'true');
30
+ }
31
+ ngOnChanges() {
32
+ this.toggleAnchors(this.enabled);
33
+ }
34
+ ngAfterViewInit() {
35
+ // Insert the anchors into the DOM before and after the host element.
36
+ this.hostEl.nativeElement.parentNode?.insertBefore(this.startAnchor, this.hostEl.nativeElement);
37
+ this.hostEl.nativeElement.parentNode?.insertBefore(this.endAnchor, this.hostEl.nativeElement.nextSibling);
38
+ // Listen for focus events on the anchors.
39
+ fromEvent(this.startAnchor, 'focus').pipe(takeUntil(this.destroyed)).subscribe(() => this.focusOutStart.emit());
40
+ fromEvent(this.endAnchor, 'focus').pipe(takeUntil(this.destroyed)).subscribe(() => this.focusOutEnd.emit());
41
+ this.toggleAnchors(this.enabled);
42
+ }
43
+ ngOnDestroy() {
44
+ this.destroyed.next();
45
+ this.destroyed.complete();
46
+ // Cleanup the anchors
47
+ this.startAnchor.remove();
48
+ this.endAnchor.remove();
49
+ }
50
+ focus() {
51
+ const firstFocusableElement = this.getFirstFocusableElement(this.hostEl.nativeElement);
52
+ firstFocusableElement?.focus();
53
+ }
54
+ getFirstFocusableElement(element) {
55
+ // These are only possibly focusable. Some may be disabled or not visible.
56
+ const elements = element.querySelectorAll('input, textarea, select, button, a, [tabindex], [contenteditable]');
57
+ // Use the Angular CDK interactivity checker to determine if an element is actually focusable and tabbable.
58
+ // This checks for disabledness among other things.
59
+ const first = Array.from(elements).find(el => {
60
+ return this.interactivityChecker.isFocusable(el) && this.interactivityChecker.isTabbable(el);
61
+ });
62
+ return first || null;
63
+ }
64
+ toggleAnchors(enabled) {
65
+ // Make the anchors focusable if the container is enabled and we have subscribers for the events.
66
+ // Otherwise, remove the tabindexes so they cannot receive focus and disrupt the tab order.
67
+ if (enabled && this.focusOutStart.observers.length > 0) {
68
+ this.startAnchor.setAttribute('tabindex', '0');
69
+ }
70
+ else {
71
+ this.startAnchor.removeAttribute('tabindex');
72
+ }
73
+ if (enabled && this.focusOutEnd.observers.length > 0) {
74
+ this.endAnchor.setAttribute('tabindex', '0');
75
+ }
76
+ else {
77
+ this.endAnchor.removeAttribute('tabindex');
78
+ }
79
+ }
80
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: KeyboardNavContainerDirective, deps: [{ token: i0.ElementRef }, { token: DOCUMENT }, { token: i1.InteractivityChecker }], target: i0.ɵɵFactoryTarget.Directive }); }
81
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: KeyboardNavContainerDirective, selector: "[ecKeyboardNavContainer]", inputs: { enabled: ["ecKeyboardNavContainer", "enabled"] }, outputs: { focusOutStart: "focusOutStart", focusOutEnd: "focusOutEnd" }, exportAs: ["ecKeyboardNavContainer"], usesOnChanges: true, ngImport: i0 }); }
82
+ }
83
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: KeyboardNavContainerDirective, decorators: [{
84
+ type: Directive,
85
+ args: [{
86
+ selector: '[ecKeyboardNavContainer]',
87
+ exportAs: 'ecKeyboardNavContainer'
88
+ }]
89
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: Document, decorators: [{
90
+ type: Inject,
91
+ args: [DOCUMENT]
92
+ }] }, { type: i1.InteractivityChecker }], propDecorators: { enabled: [{
93
+ type: Input,
94
+ args: ['ecKeyboardNavContainer']
95
+ }], focusOutStart: [{
96
+ type: Output
97
+ }], focusOutEnd: [{
98
+ type: Output
99
+ }] } });
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyboard-nav-container.directive.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/directives/keyboard-nav-container/keyboard-nav-container.directive.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAiB,SAAS,EAAc,YAAY,EAAE,MAAM,EAAE,KAAK,EAAwB,MAAM,EAAE,MAAM,eAAe,CAAC;AAChI,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;AAM3C;;;;;;;GAOG;AACH,MAAM,OAAO,6BAA6B;IAYxC,YACU,MAA+B,EACb,SAAmB,EACrC,oBAA0C;QAF1C,WAAM,GAAN,MAAM,CAAyB;QACb,cAAS,GAAT,SAAS,CAAU;QACrC,yBAAoB,GAApB,oBAAoB,CAAsB;QAbnB,YAAO,GAAY,IAAI,CAAC;QAE/C,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAKnC,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAOtC,oCAAoC;QACpC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACvD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACrD,wCAAwC;QACxC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;QACrD,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;IACrD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnC,CAAC;IAED,eAAe;QACb,qEAAqE;QACrE,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,UAAU,EAAE,YAAY,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QAChG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,UAAU,EAAE,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QAE1G,0CAA0C;QAC1C,SAAS,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,IAAI,CACvC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,CAAC;QAE7C,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,IAAI,CACrC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;QAE3C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAC1B,sBAAsB;QACtB,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QAC1B,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;IAC1B,CAAC;IAEM,KAAK;QACV,MAAM,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QACvF,qBAAqB,EAAE,KAAK,EAAE,CAAC;IACjC,CAAC;IAEO,wBAAwB,CAAC,OAAoB;QACnD,0EAA0E;QAC1E,MAAM,QAAQ,GAAG,OAAO,CAAC,gBAAgB,CAAc,mEAAmE,CAAC,CAAC;QAE5H,2GAA2G;QAC3G,mDAAmD;QACnD,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;YAC3C,OAAO,IAAI,CAAC,oBAAoB,CAAC,WAAW,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QAC/F,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,IAAI,IAAI,CAAC;IACvB,CAAC;IAEO,aAAa,CAAC,OAAgB;QACpC,iGAAiG;QACjG,2FAA2F;QAC3F,IAAI,OAAO,IAAI,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACvD,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;QACjD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,OAAO,IAAI,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACrD,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;QAC/C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAC7C,CAAC;IACH,CAAC;+GAtFU,6BAA6B,4CAc9B,QAAQ;mGAdP,6BAA6B;;4FAA7B,6BAA6B;kBAZzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,0BAA0B;oBACpC,QAAQ,EAAE,wBAAwB;iBACnC;;0BAuBI,MAAM;2BAAC,QAAQ;4EAZe,OAAO;sBAAvC,KAAK;uBAAC,wBAAwB;gBAErB,aAAa;sBAAtB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import { InteractivityChecker } from '@angular/cdk/a11y';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { AfterViewInit, Directive, ElementRef, EventEmitter, Inject, Input, OnChanges, OnDestroy, Output } from '@angular/core';\r\nimport { fromEvent, Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\n@Directive({\r\n  selector: '[ecKeyboardNavContainer]',\r\n  exportAs: 'ecKeyboardNavContainer'\r\n})\r\n/**\r\n * A basic helper directive to determine when focus leaves the host element.\r\n * \r\n * NOTE: This directive utilizes hidden anchor elements. These will disrupt tab order for elements\r\n * within a form. It is recommended to only use this directive when you need to redirect focus when\r\n * focus leaves a container. Also make sure this directive is disabled when the focus out events\r\n * are not needed to avoid keyboard nav problems. \r\n */\r\nexport class KeyboardNavContainerDirective implements OnChanges, AfterViewInit, OnDestroy {\r\n\r\n  @Input('ecKeyboardNavContainer') enabled: boolean = true;\r\n\r\n  @Output() focusOutStart = new EventEmitter();\r\n  @Output() focusOutEnd = new EventEmitter();\r\n\r\n  private startAnchor: HTMLElement;\r\n  private endAnchor: HTMLElement;\r\n\r\n  private destroyed = new Subject<void>();\r\n\r\n  constructor(\r\n    private hostEl: ElementRef<HTMLElement>,\r\n    @Inject(DOCUMENT) private _document: Document,\r\n    private interactivityChecker: InteractivityChecker,\r\n  ) {\r\n    // Create the start and end anchors.\r\n    this.startAnchor = this._document.createElement('div');\r\n    this.endAnchor = this._document.createElement('div');\r\n    // Hide the anchors from screen readers.\r\n    this.startAnchor.setAttribute('aria-hidden', 'true');\r\n    this.endAnchor.setAttribute('aria-hidden', 'true');\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    this.toggleAnchors(this.enabled);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // Insert the anchors into the DOM before and after the host element.\r\n    this.hostEl.nativeElement.parentNode?.insertBefore(this.startAnchor, this.hostEl.nativeElement);\r\n    this.hostEl.nativeElement.parentNode?.insertBefore(this.endAnchor, this.hostEl.nativeElement.nextSibling);\r\n\r\n    // Listen for focus events on the anchors.\r\n    fromEvent(this.startAnchor, 'focus').pipe(\r\n      takeUntil(this.destroyed)\r\n    ).subscribe(() => this.focusOutStart.emit());\r\n\r\n    fromEvent(this.endAnchor, 'focus').pipe(\r\n      takeUntil(this.destroyed)\r\n    ).subscribe(() => this.focusOutEnd.emit());\r\n\r\n    this.toggleAnchors(this.enabled);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroyed.next();\r\n    this.destroyed.complete();\r\n    // Cleanup the anchors\r\n    this.startAnchor.remove();\r\n    this.endAnchor.remove();\r\n  }\r\n\r\n  public focus() {\r\n    const firstFocusableElement = this.getFirstFocusableElement(this.hostEl.nativeElement);\r\n    firstFocusableElement?.focus();\r\n  }\r\n\r\n  private getFirstFocusableElement(element: HTMLElement): HTMLElement | null {\r\n    // These are only possibly focusable. Some may be disabled or not visible.\r\n    const elements = element.querySelectorAll<HTMLElement>('input, textarea, select, button, a, [tabindex], [contenteditable]');\r\n\r\n    // Use the Angular CDK interactivity checker to determine if an element is actually focusable and tabbable.\r\n    // This checks for disabledness among other things.\r\n    const first = Array.from(elements).find(el => {\r\n      return this.interactivityChecker.isFocusable(el) && this.interactivityChecker.isTabbable(el);\r\n    });\r\n\r\n    return first || null;\r\n  }\r\n\r\n  private toggleAnchors(enabled: boolean) {\r\n    // Make the anchors focusable if the container is enabled and we have subscribers for the events.\r\n    // Otherwise, remove the tabindexes so they cannot receive focus and disrupt the tab order.\r\n    if (enabled && this.focusOutStart.observers.length > 0) {\r\n      this.startAnchor.setAttribute('tabindex', '0');\r\n    } else {\r\n      this.startAnchor.removeAttribute('tabindex');\r\n    }\r\n\r\n    if (enabled && this.focusOutEnd.observers.length > 0) {\r\n      this.endAnchor.setAttribute('tabindex', '0');\r\n    } else {\r\n      this.endAnchor.removeAttribute('tabindex');\r\n    }\r\n  }\r\n}\r\n"]}