@enigmatry/entry-components 16.1.0 → 16.1.1-preview.4

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 (48) hide show
  1. package/common/common.module.d.ts +3 -1
  2. package/common/date-time/entry-date-time-adapter.d.ts +12 -7
  3. package/common/date-time/entry-date-time-formats.d.ts +25 -0
  4. package/common/date-time/entry-time-adapter.d.ts +9 -0
  5. package/common/date-time/index.d.ts +4 -2
  6. package/common/date-time/native-time-adapter.d.ts +13 -0
  7. package/common/directives/index.d.ts +2 -0
  8. package/common/directives/ng-control-accessor.directive.d.ts +12 -0
  9. package/common/directives/noop-control-value-accessor.d.ts +10 -0
  10. package/date-time-picker/README.md +69 -0
  11. package/date-time-picker/date-time-picker.component.d.ts +35 -0
  12. package/date-time-picker/date-time-picker.module.d.ts +16 -0
  13. package/date-time-picker/index.d.ts +5 -0
  14. package/date-time-picker/public-api.d.ts +2 -0
  15. package/date-time-picker/time-picker.component.d.ts +26 -0
  16. package/esm2022/common/common.module.mjs +11 -3
  17. package/esm2022/common/date-time/entry-date-time-adapter.mjs +30 -12
  18. package/esm2022/common/date-time/entry-date-time-formats.mjs +14 -0
  19. package/esm2022/common/date-time/entry-time-adapter.mjs +10 -0
  20. package/esm2022/common/date-time/index.mjs +5 -3
  21. package/esm2022/common/date-time/native-time-adapter.mjs +31 -0
  22. package/esm2022/common/directives/index.mjs +3 -1
  23. package/esm2022/common/directives/ng-control-accessor.directive.mjs +46 -0
  24. package/esm2022/common/directives/noop-control-value-accessor.mjs +32 -0
  25. package/esm2022/date-time-picker/date-time-picker.component.mjs +126 -0
  26. package/esm2022/date-time-picker/date-time-picker.module.mjs +58 -0
  27. package/esm2022/date-time-picker/enigmatry-entry-components-date-time-picker.mjs +5 -0
  28. package/esm2022/date-time-picker/public-api.mjs +3 -0
  29. package/esm2022/date-time-picker/time-picker.component.mjs +80 -0
  30. package/esm2022/search-filter/date-time/date-time-search-filter.component.mjs +4 -4
  31. package/fesm2022/enigmatry-entry-components-common.mjs +158 -16
  32. package/fesm2022/enigmatry-entry-components-common.mjs.map +1 -1
  33. package/fesm2022/enigmatry-entry-components-date-time-picker.mjs +258 -0
  34. package/fesm2022/enigmatry-entry-components-date-time-picker.mjs.map +1 -0
  35. package/fesm2022/enigmatry-entry-components-search-filter.mjs +3 -3
  36. package/fesm2022/enigmatry-entry-components-search-filter.mjs.map +1 -1
  37. package/package.json +95 -89
  38. package/styles/modules/_default-theme.scss +12 -10
  39. package/styles/modules/components/buttons/_radio.scss +10 -5
  40. package/styles/modules/components/checkboxes/_generator.scss +17 -12
  41. package/styles/modules/components/tables/_header.scss +4 -2
  42. package/styles/modules/components/tables/_rows.scss +23 -11
  43. package/styles/modules/components/toggle/_generator.scss +25 -23
  44. package/styles/partials/core/components/_index.scss +2 -1
  45. package/styles/partials/core/components/date-time-picker/_general.scss +65 -0
  46. package/styles/partials/core/components/forms/_general.scss +0 -4
  47. package/common/date-time/entry-date-time.d.ts +0 -7
  48. package/esm2022/common/date-time/entry-date-time.mjs +0 -3
@@ -0,0 +1,32 @@
1
+ /* eslint-disable @typescript-eslint/no-empty-function */
2
+ import { Directive } from "@angular/core";
3
+ import { NG_VALUE_ACCESSOR } from "@angular/forms";
4
+ import * as i0 from "@angular/core";
5
+ export class NoopControlValueAccessorDirective {
6
+ writeValue(_obj) { }
7
+ registerOnChange(_fn) { }
8
+ registerOnTouched(_fn) { }
9
+ setDisabledState(_isDisabled) { }
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NoopControlValueAccessorDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
11
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: NoopControlValueAccessorDirective, isStandalone: true, providers: [
12
+ {
13
+ provide: NG_VALUE_ACCESSOR,
14
+ multi: true,
15
+ useExisting: NoopControlValueAccessorDirective
16
+ }
17
+ ], ngImport: i0 }); }
18
+ }
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NoopControlValueAccessorDirective, decorators: [{
20
+ type: Directive,
21
+ args: [{
22
+ standalone: true,
23
+ providers: [
24
+ {
25
+ provide: NG_VALUE_ACCESSOR,
26
+ multi: true,
27
+ useExisting: NoopControlValueAccessorDirective
28
+ }
29
+ ]
30
+ }]
31
+ }] });
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9vcC1jb250cm9sLXZhbHVlLWFjY2Vzc29yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL2NvbW1vbi9kaXJlY3RpdmVzL25vb3AtY29udHJvbC12YWx1ZS1hY2Nlc3Nvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx5REFBeUQ7QUFDekQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBWXpFLE1BQU0sT0FBTyxpQ0FBaUM7SUFDMUMsVUFBVSxDQUFDLElBQVMsSUFBVSxDQUFDO0lBQy9CLGdCQUFnQixDQUFDLEdBQVEsSUFBVSxDQUFDO0lBQ3BDLGlCQUFpQixDQUFDLEdBQVEsSUFBVSxDQUFDO0lBQ3JDLGdCQUFnQixDQUFFLFdBQW9CLElBQVUsQ0FBQzsrR0FKeEMsaUNBQWlDO21HQUFqQyxpQ0FBaUMsaUNBUi9CO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsS0FBSyxFQUFFLElBQUk7Z0JBQ1gsV0FBVyxFQUFFLGlDQUFpQzthQUNqRDtTQUNKOzs0RkFFUSxpQ0FBaUM7a0JBVjdDLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFNBQVMsRUFBRTt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixLQUFLLEVBQUUsSUFBSTs0QkFDWCxXQUFXLG1DQUFtQzt5QkFDakQ7cUJBQ0o7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktZnVuY3Rpb24gKi9cbmltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZSxcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBOb29wQ29udHJvbFZhbHVlQWNjZXNzb3JEaXJlY3RpdmVcbiAgICAgICAgfVxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgTm9vcENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlIGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICAgIHdyaXRlVmFsdWUoX29iajogYW55KTogdm9pZCB7IH1cbiAgICByZWdpc3Rlck9uQ2hhbmdlKF9mbjogYW55KTogdm9pZCB7IH1cbiAgICByZWdpc3Rlck9uVG91Y2hlZChfZm46IGFueSk6IHZvaWQgeyB9XG4gICAgc2V0RGlzYWJsZWRTdGF0ZT8oX2lzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHsgfVxufSJdfQ==
@@ -0,0 +1,126 @@
1
+ import { ChangeDetectionStrategy, Component, HostBinding, Input, Output, ViewChild, inject } from '@angular/core';
2
+ import { FormControl } from '@angular/forms';
3
+ import { MAT_DATE_FORMATS, DateAdapter } from '@angular/material/core';
4
+ import { ENTRY_MAT_DATE_TIME_FORMATS, EntryDateTimeAdapter, NgControlAccessorDirective, NoopControlValueAccessorDirective } from '@enigmatry/entry-components/common';
5
+ import { EntryTimePickerComponent } from './time-picker.component';
6
+ import { Subject, takeUntil } from 'rxjs';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@enigmatry/entry-components/common";
9
+ import * as i2 from "@angular/common";
10
+ import * as i3 from "@angular/forms";
11
+ import * as i4 from "@angular/material/form-field";
12
+ import * as i5 from "@angular/material/datepicker";
13
+ import * as i6 from "@angular/material/input";
14
+ import * as i7 from "@angular/material/button";
15
+ import * as i8 from "@angular/material/icon";
16
+ import * as i9 from "./time-picker.component";
17
+ export class EntryDateTimePickerComponent {
18
+ constructor() {
19
+ this.class = 'entry-date-time-picker';
20
+ this.dateTimeChanged = new Subject();
21
+ this.ngControlAccessor = inject(NgControlAccessorDirective);
22
+ this.dateTimeAdapter = inject(DateAdapter);
23
+ this.format = inject(ENTRY_MAT_DATE_TIME_FORMATS);
24
+ // Control that is connected to calendar
25
+ this.calendarControl = new FormControl(undefined);
26
+ this.is12HourClock = this.dateTimeAdapter.is12HoursClock(this.format.display.dateInput);
27
+ this.$destroy = new Subject();
28
+ }
29
+ // Control bound to component using FormsApi (ngModel, formControl, formControlName)
30
+ get formControl() {
31
+ return this.ngControlAccessor.control;
32
+ }
33
+ get minDate() {
34
+ if (!this.min) {
35
+ return undefined;
36
+ }
37
+ const result = this.dateTimeAdapter.clone(this.min);
38
+ this.dateTimeAdapter.setTime(result, 0, 0, 0);
39
+ return result;
40
+ }
41
+ get maxDate() {
42
+ if (!this.max) {
43
+ return undefined;
44
+ }
45
+ const result = this.dateTimeAdapter.clone(this.max);
46
+ this.dateTimeAdapter.setTime(result, 0, 0, 0);
47
+ return result;
48
+ }
49
+ ngOnInit() {
50
+ this.calendarControl.setValue(this.formControl.value, { emitEvent: false });
51
+ this.formControl.statusChanges
52
+ .pipe(takeUntil(this.$destroy))
53
+ .subscribe(status => {
54
+ if (status === 'DISABLED') {
55
+ this.calendarControl.disable({ emitEvent: false });
56
+ }
57
+ else {
58
+ this.calendarControl.enable({ emitEvent: false });
59
+ }
60
+ });
61
+ this.formControl.valueChanges
62
+ .pipe(takeUntil(this.$destroy))
63
+ .subscribe(value => {
64
+ this.calendarControl.setValue(value, { emitEvent: false });
65
+ this.dateTimeChanged.next(value);
66
+ });
67
+ this.calendarControl.valueChanges
68
+ .pipe(takeUntil(this.$destroy))
69
+ .subscribe(value => {
70
+ this.timePicker.to24HourClock();
71
+ this.dateTimeAdapter.setTime(value, this.timePicker.hours, this.timePicker.minutes, this.timePicker.seconds);
72
+ this.formControl.setValue(value);
73
+ });
74
+ }
75
+ ngOnChanges(_changes) {
76
+ if (this.disabled) {
77
+ this.formControl.disable();
78
+ this.calendarControl.disable();
79
+ }
80
+ else {
81
+ this.formControl.enable();
82
+ this.calendarControl.enable();
83
+ }
84
+ }
85
+ ngOnDestroy() {
86
+ this.$destroy.next();
87
+ this.$destroy.complete();
88
+ }
89
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryDateTimePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
90
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryDateTimePickerComponent, selector: "entry-date-time-picker", inputs: { label: "label", showSeconds: "showSeconds", disabled: "disabled", min: "min", max: "max", placeholder: "placeholder", hint: "hint", defaultTime: "defaultTime" }, outputs: { dateTimeChanged: "dateTimeChanged" }, host: { properties: { "class": "this.class" } }, providers: [
91
+ { provide: MAT_DATE_FORMATS, useFactory: () => inject(ENTRY_MAT_DATE_TIME_FORMATS) },
92
+ { provide: DateAdapter, useClass: EntryDateTimeAdapter }
93
+ ], viewQueries: [{ propertyName: "timePicker", first: true, predicate: EntryTimePickerComponent, descendants: true, static: true }], usesOnChanges: true, hostDirectives: [{ directive: i1.NoopControlValueAccessorDirective }, { directive: i1.NgControlAccessorDirective }], ngImport: i0, template: "<mat-form-field>\n <mat-label>{{ label }}</mat-label>\n <input matInput [matDatepicker]=\"hiddenPicker\" [placeholder]=\"placeholder\" [formControl]=\"formControl\">\n <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n <mat-datepicker #hiddenPicker class=\"hidden\"></mat-datepicker>\n <input class=\"hidden\" matInput [min]=\"minDate\" [max]=\"maxDate\" [matDatepicker]=\"picker\"\n [formControl]=\"calendarControl\">\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker (opened)=\"timePicker.update()\">\n <mat-datepicker-actions>\n <entry-time-picker [date]=\"formControl.value\" [showSeconds]=\"showSeconds\" [is12HourClock]=\"is12HourClock\"\n [defaultTime]=\"defaultTime\"></entry-time-picker>\n <button mat-raised-button color=\"primary\" matDateRangePickerApply class=\"entry-submit-button\">\n <mat-icon aria-hidden=\"false\" aria-label=\"Apply\" fontIcon=\"done\" class=\"icon\"></mat-icon>\n </button>\n </mat-datepicker-actions>\n </mat-datepicker>\n</mat-form-field>", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i5.MatDatepickerActions, selector: "mat-datepicker-actions, mat-date-range-picker-actions" }, { kind: "directive", type: i5.MatDatepickerApply, selector: "[matDatepickerApply], [matDateRangePickerApply]" }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i7.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i9.EntryTimePickerComponent, selector: "entry-time-picker", inputs: ["date", "showSeconds", "is12HourClock", "defaultTime"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
94
+ }
95
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryDateTimePickerComponent, decorators: [{
96
+ type: Component,
97
+ args: [{ selector: 'entry-date-time-picker', providers: [
98
+ { provide: MAT_DATE_FORMATS, useFactory: () => inject(ENTRY_MAT_DATE_TIME_FORMATS) },
99
+ { provide: DateAdapter, useClass: EntryDateTimeAdapter }
100
+ ], hostDirectives: [NoopControlValueAccessorDirective, NgControlAccessorDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-form-field>\n <mat-label>{{ label }}</mat-label>\n <input matInput [matDatepicker]=\"hiddenPicker\" [placeholder]=\"placeholder\" [formControl]=\"formControl\">\n <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n <mat-datepicker #hiddenPicker class=\"hidden\"></mat-datepicker>\n <input class=\"hidden\" matInput [min]=\"minDate\" [max]=\"maxDate\" [matDatepicker]=\"picker\"\n [formControl]=\"calendarControl\">\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker (opened)=\"timePicker.update()\">\n <mat-datepicker-actions>\n <entry-time-picker [date]=\"formControl.value\" [showSeconds]=\"showSeconds\" [is12HourClock]=\"is12HourClock\"\n [defaultTime]=\"defaultTime\"></entry-time-picker>\n <button mat-raised-button color=\"primary\" matDateRangePickerApply class=\"entry-submit-button\">\n <mat-icon aria-hidden=\"false\" aria-label=\"Apply\" fontIcon=\"done\" class=\"icon\"></mat-icon>\n </button>\n </mat-datepicker-actions>\n </mat-datepicker>\n</mat-form-field>" }]
101
+ }], propDecorators: { class: [{
102
+ type: HostBinding,
103
+ args: ['class']
104
+ }], label: [{
105
+ type: Input
106
+ }], showSeconds: [{
107
+ type: Input
108
+ }], disabled: [{
109
+ type: Input
110
+ }], min: [{
111
+ type: Input
112
+ }], max: [{
113
+ type: Input
114
+ }], placeholder: [{
115
+ type: Input
116
+ }], hint: [{
117
+ type: Input
118
+ }], defaultTime: [{
119
+ type: Input
120
+ }], dateTimeChanged: [{
121
+ type: Output
122
+ }], timePicker: [{
123
+ type: ViewChild,
124
+ args: [EntryTimePickerComponent, { static: true }]
125
+ }] } });
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../../libs/entry-components/date-time-picker/date-time-picker.component.ts","../../../../../libs/entry-components/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAgC,MAAM,EAAiB,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/J,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAkB,MAAM,wBAAwB,CAAC;AACvF,OAAO,EAAE,2BAA2B,EAAE,oBAAoB,EAAE,0BAA0B,EAAE,iCAAiC,EAAE,MAAM,oCAAoC,CAAC;AACtK,OAAO,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;AAY1C,MAAM,OAAO,4BAA4B;IAVzC;QAWwB,UAAK,GAAG,wBAAwB,CAAC;QAU7C,oBAAe,GAAG,IAAI,OAAO,EAAK,CAAC;QAE7C,sBAAiB,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QACvD,oBAAe,GAAqC,MAAM,CAAC,WAAW,CAAqC,CAAC;QAC5G,WAAM,GAAmB,MAAM,CAAC,2BAA2B,CAAC,CAAC;QAO7D,wCAAwC;QACxC,oBAAe,GAAmB,IAAI,WAAW,CAAI,SAAS,CAAC,CAAC;QAEhE,kBAAa,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAI3E,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;KAiExC;IA7EC,oFAAoF;IACpF,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC;IACxC,CAAC;IAWD,IAAI,OAAO;QACT,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;YACb,OAAO,SAAS,CAAC;SAClB;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpD,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9C,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,IAAI,OAAO;QACT,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;YACb,OAAO,SAAS,CAAC;SAClB;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpD,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9C,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAE5E,IAAI,CAAC,WAAW,CAAC,aAAa;aAC3B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,MAAM,CAAC,EAAE;YAClB,IAAI,MAAM,KAAK,UAAU,EAAE;gBACzB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;aACpD;iBAAM;gBACL,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;aACnD;QACH,CAAC,CAAC,CAAA;QAEJ,IAAI,CAAC,WAAW,CAAC,YAAY;aAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,KAAK,CAAC,EAAE;YAEf,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAC3D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnC,CAAC,CACF,CAAC;QAEJ,IAAI,CAAC,eAAe,CAAC,YAAY;aAC9B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,KAAK,CAAC,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;YAChC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAC7G,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,QAAuB;QACjC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;YAC3B,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;SAChC;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YAC1B,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC;SAC/B;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;+GA7FU,4BAA4B;mGAA5B,4BAA4B,+TAP5B;YACT,EAAE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,2BAA2B,CAAC,EAAE;YACpF,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,oBAAoB,EAAE;SACzD,sEA+BU,wBAAwB,wMC5CrC,+mCAiBiB;;4FDAJ,4BAA4B;kBAVxC,SAAS;+BACE,wBAAwB,aAEvB;wBACT,EAAE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,2BAA2B,CAAC,EAAE;wBACpF,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,oBAAoB,EAAE;qBACzD,kBACe,CAAC,iCAAiC,EAAE,0BAA0B,CAAC,mBAC9D,uBAAuB,CAAC,MAAM;8BAGzB,KAAK;sBAA1B,WAAW;uBAAC,OAAO;gBAEX,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,eAAe;sBAAxB,MAAM;gBAgBgD,UAAU;sBAAhE,SAAS;uBAAC,wBAAwB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { ChangeDetectionStrategy, Component, HostBinding, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, ViewChild, inject } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { MAT_DATE_FORMATS, DateAdapter, MatDateFormats } from '@angular/material/core';\nimport { ENTRY_MAT_DATE_TIME_FORMATS, EntryDateTimeAdapter, NgControlAccessorDirective, NoopControlValueAccessorDirective } from '@enigmatry/entry-components/common';\nimport { EntryTimePickerComponent } from './time-picker.component';\nimport { Subject, takeUntil } from 'rxjs';\n\n@Component({\n  selector: 'entry-date-time-picker',\n  templateUrl: './date-time-picker.component.html',\n  providers: [\n    { provide: MAT_DATE_FORMATS, useFactory: () => inject(ENTRY_MAT_DATE_TIME_FORMATS) },\n    { provide: DateAdapter, useClass: EntryDateTimeAdapter }\n  ],\n  hostDirectives: [NoopControlValueAccessorDirective, NgControlAccessorDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class EntryDateTimePickerComponent<D> implements OnInit, OnDestroy, OnChanges {\n  @HostBinding('class') class = 'entry-date-time-picker';\n\n  @Input() label: string;\n  @Input() showSeconds: boolean;\n  @Input() disabled: boolean;\n  @Input() min: D;\n  @Input() max: D;\n  @Input() placeholder: string | undefined;\n  @Input() hint: string | undefined;\n  @Input() defaultTime: D | undefined;\n  @Output() dateTimeChanged = new Subject<D>();\n\n  ngControlAccessor = inject(NgControlAccessorDirective);\n  dateTimeAdapter: EntryDateTimeAdapter<D, unknown> = inject(DateAdapter) as EntryDateTimeAdapter<D, unknown>;\n  format: MatDateFormats = inject(ENTRY_MAT_DATE_TIME_FORMATS);\n\n  // Control bound to component using FormsApi (ngModel, formControl, formControlName)\n  get formControl(): FormControl<D> {\n    return this.ngControlAccessor.control;\n  }\n\n  // Control that is connected to calendar\n  calendarControl: FormControl<D> = new FormControl<D>(undefined);\n\n  is12HourClock = this.dateTimeAdapter.is12HoursClock(this.format.display.dateInput);\n\n  @ViewChild(EntryTimePickerComponent, { static: true }) timePicker: EntryTimePickerComponent<D>;\n\n  private $destroy = new Subject<void>();\n\n  get minDate() {\n    if (!this.min) {\n      return undefined;\n    }\n    const result = this.dateTimeAdapter.clone(this.min);\n    this.dateTimeAdapter.setTime(result, 0, 0, 0);\n    return result;\n  }\n\n  get maxDate() {\n    if (!this.max) {\n      return undefined;\n    }\n    const result = this.dateTimeAdapter.clone(this.max);\n    this.dateTimeAdapter.setTime(result, 0, 0, 0);\n    return result;\n  }\n\n  ngOnInit(): void {\n    this.calendarControl.setValue(this.formControl.value, { emitEvent: false });\n\n    this.formControl.statusChanges\n      .pipe(takeUntil(this.$destroy))\n      .subscribe(status => {\n        if (status === 'DISABLED') {\n          this.calendarControl.disable({ emitEvent: false });\n        } else {\n          this.calendarControl.enable({ emitEvent: false });\n        }\n      })\n\n    this.formControl.valueChanges\n      .pipe(takeUntil(this.$destroy))\n      .subscribe(value =>\n        {\n          this.calendarControl.setValue(value, { emitEvent: false });\n          this.dateTimeChanged.next(value);\n        }\n      );\n\n    this.calendarControl.valueChanges\n      .pipe(takeUntil(this.$destroy))\n      .subscribe(value => {\n        this.timePicker.to24HourClock();\n        this.dateTimeAdapter.setTime(value, this.timePicker.hours, this.timePicker.minutes, this.timePicker.seconds);\n        this.formControl.setValue(value);\n      });\n  }\n\n  ngOnChanges(_changes: SimpleChanges): void {\n    if (this.disabled) {\n      this.formControl.disable();\n      this.calendarControl.disable();\n    } else {\n      this.formControl.enable();\n      this.calendarControl.enable();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.$destroy.next();\n    this.$destroy.complete();\n  }\n}\n","<mat-form-field>\n    <mat-label>{{ label }}</mat-label>\n    <input matInput [matDatepicker]=\"hiddenPicker\" [placeholder]=\"placeholder\" [formControl]=\"formControl\">\n    <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n    <mat-datepicker #hiddenPicker class=\"hidden\"></mat-datepicker>\n    <input class=\"hidden\" matInput [min]=\"minDate\" [max]=\"maxDate\" [matDatepicker]=\"picker\"\n        [formControl]=\"calendarControl\">\n    <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n    <mat-datepicker #picker (opened)=\"timePicker.update()\">\n        <mat-datepicker-actions>\n            <entry-time-picker [date]=\"formControl.value\" [showSeconds]=\"showSeconds\" [is12HourClock]=\"is12HourClock\"\n                [defaultTime]=\"defaultTime\"></entry-time-picker>\n            <button mat-raised-button color=\"primary\" matDateRangePickerApply class=\"entry-submit-button\">\n                <mat-icon aria-hidden=\"false\" aria-label=\"Apply\" fontIcon=\"done\" class=\"icon\"></mat-icon>\n            </button>\n        </mat-datepicker-actions>\n    </mat-datepicker>\n</mat-form-field>"]}
@@ -0,0 +1,58 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { FormsModule, ReactiveFormsModule } from "@angular/forms";
3
+ import { MatDatepickerModule } from "@angular/material/datepicker";
4
+ import { MatFormFieldModule } from "@angular/material/form-field";
5
+ import { EntryDateTimePickerComponent } from "./date-time-picker.component";
6
+ import { CommonModule } from "@angular/common";
7
+ import { MatSelectModule } from "@angular/material/select";
8
+ import { MatButtonModule } from "@angular/material/button";
9
+ import { MatInputModule } from "@angular/material/input";
10
+ import { MatIconModule } from "@angular/material/icon";
11
+ import { EntryTimePickerComponent } from './time-picker.component';
12
+ import * as i0 from "@angular/core";
13
+ export class EntryDateTimePickerModule {
14
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryDateTimePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
15
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: EntryDateTimePickerModule, declarations: [EntryDateTimePickerComponent,
16
+ EntryTimePickerComponent], imports: [CommonModule,
17
+ FormsModule,
18
+ ReactiveFormsModule,
19
+ MatFormFieldModule,
20
+ MatDatepickerModule,
21
+ MatInputModule,
22
+ MatSelectModule,
23
+ MatButtonModule,
24
+ MatIconModule], exports: [EntryDateTimePickerComponent] }); }
25
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryDateTimePickerModule, imports: [CommonModule,
26
+ FormsModule,
27
+ ReactiveFormsModule,
28
+ MatFormFieldModule,
29
+ MatDatepickerModule,
30
+ MatInputModule,
31
+ MatSelectModule,
32
+ MatButtonModule,
33
+ MatIconModule] }); }
34
+ }
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryDateTimePickerModule, decorators: [{
36
+ type: NgModule,
37
+ args: [{
38
+ imports: [
39
+ CommonModule,
40
+ FormsModule,
41
+ ReactiveFormsModule,
42
+ MatFormFieldModule,
43
+ MatDatepickerModule,
44
+ MatInputModule,
45
+ MatSelectModule,
46
+ MatButtonModule,
47
+ MatIconModule
48
+ ],
49
+ declarations: [
50
+ EntryDateTimePickerComponent,
51
+ EntryTimePickerComponent
52
+ ],
53
+ exports: [
54
+ EntryDateTimePickerComponent
55
+ ]
56
+ }]
57
+ }] });
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLXBpY2tlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2VudHJ5LWNvbXBvbmVudHMvZGF0ZS10aW1lLXBpY2tlci9kYXRlLXRpbWUtcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUM1RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQXNCbkUsTUFBTSxPQUFPLHlCQUF5QjsrR0FBekIseUJBQXlCO2dIQUF6Qix5QkFBeUIsaUJBUDlCLDRCQUE0QjtZQUM1Qix3QkFBd0IsYUFaeEIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsa0JBQWtCO1lBQ2xCLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsZUFBZTtZQUNmLGVBQWU7WUFDZixhQUFhLGFBT2IsNEJBQTRCO2dIQUd2Qix5QkFBeUIsWUFsQjlCLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGtCQUFrQjtZQUNsQixtQkFBbUI7WUFDbkIsY0FBYztZQUNkLGVBQWU7WUFDZixlQUFlO1lBQ2YsYUFBYTs7NEZBVVIseUJBQXlCO2tCQXBCckMsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsa0JBQWtCO3dCQUNsQixtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGFBQWE7cUJBQ2hCO29CQUNELFlBQVksRUFBRTt3QkFDViw0QkFBNEI7d0JBQzVCLHdCQUF3QjtxQkFDM0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLDRCQUE0QjtxQkFDL0I7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuaW1wb3J0IHsgTWF0RGF0ZXBpY2tlck1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kYXRlcGlja2VyXCI7XG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZFwiO1xuaW1wb3J0IHsgRW50cnlEYXRlVGltZVBpY2tlckNvbXBvbmVudCB9IGZyb20gXCIuL2RhdGUtdGltZS1waWNrZXIuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBNYXRTZWxlY3RNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvc2VsZWN0XCI7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uXCI7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9pbnB1dFwiO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9pY29uXCI7XG5pbXBvcnQgeyBFbnRyeVRpbWVQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL3RpbWUtcGlja2VyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIEZvcm1zTW9kdWxlLFxuICAgICAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgICAgICBNYXRGb3JtRmllbGRNb2R1bGUsXG4gICAgICAgIE1hdERhdGVwaWNrZXJNb2R1bGUsXG4gICAgICAgIE1hdElucHV0TW9kdWxlLFxuICAgICAgICBNYXRTZWxlY3RNb2R1bGUsXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICAgICAgTWF0SWNvbk1vZHVsZVxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIEVudHJ5RGF0ZVRpbWVQaWNrZXJDb21wb25lbnQsXG4gICAgICAgIEVudHJ5VGltZVBpY2tlckNvbXBvbmVudFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICBFbnRyeURhdGVUaW1lUGlja2VyQ29tcG9uZW50XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBFbnRyeURhdGVUaW1lUGlja2VyTW9kdWxlIHsgfSJdfQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5pZ21hdHJ5LWVudHJ5LWNvbXBvbmVudHMtZGF0ZS10aW1lLXBpY2tlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZW50cnktY29tcG9uZW50cy9kYXRlLXRpbWUtcGlja2VyL2VuaWdtYXRyeS1lbnRyeS1jb21wb25lbnRzLWRhdGUtdGltZS1waWNrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -0,0 +1,3 @@
1
+ export { EntryDateTimePickerComponent } from './date-time-picker.component';
2
+ export { EntryDateTimePickerModule } from './date-time-picker.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZW50cnktY29tcG9uZW50cy9kYXRlLXRpbWUtcGlja2VyL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDNUUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBFbnRyeURhdGVUaW1lUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXRpbWUtcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBFbnRyeURhdGVUaW1lUGlja2VyTW9kdWxlIH0gZnJvbSAnLi9kYXRlLXRpbWUtcGlja2VyLm1vZHVsZSc7XG4iXX0=
@@ -0,0 +1,80 @@
1
+ import { Component, HostBinding, Input, inject } from '@angular/core';
2
+ import { DateAdapter } from '@angular/material/core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@angular/forms";
6
+ import * as i3 from "@angular/material/form-field";
7
+ import * as i4 from "@angular/material/select";
8
+ import * as i5 from "@angular/material/core";
9
+ export class EntryTimePickerComponent {
10
+ constructor() {
11
+ this.class = 'entry-time-picker';
12
+ this.timeAdapter = inject(DateAdapter);
13
+ this.hours = 0;
14
+ this.minutes = 0;
15
+ this.seconds = 0;
16
+ this.meridiem = 'am';
17
+ this.hours12 = Array.from(Array(12), (_, i) => i + 1);
18
+ this.hours24 = Array.from(Array(24), (_, i) => i);
19
+ this.sixty = Array.from(Array(60), (_, i) => i);
20
+ }
21
+ get possibleHours() {
22
+ return this.is12HourClock ? this.hours12 : this.hours24;
23
+ }
24
+ ngOnChanges(_changes) {
25
+ this.update();
26
+ }
27
+ update() {
28
+ const now = this.timeAdapter.today();
29
+ this.hours = this.date
30
+ ? this.timeAdapter.getHours(this.date)
31
+ : this.timeAdapter.getHours(this.defaultTime ?? now);
32
+ this.minutes = this.date
33
+ ? this.timeAdapter.getMinutes(this.date)
34
+ : this.timeAdapter.getMinutes(this.defaultTime ?? now);
35
+ this.seconds = (this.showSeconds && this.date)
36
+ ? this.timeAdapter.getSeconds(this.date)
37
+ : this.timeAdapter.getSeconds(this.defaultTime ?? now);
38
+ this.meridiem = this.hours >= 12 ? 'pm' : 'am';
39
+ if (this.is12HourClock) {
40
+ this.to12HourClock();
41
+ }
42
+ }
43
+ to12HourClock() {
44
+ if (this.hours > 12) {
45
+ this.hours = this.hours - 12;
46
+ }
47
+ if (this.hours === 0) {
48
+ this.hours = 12;
49
+ }
50
+ }
51
+ to24HourClock() {
52
+ if (!this.is12HourClock) {
53
+ return;
54
+ }
55
+ if (this.meridiem === "am" && this.hours === 12) {
56
+ this.hours = 0;
57
+ }
58
+ if (this.meridiem == "pm" && this.hours != 12) {
59
+ this.hours = this.hours + 12;
60
+ }
61
+ }
62
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryTimePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
63
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryTimePickerComponent, selector: "entry-time-picker", inputs: { date: "date", showSeconds: "showSeconds", is12HourClock: "is12HourClock", defaultTime: "defaultTime" }, host: { properties: { "class": "this.class" } }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field appearance=\"fill\">\n <mat-select [(ngModel)]=\"hours\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n <mat-option *ngFor=\"let hour of possibleHours\" [value]=\"hour\">{{hour | number:'2.0'}}</mat-option>\n </mat-select>\n</mat-form-field>\n<span class=\"time-separator\">&#58;</span>\n<mat-form-field appearance=\"fill\">\n <mat-select [(ngModel)]=\"minutes\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n <mat-option *ngFor=\"let minute of sixty\" [value]=\"minute\">{{minute | number:'2.0'}}</mat-option>\n </mat-select>\n</mat-form-field>\n<span *ngIf=\"showSeconds\" class=\"time-separator\">&#58;</span>\n<mat-form-field *ngIf=\"showSeconds\" appearance=\"fill\">\n <mat-select [(ngModel)]=\"seconds\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n <mat-option *ngFor=\"let second of sixty\" [value]=\"second\">{{second | number:'2.0'}}</mat-option>\n </mat-select>\n</mat-form-field>\n<mat-form-field *ngIf=\"is12HourClock\" appearance=\"fill\">\n <mat-select [(ngModel)]=\"meridiem\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n <mat-option value=\"am\">AM</mat-option>\n <mat-option value=\"pm\">PM</mat-option>\n </mat-select>\n</mat-form-field>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }] }); }
64
+ }
65
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryTimePickerComponent, decorators: [{
66
+ type: Component,
67
+ args: [{ selector: 'entry-time-picker', template: "<mat-form-field appearance=\"fill\">\n <mat-select [(ngModel)]=\"hours\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n <mat-option *ngFor=\"let hour of possibleHours\" [value]=\"hour\">{{hour | number:'2.0'}}</mat-option>\n </mat-select>\n</mat-form-field>\n<span class=\"time-separator\">&#58;</span>\n<mat-form-field appearance=\"fill\">\n <mat-select [(ngModel)]=\"minutes\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n <mat-option *ngFor=\"let minute of sixty\" [value]=\"minute\">{{minute | number:'2.0'}}</mat-option>\n </mat-select>\n</mat-form-field>\n<span *ngIf=\"showSeconds\" class=\"time-separator\">&#58;</span>\n<mat-form-field *ngIf=\"showSeconds\" appearance=\"fill\">\n <mat-select [(ngModel)]=\"seconds\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n <mat-option *ngFor=\"let second of sixty\" [value]=\"second\">{{second | number:'2.0'}}</mat-option>\n </mat-select>\n</mat-form-field>\n<mat-form-field *ngIf=\"is12HourClock\" appearance=\"fill\">\n <mat-select [(ngModel)]=\"meridiem\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n <mat-option value=\"am\">AM</mat-option>\n <mat-option value=\"pm\">PM</mat-option>\n </mat-select>\n</mat-form-field>" }]
68
+ }], propDecorators: { class: [{
69
+ type: HostBinding,
70
+ args: ['class']
71
+ }], date: [{
72
+ type: Input
73
+ }], showSeconds: [{
74
+ type: Input
75
+ }], is12HourClock: [{
76
+ type: Input
77
+ }], defaultTime: [{
78
+ type: Input
79
+ }] } });
80
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../libs/entry-components/date-time-picker/time-picker.component.ts","../../../../../libs/entry-components/date-time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Input, OnChanges, SimpleChanges, inject } from '@angular/core';\nimport { DateAdapter } from '@angular/material/core';\nimport { EntryDateTimeAdapter } from '@enigmatry/entry-components/common';\n\nexport type meridiem = 'am' | 'pm';\n\n@Component({\n  selector: 'entry-time-picker',\n  templateUrl: './time-picker.component.html'\n})\nexport class EntryTimePickerComponent<D> implements OnChanges {\n  @HostBinding('class') class = 'entry-time-picker';\n\n  readonly timeAdapter = inject(DateAdapter) as EntryDateTimeAdapter<D, unknown>;\n\n  @Input() date: D | undefined;\n  @Input() showSeconds: boolean;\n  @Input() is12HourClock: boolean;\n  @Input() defaultTime: D | undefined;\n\n  hours = 0;\n  minutes = 0;\n  seconds = 0;\n  meridiem: meridiem = 'am';\n\n  readonly hours12 = Array.from(Array(12), (_, i) => i + 1);\n  readonly hours24 = Array.from(Array(24), (_, i) => i);\n  readonly sixty = Array.from(Array(60), (_, i) => i);\n\n  get possibleHours() {\n    return this.is12HourClock ? this.hours12 : this.hours24;\n  }\n\n  ngOnChanges(_changes: SimpleChanges): void {\n    this.update();\n  }\n\n  update() {\n    const now = this.timeAdapter.today();\n\n    this.hours = this.date\n      ? this.timeAdapter.getHours(this.date)\n      : this.timeAdapter.getHours(this.defaultTime ?? now);\n\n    this.minutes = this.date\n      ? this.timeAdapter.getMinutes(this.date)\n      : this.timeAdapter.getMinutes(this.defaultTime ?? now);\n\n    this.seconds = (this.showSeconds && this.date)\n      ? this.timeAdapter.getSeconds(this.date)\n      : this.timeAdapter.getSeconds(this.defaultTime ?? now);\n\n    this.meridiem = this.hours >= 12 ? 'pm' : 'am';\n\n    if (this.is12HourClock) {\n      this.to12HourClock();\n    }\n  }\n\n  to12HourClock() {\n    if (this.hours > 12) {\n      this.hours = this.hours - 12;\n    }\n    if (this.hours === 0) {\n      this.hours = 12;\n    }\n  }\n\n  to24HourClock() {\n    if (!this.is12HourClock) {\n      return;\n    }\n    if (this.meridiem === \"am\" && this.hours === 12) {\n      this.hours = 0;\n    }\n    if (this.meridiem == \"pm\" && this.hours != 12) {\n      this.hours = this.hours + 12;\n    }\n  }\n}\n","<mat-form-field appearance=\"fill\">\n  <mat-select [(ngModel)]=\"hours\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n    <mat-option *ngFor=\"let hour of possibleHours\" [value]=\"hour\">{{hour | number:'2.0'}}</mat-option>\n  </mat-select>\n</mat-form-field>\n<span class=\"time-separator\">&#58;</span>\n<mat-form-field appearance=\"fill\">\n  <mat-select [(ngModel)]=\"minutes\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n    <mat-option *ngFor=\"let minute of sixty\" [value]=\"minute\">{{minute | number:'2.0'}}</mat-option>\n  </mat-select>\n</mat-form-field>\n<span *ngIf=\"showSeconds\" class=\"time-separator\">&#58;</span>\n<mat-form-field *ngIf=\"showSeconds\" appearance=\"fill\">\n  <mat-select [(ngModel)]=\"seconds\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n    <mat-option *ngFor=\"let second of sixty\" [value]=\"second\">{{second | number:'2.0'}}</mat-option>\n  </mat-select>\n</mat-form-field>\n<mat-form-field *ngIf=\"is12HourClock\" appearance=\"fill\">\n  <mat-select [(ngModel)]=\"meridiem\" [hideSingleSelectionIndicator]=\"true\" [panelWidth]=\"null\">\n    <mat-option value=\"am\">AM</mat-option>\n    <mat-option value=\"pm\">PM</mat-option>\n  </mat-select>\n</mat-form-field>"]}
@@ -1,6 +1,6 @@
1
1
  import { Component, Input, inject } from '@angular/core';
2
2
  import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
3
- import { ENTRY_MAT_DATE_TIME, EntryDateTimeAdapter } from '@enigmatry/entry-components/common';
3
+ import { ENTRY_MAT_DATE_TIME_FORMATS, EntryDateTimeAdapter } from '@enigmatry/entry-components/common';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/forms";
6
6
  import * as i2 from "@angular/material/input";
@@ -9,14 +9,14 @@ import * as i4 from "@angular/material/datepicker";
9
9
  export class DateTimeSearchFilterComponent {
10
10
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DateTimeSearchFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
11
11
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DateTimeSearchFilterComponent, selector: "entry-date-time-search-filter", inputs: { searchFilter: "searchFilter", form: "form" }, providers: [
12
- { provide: MAT_DATE_FORMATS, useFactory: () => inject(ENTRY_MAT_DATE_TIME).matDateFormats },
12
+ { provide: MAT_DATE_FORMATS, useFactory: () => inject(ENTRY_MAT_DATE_TIME_FORMATS) },
13
13
  { provide: DateAdapter, useClass: EntryDateTimeAdapter }
14
14
  ], ngImport: i0, template: "<mat-form-field [formGroup]=\"form\" subscriptSizing=\"dynamic\">\n <mat-label [attr.for]=\"searchFilter.key\">{{searchFilter.label}}</mat-label>\n <input matInput [formControlName]=\"searchFilter.key\" [matDatepicker]=\"picker\" [id]=\"searchFilter.key\">\n <mat-datepicker-toggle matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n</mat-form-field>", dependencies: [{ kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i4.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i4.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }] }); }
15
15
  }
16
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DateTimeSearchFilterComponent, decorators: [{
17
17
  type: Component,
18
18
  args: [{ selector: 'entry-date-time-search-filter', providers: [
19
- { provide: MAT_DATE_FORMATS, useFactory: () => inject(ENTRY_MAT_DATE_TIME).matDateFormats },
19
+ { provide: MAT_DATE_FORMATS, useFactory: () => inject(ENTRY_MAT_DATE_TIME_FORMATS) },
20
20
  { provide: DateAdapter, useClass: EntryDateTimeAdapter }
21
21
  ], template: "<mat-form-field [formGroup]=\"form\" subscriptSizing=\"dynamic\">\n <mat-label [attr.for]=\"searchFilter.key\">{{searchFilter.label}}</mat-label>\n <input matInput [formControlName]=\"searchFilter.key\" [matDatepicker]=\"picker\" [id]=\"searchFilter.key\">\n <mat-datepicker-toggle matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n</mat-form-field>" }]
22
22
  }], propDecorators: { searchFilter: [{
@@ -24,4 +24,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
24
24
  }], form: [{
25
25
  type: Input
26
26
  }] } });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3NlYXJjaC1maWx0ZXIvZGF0ZS10aW1lL2RhdGUtdGltZS1zZWFyY2gtZmlsdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZW50cnktY29tcG9uZW50cy9zZWFyY2gtZmlsdGVyL2RhdGUtdGltZS9kYXRlLXRpbWUtc2VhcmNoLWZpbHRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHekQsT0FBTyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOzs7Ozs7QUFVL0YsTUFBTSxPQUFPLDZCQUE2QjsrR0FBN0IsNkJBQTZCO21HQUE3Qiw2QkFBNkIsZ0hBTDdCO1lBQ1QsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLGNBQWMsRUFBRTtZQUMzRixFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLG9CQUFvQixFQUFFO1NBQ3pELDBCQ1pILDhaQUtpQjs7NEZEU0osNkJBQTZCO2tCQVJ6QyxTQUFTOytCQUNFLCtCQUErQixhQUU5Qjt3QkFDVCxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxVQUFVLEVBQUUsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUMsY0FBYyxFQUFFO3dCQUMzRixFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLG9CQUFvQixFQUFFO3FCQUN6RDs4QkFHUSxZQUFZO3NCQUFwQixLQUFLO2dCQUVHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGF0ZVRpbWVTZWFyY2hGaWx0ZXIgfSBmcm9tICcuL2RhdGUtdGltZS1zZWFyY2gtZmlsdGVyLm1vZGVsJztcbmltcG9ydCB7IFVudHlwZWRGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBEYXRlQWRhcHRlciwgTUFUX0RBVEVfRk9STUFUUyB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRU5UUllfTUFUX0RBVEVfVElNRSwgRW50cnlEYXRlVGltZUFkYXB0ZXIgfSBmcm9tICdAZW5pZ21hdHJ5L2VudHJ5LWNvbXBvbmVudHMvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZW50cnktZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXIuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFtcbiAgICB7IHByb3ZpZGU6IE1BVF9EQVRFX0ZPUk1BVFMsIHVzZUZhY3Rvcnk6ICgpID0+IGluamVjdChFTlRSWV9NQVRfREFURV9USU1FKS5tYXREYXRlRm9ybWF0cyB9LFxuICAgIHsgcHJvdmlkZTogRGF0ZUFkYXB0ZXIsIHVzZUNsYXNzOiBFbnRyeURhdGVUaW1lQWRhcHRlciB9XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRGF0ZVRpbWVTZWFyY2hGaWx0ZXJDb21wb25lbnQ8RD4ge1xuICBASW5wdXQoKSBzZWFyY2hGaWx0ZXI6IERhdGVUaW1lU2VhcmNoRmlsdGVyPEQ+O1xuICAvKiogRm9ybSBncm91cCB0byB3aGljaCB0aGUgc2VhcmNoLWZpbHRlciBpbnB1dCBjb21wb25lbnQgd2lsbCBiZSBhZGRlZC4gKi9cbiAgQElucHV0KCkgZm9ybTogVW50eXBlZEZvcm1Hcm91cDtcbn1cbiIsIjxtYXQtZm9ybS1maWVsZCBbZm9ybUdyb3VwXT1cImZvcm1cIiBzdWJzY3JpcHRTaXppbmc9XCJkeW5hbWljXCI+XG4gICAgPG1hdC1sYWJlbCBbYXR0ci5mb3JdPVwic2VhcmNoRmlsdGVyLmtleVwiPnt7c2VhcmNoRmlsdGVyLmxhYmVsfX08L21hdC1sYWJlbD5cbiAgICA8aW5wdXQgbWF0SW5wdXQgW2Zvcm1Db250cm9sTmFtZV09XCJzZWFyY2hGaWx0ZXIua2V5XCIgW21hdERhdGVwaWNrZXJdPVwicGlja2VyXCIgW2lkXT1cInNlYXJjaEZpbHRlci5rZXlcIj5cbiAgICA8bWF0LWRhdGVwaWNrZXItdG9nZ2xlIG1hdEljb25TdWZmaXggW2Zvcl09XCJwaWNrZXJcIj48L21hdC1kYXRlcGlja2VyLXRvZ2dsZT5cbiAgICA8bWF0LWRhdGVwaWNrZXIgI3BpY2tlcj48L21hdC1kYXRlcGlja2VyPlxuPC9tYXQtZm9ybS1maWVsZD4iXX0=
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3NlYXJjaC1maWx0ZXIvZGF0ZS10aW1lL2RhdGUtdGltZS1zZWFyY2gtZmlsdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZW50cnktY29tcG9uZW50cy9zZWFyY2gtZmlsdGVyL2RhdGUtdGltZS9kYXRlLXRpbWUtc2VhcmNoLWZpbHRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHekQsT0FBTyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOzs7Ozs7QUFVdkcsTUFBTSxPQUFPLDZCQUE2QjsrR0FBN0IsNkJBQTZCO21HQUE3Qiw2QkFBNkIsZ0hBTDdCO1lBQ1QsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQywyQkFBMkIsQ0FBQyxFQUFFO1lBQ3BGLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsb0JBQW9CLEVBQUU7U0FDekQsMEJDWkgsOFpBS2lCOzs0RkRTSiw2QkFBNkI7a0JBUnpDLFNBQVM7K0JBQ0UsK0JBQStCLGFBRTlCO3dCQUNULEVBQUUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsMkJBQTJCLENBQUMsRUFBRTt3QkFDcEYsRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxvQkFBb0IsRUFBRTtxQkFDekQ7OEJBR1EsWUFBWTtzQkFBcEIsS0FBSztnQkFFRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERhdGVUaW1lU2VhcmNoRmlsdGVyIH0gZnJvbSAnLi9kYXRlLXRpbWUtc2VhcmNoLWZpbHRlci5tb2RlbCc7XG5pbXBvcnQgeyBVbnR5cGVkRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRGF0ZUFkYXB0ZXIsIE1BVF9EQVRFX0ZPUk1BVFMgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IEVOVFJZX01BVF9EQVRFX1RJTUVfRk9STUFUUywgRW50cnlEYXRlVGltZUFkYXB0ZXIgfSBmcm9tICdAZW5pZ21hdHJ5L2VudHJ5LWNvbXBvbmVudHMvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZW50cnktZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXIuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFtcbiAgICB7IHByb3ZpZGU6IE1BVF9EQVRFX0ZPUk1BVFMsIHVzZUZhY3Rvcnk6ICgpID0+IGluamVjdChFTlRSWV9NQVRfREFURV9USU1FX0ZPUk1BVFMpIH0sXG4gICAgeyBwcm92aWRlOiBEYXRlQWRhcHRlciwgdXNlQ2xhc3M6IEVudHJ5RGF0ZVRpbWVBZGFwdGVyIH1cbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBEYXRlVGltZVNlYXJjaEZpbHRlckNvbXBvbmVudDxEPiB7XG4gIEBJbnB1dCgpIHNlYXJjaEZpbHRlcjogRGF0ZVRpbWVTZWFyY2hGaWx0ZXI8RD47XG4gIC8qKiBGb3JtIGdyb3VwIHRvIHdoaWNoIHRoZSBzZWFyY2gtZmlsdGVyIGlucHV0IGNvbXBvbmVudCB3aWxsIGJlIGFkZGVkLiAqL1xuICBASW5wdXQoKSBmb3JtOiBVbnR5cGVkRm9ybUdyb3VwO1xufVxuIiwiPG1hdC1mb3JtLWZpZWxkIFtmb3JtR3JvdXBdPVwiZm9ybVwiIHN1YnNjcmlwdFNpemluZz1cImR5bmFtaWNcIj5cbiAgICA8bWF0LWxhYmVsIFthdHRyLmZvcl09XCJzZWFyY2hGaWx0ZXIua2V5XCI+e3tzZWFyY2hGaWx0ZXIubGFiZWx9fTwvbWF0LWxhYmVsPlxuICAgIDxpbnB1dCBtYXRJbnB1dCBbZm9ybUNvbnRyb2xOYW1lXT1cInNlYXJjaEZpbHRlci5rZXlcIiBbbWF0RGF0ZXBpY2tlcl09XCJwaWNrZXJcIiBbaWRdPVwic2VhcmNoRmlsdGVyLmtleVwiPlxuICAgIDxtYXQtZGF0ZXBpY2tlci10b2dnbGUgbWF0SWNvblN1ZmZpeCBbZm9yXT1cInBpY2tlclwiPjwvbWF0LWRhdGVwaWNrZXItdG9nZ2xlPlxuICAgIDxtYXQtZGF0ZXBpY2tlciAjcGlja2VyPjwvbWF0LWRhdGVwaWNrZXI+XG48L21hdC1mb3JtLWZpZWxkPiJdfQ==