@energinet/watt 3.0.33 → 3.0.35
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/esm2022/picker/__shared/watt-picker-base.js +11 -110
- package/esm2022/picker/datepicker/watt-datepicker.component.js +45 -151
- package/esm2022/picker/timepicker/watt-timepicker.component.js +19 -91
- package/package.json +1 -1
- package/picker/__shared/watt-picker-base.d.ts +5 -129
- package/picker/datepicker/watt-datepicker.component.d.ts +9 -93
- package/picker/timepicker/watt-timepicker.component.d.ts +6 -69
|
@@ -16,7 +16,7 @@
|
|
|
16
16
|
* limitations under the License.
|
|
17
17
|
*/
|
|
18
18
|
//#endregion
|
|
19
|
-
import { ChangeDetectorRef, Component, ElementRef, LOCALE_ID,
|
|
19
|
+
import { ChangeDetectorRef, Component, ElementRef, LOCALE_ID, ViewEncapsulation, computed, inject, input, effect, linkedSignal, booleanAttribute, viewChild, } from '@angular/core';
|
|
20
20
|
import { NgControl } from '@angular/forms';
|
|
21
21
|
import { MatDateRangeInput, MatDateRangePicker, MatDatepickerInput, MatDatepickerModule, MatEndDate, MatStartDate, } from '@angular/material/datepicker';
|
|
22
22
|
import { MatFormFieldControl } from '@angular/material/form-field';
|
|
@@ -51,75 +51,33 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
51
51
|
label = input('', ...(ngDevMode ? [{ debugName: "label" }] : []));
|
|
52
52
|
dateClass = input(() => '', ...(ngDevMode ? [{ debugName: "dateClass" }] : []));
|
|
53
53
|
canStepThroughDays = input(false, ...(ngDevMode ? [{ debugName: "canStepThroughDays", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
matStartDate;
|
|
64
|
-
/**
|
|
65
|
-
* @ignore
|
|
66
|
-
*/
|
|
67
|
-
matEndDate;
|
|
68
|
-
/**
|
|
69
|
-
* @ignore
|
|
70
|
-
*/
|
|
71
|
-
actualInput;
|
|
72
|
-
/**
|
|
73
|
-
* @ignore
|
|
74
|
-
*/
|
|
75
|
-
input;
|
|
76
|
-
/**
|
|
77
|
-
* @ignore
|
|
78
|
-
*/
|
|
79
|
-
startInput;
|
|
80
|
-
/**
|
|
81
|
-
* @ignore
|
|
82
|
-
*/
|
|
83
|
-
endInput;
|
|
84
|
-
/**
|
|
85
|
-
* @ignore
|
|
86
|
-
*/
|
|
54
|
+
matDatepickerInput = viewChild.required(MatDatepickerInput);
|
|
55
|
+
matDateRangePicker = viewChild.required(MatDateRangePicker);
|
|
56
|
+
matDateRangeInput = viewChild.required(MatDateRangeInput);
|
|
57
|
+
matStartDate = viewChild.required(MatStartDate);
|
|
58
|
+
matEndDate = viewChild.required(MatEndDate);
|
|
59
|
+
actualInput = viewChild.required('actualInput');
|
|
60
|
+
input = viewChild('dateInput', ...(ngDevMode ? [{ debugName: "input" }] : []));
|
|
61
|
+
startInput = viewChild('startDateInput', ...(ngDevMode ? [{ debugName: "startInput" }] : []));
|
|
62
|
+
endInput = viewChild('endDateInput', ...(ngDevMode ? [{ debugName: "endInput" }] : []));
|
|
87
63
|
_placeholder = this.getPlaceholderByLocale(this.locale);
|
|
88
|
-
/**
|
|
89
|
-
* @ignore
|
|
90
|
-
*/
|
|
91
64
|
rangeSeparator = ' - ';
|
|
92
|
-
/**
|
|
93
|
-
* @ignore
|
|
94
|
-
*/
|
|
95
65
|
rangePlaceholder = this.getRangePlaceholder();
|
|
96
|
-
/**
|
|
97
|
-
* @ignore
|
|
98
|
-
*/
|
|
99
66
|
inputMask = computed(() => maskitoDateOptionsGenerator({
|
|
100
67
|
mode: 'dd/mm/yyyy',
|
|
101
68
|
separator: '-',
|
|
102
69
|
max: this.max(),
|
|
103
70
|
min: this.min(),
|
|
104
71
|
}), ...(ngDevMode ? [{ debugName: "inputMask" }] : []));
|
|
105
|
-
/**
|
|
106
|
-
* @ignore
|
|
107
|
-
*/
|
|
108
72
|
rangeInputMask = computed(() => maskitoDateRangeOptionsGenerator({
|
|
109
73
|
mode: 'dd/mm/yyyy',
|
|
110
74
|
dateSeparator: '-',
|
|
111
75
|
max: this.max(),
|
|
112
76
|
min: this.min(),
|
|
113
77
|
}), ...(ngDevMode ? [{ debugName: "rangeInputMask" }] : []));
|
|
114
|
-
/**
|
|
115
|
-
* @ignore
|
|
116
|
-
*/
|
|
117
78
|
getPlaceholderByLocale(locale) {
|
|
118
79
|
return locale === 'da' ? 'dd-mm-åååå' : 'dd-mm-yyyy';
|
|
119
80
|
}
|
|
120
|
-
/**
|
|
121
|
-
* @ignore
|
|
122
|
-
*/
|
|
123
81
|
getRangePlaceholder() {
|
|
124
82
|
return this.placeholder + this.rangeSeparator + this.placeholder;
|
|
125
83
|
}
|
|
@@ -154,7 +112,7 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
154
112
|
}
|
|
155
113
|
initSingleInput() {
|
|
156
114
|
if (this.initialValue) {
|
|
157
|
-
this.matDatepickerInput.value = this.initialValue;
|
|
115
|
+
this.matDatepickerInput().value = this.initialValue;
|
|
158
116
|
this.datepickerClosed();
|
|
159
117
|
}
|
|
160
118
|
}
|
|
@@ -171,39 +129,39 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
171
129
|
this.control?.setValue(this.formatDateFromViewToModel(date));
|
|
172
130
|
}
|
|
173
131
|
datepickerClosed() {
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
132
|
+
const matDatepickerInput = this.matDatepickerInput();
|
|
133
|
+
const actualInput = this.actualInput();
|
|
134
|
+
if (matDatepickerInput.value) {
|
|
135
|
+
this.control?.setValue(matDatepickerInput.value);
|
|
136
|
+
actualInput.nativeElement.value = this.formatDateTimeFromModelToView(this.formatDateFromViewToModel(matDatepickerInput.value));
|
|
177
137
|
}
|
|
178
138
|
else {
|
|
179
|
-
|
|
139
|
+
actualInput.nativeElement.value = '';
|
|
180
140
|
this.control?.setValue(null);
|
|
181
141
|
}
|
|
182
142
|
this.isPrevDayButtonDisabled.set(this.isPrevDayBeforeOrEqualToMinDate());
|
|
183
143
|
this.isNextDayButtonDisabled.set(this.isNextDayAfterOrEqualToMaxDate());
|
|
184
|
-
|
|
144
|
+
actualInput.nativeElement.dispatchEvent(new InputEvent('input'));
|
|
185
145
|
}
|
|
186
146
|
onMonthSelected(date) {
|
|
187
147
|
if (this.rangeMonthOnlyMode() && date) {
|
|
188
|
-
this.matDateRangePicker.select(dayjs(date).startOf('month').toDate());
|
|
189
|
-
this.matDateRangePicker.select(dayjs(date).endOf('month').toDate());
|
|
190
|
-
this.matDateRangePicker.close();
|
|
148
|
+
this.matDateRangePicker().select(dayjs(date).startOf('month').toDate());
|
|
149
|
+
this.matDateRangePicker().select(dayjs(date).endOf('month').toDate());
|
|
150
|
+
this.matDateRangePicker().close();
|
|
191
151
|
}
|
|
192
152
|
}
|
|
193
|
-
/**
|
|
194
|
-
* @ignore
|
|
195
|
-
*/
|
|
196
153
|
initRangeInput() {
|
|
197
154
|
if (this.initialValue) {
|
|
198
|
-
this.matStartDate.value = this.initialValue.start;
|
|
199
|
-
this.matEndDate.value = this.initialValue.end;
|
|
155
|
+
this.matStartDate().value = this.initialValue.start;
|
|
156
|
+
this.matEndDate().value = this.initialValue.end;
|
|
200
157
|
this.rangePickerClosed();
|
|
201
158
|
}
|
|
202
159
|
}
|
|
203
160
|
clearRangePicker() {
|
|
204
161
|
this.control?.setValue(null);
|
|
205
|
-
|
|
206
|
-
|
|
162
|
+
const actualInput = this.actualInput();
|
|
163
|
+
actualInput.nativeElement.value = '';
|
|
164
|
+
actualInput.nativeElement.dispatchEvent(new InputEvent('input'));
|
|
207
165
|
}
|
|
208
166
|
rangeInputChanged(value) {
|
|
209
167
|
const startDateString = value.slice(0, this.placeholder.length);
|
|
@@ -223,53 +181,40 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
223
181
|
}
|
|
224
182
|
}
|
|
225
183
|
rangePickerClosed() {
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
184
|
+
const matDateRangeInput = this.matDateRangeInput();
|
|
185
|
+
const actualInput = this.actualInput();
|
|
186
|
+
if (matDateRangeInput.value?.start && matDateRangeInput.value.end) {
|
|
187
|
+
actualInput.nativeElement.value =
|
|
188
|
+
this.formatDateTimeFromModelToView(this.formatDateFromViewToModel(matDateRangeInput.value?.start)) +
|
|
229
189
|
'-' +
|
|
230
|
-
this.formatDateTimeFromModelToView(this.formatDateFromViewToModel(
|
|
190
|
+
this.formatDateTimeFromModelToView(this.formatDateFromViewToModel(matDateRangeInput.value.end));
|
|
231
191
|
this.control?.setValue({
|
|
232
|
-
start: this.formatDateFromViewToModel(
|
|
233
|
-
end: this.formatDateFromViewToModel(
|
|
192
|
+
start: this.formatDateFromViewToModel(matDateRangeInput.value.start),
|
|
193
|
+
end: this.formatDateFromViewToModel(matDateRangeInput.value.end),
|
|
234
194
|
});
|
|
235
195
|
}
|
|
236
196
|
else {
|
|
237
|
-
|
|
197
|
+
actualInput.nativeElement.value = '';
|
|
238
198
|
this.control?.setValue(null);
|
|
239
199
|
}
|
|
240
|
-
|
|
200
|
+
actualInput.nativeElement.dispatchEvent(new InputEvent('input'));
|
|
241
201
|
}
|
|
242
|
-
/**
|
|
243
|
-
* @ignore
|
|
244
|
-
*/
|
|
245
202
|
setSingleValue(value, input) {
|
|
246
|
-
this.setValueToInput(value, input, this.matDatepickerInput);
|
|
203
|
+
this.setValueToInput(value, input, this.matDatepickerInput());
|
|
247
204
|
}
|
|
248
|
-
/**
|
|
249
|
-
* @ignore
|
|
250
|
-
*/
|
|
251
205
|
setRangeValue(value, startInput, endInput) {
|
|
252
206
|
const { start, end } = value ?? {};
|
|
253
|
-
this.setValueToInput(start, startInput, this.matStartDate);
|
|
254
|
-
this.setValueToInput(end, endInput, this.matEndDate);
|
|
207
|
+
this.setValueToInput(start, startInput, this.matStartDate());
|
|
208
|
+
this.setValueToInput(end, endInput, this.matEndDate());
|
|
255
209
|
}
|
|
256
|
-
/**
|
|
257
|
-
* @ignore
|
|
258
|
-
*/
|
|
259
210
|
prevDay() {
|
|
260
211
|
this.changeDay(-1);
|
|
261
212
|
}
|
|
262
|
-
/**
|
|
263
|
-
* @ignore
|
|
264
|
-
*/
|
|
265
213
|
nextDay() {
|
|
266
214
|
this.changeDay(1);
|
|
267
215
|
}
|
|
268
|
-
/**
|
|
269
|
-
* @ignore
|
|
270
|
-
*/
|
|
271
216
|
changeDay(value) {
|
|
272
|
-
const currentDate = this.matDatepickerInput.value;
|
|
217
|
+
const currentDate = this.matDatepickerInput().value;
|
|
273
218
|
if (currentDate) {
|
|
274
219
|
const newDate = dayjs(currentDate).add(value, 'day').toISOString();
|
|
275
220
|
const newDateFormatted = this.formatDateTimeFromModelToView(newDate);
|
|
@@ -277,39 +222,27 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
277
222
|
this.datepickerClosed();
|
|
278
223
|
}
|
|
279
224
|
}
|
|
280
|
-
/**
|
|
281
|
-
* @ignore
|
|
282
|
-
*/
|
|
283
225
|
isPrevDayBeforeOrEqualToMinDate() {
|
|
284
226
|
const min = this.min();
|
|
285
|
-
const selectedDate = this.matDatepickerInput?.value;
|
|
227
|
+
const selectedDate = this.matDatepickerInput()?.value;
|
|
286
228
|
if (!min || !selectedDate)
|
|
287
229
|
return false;
|
|
288
230
|
const isBefore = dayjs(selectedDate).isBefore(min, 'day');
|
|
289
231
|
const isSame = dayjs(selectedDate).isSame(min, 'day');
|
|
290
232
|
return isSame || isBefore;
|
|
291
233
|
}
|
|
292
|
-
/**
|
|
293
|
-
* @ignore
|
|
294
|
-
*/
|
|
295
234
|
isNextDayAfterOrEqualToMaxDate() {
|
|
296
235
|
const max = this.max();
|
|
297
|
-
const selectedDate = this.matDatepickerInput?.value;
|
|
236
|
+
const selectedDate = this.matDatepickerInput()?.value;
|
|
298
237
|
if (!max || !selectedDate)
|
|
299
238
|
return false;
|
|
300
239
|
const isAfter = dayjs(selectedDate).isAfter(max, 'day');
|
|
301
240
|
const isSame = dayjs(selectedDate).isSame(max, 'day');
|
|
302
241
|
return isSame || isAfter;
|
|
303
242
|
}
|
|
304
|
-
/**
|
|
305
|
-
* @ignore
|
|
306
|
-
*/
|
|
307
243
|
parseDateShortFormat(value) {
|
|
308
244
|
return dayjs(value, dateShortFormat).toDate();
|
|
309
245
|
}
|
|
310
|
-
/**
|
|
311
|
-
* @ignore
|
|
312
|
-
*/
|
|
313
246
|
setValueToInput(value, nativeInput, matDateInput) {
|
|
314
247
|
nativeInput.value = value ? this.formatDateTimeFromModelToView(value) : '';
|
|
315
248
|
matDateInput.value = value ? dayjs(value).utc().toDate() : null;
|
|
@@ -321,27 +254,15 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
321
254
|
formatDateFromViewToModel(value) {
|
|
322
255
|
return dayjs(value).utc().toISOString();
|
|
323
256
|
}
|
|
324
|
-
/**
|
|
325
|
-
* @ignore
|
|
326
|
-
*/
|
|
327
257
|
formatDateTimeFromModelToView(value) {
|
|
328
258
|
return dayjs(value).tz(danishTimeZoneIdentifier).format(dateShortFormat);
|
|
329
259
|
}
|
|
330
|
-
/**
|
|
331
|
-
* @ignore
|
|
332
|
-
*/
|
|
333
260
|
toDanishTimeZone(value) {
|
|
334
261
|
return dayjs(value.toISOString()).tz(danishTimeZoneIdentifier).toDate();
|
|
335
262
|
}
|
|
336
|
-
/**
|
|
337
|
-
* @ignore
|
|
338
|
-
*/
|
|
339
263
|
setToEndOfDay(value) {
|
|
340
264
|
return dayjs(value).endOf('day').toDate();
|
|
341
265
|
}
|
|
342
|
-
/**
|
|
343
|
-
* @ignore
|
|
344
|
-
*/
|
|
345
266
|
setEndDateToDanishTimeZone(value) {
|
|
346
267
|
const dateBasedOnShortFormat = this.parseDateShortFormat(value);
|
|
347
268
|
let maybeDateInDanishTimeZone = null;
|
|
@@ -351,7 +272,7 @@ export class WattDatepickerComponent extends WattPickerBase {
|
|
|
351
272
|
return maybeDateInDanishTimeZone;
|
|
352
273
|
}
|
|
353
274
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattDatepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
354
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.1.3", type: WattDatepickerComponent, isStandalone: true, selector: "watt-datepicker", inputs: { max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, rangeMonthOnlyMode: { classPropertyName: "rangeMonthOnlyMode", publicName: "rangeMonthOnlyMode", isSignal: true, isRequired: false, transformFunction: null }, startAt: { classPropertyName: "startAt", publicName: "startAt", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, dateClass: { classPropertyName: "dateClass", publicName: "dateClass", isSignal: true, isRequired: false, transformFunction: null }, canStepThroughDays: { classPropertyName: "canStepThroughDays", publicName: "canStepThroughDays", isSignal: true, isRequired: false, transformFunction: null } }, providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }], viewQueries: [{ propertyName: "matDatepickerInput", first: true, predicate: MatDatepickerInput, descendants: true }, { propertyName: "matDateRangePicker", first: true, predicate: MatDateRangePicker, descendants: true }, { propertyName: "matDateRangeInput", first: true, predicate: MatDateRangeInput, descendants: true }, { propertyName: "matStartDate", first: true, predicate: MatStartDate, descendants: true }, { propertyName: "matEndDate", first: true, predicate: MatEndDate, descendants: true }, { propertyName: "actualInput", first: true, predicate: ["actualInput"], descendants: true }, { propertyName: "input", first: true, predicate: ["dateInput"], descendants: true }, { propertyName: "startInput", first: true, predicate: ["startDateInput"], descendants: true }, { propertyName: "endInput", first: true, predicate: ["endDateInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<watt-field [control]=\"control\" [label]=\"label()\">\n @if (range) {\n <mat-date-range-input\n [disabled]=\"disabled\"\n [rangePicker]=\"rangeDatepicker\"\n [min]=\"min() ?? null\"\n [max]=\"max() ?? null\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n >\n <input\n inert\n aria-label=\"start-date-input\"\n matStartDate\n #startDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n\n <input\n inert\n aria-label=\"end-date-input\"\n matEndDate\n #endDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n </mat-date-range-input>\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"rangeInputMask()\"\n [placeholder]=\"rangePlaceholder\"\n (maskApplied)=\"rangeInputChanged($event)\"\n />\n\n <watt-button\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n [attr.aria-pressed]=\"false\"\n (click)=\"rangeDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-date-range-picker\n [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n [startAt]=\"startAt()\"\n (monthSelected)=\"onMonthSelected($event)\"\n (closed)=\"rangePickerClosed()\"\n #rangeDatepicker\n />\n } @else {\n <input\n inert\n matInput\n tabindex=\"-1\"\n aria-label=\"date-input\"\n #dateInput\n autocomplete=\"off\"\n spellcheck=\"false\"\n [disabled]=\"disabled\"\n [min]=\"min()\"\n [max]=\"max()\"\n [matDatepicker]=\"singleDatepicker\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"inputMask()\"\n [placeholder]=\"placeholder\"\n (maskApplied)=\"inputChanged($event)\"\n />\n\n <watt-button\n wattSuffix\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n (click)=\"singleDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-datepicker\n #singleDatepicker\n panelClass=\"watt-datepicker-single__panel\"\n [dateClass]=\"dateClass()\"\n [startAt]=\"startAt()\"\n (closed)=\"datepickerClosed()\"\n />\n }\n\n <ng-content />\n <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n <span\n class=\"watt-datepicker-single__step-through\"\n [class.watt-datepicker-single__has-label]=\"!!label()\"\n >\n <watt-button\n variant=\"icon\"\n icon=\"left\"\n (click)=\"prevDay()\"\n [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n />\n <watt-button\n variant=\"icon\"\n icon=\"right\"\n (click)=\"nextDay()\"\n [disabled]=\"disabled || isNextDayButtonDisabled()\"\n />\n </span>\n}\n", styles: ["watt-datepicker{display:flex;align-items:center;width:100%}watt-datepicker watt-button[variant=icon]{margin-left:auto}watt-datepicker watt-button[variant=icon] .watt-button--icon{height:42px}watt-datepicker mat-datepicker,watt-datepicker mat-date-range-picker{display:none}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker .mat-date-range-input-mirror,watt-datepicker input.mask-input{font-family:Droid Sans Mono,monospace}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker input.mask-input{border:none;caret-color:var(--watt-color-neutral-black);letter-spacing:-.03em;-webkit-background-clip:text;-moz-background-clip:text;background-clip:text;color:transparent}watt-datepicker input.mask-input{color:#000}watt-datepicker input.mask-input{position:absolute;min-width:100%;padding:2px 1px}watt-datepicker input.mask-input:focus-visible{outline:none}watt-datepicker .mat-date-range-input-container{align-items:initial}watt-datepicker .mat-date-range-input-start-wrapper,watt-datepicker .mat-date-range-input-end-wrapper{max-width:calc(50% - var(--watt-space-s));overflow:visible;position:relative}watt-datepicker .mat-date-range-input-separator{display:flex;align-items:center}watt-datepicker .mat-date-range-input-separator-hidden,watt-datepicker .mat-date-range-input-separator{opacity:0!important}watt-datepicker .mat-date-range-input-inner::-webkit-input-placeholder{color:var(--watt-color-neutral-grey-500)!important;-webkit-text-fill-color:var(--watt-color-neutral-grey-500)}watt-datepicker watt-button .mat-button{background:transparent}watt-datepicker:has(.watt-datepicker-single__step-through){align-items:flex-start}watt-datepicker:has(.watt-datepicker-single__step-through) .watt-datepicker-single__step-through{display:flex;margin-top:1px}watt-datepicker:has(.watt-datepicker-single__has-label) .watt-datepicker-single__step-through{margin-top:28px}.watt-datepicker-range__panel--month-only .mat-calendar-period-button{pointer-events:none}\n"], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i1.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i1.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i1.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i1.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i1.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i1.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "ngmodule", type: MatInputModule }, { 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", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "component", type: WattButtonComponent, selector: "watt-button", inputs: ["icon", "variant", "size", "type", "formId", "disabled", "loading"] }, { kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName"] }, { kind: "component", type: WattPlaceholderMaskComponent, selector: "watt-placeholder-mask", inputs: ["primaryInputElement", "secondaryInputElement", "mask", "placeholder"], outputs: ["maskApplied"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
275
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.1.3", type: WattDatepickerComponent, isStandalone: true, selector: "watt-datepicker", inputs: { max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, rangeMonthOnlyMode: { classPropertyName: "rangeMonthOnlyMode", publicName: "rangeMonthOnlyMode", isSignal: true, isRequired: false, transformFunction: null }, startAt: { classPropertyName: "startAt", publicName: "startAt", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, dateClass: { classPropertyName: "dateClass", publicName: "dateClass", isSignal: true, isRequired: false, transformFunction: null }, canStepThroughDays: { classPropertyName: "canStepThroughDays", publicName: "canStepThroughDays", isSignal: true, isRequired: false, transformFunction: null } }, providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }], viewQueries: [{ propertyName: "matDatepickerInput", first: true, predicate: MatDatepickerInput, descendants: true, isSignal: true }, { propertyName: "matDateRangePicker", first: true, predicate: MatDateRangePicker, descendants: true, isSignal: true }, { propertyName: "matDateRangeInput", first: true, predicate: MatDateRangeInput, descendants: true, isSignal: true }, { propertyName: "matStartDate", first: true, predicate: MatStartDate, descendants: true, isSignal: true }, { propertyName: "matEndDate", first: true, predicate: MatEndDate, descendants: true, isSignal: true }, { propertyName: "actualInput", first: true, predicate: ["actualInput"], descendants: true, isSignal: true }, { propertyName: "input", first: true, predicate: ["dateInput"], descendants: true, isSignal: true }, { propertyName: "startInput", first: true, predicate: ["startDateInput"], descendants: true, isSignal: true }, { propertyName: "endInput", first: true, predicate: ["endDateInput"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<watt-field [control]=\"control\" [label]=\"label()\">\n @if (range) {\n <mat-date-range-input\n [disabled]=\"disabled\"\n [rangePicker]=\"rangeDatepicker\"\n [min]=\"min() ?? null\"\n [max]=\"max() ?? null\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n >\n <input\n inert\n aria-label=\"start-date-input\"\n matStartDate\n #startDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n\n <input\n inert\n aria-label=\"end-date-input\"\n matEndDate\n #endDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n </mat-date-range-input>\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"rangeInputMask()\"\n [placeholder]=\"rangePlaceholder\"\n (maskApplied)=\"rangeInputChanged($event)\"\n />\n\n <watt-button\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n [attr.aria-pressed]=\"false\"\n (click)=\"rangeDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-date-range-picker\n [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n [startAt]=\"startAt()\"\n (monthSelected)=\"onMonthSelected($event)\"\n (closed)=\"rangePickerClosed()\"\n #rangeDatepicker\n />\n } @else {\n <input\n inert\n matInput\n tabindex=\"-1\"\n aria-label=\"date-input\"\n #dateInput\n autocomplete=\"off\"\n spellcheck=\"false\"\n [disabled]=\"disabled\"\n [min]=\"min()\"\n [max]=\"max()\"\n [matDatepicker]=\"singleDatepicker\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"inputMask()\"\n [placeholder]=\"placeholder\"\n (maskApplied)=\"inputChanged($event)\"\n />\n\n <watt-button\n wattSuffix\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n (click)=\"singleDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-datepicker\n #singleDatepicker\n panelClass=\"watt-datepicker-single__panel\"\n [dateClass]=\"dateClass()\"\n [startAt]=\"startAt()\"\n (closed)=\"datepickerClosed()\"\n />\n }\n\n <ng-content />\n <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n <span\n class=\"watt-datepicker-single__step-through\"\n [class.watt-datepicker-single__has-label]=\"!!label()\"\n >\n <watt-button\n variant=\"icon\"\n icon=\"left\"\n (click)=\"prevDay()\"\n [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n />\n <watt-button\n variant=\"icon\"\n icon=\"right\"\n (click)=\"nextDay()\"\n [disabled]=\"disabled || isNextDayButtonDisabled()\"\n />\n </span>\n}\n", styles: ["watt-datepicker{display:flex;align-items:center;width:100%}watt-datepicker watt-button[variant=icon]{margin-left:auto}watt-datepicker watt-button[variant=icon] .watt-button--icon{height:42px}watt-datepicker mat-datepicker,watt-datepicker mat-date-range-picker{display:none}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker .mat-date-range-input-mirror,watt-datepicker input.mask-input{font-family:Droid Sans Mono,monospace}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker input.mask-input{border:none;caret-color:var(--watt-color-neutral-black);letter-spacing:-.03em;-webkit-background-clip:text;-moz-background-clip:text;background-clip:text;color:transparent}watt-datepicker input.mask-input{color:#000}watt-datepicker input.mask-input{position:absolute;min-width:100%;padding:2px 1px}watt-datepicker input.mask-input:focus-visible{outline:none}watt-datepicker .mat-date-range-input-container{align-items:initial}watt-datepicker .mat-date-range-input-start-wrapper,watt-datepicker .mat-date-range-input-end-wrapper{max-width:calc(50% - var(--watt-space-s));overflow:visible;position:relative}watt-datepicker .mat-date-range-input-separator{display:flex;align-items:center}watt-datepicker .mat-date-range-input-separator-hidden,watt-datepicker .mat-date-range-input-separator{opacity:0!important}watt-datepicker .mat-date-range-input-inner::-webkit-input-placeholder{color:var(--watt-color-neutral-grey-500)!important;-webkit-text-fill-color:var(--watt-color-neutral-grey-500)}watt-datepicker watt-button .mat-button{background:transparent}watt-datepicker:has(.watt-datepicker-single__step-through){align-items:flex-start}watt-datepicker:has(.watt-datepicker-single__step-through) .watt-datepicker-single__step-through{display:flex;margin-top:1px}watt-datepicker:has(.watt-datepicker-single__has-label) .watt-datepicker-single__step-through{margin-top:28px}.watt-datepicker-range__panel--month-only .mat-calendar-period-button{pointer-events:none}\n"], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i1.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i1.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i1.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i1.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i1.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i1.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "ngmodule", type: MatInputModule }, { 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", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "component", type: WattButtonComponent, selector: "watt-button", inputs: ["icon", "variant", "size", "type", "formId", "disabled", "loading"] }, { kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName"] }, { kind: "component", type: WattPlaceholderMaskComponent, selector: "watt-placeholder-mask", inputs: ["primaryInputElement", "secondaryInputElement", "mask", "placeholder"], outputs: ["maskApplied"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
355
276
|
}
|
|
356
277
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattDatepickerComponent, decorators: [{
|
|
357
278
|
type: Component,
|
|
@@ -362,32 +283,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
|
|
|
362
283
|
WattFieldComponent,
|
|
363
284
|
WattPlaceholderMaskComponent,
|
|
364
285
|
], template: "<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<watt-field [control]=\"control\" [label]=\"label()\">\n @if (range) {\n <mat-date-range-input\n [disabled]=\"disabled\"\n [rangePicker]=\"rangeDatepicker\"\n [min]=\"min() ?? null\"\n [max]=\"max() ?? null\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n >\n <input\n inert\n aria-label=\"start-date-input\"\n matStartDate\n #startDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n\n <input\n inert\n aria-label=\"end-date-input\"\n matEndDate\n #endDateInput\n [readOnly]=\"rangeMonthOnlyMode()\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n [hidden]=\"true\"\n />\n </mat-date-range-input>\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"rangeInputMask()\"\n [placeholder]=\"rangePlaceholder\"\n (maskApplied)=\"rangeInputChanged($event)\"\n />\n\n <watt-button\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n [attr.aria-pressed]=\"false\"\n (click)=\"rangeDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-date-range-picker\n [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n [startAt]=\"startAt()\"\n (monthSelected)=\"onMonthSelected($event)\"\n (closed)=\"rangePickerClosed()\"\n #rangeDatepicker\n />\n } @else {\n <input\n inert\n matInput\n tabindex=\"-1\"\n aria-label=\"date-input\"\n #dateInput\n autocomplete=\"off\"\n spellcheck=\"false\"\n [disabled]=\"disabled\"\n [min]=\"min()\"\n [max]=\"max()\"\n [matDatepicker]=\"singleDatepicker\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n <watt-placeholder-mask\n [primaryInputElement]=\"actualInput\"\n [mask]=\"inputMask()\"\n [placeholder]=\"placeholder\"\n (maskApplied)=\"inputChanged($event)\"\n />\n\n <watt-button\n wattSuffix\n variant=\"icon\"\n icon=\"date\"\n [disabled]=\"disabled\"\n (click)=\"singleDatepicker.open()\"\n (focusin)=\"onFocusIn()\"\n (focusout)=\"onFocusOut($event)\"\n />\n\n <mat-datepicker\n #singleDatepicker\n panelClass=\"watt-datepicker-single__panel\"\n [dateClass]=\"dateClass()\"\n [startAt]=\"startAt()\"\n (closed)=\"datepickerClosed()\"\n />\n }\n\n <ng-content />\n <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n <span\n class=\"watt-datepicker-single__step-through\"\n [class.watt-datepicker-single__has-label]=\"!!label()\"\n >\n <watt-button\n variant=\"icon\"\n icon=\"left\"\n (click)=\"prevDay()\"\n [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n />\n <watt-button\n variant=\"icon\"\n icon=\"right\"\n (click)=\"nextDay()\"\n [disabled]=\"disabled || isNextDayButtonDisabled()\"\n />\n </span>\n}\n", styles: ["watt-datepicker{display:flex;align-items:center;width:100%}watt-datepicker watt-button[variant=icon]{margin-left:auto}watt-datepicker watt-button[variant=icon] .watt-button--icon{height:42px}watt-datepicker mat-datepicker,watt-datepicker mat-date-range-picker{display:none}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker .mat-date-range-input-mirror,watt-datepicker input.mask-input{font-family:Droid Sans Mono,monospace}watt-datepicker input.mat-date-range-input-inner,watt-datepicker input.mat-mdc-input-element,watt-datepicker input.mask-input{border:none;caret-color:var(--watt-color-neutral-black);letter-spacing:-.03em;-webkit-background-clip:text;-moz-background-clip:text;background-clip:text;color:transparent}watt-datepicker input.mask-input{color:#000}watt-datepicker input.mask-input{position:absolute;min-width:100%;padding:2px 1px}watt-datepicker input.mask-input:focus-visible{outline:none}watt-datepicker .mat-date-range-input-container{align-items:initial}watt-datepicker .mat-date-range-input-start-wrapper,watt-datepicker .mat-date-range-input-end-wrapper{max-width:calc(50% - var(--watt-space-s));overflow:visible;position:relative}watt-datepicker .mat-date-range-input-separator{display:flex;align-items:center}watt-datepicker .mat-date-range-input-separator-hidden,watt-datepicker .mat-date-range-input-separator{opacity:0!important}watt-datepicker .mat-date-range-input-inner::-webkit-input-placeholder{color:var(--watt-color-neutral-grey-500)!important;-webkit-text-fill-color:var(--watt-color-neutral-grey-500)}watt-datepicker watt-button .mat-button{background:transparent}watt-datepicker:has(.watt-datepicker-single__step-through){align-items:flex-start}watt-datepicker:has(.watt-datepicker-single__step-through) .watt-datepicker-single__step-through{display:flex;margin-top:1px}watt-datepicker:has(.watt-datepicker-single__has-label) .watt-datepicker-single__step-through{margin-top:28px}.watt-datepicker-range__panel--month-only .mat-calendar-period-button{pointer-events:none}\n"] }]
|
|
365
|
-
}], ctorParameters: () => []
|
|
366
|
-
type: ViewChild,
|
|
367
|
-
args: [MatDatepickerInput]
|
|
368
|
-
}], matDateRangePicker: [{
|
|
369
|
-
type: ViewChild,
|
|
370
|
-
args: [MatDateRangePicker]
|
|
371
|
-
}], matDateRangeInput: [{
|
|
372
|
-
type: ViewChild,
|
|
373
|
-
args: [MatDateRangeInput]
|
|
374
|
-
}], matStartDate: [{
|
|
375
|
-
type: ViewChild,
|
|
376
|
-
args: [MatStartDate]
|
|
377
|
-
}], matEndDate: [{
|
|
378
|
-
type: ViewChild,
|
|
379
|
-
args: [MatEndDate]
|
|
380
|
-
}], actualInput: [{
|
|
381
|
-
type: ViewChild,
|
|
382
|
-
args: ['actualInput']
|
|
383
|
-
}], input: [{
|
|
384
|
-
type: ViewChild,
|
|
385
|
-
args: ['dateInput']
|
|
386
|
-
}], startInput: [{
|
|
387
|
-
type: ViewChild,
|
|
388
|
-
args: ['startDateInput']
|
|
389
|
-
}], endInput: [{
|
|
390
|
-
type: ViewChild,
|
|
391
|
-
args: ['endDateInput']
|
|
392
|
-
}] } });
|
|
393
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-datepicker.component.js","sourceRoot":"","sources":["../../../../../libs/watt/package/picker/datepicker/watt-datepicker.component.ts","../../../../../libs/watt/package/picker/datepicker/watt-datepicker.component.html"],"names":[],"mappings":"AAAA,iBAAiB;AACjB;;;;;;;;;;;;;;;GAeG;AACH,YAAY;AACZ,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,SAAS,EACT,SAAS,EACT,iBAAiB,EACjB,QAAQ,EACR,MAAM,EACN,KAAK,EAEL,MAAM,EACN,YAAY,EACZ,gBAAgB,GACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,SAAS,EAAa,MAAM,gBAAgB,CAAC;AACvE,OAAO,EAEL,iBAAiB,EACjB,kBAAkB,EAClB,kBAAkB,EAClB,mBAAmB,EACnB,UAAU,EACV,YAAY,GACb,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,2BAA2B,EAAE,gCAAgC,EAAE,MAAM,cAAc,CAAC;AAE7F,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAEL,iBAAiB,EAGjB,KAAK,GACN,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE7D,OAAO,EACL,cAAc,EAEd,4BAA4B,GAC7B,MAAM,iCAAiC,CAAC;;;;AAEzC,MAAM,eAAe,GAAG,YAAY,CAAC;AACrC,MAAM,CAAC,MAAM,wBAAwB,GAAG,mBAAmB,CAAC;AAE5D;;;;;;GAMG;AAeH,MAAM,OAAO,uBAAwB,SAAQ,cAAc;IACtC,UAAU,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;IACzD,kBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAC/C,SAAS,GAAG,MAAM,CAAC,SAAS,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;IACzE,aAAa,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAC1C,MAAM,GAAG,MAAM,CAAuB,SAAS,CAAC,CAAC;IAEzD,GAAG,GAAG,KAAK,yDAAQ,CAAC;IACpB,GAAG,GAAG,KAAK,yDAAQ,CAAC;IACpB,kBAAkB,GAAG,KAAK,CAAC,KAAK,8DAAC,CAAC;IAClC,OAAO,GAAG,KAAK,CAAc,IAAI,mDAAC,CAAC;IACnC,KAAK,GAAG,KAAK,CAAS,EAAE,iDAAC,CAAC;IAC1B,SAAS,GAAG,KAAK,CAAqC,GAAG,EAAE,CAAC,EAAE,qDAAC,CAAC;IAChE,kBAAkB,GAAG,KAAK,CAAC,KAAK,sDAAI,SAAS,EAAE,gBAAgB,OAA7B,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAC,CAAC;IAEnE;;OAEG;IAEH,kBAAkB,CAAmC;IAGrD,kBAAkB,CAAmC;IAGrD,iBAAiB,CAAkC;IAEnD;;OAEG;IAEH,YAAY,CAA6B;IAEzC;;OAEG;IAEH,UAAU,CAA2B;IAErC;;OAEG;IAEH,WAAW,CAAgC;IAE3C;;OAEG;IAEH,KAAK,CAAgC;IAErC;;OAEG;IAEH,UAAU,CAAgC;IAE1C;;OAEG;IAEH,QAAQ,CAAgC;IACxC;;OAEG;IACO,YAAY,GAAG,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAElE;;OAEG;IACH,cAAc,GAAG,KAAK,CAAC;IAEvB;;OAEG;IACH,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAE9C;;OAEG;IACH,SAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CACxB,2BAA2B,CAAC;QAC1B,IAAI,EAAE,YAAY;QAClB,SAAS,EAAE,GAAG;QACd,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE;QACf,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE;KAChB,CAAC,qDACH,CAAC;IAEF;;OAEG;IACH,cAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAC7B,gCAAgC,CAAC;QAC/B,IAAI,EAAE,YAAY;QAClB,aAAa,EAAE,GAAG;QAClB,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE;QACf,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE;KAChB,CAAC,0DACH,CAAC;IAEF;;OAEG;IACH,sBAAsB,CAAC,MAA4B;QACjD,OAAO,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC;IACvD,CAAC;IAED;;OAEG;IACH,mBAAmB;QACjB,OAAO,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC;IACnE,CAAC;IAED,uBAAuB,GAAG,YAAY,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,+BAA+B,EAAE,CAAC,CAAC;IACrF,uBAAuB,GAAG,YAAY,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,8BAA8B,EAAE,CAAC,CAAC;IAEpF;QACE,KAAK,CAAC,mBAAmB,uBAAuB,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QAE7D,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;YAC3C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC;YACvD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,EAAE;YACV,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,sBAAsB,EAAE,CAAC;QACpD,CAAC,CAAC,CAAC;IACL,CAAC;IAEQ,eAAe;QACtB,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACnE,CAAC;IAED,QAAQ,CAAC,EAAE,KAAK,EAAsC;QACpD,IAAI,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,KAAK;YAAE,OAAO,IAAI,CAAC;QAC9C,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAAE,OAAO,IAAI,CAAC;QAC5C,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACjC,MAAM,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC7B,OAAO,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC7E,CAAC,CAAC,IAAI;YACN,CAAC,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;IAC1B,CAAC;IAES,eAAe;QACvB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,kBAAkB,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC;YAClD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,YAAY,CAAC,KAAa;QACxB,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAE3D,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,IAAI,UAAU,CAAC,MAAM,KAAK,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YAClD,OAAO;QACT,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;QACnD,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC,CAAC;IAC/D,CAAC;IAED,gBAAgB;QACd,IAAI,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;YAClC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAEtD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,6BAA6B,CACvE,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAC9D,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;YAC1C,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC;QAED,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,+BAA+B,EAAE,CAAC,CAAC;QACzE,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,8BAA8B,EAAE,CAAC,CAAC;QAExE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,IAAI,IAAI,CAAC,kBAAkB,EAAE,IAAI,IAAI,EAAE,CAAC;YACtC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;YACtE,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;YACpE,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QAClC,CAAC;IACH,CAAC;IAED;;OAEG;IACO,cAAc;QACtB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,YAAY,CAAC,KAAK,GAAI,IAAI,CAAC,YAA8B,CAAC,KAAK,CAAC;YACrE,IAAI,CAAC,UAAU,CAAC,KAAK,GAAI,IAAI,CAAC,YAA8B,CAAC,GAAG,CAAC;YACjE,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC7B,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,iBAAiB,CAAC,KAAa;QAC7B,MAAM,eAAe,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAEhE,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,IAAI,eAAe,CAAC,MAAM,KAAK,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YACvD,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,CAAC;QACzD,MAAM,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QACxF,IAAI,GAAG,GAAG,IAAI,CAAC,0BAA0B,CAAC,aAAa,CAAC,CAAC;QAEzD,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;YACjB,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAC9B,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,iBAAiB;QACf,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;YAC5E,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK;gBAClC,IAAI,CAAC,6BAA6B,CAChC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CACpE;oBACD,GAAG;oBACH,IAAI,CAAC,6BAA6B,CAChC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,CACjE,CAAC;YAEJ,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC;gBACrB,KAAK,EAAE,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,CAAC;gBACzE,GAAG,EAAE,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC;aACtE,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;YAC1C,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;IACxE,CAAC;IAED;;OAEG;IACO,cAAc,CACtB,KAA8C,EAC9C,KAAuB;QAEvB,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC9D,CAAC;IAED;;OAEG;IACO,aAAa,CACrB,KAA2B,EAC3B,UAA4B,EAC5B,QAA0B;QAE1B,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC;QAEnC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC3D,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACvD,CAAC;IACD;;OAEG;IACH,OAAO;QACL,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IACD;;OAEG;IACH,OAAO;QACL,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IACpB,CAAC;IAED;;OAEG;IACK,SAAS,CAAC,KAAa;QAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;QAElD,IAAI,WAAW,EAAE,CAAC;YAChB,MAAM,OAAO,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;YACnE,MAAM,gBAAgB,GAAG,IAAI,CAAC,6BAA6B,CAAC,OAAO,CAAC,CAAC;YAErE,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC;YACpC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAED;;OAEG;IACK,+BAA+B;QACrC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,EAAE,KAAK,CAAC;QAEpD,IAAI,CAAC,GAAG,IAAI,CAAC,YAAY;YAAE,OAAO,KAAK,CAAC;QAExC,MAAM,QAAQ,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAC1D,MAAM,MAAM,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAEtD,OAAO,MAAM,IAAI,QAAQ,CAAC;IAC5B,CAAC;IAED;;OAEG;IACK,8BAA8B;QACpC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,EAAE,KAAK,CAAC;QAEpD,IAAI,CAAC,GAAG,IAAI,CAAC,YAAY;YAAE,OAAO,KAAK,CAAC;QAExC,MAAM,OAAO,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QACxD,MAAM,MAAM,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAEtD,OAAO,MAAM,IAAI,OAAO,CAAC;IAC3B,CAAC;IAED;;OAEG;IACK,oBAAoB,CAAC,KAAa;QACxC,OAAO,KAAK,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC,MAAM,EAAE,CAAC;IAChD,CAAC;IAED;;OAEG;IACK,eAAe,CACrB,KAAgC,EAChC,WAA6B,EAC7B,YAAe;QAEf,WAAW,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,6BAA6B,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3E,YAAY,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IAClE,CAAC;IAED;;;OAGG;IACK,yBAAyB,CAAC,KAAW;QAC3C,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;IAC1C,CAAC;IAED;;OAEG;IACK,6BAA6B,CAAC,KAAa;QACjD,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,wBAAwB,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;IAC3E,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,KAAW;QAClC,OAAO,KAAK,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,wBAAwB,CAAC,CAAC,MAAM,EAAE,CAAC;IAC1E,CAAC;IAED;;OAEG;IACK,aAAa,CAAC,KAAW;QAC/B,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,CAAC;IAC5C,CAAC;IAED;;OAEG;IACK,0BAA0B,CAAC,KAAa;QAC9C,MAAM,sBAAsB,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;QAEhE,IAAI,yBAAyB,GAAgB,IAAI,CAAC;QAElD,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC;YAC5C,yBAAyB,GAAG,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,CAAC;QAC5E,CAAC;QAED,OAAO,yBAAyB,CAAC;IACnC,CAAC;uGAlZU,uBAAuB;2FAAvB,uBAAuB,s+BAVvB,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,uBAAuB,EAAE,CAAC,8EA4BxE,kBAAkB,qFAGlB,kBAAkB,oFAGlB,iBAAiB,+EAMjB,YAAY,6EAMZ,UAAU,mbC3HvB,0jIA6IA,8kED7DI,mBAAmB,i5BACnB,cAAc,kYACd,mBAAmB,sIACnB,kBAAkB,+IAClB,4BAA4B;;2FAGnB,uBAAuB;kBAdnC,SAAS;+BACE,iBAAiB,aAGhB,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,yBAAyB,EAAE,CAAC,iBACpE,iBAAiB,CAAC,IAAI,WAC5B;wBACP,mBAAmB;wBACnB,cAAc;wBACd,mBAAmB;wBACnB,kBAAkB;wBAClB,4BAA4B;qBAC7B;wDAqBD,kBAAkB;sBADjB,SAAS;uBAAC,kBAAkB;gBAI7B,kBAAkB;sBADjB,SAAS;uBAAC,kBAAkB;gBAI7B,iBAAiB;sBADhB,SAAS;uBAAC,iBAAiB;gBAO5B,YAAY;sBADX,SAAS;uBAAC,YAAY;gBAOvB,UAAU;sBADT,SAAS;uBAAC,UAAU;gBAOrB,WAAW;sBADV,SAAS;uBAAC,aAAa;gBAOxB,KAAK;sBADJ,SAAS;uBAAC,WAAW;gBAOtB,UAAU;sBADT,SAAS;uBAAC,gBAAgB;gBAO3B,QAAQ;sBADP,SAAS;uBAAC,cAAc","sourcesContent":["//#region License\n/**\n * @license\n * Copyright 2020 Energinet DataHub A/S\n *\n * Licensed under the Apache License, Version 2.0 (the \"License2\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n//#endregion\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  LOCALE_ID,\n  ViewChild,\n  ViewEncapsulation,\n  computed,\n  inject,\n  input,\n  AfterViewInit,\n  effect,\n  linkedSignal,\n  booleanAttribute,\n} from '@angular/core';\nimport { AbstractControl, NgControl, Validator } from '@angular/forms';\nimport {\n  MatCalendarCellClassFunction,\n  MatDateRangeInput,\n  MatDateRangePicker,\n  MatDatepickerInput,\n  MatDatepickerModule,\n  MatEndDate,\n  MatStartDate,\n} from '@angular/material/datepicker';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { maskitoDateOptionsGenerator, maskitoDateRangeOptionsGenerator } from '@maskito/kit';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport {\n  WattDateRange,\n  WattLocaleService,\n  WattRange,\n  WattSupportedLocales,\n  dayjs,\n} from '@energinet/watt/core/date';\nimport { WattButtonComponent } from '@energinet/watt/button';\n\nimport {\n  WattPickerBase,\n  WattPickerValue,\n  WattPlaceholderMaskComponent,\n} from '@energinet/watt/picker/__shared';\n\nconst dateShortFormat = 'DD-MM-YYYY';\nexport const danishTimeZoneIdentifier = 'Europe/Copenhagen';\n\n/**\n * Usage:\n * `import { WattDatepickerComponent } from '@energinet-datahub/watt/datepicker';`\n *\n * IMPORTANT:\n * The styling is calculated based on our monospaced font.\n */\n@Component({\n  selector: 'watt-datepicker',\n  templateUrl: './watt-datepicker.component.html',\n  styleUrls: ['./watt-datepicker.component.scss'],\n  providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }],\n  encapsulation: ViewEncapsulation.None,\n  imports: [\n    MatDatepickerModule,\n    MatInputModule,\n    WattButtonComponent,\n    WattFieldComponent,\n    WattPlaceholderMaskComponent,\n  ],\n})\nexport class WattDatepickerComponent extends WattPickerBase implements Validator, AfterViewInit {\n  protected override elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  protected override changeDetectionRef = inject(ChangeDetectorRef);\n  protected override ngControl = inject(NgControl, { optional: true, self: true });\n  private localeService = inject(WattLocaleService);\n  private locale = inject<WattSupportedLocales>(LOCALE_ID);\n\n  max = input<Date>();\n  min = input<Date>();\n  rangeMonthOnlyMode = input(false);\n  startAt = input<Date | null>(null);\n  label = input<string>('');\n  dateClass = input<MatCalendarCellClassFunction<Date>>(() => '');\n  canStepThroughDays = input(false, { transform: booleanAttribute });\n\n  /**\n   * @ignore\n   */\n  @ViewChild(MatDatepickerInput)\n  matDatepickerInput!: MatDatepickerInput<Date | null>;\n\n  @ViewChild(MatDateRangePicker)\n  matDateRangePicker!: MatDateRangePicker<Date | null>;\n\n  @ViewChild(MatDateRangeInput)\n  matDateRangeInput!: MatDateRangeInput<Date | null>;\n\n  /**\n   * @ignore\n   */\n  @ViewChild(MatStartDate)\n  matStartDate!: MatStartDate<Date | null>;\n\n  /**\n   * @ignore\n   */\n  @ViewChild(MatEndDate)\n  matEndDate!: MatEndDate<Date | null>;\n\n  /**\n   * @ignore\n   */\n  @ViewChild('actualInput')\n  actualInput!: ElementRef<HTMLInputElement>;\n\n  /**\n   * @ignore\n   */\n  @ViewChild('dateInput')\n  input!: ElementRef<HTMLInputElement>;\n\n  /**\n   * @ignore\n   */\n  @ViewChild('startDateInput')\n  startInput!: ElementRef<HTMLInputElement>;\n\n  /**\n   * @ignore\n   */\n  @ViewChild('endDateInput')\n  endInput!: ElementRef<HTMLInputElement>;\n  /**\n   * @ignore\n   */\n  protected _placeholder = this.getPlaceholderByLocale(this.locale);\n\n  /**\n   * @ignore\n   */\n  rangeSeparator = ' - ';\n\n  /**\n   * @ignore\n   */\n  rangePlaceholder = this.getRangePlaceholder();\n\n  /**\n   * @ignore\n   */\n  inputMask = computed(() =>\n    maskitoDateOptionsGenerator({\n      mode: 'dd/mm/yyyy',\n      separator: '-',\n      max: this.max(),\n      min: this.min(),\n    })\n  );\n\n  /**\n   * @ignore\n   */\n  rangeInputMask = computed(() =>\n    maskitoDateRangeOptionsGenerator({\n      mode: 'dd/mm/yyyy',\n      dateSeparator: '-',\n      max: this.max(),\n      min: this.min(),\n    })\n  );\n\n  /**\n   * @ignore\n   */\n  getPlaceholderByLocale(locale: WattSupportedLocales): string {\n    return locale === 'da' ? 'dd-mm-åååå' : 'dd-mm-yyyy';\n  }\n\n  /**\n   * @ignore\n   */\n  getRangePlaceholder(): string {\n    return this.placeholder + this.rangeSeparator + this.placeholder;\n  }\n\n  isPrevDayButtonDisabled = linkedSignal(() => this.isPrevDayBeforeOrEqualToMinDate());\n  isNextDayButtonDisabled = linkedSignal(() => this.isNextDayAfterOrEqualToMaxDate());\n\n  constructor() {\n    super(`watt-datepicker-${WattDatepickerComponent.nextId++}`);\n\n    effect(() => {\n      const locale = this.localeService.locale();\n      this.placeholder = this.getPlaceholderByLocale(locale);\n      this.rangePlaceholder = this.getRangePlaceholder();\n    });\n\n    effect(() => {\n      this.rangeMonthOnlyMode();\n      this.ngControl?.control?.updateValueAndValidity();\n    });\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n\n    this.ngControl?.control?.addValidators(this.validate.bind(this));\n  }\n\n  validate({ value }: AbstractControl<WattRange<string>>) {\n    if (!value?.end || !value?.start) return null;\n    if (!this.rangeMonthOnlyMode()) return null;\n    const start = dayjs(value.start);\n    const end = dayjs(value.end);\n    return start.isSame(start.startOf('month')) && end.isSame(start.endOf('month'))\n      ? null\n      : { monthOnly: true };\n  }\n\n  protected initSingleInput() {\n    if (this.initialValue) {\n      this.matDatepickerInput.value = this.initialValue;\n      this.datepickerClosed();\n    }\n  }\n\n  inputChanged(value: string) {\n    const dateString = value.slice(0, this.placeholder.length);\n\n    if (dateString.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n\n    if (dateString.length !== this.placeholder.length) {\n      return;\n    }\n\n    const date = this.parseDateShortFormat(dateString);\n    this.control?.setValue(this.formatDateFromViewToModel(date));\n  }\n\n  datepickerClosed() {\n    if (this.matDatepickerInput.value) {\n      this.control?.setValue(this.matDatepickerInput.value);\n\n      this.actualInput.nativeElement.value = this.formatDateTimeFromModelToView(\n        this.formatDateFromViewToModel(this.matDatepickerInput.value)\n      );\n    } else {\n      this.actualInput.nativeElement.value = '';\n      this.control?.setValue(null);\n    }\n\n    this.isPrevDayButtonDisabled.set(this.isPrevDayBeforeOrEqualToMinDate());\n    this.isNextDayButtonDisabled.set(this.isNextDayAfterOrEqualToMaxDate());\n\n    this.actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  onMonthSelected(date: Date) {\n    if (this.rangeMonthOnlyMode() && date) {\n      this.matDateRangePicker.select(dayjs(date).startOf('month').toDate());\n      this.matDateRangePicker.select(dayjs(date).endOf('month').toDate());\n      this.matDateRangePicker.close();\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  protected initRangeInput() {\n    if (this.initialValue) {\n      this.matStartDate.value = (this.initialValue as WattDateRange).start;\n      this.matEndDate.value = (this.initialValue as WattDateRange).end;\n      this.rangePickerClosed();\n    }\n  }\n\n  clearRangePicker() {\n    this.control?.setValue(null);\n    this.actualInput.nativeElement.value = '';\n    this.actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  rangeInputChanged(value: string) {\n    const startDateString = value.slice(0, this.placeholder.length);\n\n    if (startDateString.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n\n    if (startDateString.length !== this.placeholder.length) {\n      return;\n    }\n\n    const start = this.parseDateShortFormat(startDateString);\n    const endDateString = value.slice(this.placeholder.length + this.rangeSeparator.length);\n    let end = this.setEndDateToDanishTimeZone(endDateString);\n\n    if (end !== null) {\n      end = this.setToEndOfDay(end);\n      this.control?.setValue({ start, end });\n    }\n  }\n\n  rangePickerClosed() {\n    if (this.matDateRangeInput.value?.start && this.matDateRangeInput.value.end) {\n      this.actualInput.nativeElement.value =\n        this.formatDateTimeFromModelToView(\n          this.formatDateFromViewToModel(this.matDateRangeInput.value?.start)\n        ) +\n        '-' +\n        this.formatDateTimeFromModelToView(\n          this.formatDateFromViewToModel(this.matDateRangeInput.value.end)\n        );\n\n      this.control?.setValue({\n        start: this.formatDateFromViewToModel(this.matDateRangeInput.value.start),\n        end: this.formatDateFromViewToModel(this.matDateRangeInput.value.end),\n      });\n    } else {\n      this.actualInput.nativeElement.value = '';\n      this.control?.setValue(null);\n    }\n\n    this.actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  /**\n   * @ignore\n   */\n  protected setSingleValue(\n    value: Exclude<WattPickerValue, WattDateRange>,\n    input: HTMLInputElement\n  ) {\n    this.setValueToInput(value, input, this.matDatepickerInput);\n  }\n\n  /**\n   * @ignore\n   */\n  protected setRangeValue(\n    value: WattDateRange | null,\n    startInput: HTMLInputElement,\n    endInput: HTMLInputElement\n  ) {\n    const { start, end } = value ?? {};\n\n    this.setValueToInput(start, startInput, this.matStartDate);\n    this.setValueToInput(end, endInput, this.matEndDate);\n  }\n  /**\n   * @ignore\n   */\n  prevDay(): void {\n    this.changeDay(-1);\n  }\n  /**\n   * @ignore\n   */\n  nextDay(): void {\n    this.changeDay(1);\n  }\n\n  /**\n   * @ignore\n   */\n  private changeDay(value: number): void {\n    const currentDate = this.matDatepickerInput.value;\n\n    if (currentDate) {\n      const newDate = dayjs(currentDate).add(value, 'day').toISOString();\n      const newDateFormatted = this.formatDateTimeFromModelToView(newDate);\n\n      this.inputChanged(newDateFormatted);\n      this.datepickerClosed();\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  private isPrevDayBeforeOrEqualToMinDate() {\n    const min = this.min();\n    const selectedDate = this.matDatepickerInput?.value;\n\n    if (!min || !selectedDate) return false;\n\n    const isBefore = dayjs(selectedDate).isBefore(min, 'day');\n    const isSame = dayjs(selectedDate).isSame(min, 'day');\n\n    return isSame || isBefore;\n  }\n\n  /**\n   * @ignore\n   */\n  private isNextDayAfterOrEqualToMaxDate() {\n    const max = this.max();\n    const selectedDate = this.matDatepickerInput?.value;\n\n    if (!max || !selectedDate) return false;\n\n    const isAfter = dayjs(selectedDate).isAfter(max, 'day');\n    const isSame = dayjs(selectedDate).isSame(max, 'day');\n\n    return isSame || isAfter;\n  }\n\n  /**\n   * @ignore\n   */\n  private parseDateShortFormat(value: string): Date {\n    return dayjs(value, dateShortFormat).toDate();\n  }\n\n  /**\n   * @ignore\n   */\n  private setValueToInput<D extends { value: Date | null }>(\n    value: string | null | undefined,\n    nativeInput: HTMLInputElement,\n    matDateInput: D\n  ): void {\n    nativeInput.value = value ? this.formatDateTimeFromModelToView(value) : '';\n    matDateInput.value = value ? dayjs(value).utc().toDate() : null;\n  }\n\n  /**\n   * @ignore\n   * Formats Date to full ISO 8601 format (e.g. `2022-08-31T22:00:00.000Z`)\n   */\n  private formatDateFromViewToModel(value: Date): string {\n    return dayjs(value).utc().toISOString();\n  }\n\n  /**\n   * @ignore\n   */\n  private formatDateTimeFromModelToView(value: string): string {\n    return dayjs(value).tz(danishTimeZoneIdentifier).format(dateShortFormat);\n  }\n\n  /**\n   * @ignore\n   */\n  private toDanishTimeZone(value: Date): Date {\n    return dayjs(value.toISOString()).tz(danishTimeZoneIdentifier).toDate();\n  }\n\n  /**\n   * @ignore\n   */\n  private setToEndOfDay(value: Date): Date {\n    return dayjs(value).endOf('day').toDate();\n  }\n\n  /**\n   * @ignore\n   */\n  private setEndDateToDanishTimeZone(value: string): Date | null {\n    const dateBasedOnShortFormat = this.parseDateShortFormat(value);\n\n    let maybeDateInDanishTimeZone: Date | null = null;\n\n    if (dayjs(dateBasedOnShortFormat).isValid()) {\n      maybeDateInDanishTimeZone = this.toDanishTimeZone(dateBasedOnShortFormat);\n    }\n\n    return maybeDateInDanishTimeZone;\n  }\n}\n","<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<watt-field [control]=\"control\" [label]=\"label()\">\n  @if (range) {\n    <mat-date-range-input\n      [disabled]=\"disabled\"\n      [rangePicker]=\"rangeDatepicker\"\n      [min]=\"min() ?? null\"\n      [max]=\"max() ?? null\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    >\n      <input\n        inert\n        aria-label=\"start-date-input\"\n        matStartDate\n        #startDateInput\n        [readOnly]=\"rangeMonthOnlyMode()\"\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n        [hidden]=\"true\"\n      />\n\n      <input\n        inert\n        aria-label=\"end-date-input\"\n        matEndDate\n        #endDateInput\n        [readOnly]=\"rangeMonthOnlyMode()\"\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n        [hidden]=\"true\"\n      />\n    </mat-date-range-input>\n    <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"actualInput\"\n      [mask]=\"rangeInputMask()\"\n      [placeholder]=\"rangePlaceholder\"\n      (maskApplied)=\"rangeInputChanged($event)\"\n    />\n\n    <watt-button\n      variant=\"icon\"\n      icon=\"date\"\n      [disabled]=\"disabled\"\n      [attr.aria-pressed]=\"false\"\n      (click)=\"rangeDatepicker.open()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <mat-date-range-picker\n      [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n      [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n      [startAt]=\"startAt()\"\n      (monthSelected)=\"onMonthSelected($event)\"\n      (closed)=\"rangePickerClosed()\"\n      #rangeDatepicker\n    />\n  } @else {\n    <input\n      inert\n      matInput\n      tabindex=\"-1\"\n      aria-label=\"date-input\"\n      #dateInput\n      autocomplete=\"off\"\n      spellcheck=\"false\"\n      [disabled]=\"disabled\"\n      [min]=\"min()\"\n      [max]=\"max()\"\n      [matDatepicker]=\"singleDatepicker\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n    <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"actualInput\"\n      [mask]=\"inputMask()\"\n      [placeholder]=\"placeholder\"\n      (maskApplied)=\"inputChanged($event)\"\n    />\n\n    <watt-button\n      wattSuffix\n      variant=\"icon\"\n      icon=\"date\"\n      [disabled]=\"disabled\"\n      (click)=\"singleDatepicker.open()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <mat-datepicker\n      #singleDatepicker\n      panelClass=\"watt-datepicker-single__panel\"\n      [dateClass]=\"dateClass()\"\n      [startAt]=\"startAt()\"\n      (closed)=\"datepickerClosed()\"\n    />\n  }\n\n  <ng-content />\n  <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n  <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n  <span\n    class=\"watt-datepicker-single__step-through\"\n    [class.watt-datepicker-single__has-label]=\"!!label()\"\n  >\n    <watt-button\n      variant=\"icon\"\n      icon=\"left\"\n      (click)=\"prevDay()\"\n      [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n    />\n    <watt-button\n      variant=\"icon\"\n      icon=\"right\"\n      (click)=\"nextDay()\"\n      [disabled]=\"disabled || isNextDayButtonDisabled()\"\n    />\n  </span>\n}\n"]}
|
|
286
|
+
}], ctorParameters: () => [] });
|
|
287
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-datepicker.component.js","sourceRoot":"","sources":["../../../../../libs/watt/package/picker/datepicker/watt-datepicker.component.ts","../../../../../libs/watt/package/picker/datepicker/watt-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["//#region License\n/**\n * @license\n * Copyright 2020 Energinet DataHub A/S\n *\n * Licensed under the Apache License, Version 2.0 (the \"License2\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n//#endregion\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  LOCALE_ID,\n  ViewEncapsulation,\n  computed,\n  inject,\n  input,\n  AfterViewInit,\n  effect,\n  linkedSignal,\n  booleanAttribute,\n  viewChild,\n} from '@angular/core';\nimport { AbstractControl, NgControl, Validator } from '@angular/forms';\nimport {\n  MatCalendarCellClassFunction,\n  MatDateRangeInput,\n  MatDateRangePicker,\n  MatDatepickerInput,\n  MatDatepickerModule,\n  MatEndDate,\n  MatStartDate,\n} from '@angular/material/datepicker';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { maskitoDateOptionsGenerator, maskitoDateRangeOptionsGenerator } from '@maskito/kit';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport {\n  WattDateRange,\n  WattLocaleService,\n  WattRange,\n  WattSupportedLocales,\n  dayjs,\n} from '@energinet/watt/core/date';\nimport { WattButtonComponent } from '@energinet/watt/button';\n\nimport {\n  WattPickerBase,\n  WattPickerValue,\n  WattPlaceholderMaskComponent,\n} from '@energinet/watt/picker/__shared';\n\nconst dateShortFormat = 'DD-MM-YYYY';\nexport const danishTimeZoneIdentifier = 'Europe/Copenhagen';\n\n/**\n * Usage:\n * `import { WattDatepickerComponent } from '@energinet-datahub/watt/datepicker';`\n *\n * IMPORTANT:\n * The styling is calculated based on our monospaced font.\n */\n@Component({\n  selector: 'watt-datepicker',\n  templateUrl: './watt-datepicker.component.html',\n  styleUrls: ['./watt-datepicker.component.scss'],\n  providers: [{ provide: MatFormFieldControl, useExisting: WattDatepickerComponent }],\n  encapsulation: ViewEncapsulation.None,\n  imports: [\n    MatDatepickerModule,\n    MatInputModule,\n    WattButtonComponent,\n    WattFieldComponent,\n    WattPlaceholderMaskComponent,\n  ],\n})\nexport class WattDatepickerComponent extends WattPickerBase implements Validator, AfterViewInit {\n  protected override elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  protected override changeDetectionRef = inject(ChangeDetectorRef);\n  protected override ngControl = inject(NgControl, { optional: true, self: true });\n  private localeService = inject(WattLocaleService);\n  private locale = inject<WattSupportedLocales>(LOCALE_ID);\n\n  max = input<Date>();\n  min = input<Date>();\n  rangeMonthOnlyMode = input(false);\n  startAt = input<Date | null>(null);\n  label = input<string>('');\n  dateClass = input<MatCalendarCellClassFunction<Date>>(() => '');\n  canStepThroughDays = input(false, { transform: booleanAttribute });\n\n  protected matDatepickerInput =\n    viewChild.required<MatDatepickerInput<Date | null>>(MatDatepickerInput);\n  protected matDateRangePicker =\n    viewChild.required<MatDateRangePicker<Date | null>>(MatDateRangePicker);\n  protected matDateRangeInput =\n    viewChild.required<MatDateRangeInput<Date | null>>(MatDateRangeInput);\n\n  protected matStartDate = viewChild.required<MatStartDate<Date | null>>(MatStartDate);\n  protected matEndDate = viewChild.required<MatEndDate<Date | null>>(MatEndDate);\n  protected actualInput = viewChild.required<ElementRef<HTMLInputElement>>('actualInput');\n  protected override input = viewChild<ElementRef<HTMLInputElement>>('dateInput');\n  protected override startInput = viewChild<ElementRef<HTMLInputElement>>('startDateInput');\n  protected override endInput = viewChild<ElementRef<HTMLInputElement>>('endDateInput');\n\n  protected override _placeholder = this.getPlaceholderByLocale(this.locale);\n\n  rangeSeparator = ' - ';\n\n  rangePlaceholder = this.getRangePlaceholder();\n\n  inputMask = computed(() =>\n    maskitoDateOptionsGenerator({\n      mode: 'dd/mm/yyyy',\n      separator: '-',\n      max: this.max(),\n      min: this.min(),\n    })\n  );\n\n  rangeInputMask = computed(() =>\n    maskitoDateRangeOptionsGenerator({\n      mode: 'dd/mm/yyyy',\n      dateSeparator: '-',\n      max: this.max(),\n      min: this.min(),\n    })\n  );\n\n  getPlaceholderByLocale(locale: WattSupportedLocales): string {\n    return locale === 'da' ? 'dd-mm-åååå' : 'dd-mm-yyyy';\n  }\n\n  getRangePlaceholder(): string {\n    return this.placeholder + this.rangeSeparator + this.placeholder;\n  }\n\n  isPrevDayButtonDisabled = linkedSignal(() => this.isPrevDayBeforeOrEqualToMinDate());\n  isNextDayButtonDisabled = linkedSignal(() => this.isNextDayAfterOrEqualToMaxDate());\n\n  constructor() {\n    super(`watt-datepicker-${WattDatepickerComponent.nextId++}`);\n\n    effect(() => {\n      const locale = this.localeService.locale();\n      this.placeholder = this.getPlaceholderByLocale(locale);\n      this.rangePlaceholder = this.getRangePlaceholder();\n    });\n\n    effect(() => {\n      this.rangeMonthOnlyMode();\n      this.ngControl?.control?.updateValueAndValidity();\n    });\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n\n    this.ngControl?.control?.addValidators(this.validate.bind(this));\n  }\n\n  validate({ value }: AbstractControl<WattRange<string>>) {\n    if (!value?.end || !value?.start) return null;\n    if (!this.rangeMonthOnlyMode()) return null;\n    const start = dayjs(value.start);\n    const end = dayjs(value.end);\n    return start.isSame(start.startOf('month')) && end.isSame(start.endOf('month'))\n      ? null\n      : { monthOnly: true };\n  }\n\n  protected initSingleInput() {\n    if (this.initialValue) {\n      this.matDatepickerInput().value = this.initialValue;\n      this.datepickerClosed();\n    }\n  }\n\n  inputChanged(value: string) {\n    const dateString = value.slice(0, this.placeholder.length);\n\n    if (dateString.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n\n    if (dateString.length !== this.placeholder.length) {\n      return;\n    }\n\n    const date = this.parseDateShortFormat(dateString);\n    this.control?.setValue(this.formatDateFromViewToModel(date));\n  }\n\n  datepickerClosed() {\n    const matDatepickerInput = this.matDatepickerInput();\n    const actualInput = this.actualInput();\n    if (matDatepickerInput.value) {\n      this.control?.setValue(matDatepickerInput.value);\n\n      actualInput.nativeElement.value = this.formatDateTimeFromModelToView(\n        this.formatDateFromViewToModel(matDatepickerInput.value)\n      );\n    } else {\n      actualInput.nativeElement.value = '';\n      this.control?.setValue(null);\n    }\n\n    this.isPrevDayButtonDisabled.set(this.isPrevDayBeforeOrEqualToMinDate());\n    this.isNextDayButtonDisabled.set(this.isNextDayAfterOrEqualToMaxDate());\n\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  onMonthSelected(date: Date) {\n    if (this.rangeMonthOnlyMode() && date) {\n      this.matDateRangePicker().select(dayjs(date).startOf('month').toDate());\n      this.matDateRangePicker().select(dayjs(date).endOf('month').toDate());\n      this.matDateRangePicker().close();\n    }\n  }\n\n  protected initRangeInput() {\n    if (this.initialValue) {\n      this.matStartDate().value = (this.initialValue as WattDateRange).start;\n      this.matEndDate().value = (this.initialValue as WattDateRange).end;\n      this.rangePickerClosed();\n    }\n  }\n\n  clearRangePicker() {\n    this.control?.setValue(null);\n    const actualInput = this.actualInput();\n    actualInput.nativeElement.value = '';\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  rangeInputChanged(value: string) {\n    const startDateString = value.slice(0, this.placeholder.length);\n\n    if (startDateString.length === 0) {\n      this.control?.setValue(null);\n      return;\n    }\n\n    if (startDateString.length !== this.placeholder.length) {\n      return;\n    }\n\n    const start = this.parseDateShortFormat(startDateString);\n    const endDateString = value.slice(this.placeholder.length + this.rangeSeparator.length);\n    let end = this.setEndDateToDanishTimeZone(endDateString);\n\n    if (end !== null) {\n      end = this.setToEndOfDay(end);\n      this.control?.setValue({ start, end });\n    }\n  }\n\n  rangePickerClosed() {\n    const matDateRangeInput = this.matDateRangeInput();\n    const actualInput = this.actualInput();\n    if (matDateRangeInput.value?.start && matDateRangeInput.value.end) {\n      actualInput.nativeElement.value =\n        this.formatDateTimeFromModelToView(\n          this.formatDateFromViewToModel(matDateRangeInput.value?.start)\n        ) +\n        '-' +\n        this.formatDateTimeFromModelToView(\n          this.formatDateFromViewToModel(matDateRangeInput.value.end)\n        );\n\n      this.control?.setValue({\n        start: this.formatDateFromViewToModel(matDateRangeInput.value.start),\n        end: this.formatDateFromViewToModel(matDateRangeInput.value.end),\n      });\n    } else {\n      actualInput.nativeElement.value = '';\n      this.control?.setValue(null);\n    }\n\n    actualInput.nativeElement.dispatchEvent(new InputEvent('input'));\n  }\n\n  protected setSingleValue(\n    value: Exclude<WattPickerValue, WattDateRange>,\n    input: HTMLInputElement\n  ) {\n    this.setValueToInput(value, input, this.matDatepickerInput());\n  }\n\n  protected setRangeValue(\n    value: WattDateRange | null,\n    startInput: HTMLInputElement,\n    endInput: HTMLInputElement\n  ) {\n    const { start, end } = value ?? {};\n\n    this.setValueToInput(start, startInput, this.matStartDate());\n    this.setValueToInput(end, endInput, this.matEndDate());\n  }\n  prevDay(): void {\n    this.changeDay(-1);\n  }\n  nextDay(): void {\n    this.changeDay(1);\n  }\n\n  private changeDay(value: number): void {\n    const currentDate = this.matDatepickerInput().value;\n\n    if (currentDate) {\n      const newDate = dayjs(currentDate).add(value, 'day').toISOString();\n      const newDateFormatted = this.formatDateTimeFromModelToView(newDate);\n\n      this.inputChanged(newDateFormatted);\n      this.datepickerClosed();\n    }\n  }\n\n  private isPrevDayBeforeOrEqualToMinDate() {\n    const min = this.min();\n    const selectedDate = this.matDatepickerInput()?.value;\n\n    if (!min || !selectedDate) return false;\n\n    const isBefore = dayjs(selectedDate).isBefore(min, 'day');\n    const isSame = dayjs(selectedDate).isSame(min, 'day');\n\n    return isSame || isBefore;\n  }\n\n  private isNextDayAfterOrEqualToMaxDate() {\n    const max = this.max();\n    const selectedDate = this.matDatepickerInput()?.value;\n\n    if (!max || !selectedDate) return false;\n\n    const isAfter = dayjs(selectedDate).isAfter(max, 'day');\n    const isSame = dayjs(selectedDate).isSame(max, 'day');\n\n    return isSame || isAfter;\n  }\n\n  private parseDateShortFormat(value: string): Date {\n    return dayjs(value, dateShortFormat).toDate();\n  }\n\n  private setValueToInput<D extends { value: Date | null }>(\n    value: string | null | undefined,\n    nativeInput: HTMLInputElement,\n    matDateInput: D\n  ): void {\n    nativeInput.value = value ? this.formatDateTimeFromModelToView(value) : '';\n    matDateInput.value = value ? dayjs(value).utc().toDate() : null;\n  }\n\n  /**\n   * @ignore\n   * Formats Date to full ISO 8601 format (e.g. `2022-08-31T22:00:00.000Z`)\n   */\n  private formatDateFromViewToModel(value: Date): string {\n    return dayjs(value).utc().toISOString();\n  }\n\n  private formatDateTimeFromModelToView(value: string): string {\n    return dayjs(value).tz(danishTimeZoneIdentifier).format(dateShortFormat);\n  }\n\n  private toDanishTimeZone(value: Date): Date {\n    return dayjs(value.toISOString()).tz(danishTimeZoneIdentifier).toDate();\n  }\n\n  private setToEndOfDay(value: Date): Date {\n    return dayjs(value).endOf('day').toDate();\n  }\n\n  private setEndDateToDanishTimeZone(value: string): Date | null {\n    const dateBasedOnShortFormat = this.parseDateShortFormat(value);\n\n    let maybeDateInDanishTimeZone: Date | null = null;\n\n    if (dayjs(dateBasedOnShortFormat).isValid()) {\n      maybeDateInDanishTimeZone = this.toDanishTimeZone(dateBasedOnShortFormat);\n    }\n\n    return maybeDateInDanishTimeZone;\n  }\n}\n","<!--\n@license\nCopyright 2020 Energinet DataHub A/S\n\nLicensed under the Apache License, Version 2.0 (the \"License2\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n-->\n<watt-field [control]=\"control\" [label]=\"label()\">\n  @if (range) {\n    <mat-date-range-input\n      [disabled]=\"disabled\"\n      [rangePicker]=\"rangeDatepicker\"\n      [min]=\"min() ?? null\"\n      [max]=\"max() ?? null\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    >\n      <input\n        inert\n        aria-label=\"start-date-input\"\n        matStartDate\n        #startDateInput\n        [readOnly]=\"rangeMonthOnlyMode()\"\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n        [hidden]=\"true\"\n      />\n\n      <input\n        inert\n        aria-label=\"end-date-input\"\n        matEndDate\n        #endDateInput\n        [readOnly]=\"rangeMonthOnlyMode()\"\n        autocomplete=\"off\"\n        spellcheck=\"false\"\n        [hidden]=\"true\"\n      />\n    </mat-date-range-input>\n    <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"actualInput\"\n      [mask]=\"rangeInputMask()\"\n      [placeholder]=\"rangePlaceholder\"\n      (maskApplied)=\"rangeInputChanged($event)\"\n    />\n\n    <watt-button\n      variant=\"icon\"\n      icon=\"date\"\n      [disabled]=\"disabled\"\n      [attr.aria-pressed]=\"false\"\n      (click)=\"rangeDatepicker.open()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <mat-date-range-picker\n      [panelClass]=\"rangeMonthOnlyMode() ? 'watt-datepicker-range__panel--month-only' : ''\"\n      [startView]=\"rangeMonthOnlyMode() ? 'multi-year' : 'month'\"\n      [startAt]=\"startAt()\"\n      (monthSelected)=\"onMonthSelected($event)\"\n      (closed)=\"rangePickerClosed()\"\n      #rangeDatepicker\n    />\n  } @else {\n    <input\n      inert\n      matInput\n      tabindex=\"-1\"\n      aria-label=\"date-input\"\n      #dateInput\n      autocomplete=\"off\"\n      spellcheck=\"false\"\n      [disabled]=\"disabled\"\n      [min]=\"min()\"\n      [max]=\"max()\"\n      [matDatepicker]=\"singleDatepicker\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n    <input #actualInput class=\"mask-input\" [disabled]=\"disabled\" />\n    <watt-placeholder-mask\n      [primaryInputElement]=\"actualInput\"\n      [mask]=\"inputMask()\"\n      [placeholder]=\"placeholder\"\n      (maskApplied)=\"inputChanged($event)\"\n    />\n\n    <watt-button\n      wattSuffix\n      variant=\"icon\"\n      icon=\"date\"\n      [disabled]=\"disabled\"\n      (click)=\"singleDatepicker.open()\"\n      (focusin)=\"onFocusIn()\"\n      (focusout)=\"onFocusOut($event)\"\n    />\n\n    <mat-datepicker\n      #singleDatepicker\n      panelClass=\"watt-datepicker-single__panel\"\n      [dateClass]=\"dateClass()\"\n      [startAt]=\"startAt()\"\n      (closed)=\"datepickerClosed()\"\n    />\n  }\n\n  <ng-content />\n  <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n  <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n</watt-field>\n\n@if (!range && canStepThroughDays()) {\n  <span\n    class=\"watt-datepicker-single__step-through\"\n    [class.watt-datepicker-single__has-label]=\"!!label()\"\n  >\n    <watt-button\n      variant=\"icon\"\n      icon=\"left\"\n      (click)=\"prevDay()\"\n      [disabled]=\"disabled || isPrevDayButtonDisabled()\"\n    />\n    <watt-button\n      variant=\"icon\"\n      icon=\"right\"\n      (click)=\"nextDay()\"\n      [disabled]=\"disabled || isNextDayButtonDisabled()\"\n    />\n  </span>\n}\n"]}
|