@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.
- package/common/common.module.d.ts +3 -1
- package/common/date-time/entry-date-time-adapter.d.ts +12 -7
- package/common/date-time/entry-date-time-formats.d.ts +25 -0
- package/common/date-time/entry-time-adapter.d.ts +9 -0
- package/common/date-time/index.d.ts +4 -2
- package/common/date-time/native-time-adapter.d.ts +13 -0
- package/common/directives/index.d.ts +2 -0
- package/common/directives/ng-control-accessor.directive.d.ts +12 -0
- package/common/directives/noop-control-value-accessor.d.ts +10 -0
- package/date-time-picker/README.md +69 -0
- package/date-time-picker/date-time-picker.component.d.ts +35 -0
- package/date-time-picker/date-time-picker.module.d.ts +16 -0
- package/date-time-picker/index.d.ts +5 -0
- package/date-time-picker/public-api.d.ts +2 -0
- package/date-time-picker/time-picker.component.d.ts +26 -0
- package/esm2022/common/common.module.mjs +11 -3
- package/esm2022/common/date-time/entry-date-time-adapter.mjs +30 -12
- package/esm2022/common/date-time/entry-date-time-formats.mjs +14 -0
- package/esm2022/common/date-time/entry-time-adapter.mjs +10 -0
- package/esm2022/common/date-time/index.mjs +5 -3
- package/esm2022/common/date-time/native-time-adapter.mjs +31 -0
- package/esm2022/common/directives/index.mjs +3 -1
- package/esm2022/common/directives/ng-control-accessor.directive.mjs +46 -0
- package/esm2022/common/directives/noop-control-value-accessor.mjs +32 -0
- package/esm2022/date-time-picker/date-time-picker.component.mjs +126 -0
- package/esm2022/date-time-picker/date-time-picker.module.mjs +58 -0
- package/esm2022/date-time-picker/enigmatry-entry-components-date-time-picker.mjs +5 -0
- package/esm2022/date-time-picker/public-api.mjs +3 -0
- package/esm2022/date-time-picker/time-picker.component.mjs +80 -0
- package/esm2022/search-filter/date-time/date-time-search-filter.component.mjs +4 -4
- package/fesm2022/enigmatry-entry-components-common.mjs +158 -16
- package/fesm2022/enigmatry-entry-components-common.mjs.map +1 -1
- package/fesm2022/enigmatry-entry-components-date-time-picker.mjs +258 -0
- package/fesm2022/enigmatry-entry-components-date-time-picker.mjs.map +1 -0
- package/fesm2022/enigmatry-entry-components-search-filter.mjs +3 -3
- package/fesm2022/enigmatry-entry-components-search-filter.mjs.map +1 -1
- package/package.json +95 -89
- package/styles/modules/_default-theme.scss +12 -10
- package/styles/modules/components/buttons/_radio.scss +10 -5
- package/styles/modules/components/checkboxes/_generator.scss +17 -12
- package/styles/modules/components/tables/_header.scss +4 -2
- package/styles/modules/components/tables/_rows.scss +23 -11
- package/styles/modules/components/toggle/_generator.scss +25 -23
- package/styles/partials/core/components/_index.scss +2 -1
- package/styles/partials/core/components/date-time-picker/_general.scss +65 -0
- package/styles/partials/core/components/forms/_general.scss +0 -4
- package/common/date-time/entry-date-time.d.ts +0 -7
- 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":"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","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\">:</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\">:</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\">:</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\">:</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 {
|
|
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(
|
|
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(
|
|
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,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3NlYXJjaC1maWx0ZXIvZGF0ZS10aW1lL2RhdGUtdGltZS1zZWFyY2gtZmlsdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZW50cnktY29tcG9uZW50cy9zZWFyY2gtZmlsdGVyL2RhdGUtdGltZS9kYXRlLXRpbWUtc2VhcmNoLWZpbHRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHekQsT0FBTyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOzs7Ozs7QUFVdkcsTUFBTSxPQUFPLDZCQUE2QjsrR0FBN0IsNkJBQTZCO21HQUE3Qiw2QkFBNkIsZ0hBTDdCO1lBQ1QsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQywyQkFBMkIsQ0FBQyxFQUFFO1lBQ3BGLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsb0JBQW9CLEVBQUU7U0FDekQsMEJDWkgsOFpBS2lCOzs0RkRTSiw2QkFBNkI7a0JBUnpDLFNBQVM7K0JBQ0UsK0JBQStCLGFBRTlCO3dCQUNULEVBQUUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsMkJBQTJCLENBQUMsRUFBRTt3QkFDcEYsRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxvQkFBb0IsRUFBRTtxQkFDekQ7OEJBR1EsWUFBWTtzQkFBcEIsS0FBSztnQkFFRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERhdGVUaW1lU2VhcmNoRmlsdGVyIH0gZnJvbSAnLi9kYXRlLXRpbWUtc2VhcmNoLWZpbHRlci5tb2RlbCc7XG5pbXBvcnQgeyBVbnR5cGVkRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRGF0ZUFkYXB0ZXIsIE1BVF9EQVRFX0ZPUk1BVFMgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IEVOVFJZX01BVF9EQVRFX1RJTUVfRk9STUFUUywgRW50cnlEYXRlVGltZUFkYXB0ZXIgfSBmcm9tICdAZW5pZ21hdHJ5L2VudHJ5LWNvbXBvbmVudHMvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZW50cnktZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZGF0ZS10aW1lLXNlYXJjaC1maWx0ZXIuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFtcbiAgICB7IHByb3ZpZGU6IE1BVF9EQVRFX0ZPUk1BVFMsIHVzZUZhY3Rvcnk6ICgpID0+IGluamVjdChFTlRSWV9NQVRfREFURV9USU1FX0ZPUk1BVFMpIH0sXG4gICAgeyBwcm92aWRlOiBEYXRlQWRhcHRlciwgdXNlQ2xhc3M6IEVudHJ5RGF0ZVRpbWVBZGFwdGVyIH1cbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBEYXRlVGltZVNlYXJjaEZpbHRlckNvbXBvbmVudDxEPiB7XG4gIEBJbnB1dCgpIHNlYXJjaEZpbHRlcjogRGF0ZVRpbWVTZWFyY2hGaWx0ZXI8RD47XG4gIC8qKiBGb3JtIGdyb3VwIHRvIHdoaWNoIHRoZSBzZWFyY2gtZmlsdGVyIGlucHV0IGNvbXBvbmVudCB3aWxsIGJlIGFkZGVkLiAqL1xuICBASW5wdXQoKSBmb3JtOiBVbnR5cGVkRm9ybUdyb3VwO1xufVxuIiwiPG1hdC1mb3JtLWZpZWxkIFtmb3JtR3JvdXBdPVwiZm9ybVwiIHN1YnNjcmlwdFNpemluZz1cImR5bmFtaWNcIj5cbiAgICA8bWF0LWxhYmVsIFthdHRyLmZvcl09XCJzZWFyY2hGaWx0ZXIua2V5XCI+e3tzZWFyY2hGaWx0ZXIubGFiZWx9fTwvbWF0LWxhYmVsPlxuICAgIDxpbnB1dCBtYXRJbnB1dCBbZm9ybUNvbnRyb2xOYW1lXT1cInNlYXJjaEZpbHRlci5rZXlcIiBbbWF0RGF0ZXBpY2tlcl09XCJwaWNrZXJcIiBbaWRdPVwic2VhcmNoRmlsdGVyLmtleVwiPlxuICAgIDxtYXQtZGF0ZXBpY2tlci10b2dnbGUgbWF0SWNvblN1ZmZpeCBbZm9yXT1cInBpY2tlclwiPjwvbWF0LWRhdGVwaWNrZXItdG9nZ2xlPlxuICAgIDxtYXQtZGF0ZXBpY2tlciAjcGlja2VyPjwvbWF0LWRhdGVwaWNrZXI+XG48L21hdC1mb3JtLWZpZWxkPiJdfQ==
|