verben-ng-ui 1.2.43 → 1.2.44
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/src/lib/components/date-picker/date-picker.component.mjs +54 -17
- package/fesm2022/verben-ng-ui-src-lib-components-date-picker.mjs +53 -16
- package/fesm2022/verben-ng-ui-src-lib-components-date-picker.mjs.map +1 -1
- package/package.json +57 -57
- package/src/lib/components/date-picker/date-picker.component.d.ts +7 -5
|
@@ -20,13 +20,14 @@ export class DatePickerComponent {
|
|
|
20
20
|
monthPlaceholder = 'Select a month';
|
|
21
21
|
date = null;
|
|
22
22
|
showTime = false;
|
|
23
|
+
datePickerWidth = '400px';
|
|
24
|
+
useDefaultDate = false;
|
|
23
25
|
dateChange = new EventEmitter();
|
|
24
26
|
yearRange = [];
|
|
25
27
|
filteredYearRange = [];
|
|
26
|
-
selectedDate =
|
|
27
|
-
tempSelectedDate =
|
|
28
|
+
selectedDate = null;
|
|
29
|
+
tempSelectedDate = null;
|
|
28
30
|
showCalendar = false;
|
|
29
|
-
datePickerWidth = '400px';
|
|
30
31
|
weekDays = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'];
|
|
31
32
|
months = [
|
|
32
33
|
'January', 'February', 'March', 'April', 'May', 'June',
|
|
@@ -84,7 +85,7 @@ export class DatePickerComponent {
|
|
|
84
85
|
const endYear = currentYear + 10;
|
|
85
86
|
this.yearRange = Array.from({ length: endYear - 1960 + 1 }, (_, i) => 1960 + i);
|
|
86
87
|
this.yearRange.sort((a, b) => b - a);
|
|
87
|
-
if (!this.date) {
|
|
88
|
+
if (!this.date && this.useDefaultDate) {
|
|
88
89
|
const now = new Date();
|
|
89
90
|
const pad = (n) => n.toString().padStart(2, '0');
|
|
90
91
|
const localDateString = `${now.getFullYear()}-${pad(now.getMonth() + 1)}-${pad(now.getDate())}T${pad(now.getHours())}:${pad(now.getMinutes())}:${pad(now.getSeconds())}`;
|
|
@@ -131,16 +132,26 @@ export class DatePickerComponent {
|
|
|
131
132
|
}
|
|
132
133
|
toggleCalendar() {
|
|
133
134
|
this.showCalendar = !this.showCalendar;
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
135
|
+
if (this.date) {
|
|
136
|
+
this.tempSelectedDate = new Date(this.date);
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
this.tempSelectedDate = this.useDefaultDate ? new Date() : null;
|
|
140
|
+
}
|
|
141
|
+
if (this.tempSelectedDate) {
|
|
142
|
+
this.selectedMonth = this.tempSelectedDate.getMonth();
|
|
143
|
+
this.selectedMonthString = this.months[this.selectedMonth];
|
|
144
|
+
this.selectedYear = this.tempSelectedDate.getFullYear();
|
|
145
|
+
}
|
|
138
146
|
if (this.showTime && !this.tempTime) {
|
|
139
147
|
const today = new Date();
|
|
140
|
-
const isToday = this.
|
|
148
|
+
const isToday = this.tempSelectedDate &&
|
|
149
|
+
this.isSameDate(this.tempSelectedDate, today);
|
|
141
150
|
const hours = isToday ? today.getHours() : 0;
|
|
142
151
|
const minutes = isToday ? today.getMinutes() : 0;
|
|
143
|
-
this.tempSelectedDate
|
|
152
|
+
if (this.tempSelectedDate) {
|
|
153
|
+
this.tempSelectedDate.setHours(hours, minutes, 0, 0);
|
|
154
|
+
}
|
|
144
155
|
this.selectedHour = hours.toString().padStart(2, '0');
|
|
145
156
|
this.selectedMinute = minutes.toString().padStart(2, '0');
|
|
146
157
|
this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;
|
|
@@ -152,7 +163,19 @@ export class DatePickerComponent {
|
|
|
152
163
|
this.selectedHour = hours.toString().padStart(2, '0');
|
|
153
164
|
this.selectedMinute = minutes.toString().padStart(2, '0');
|
|
154
165
|
this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;
|
|
155
|
-
this.tempSelectedDate
|
|
166
|
+
this.tempSelectedDate?.setHours(hours, minutes, 0, 0);
|
|
167
|
+
}
|
|
168
|
+
clearDate() {
|
|
169
|
+
this.date = null;
|
|
170
|
+
this.selectedDate = null;
|
|
171
|
+
this.tempSelectedDate = null;
|
|
172
|
+
this.tempTime = '';
|
|
173
|
+
this.selectedHour = '00';
|
|
174
|
+
this.selectedMinute = '00';
|
|
175
|
+
this.dateChange.emit(null);
|
|
176
|
+
this.onChange(null);
|
|
177
|
+
this.onTouched();
|
|
178
|
+
this.showCalendar = false;
|
|
156
179
|
}
|
|
157
180
|
fixToUTC(dateValue) {
|
|
158
181
|
if (!dateValue)
|
|
@@ -163,6 +186,8 @@ export class DatePickerComponent {
|
|
|
163
186
|
return new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds()));
|
|
164
187
|
}
|
|
165
188
|
confirm() {
|
|
189
|
+
if (!this.tempSelectedDate)
|
|
190
|
+
return;
|
|
166
191
|
if (this.isDisabled(this.tempSelectedDate))
|
|
167
192
|
return;
|
|
168
193
|
const hours = Number(this.selectedHour);
|
|
@@ -178,6 +203,8 @@ export class DatePickerComponent {
|
|
|
178
203
|
this.showCalendar = false;
|
|
179
204
|
}
|
|
180
205
|
setToStartOfDay() {
|
|
206
|
+
if (!this.tempSelectedDate)
|
|
207
|
+
return;
|
|
181
208
|
this.selectedHour = '00';
|
|
182
209
|
this.selectedMinute = '00';
|
|
183
210
|
this.tempSelectedDate.setHours(0, 0, 0, 0);
|
|
@@ -185,6 +212,8 @@ export class DatePickerComponent {
|
|
|
185
212
|
this.selectedDate = new Date(this.tempSelectedDate);
|
|
186
213
|
}
|
|
187
214
|
setToEndOfDay() {
|
|
215
|
+
if (!this.tempSelectedDate)
|
|
216
|
+
return;
|
|
188
217
|
this.selectedHour = '23';
|
|
189
218
|
this.selectedMinute = '59';
|
|
190
219
|
this.tempSelectedDate.setHours(23, 59, 59, 999);
|
|
@@ -216,6 +245,8 @@ export class DatePickerComponent {
|
|
|
216
245
|
this.updateTempSelectedDate();
|
|
217
246
|
}
|
|
218
247
|
updateTempSelectedDate() {
|
|
248
|
+
if (!this.tempSelectedDate)
|
|
249
|
+
return;
|
|
219
250
|
this.tempSelectedDate.setMonth(this.selectedMonth);
|
|
220
251
|
this.tempSelectedDate.setFullYear(this.selectedYear);
|
|
221
252
|
}
|
|
@@ -257,6 +288,8 @@ export class DatePickerComponent {
|
|
|
257
288
|
}
|
|
258
289
|
is24Hour = true;
|
|
259
290
|
selectTemporaryDate(day) {
|
|
291
|
+
if (!this.tempSelectedDate)
|
|
292
|
+
this.tempSelectedDate = new Date(day);
|
|
260
293
|
if (this.isDisabled(day))
|
|
261
294
|
return;
|
|
262
295
|
const isNewDate = !this.isSameDate(this.tempSelectedDate, day);
|
|
@@ -282,6 +315,8 @@ export class DatePickerComponent {
|
|
|
282
315
|
}
|
|
283
316
|
}
|
|
284
317
|
isSelected(day) {
|
|
318
|
+
if (!this.tempSelectedDate)
|
|
319
|
+
return false;
|
|
285
320
|
return (day.getDate() === this.tempSelectedDate.getDate() &&
|
|
286
321
|
day.getMonth() === this.tempSelectedDate.getMonth() &&
|
|
287
322
|
day.getFullYear() === this.tempSelectedDate.getFullYear());
|
|
@@ -302,13 +337,13 @@ export class DatePickerComponent {
|
|
|
302
337
|
this.showCalendar = false;
|
|
303
338
|
}
|
|
304
339
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: DatePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
305
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.10", type: DatePickerComponent, selector: "app-date-picker", inputs: { placeholder: "placeholder", format: "format", minDate: "minDate", maxDate: "maxDate", disabled: "disabled", bgColor: "bgColor", border: "border", useDropdowns: "useDropdowns", yearPlaceholder: "yearPlaceholder", monthPlaceholder: "monthPlaceholder", date: "date", showTime: "showTime", datePickerWidth: "datePickerWidth" }, outputs: { dateChange: "dateChange" }, providers: [
|
|
340
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.10", type: DatePickerComponent, selector: "app-date-picker", inputs: { placeholder: "placeholder", format: "format", minDate: "minDate", maxDate: "maxDate", disabled: "disabled", bgColor: "bgColor", border: "border", useDropdowns: "useDropdowns", yearPlaceholder: "yearPlaceholder", monthPlaceholder: "monthPlaceholder", date: "date", showTime: "showTime", datePickerWidth: "datePickerWidth", useDefaultDate: "useDefaultDate" }, outputs: { dateChange: "dateChange" }, providers: [
|
|
306
341
|
{
|
|
307
342
|
provide: NG_VALUE_ACCESSOR,
|
|
308
343
|
useExisting: forwardRef(() => DatePickerComponent),
|
|
309
344
|
multi: true,
|
|
310
345
|
},
|
|
311
|
-
], usesOnChanges: true, ngImport: i0, template: "<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n</div>\n\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n", styles: [".date-picker{position:relative;width:100%}.calendar-container{position:relative}.icon{position:absolute;top:5px;right:10px;cursor:pointer}input{width:100%;padding:10px;font-size:13px;border:1px solid #ccc;border-radius:4px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed;color:#8080808f}.calendar{position:absolute;top:100%;left:0;border:1px solid #ccc;background-color:#fff;z-index:10;border-radius:4px}.calendar-header{display:flex;justify-content:center;gap:5px;align-items:center;font-size:13px;padding:15px 15px 0}.weekdays,.dates{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px;padding:15px 15px 0;font-size:13px}button{border:none;background:none;cursor:pointer;padding:5px;width:40px;height:40px}button.selected{background-color:#ffe681;color:#000;border-radius:30px}.calendar-footer{display:flex;justify-content:end;gap:10px;padding:4px 15px;color:#000;font-weight:500;font-size:13px}.calendar-footer button{color:#000}.disabled-day{opacity:.4;cursor:not-allowed}.time-picker input{border:1px solid #ccc;border-radius:4px;padding:4px 6px;text-align:center;width:50px;outline:none;height:40px}.time-picker button{border:1px solid #ccc;border-radius:4px;background-color:#f3f3f3;font-size:10px;width:fit-content;height:30px;cursor:pointer}.box{border:1px solid #ccc}::ng-deep .drop-down .verben-drop-down,::ng-deep .drop-down *{font-size:13px!important}.dropdown{position:absolute;top:110%;left:0;width:60px;max-height:120px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:20}.dropdown-item{padding:6px;text-align:center;cursor:pointer}.dropdown-item:hover,.dropdown-item.active{background:#3182ce;color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.SvgComponent, selector: "verben-svg", inputs: ["icon", "width", "height", "fill", "stroke", "type", "size"] }, { kind: "component", type: i4.DropDownComponent, selector: "verben-drop-down", inputs: ["options", "width", "showHorizontalLine", "horizontalLineColor", "optionLabel", "optionSubLabel", "optionValue", "placeholder", "invalidMessage", "errorPosition", "loadMoreCaption", "display", "showClear", "lazyLoad", "selectKey", "styleClass", "group", "multiselect", "filter", "avoidDuplication", "filterBy", "debounceTime", "minChar", "disabled", "required", "load", "asyncLabel", "search"], outputs: ["optionsChange", "onChange", "onClick", "onClear"] }, { kind: "directive", type: i5.OutSideClickDirective, selector: "[appOutSideClick]", inputs: ["appOutSideClick"], outputs: ["outSideClick"] }, { kind: "component", type: i6.TooltipComponent, selector: "verben-tooltip", inputs: ["tooltipContent", "customClass", "backgroundColor", "textColor", "padding", "borderRadius", "zIndex", "border", "width", "top", "bottom", "left", "right"] }] });
|
|
346
|
+
], usesOnChanges: true, ngImport: i0, template: "<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n\n</div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"clearTooltip\"\n #clearDateTip\n >\n <verben-svg\n (click)=\"clearDate()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'close'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #clearTooltip>\n <div>\n <p class=\"text-xs\">clear date</p>\n </div>\n </ng-template>\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n", styles: [".date-picker{position:relative;width:100%}.calendar-container{position:relative}.icon{position:absolute;top:5px;right:10px;cursor:pointer}input{width:100%;padding:10px;font-size:13px;border:1px solid #ccc;border-radius:4px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed;color:#8080808f}.calendar{position:absolute;top:100%;left:0;border:1px solid #ccc;background-color:#fff;z-index:10;border-radius:4px}.calendar-header{display:flex;justify-content:center;gap:5px;align-items:center;font-size:13px;padding:15px 15px 0}.weekdays,.dates{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px;padding:15px 15px 0;font-size:13px}button{border:none;background:none;cursor:pointer;padding:5px;width:40px;height:40px}button.selected{background-color:#ffe681;color:#000;border-radius:30px}.calendar-footer{display:flex;justify-content:end;gap:10px;padding:4px 15px;color:#000;font-weight:500;font-size:13px}.calendar-footer button{color:#000}.disabled-day{opacity:.4;cursor:not-allowed}.time-picker input{border:1px solid #ccc;border-radius:4px;padding:4px 6px;text-align:center;width:50px;outline:none;height:40px}.time-picker button{border:1px solid #ccc;border-radius:4px;background-color:#f3f3f3;font-size:10px;width:fit-content;height:30px;cursor:pointer}.box{border:1px solid #ccc}::ng-deep .drop-down .verben-drop-down,::ng-deep .drop-down *{font-size:13px!important}.dropdown{position:absolute;top:110%;left:0;width:60px;max-height:120px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:20}.dropdown-item{padding:6px;text-align:center;cursor:pointer}.dropdown-item:hover,.dropdown-item.active{background:#3182ce;color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.SvgComponent, selector: "verben-svg", inputs: ["icon", "width", "height", "fill", "stroke", "type", "size"] }, { kind: "component", type: i4.DropDownComponent, selector: "verben-drop-down", inputs: ["options", "width", "showHorizontalLine", "horizontalLineColor", "optionLabel", "optionSubLabel", "optionValue", "placeholder", "invalidMessage", "errorPosition", "loadMoreCaption", "display", "showClear", "lazyLoad", "selectKey", "styleClass", "group", "multiselect", "filter", "avoidDuplication", "filterBy", "debounceTime", "minChar", "disabled", "required", "load", "asyncLabel", "search"], outputs: ["optionsChange", "onChange", "onClick", "onClear"] }, { kind: "directive", type: i5.OutSideClickDirective, selector: "[appOutSideClick]", inputs: ["appOutSideClick"], outputs: ["outSideClick"] }, { kind: "component", type: i6.TooltipComponent, selector: "verben-tooltip", inputs: ["tooltipContent", "customClass", "backgroundColor", "textColor", "padding", "borderRadius", "zIndex", "border", "width", "top", "bottom", "left", "right"] }] });
|
|
312
347
|
}
|
|
313
348
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: DatePickerComponent, decorators: [{
|
|
314
349
|
type: Component,
|
|
@@ -318,7 +353,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
|
|
|
318
353
|
useExisting: forwardRef(() => DatePickerComponent),
|
|
319
354
|
multi: true,
|
|
320
355
|
},
|
|
321
|
-
], template: "<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n</div>\n\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n", styles: [".date-picker{position:relative;width:100%}.calendar-container{position:relative}.icon{position:absolute;top:5px;right:10px;cursor:pointer}input{width:100%;padding:10px;font-size:13px;border:1px solid #ccc;border-radius:4px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed;color:#8080808f}.calendar{position:absolute;top:100%;left:0;border:1px solid #ccc;background-color:#fff;z-index:10;border-radius:4px}.calendar-header{display:flex;justify-content:center;gap:5px;align-items:center;font-size:13px;padding:15px 15px 0}.weekdays,.dates{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px;padding:15px 15px 0;font-size:13px}button{border:none;background:none;cursor:pointer;padding:5px;width:40px;height:40px}button.selected{background-color:#ffe681;color:#000;border-radius:30px}.calendar-footer{display:flex;justify-content:end;gap:10px;padding:4px 15px;color:#000;font-weight:500;font-size:13px}.calendar-footer button{color:#000}.disabled-day{opacity:.4;cursor:not-allowed}.time-picker input{border:1px solid #ccc;border-radius:4px;padding:4px 6px;text-align:center;width:50px;outline:none;height:40px}.time-picker button{border:1px solid #ccc;border-radius:4px;background-color:#f3f3f3;font-size:10px;width:fit-content;height:30px;cursor:pointer}.box{border:1px solid #ccc}::ng-deep .drop-down .verben-drop-down,::ng-deep .drop-down *{font-size:13px!important}.dropdown{position:absolute;top:110%;left:0;width:60px;max-height:120px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:20}.dropdown-item{padding:6px;text-align:center;cursor:pointer}.dropdown-item:hover,.dropdown-item.active{background:#3182ce;color:#fff}\n"] }]
|
|
356
|
+
], template: "<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n\n</div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"clearTooltip\"\n #clearDateTip\n >\n <verben-svg\n (click)=\"clearDate()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'close'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #clearTooltip>\n <div>\n <p class=\"text-xs\">clear date</p>\n </div>\n </ng-template>\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n", styles: [".date-picker{position:relative;width:100%}.calendar-container{position:relative}.icon{position:absolute;top:5px;right:10px;cursor:pointer}input{width:100%;padding:10px;font-size:13px;border:1px solid #ccc;border-radius:4px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed;color:#8080808f}.calendar{position:absolute;top:100%;left:0;border:1px solid #ccc;background-color:#fff;z-index:10;border-radius:4px}.calendar-header{display:flex;justify-content:center;gap:5px;align-items:center;font-size:13px;padding:15px 15px 0}.weekdays,.dates{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px;padding:15px 15px 0;font-size:13px}button{border:none;background:none;cursor:pointer;padding:5px;width:40px;height:40px}button.selected{background-color:#ffe681;color:#000;border-radius:30px}.calendar-footer{display:flex;justify-content:end;gap:10px;padding:4px 15px;color:#000;font-weight:500;font-size:13px}.calendar-footer button{color:#000}.disabled-day{opacity:.4;cursor:not-allowed}.time-picker input{border:1px solid #ccc;border-radius:4px;padding:4px 6px;text-align:center;width:50px;outline:none;height:40px}.time-picker button{border:1px solid #ccc;border-radius:4px;background-color:#f3f3f3;font-size:10px;width:fit-content;height:30px;cursor:pointer}.box{border:1px solid #ccc}::ng-deep .drop-down .verben-drop-down,::ng-deep .drop-down *{font-size:13px!important}.dropdown{position:absolute;top:110%;left:0;width:60px;max-height:120px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:20}.dropdown-item{padding:6px;text-align:center;cursor:pointer}.dropdown-item:hover,.dropdown-item.active{background:#3182ce;color:#fff}\n"] }]
|
|
322
357
|
}], propDecorators: { placeholder: [{
|
|
323
358
|
type: Input
|
|
324
359
|
}], format: [{
|
|
@@ -343,9 +378,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
|
|
|
343
378
|
type: Input
|
|
344
379
|
}], showTime: [{
|
|
345
380
|
type: Input
|
|
346
|
-
}], dateChange: [{
|
|
347
|
-
type: Output
|
|
348
381
|
}], datePickerWidth: [{
|
|
349
382
|
type: Input
|
|
383
|
+
}], useDefaultDate: [{
|
|
384
|
+
type: Input
|
|
385
|
+
}], dateChange: [{
|
|
386
|
+
type: Output
|
|
350
387
|
}] } });
|
|
351
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmVyYmVuLW5nLXVpL3NyYy9saWIvY29tcG9uZW50cy9kYXRlLXBpY2tlci9kYXRlLXBpY2tlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tbmctdWkvc3JjL2xpYi9jb21wb25lbnRzL2RhdGUtcGlja2VyL2RhdGUtcGlja2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5GLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7Ozs7QUFjekUsTUFBTSxPQUFPLG1CQUFtQjtJQUNyQixXQUFXLEdBQUcsYUFBYSxDQUFDO0lBQzVCLE1BQU0sR0FBRyxZQUFZLENBQUM7SUFDdEIsT0FBTyxDQUFRO0lBQ2YsT0FBTyxDQUFRO0lBQ2YsUUFBUSxHQUFhLEtBQUssQ0FBQztJQUMzQixPQUFPLEdBQVksTUFBTSxDQUFDO0lBQzFCLE1BQU0sR0FBWSxFQUFFLENBQUM7SUFDckIsWUFBWSxHQUFZLElBQUksQ0FBQztJQUM3QixlQUFlLEdBQVcsZUFBZSxDQUFDO0lBQzFDLGdCQUFnQixHQUFXLGdCQUFnQixDQUFDO0lBQzVDLElBQUksR0FBeUIsSUFBSSxDQUFDO0lBQ2xDLFFBQVEsR0FBWSxLQUFLLENBQUM7SUFDekIsVUFBVSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7SUFFaEQsU0FBUyxHQUFhLEVBQUUsQ0FBQztJQUN6QixpQkFBaUIsR0FBYSxFQUFFLENBQUM7SUFDakMsWUFBWSxHQUFTLElBQUksSUFBSSxFQUFFLENBQUM7SUFDaEMsZ0JBQWdCLEdBQVMsSUFB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LElBQUksRUFBRSxDQUFDO1lBQ25DLEtBQUssWUFBWSxDQUFDO1lBQ2xCO2dCQUNFLE9BQU8sR0FBRyxLQUFLLElBQUksR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ3JDLENBQUM7SUFDSCxDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksQ0FBQyxZQUFZLEdBQUcsS0FBSyxDQUFDO0lBQzVCLENBQUM7d0dBNVlVLG1CQUFtQjs0RkFBbkIsbUJBQW1CLCtaQVJuQjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsbUJBQW1CLENBQUM7Z0JBQ2xELEtBQUssRUFBRSxJQUFJO2FBQ1o7U0FDRiwrQ0NkSCxpdktBMkxBOzs0RkQzS2EsbUJBQW1CO2tCQVovQixTQUFTOytCQUNFLGlCQUFpQixhQUdoQjt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxvQkFBb0IsQ0FBQzs0QkFDbEQsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7OEJBR1EsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDSSxVQUFVO3NCQUFuQixNQUFNO2dCQU9DLGVBQWU7c0JBQXZCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgZm9yd2FyZFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJvcGRvd25DaGFuZ2VFdmVudCB9IGZyb20gJ3ZlcmJlbi1uZy11aS9zcmMvbGliL2NvbXBvbmVudHMvZHJvcC1kb3duJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWRhdGUtcGlja2VyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtcGlja2VyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGF0ZS1waWNrZXIuY29tcG9uZW50LmNzcyddLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IERhdGVQaWNrZXJDb21wb25lbnQpLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRGF0ZVBpY2tlckNvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgQElucHV0KCkgcGxhY2Vob2xkZXIgPSAnU2VsZWN0IGRhdGUnO1xuICBASW5wdXQoKSBmb3JtYXQgPSAnTU0vREQvWVlZWSc7XG4gIEBJbnB1dCgpIG1pbkRhdGU/OiBEYXRlO1xuICBASW5wdXQoKSBtYXhEYXRlPzogRGF0ZTtcbiAgQElucHV0KCkgZGlzYWJsZWQ/OiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIGJnQ29sb3I/OiBzdHJpbmcgPSAnI2ZmZic7XG4gIEBJbnB1dCgpIGJvcmRlcj86IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSB1c2VEcm9wZG93bnM6IGJvb2xlYW4gPSB0cnVlO1xuICBASW5wdXQoKSB5ZWFyUGxhY2Vob2xkZXI6IHN0cmluZyA9ICdTZWxlY3QgYSB5ZWFyJztcbiAgQElucHV0KCkgbW9udGhQbGFjZWhvbGRlcjogc3RyaW5nID0gJ1NlbGVjdCBhIG1vbnRoJztcbiAgQElucHV0KCkgZGF0ZTogRGF0ZSB8IG51bGwgfCBzdHJpbmcgPSBudWxsO1xuICBASW5wdXQoKSBzaG93VGltZTogYm9vbGVhbiA9IGZhbHNlO1xuICBAT3V0cHV0KCkgZGF0ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8RGF0ZT4oKTtcblxuICB5ZWFyUmFuZ2U6IG51bWJlcltdID0gW107XG4gIGZpbHRlcmVkWWVhclJhbmdlOiBudW1iZXJbXSA9IFtdO1xuICBzZWxlY3RlZERhdGU6IERhdGUgPSBuZXcgRGF0ZSgpO1xuICB0ZW1wU2VsZWN0ZWREYXRlOiBEYXRlID0gbmV3IERhdGUoKTtcbiAgc2hvd0NhbGVuZGFyID0gZmFsc2U7XG4gQElucHV0KCkgZGF0ZVBpY2tlcldpZHRoOnN0cmluZz0nNDAwcHgnXG4gIHdlZWtEYXlzID0gWydNb24nLCAnVHVlJywgJ1dlZCcsICdUaHUnLCAnRnJpJywgJ1NhdCcsICdTdW4nXTtcbiAgbW9udGhzID0gW1xuICAgICdKYW51YXJ5JywgJ0ZlYnJ1YXJ5JywgJ01hcmNoJywgJ0FwcmlsJywgJ01heScsICdKdW5lJyxcbiAgICAnSnVseScsICdBdWd1c3QnLCAnU2VwdGVtYmVyJywgJ09jdG9iZXInLCAnTm92ZW1iZXInLCAnRGVjZW1iZXInLFxuICBdO1xuXG4gIHNlbGVjdGVkTW9udGg6IG51bWJlciA9IDE7XG4gIHNlbGVjdGVkTW9udGhTdHJpbmc6IHN0cmluZyA9ICcnO1xuICBzZWxlY3RlZFllYXI6IG51bWJlciA9IG5ldyBEYXRlKCkuZ2V0RnVsbFllYXIoKTtcblxuICBwcml2YXRlIG9uQ2hhbmdlOiBhbnkgPSAoKSA9PiB7fTtcbiAgcHJpdmF0ZSBvblRvdWNoZWQ6IGFueSA9ICgpID0+IHt9O1xud3JpdGVWYWx1ZSh2YWx1ZTogRGF0ZSB8IHN0cmluZyB8IG51bGwpOiB2b2lkIHtcbiAgaWYgKHZhbHVlKSB7XG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHZhbHVlID0gdGhpcy5zYW5pdGl6ZURhdGVTdHJpbmcodmFsdWUpO1xuICAgIH1cblxuICAgIGNvbnN0IHBhcnNlZERhdGUgPSB0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnID8gbmV3IERhdGUodmFsdWUpIDogdmFsdWU7XG4gICAgdGhpcy5kYXRlID0gcGFyc2VkRGF0ZTtcblxuICAgIHRoaXMuc2VsZWN0ZWREYXRlID0gbmV3IERhdGUocGFyc2VkRGF0ZSk7XG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlID0gbmV3IERhdGUocGFyc2VkRGF0ZSk7XG4gICAgdGhpcy5zZWxlY3RlZE1vbnRoID0gdGhpcy5zZWxlY3RlZERhdGUuZ2V0TW9udGgoKTtcbiAgICB0aGlzLnNlbGVjdGVkWWVhciA9IHRoaXMuc2VsZWN0ZWREYXRlLmdldEZ1bGxZZWFyKCk7XG5cbiAgICBpZiAodGhpcy5zaG93VGltZSkge1xuICAgICAgdGhpcy5pbml0VGltZUZyb21EYXRlKHRoaXMuc2VsZWN0ZWREYXRlKTtcbiAgICB9XG4gIH1cbn1cblxuXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSk6IHZvaWQge1xuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcbiAgfVxuXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xuICB9XG5cbiAgc2V0RGlzYWJsZWRTdGF0ZT8oaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgIHRoaXMuZGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xuICB9XG5cbm5nT25DaGFuZ2VzKCkge1xuICBpZiAodGhpcy5kYXRlKSB7XG4gICAgbGV0IGQgPSB0aGlzLmRhdGU7XG4gICAgaWYgKHR5cGVvZiBkID09PSAnc3RyaW5nJykgZCA9IHRoaXMuc2FuaXRpemVEYXRlU3RyaW5nKGQpO1xuXG4gICAgY29uc3QgcGFyc2VkRGF0ZSA9IG5ldyBEYXRlKGQpO1xuICAgIHRoaXMuc2VsZWN0ZWREYXRlID0gbmV3IERhdGUocGFyc2VkRGF0ZSk7XG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlID0gbmV3IERhdGUocGFyc2VkRGF0ZSk7XG4gICAgdGhpcy5zZWxlY3RlZE1vbnRoID0gdGhpcy5zZWxlY3RlZERhdGUuZ2V0TW9udGgoKTtcbiAgICB0aGlzLnNlbGVjdGVkWWVhciA9IHRoaXMuc2VsZWN0ZWREYXRlLmdldEZ1bGxZZWFyKCk7XG4gIFxuICAgIFxuICB9XG59XG5cblxuICBpc1NhbWVEYXRlKGQxOiBEYXRlLCBkMjogRGF0ZSk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAoXG4gICAgICBkMS5nZXRGdWxsWWVhcigpID09PSBkMi5nZXRGdWxsWWVhcigpICYmXG4gICAgICBkMS5nZXRNb250aCgpID09PSBkMi5nZXRNb250aCgpICYmXG4gICAgICBkMS5nZXREYXRlKCkgPT09IGQyLmdldERhdGUoKVxuICAgICk7XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICBjb25zdCBjdXJyZW50WWVhciA9IG5ldyBEYXRlKCkuZ2V0RnVsbFllYXIoKTtcbiAgICBjb25zdCBlbmRZZWFyID0gY3VycmVudFllYXIgKyAxMDtcbiAgICB0aGlzLnllYXJSYW5nZSA9IEFycmF5LmZyb20oXG4gICAgICB7IGxlbmd0aDogZW5kWWVhciAtIDE5NjAgKyAxIH0sXG4gICAgICAoXywgaSkgPT4gMTk2MCArIGlcbiAgICApO1xuICAgIHRoaXMueWVhclJhbmdlLnNvcnQoKGEsIGIpID0+IGIgLSBhKTtcblxuICAgIGlmICghdGhpcy5kYXRlKSB7XG4gICAgICBjb25zdCBub3cgPSBuZXcgRGF0ZSgpO1xuICAgICAgY29uc3QgcGFkID0gKG46IG51bWJlcikgPT4gbi50b1N0cmluZygpLnBhZFN0YXJ0KDIsICcwJyk7XG5cbiAgICAgIGNvbnN0IGxvY2FsRGF0ZVN0cmluZyA9IGAke25vdy5nZXRGdWxsWWVhcigpfS0ke3BhZChcbiAgICAgICAgbm93LmdldE1vbnRoKCkgKyAxXG4gICAgICApfS0ke3BhZChub3cuZ2V0RGF0ZSgpKX1UJHtwYWQobm93LmdldEhvdXJzKCkpfToke3BhZChcbiAgICAgICAgbm93LmdldE1pbnV0ZXMoKVxuICAgICAgKX06JHtwYWQobm93LmdldFNlY29uZHMoKSl9YDtcblxuICAgICAgdGhpcy5zZWxlY3RlZERhdGUgPSBuZXcgRGF0ZShsb2NhbERhdGVTdHJpbmcpO1xuICAgICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlID0gbmV3IERhdGUobG9jYWxEYXRlU3RyaW5nKTtcbiAgICAgIHRoaXMuZGF0ZSA9IHRoaXMuc2VsZWN0ZWREYXRlO1xuXG4gICAgICBpZiAodGhpcy5zaG93VGltZSkge1xuICAgICAgICBjb25zdCBob3VycyA9IG5vdy5nZXRIb3VycygpO1xuICAgICAgICBjb25zdCBtaW51dGVzID0gbm93LmdldE1pbnV0ZXMoKTtcblxuICAgICAgICB0aGlzLnNlbGVjdGVkSG91ciA9IGhvdXJzLnRvU3RyaW5nKCkucGFkU3RhcnQoMiwgJzAnKTtcbiAgICAgICAgdGhpcy5zZWxlY3RlZE1pbnV0ZSA9IG1pbnV0ZXMudG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpO1xuICAgICAgICB0aGlzLnRlbXBUaW1lID0gYCR7dGhpcy5zZWxlY3RlZEhvdXJ9OiR7dGhpcy5zZWxlY3RlZE1pbnV0ZX1gO1xuICAgICAgfVxuXG4gICAgICB0aGlzLmRhdGVDaGFuZ2UuZW1pdCh0aGlzLnNlbGVjdGVkRGF0ZSk7XG4gICAgICB0aGlzLm9uQ2hhbmdlKGxvY2FsRGF0ZVN0cmluZyk7XG4gICAgfVxuICB9XG5cbiAgZ2V0IGRpc3BsYXlEYXRlKCk6IHN0cmluZyB7XG4gICAgY29uc3QgcGFyc2VkRGF0ZSA9XG4gICAgICB0eXBlb2YgdGhpcy5kYXRlID09PSAnc3RyaW5nJyA/IG5ldyBEYXRlKHRoaXMuZGF0ZSkgOiB0aGlzLmRhdGU7XG4gICAgcmV0dXJuIHBhcnNlZERhdGUgPyB0aGlzLmZvcm1hdERhdGUocGFyc2VkRGF0ZSwgdGhpcy5mb3JtYXQpIDogJyc7XG4gIH1cblxuICB0ZW1wVGltZTogc3RyaW5nID0gJyc7XG4gIHNlbGVjdGVkSG91ciA9ICcwMCc7XG4gIHNlbGVjdGVkTWludXRlID0gJzAwJztcblxuICBzaG93SG91ck9wdGlvbnMgPSBmYWxzZTtcbiAgc2hvd01pbnV0ZU9wdGlvbnMgPSBmYWxzZTtcblxuICBob3VycyA9IEFycmF5LmZyb20oeyBsZW5ndGg6IDI0IH0sIChfLCBpKSA9PiBTdHJpbmcoaSkucGFkU3RhcnQoMiwgJzAnKSk7XG4gIG1pbnV0ZXMgPSBBcnJheS5mcm9tKHsgbGVuZ3RoOiA2MCB9LCAoXywgaSkgPT4gU3RyaW5nKGkpLnBhZFN0YXJ0KDIsICcwJykpO1xuXG4gIHRvZ2dsZUhvdXJEcm9wZG93bigpIHtcbiAgICB0aGlzLnNob3dIb3VyT3B0aW9ucyA9ICF0aGlzLnNob3dIb3VyT3B0aW9ucztcbiAgICB0aGlzLnNob3dNaW51dGVPcHRpb25zID0gZmFsc2U7XG4gIH1cblxuICB0b2dnbGVNaW51dGVEcm9wZG93bigpIHtcbiAgICB0aGlzLnNob3dNaW51dGVPcHRpb25zID0gIXRoaXMuc2hvd01pbnV0ZU9wdGlvbnM7XG4gICAgdGhpcy5zaG93SG91ck9wdGlvbnMgPSBmYWxzZTtcbiAgfVxuXG4gIHNlbGVjdEhvdXIoaDogc3RyaW5nKSB7XG4gICAgdGhpcy5zZWxlY3RlZEhvdXIgPSBoO1xuICAgIHRoaXMuc2hvd0hvdXJPcHRpb25zID0gZmFsc2U7XG4gIH1cblxuICBzZWxlY3RNaW51dGUobTogc3RyaW5nKSB7XG4gICAgdGhpcy5zZWxlY3RlZE1pbnV0ZSA9IG07XG4gICAgdGhpcy5zaG93TWludXRlT3B0aW9ucyA9IGZhbHNlO1xuICB9XG5cbiAgdG9nZ2xlQ2FsZW5kYXIoKSB7XG4gICAgdGhpcy5zaG93Q2FsZW5kYXIgPSAhdGhpcy5zaG93Q2FsZW5kYXI7XG5cbiAgICB0aGlzLnRlbXBTZWxlY3RlZERhdGUgPSBuZXcgRGF0ZSh0aGlzLmRhdGUgfHwgbmV3IERhdGUoKSk7XG4gICAgdGhpcy5zZWxlY3RlZE1vbnRoID0gdGhpcy50ZW1wU2VsZWN0ZWREYXRlLmdldE1vbnRoKCk7XG4gICAgdGhpcy5zZWxlY3RlZE1vbnRoU3RyaW5nID0gdGhpcy5tb250aHNbdGhpcy5zZWxlY3RlZE1vbnRoXTtcbiAgICB0aGlzLnNlbGVjdGVkWWVhciA9IHRoaXMudGVtcFNlbGVjdGVkRGF0ZS5nZXRGdWxsWWVhcigpO1xuXG4gICAgaWYgKHRoaXMuc2hvd1RpbWUgJiYgIXRoaXMudGVtcFRpbWUpIHtcbiAgICAgIGNvbnN0IHRvZGF5ID0gbmV3IERhdGUoKTtcbiAgICAgIGNvbnN0IGlzVG9kYXkgPSB0aGlzLmlzU2FtZURhdGUodGhpcy50ZW1wU2VsZWN0ZWREYXRlLCB0b2RheSk7XG5cbiAgICAgIGNvbnN0IGhvdXJzID0gaXNUb2RheSA/IHRvZGF5LmdldEhvdXJzKCkgOiAwO1xuICAgICAgY29uc3QgbWludXRlcyA9IGlzVG9kYXkgPyB0b2RheS5nZXRNaW51dGVzKCkgOiAwO1xuXG4gICAgICB0aGlzLnRlbXBTZWxlY3RlZERhdGUuc2V0SG91cnMoaG91cnMsIG1pbnV0ZXMsIDAsIDApO1xuICAgICAgdGhpcy5zZWxlY3RlZEhvdXIgPSBob3Vycy50b1N0cmluZygpLnBhZFN0YXJ0KDIsICcwJyk7XG4gICAgICB0aGlzLnNlbGVjdGVkTWludXRlID0gbWludXRlcy50b1N0cmluZygpLnBhZFN0YXJ0KDIsICcwJyk7XG4gICAgICB0aGlzLnRlbXBUaW1lID0gYCR7dGhpcy5zZWxlY3RlZEhvdXJ9OiR7dGhpcy5zZWxlY3RlZE1pbnV0ZX1gO1xuICAgIH1cbiAgfVxuXG4gIGluaXRUaW1lRnJvbURhdGUoZGF0ZTogRGF0ZSkge1xuICAgIGNvbnN0IGhvdXJzID0gZGF0ZS5nZXRIb3VycygpO1xuICAgIGNvbnN0IG1pbnV0ZXMgPSBkYXRlLmdldE1pbnV0ZXMoKTtcblxuICAgIHRoaXMuc2VsZWN0ZWRIb3VyID0gaG91cnMudG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpO1xuICAgIHRoaXMuc2VsZWN0ZWRNaW51dGUgPSBtaW51dGVzLnRvU3RyaW5nKCkucGFkU3RhcnQoMiwgJzAnKTtcbiAgICB0aGlzLnRlbXBUaW1lID0gYCR7dGhpcy5zZWxlY3RlZEhvdXJ9OiR7dGhpcy5zZWxlY3RlZE1pbnV0ZX1gO1xuICAgIHRoaXMudGVtcFNlbGVjdGVkRGF0ZS5zZXRIb3Vycyhob3VycywgbWludXRlcywgMCwgMCk7XG4gIH1cblxuICBmaXhUb1VUQyhkYXRlVmFsdWU6IGFueSkge1xuICAgIGlmICghZGF0ZVZhbHVlKSByZXR1cm4gbnVsbDtcblxuICAgIGNvbnN0IGRhdGUgPSBkYXRlVmFsdWUgaW5zdGFuY2VvZiBEYXRlID8gZGF0ZVZhbHVlIDogbmV3IERhdGUoZGF0ZVZhbHVlKTtcbiAgICBpZiAoaXNOYU4oZGF0ZS5nZXRUaW1lKCkpKSByZXR1cm4gbnVsbDtcblxuICAgIHJldHVybiBuZXcgRGF0ZShcbiAgICAgIERhdGUuVVRDKFxuICAgICAgICBkYXRlLmdldEZ1bGxZZWFyKCksXG4gICAgICAgIGRhdGUuZ2V0TW9udGgoKSxcbiAgICAgICAgZGF0ZS5nZXREYXRlKCksXG4gICAgICAgIGRhdGUuZ2V0SG91cnMoKSxcbiAgICAgICAgZGF0ZS5nZXRNaW51dGVzKCksXG4gICAgICAgIGRhdGUuZ2V0U2Vjb25kcygpLFxuICAgICAgICBkYXRlLmdldE1pbGxpc2Vjb25kcygpXG4gICAgICApXG4gICAgKTtcbiAgfVxuXG4gIGNvbmZpcm0oKSB7XG4gICAgaWYgKHRoaXMuaXNEaXNhYmxlZCh0aGlzLnRlbXBTZWxlY3RlZERhdGUpKSByZXR1cm47XG5cbiAgICBjb25zdCBob3VycyA9IE51bWJlcih0aGlzLnNlbGVjdGVkSG91cik7XG4gICAgY29uc3QgbWludXRlcyA9IE51bWJlcih0aGlzLnNlbGVjdGVkTWludXRlKTtcblxuICAgIHRoaXMudGVtcFNlbGVjdGVkRGF0ZS5zZXRIb3Vycyhob3VycywgbWludXRlcywgMCwgMCk7XG5cbiAgICB0aGlzLnNlbGVjdGVkRGF0ZSA9IG5ldyBEYXRlKHRoaXMudGVtcFNlbGVjdGVkRGF0ZSk7XG4gICAgdGhpcy5kYXRlID0gdGhpcy5zZWxlY3RlZERhdGU7XG5cbiAgICBjb25zdCBwYWQgPSAobjogbnVtYmVyKSA9PiBuLnRvU3RyaW5nKCkucGFkU3RhcnQoMiwgJzAnKTtcbiAgICBjb25zdCBsb2NhbERhdGVTdHJpbmcgPSBgJHt0aGlzLnNlbGVjdGVkRGF0ZS5nZXRGdWxsWWVhcigpfS0ke3BhZChcbiAgICAgIHRoaXMuc2VsZWN0ZWREYXRlLmdldE1vbnRoKCkgKyAxXG4gICAgKX0tJHtwYWQodGhpcy5zZWxlY3RlZERhdGUuZ2V0RGF0ZSgpKX1UJHtwYWQoXG4gICAgICB0aGlzLnNlbGVjdGVkRGF0ZS5nZXRIb3VycygpXG4gICAgKX06JHtwYWQodGhpcy5zZWxlY3RlZERhdGUuZ2V0TWludXRlcygpKX06JHtwYWQoXG4gICAgICB0aGlzLnNlbGVjdGVkRGF0ZS5nZXRTZWNvbmRzKClcbiAgICApfWA7XG5cbiAgICBcblxuICAgIHRoaXMuZGF0ZUNoYW5nZS5lbWl0KHRoaXMuc2VsZWN0ZWREYXRlKTtcbiAgICB0aGlzLm9uQ2hhbmdlKGxvY2FsRGF0ZVN0cmluZyk7XG4gICAgdGhpcy5vblRvdWNoZWQoKTtcblxuICAgIHRoaXMuc2hvd0NhbGVuZGFyID0gZmFsc2U7XG4gIH1cblxuICBzZXRUb1N0YXJ0T2ZEYXkoKSB7XG4gICAgdGhpcy5zZWxlY3RlZEhvdXIgPSAnMDAnO1xuICAgIHRoaXMuc2VsZWN0ZWRNaW51dGUgPSAnMDAnO1xuXG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlLnNldEhvdXJzKDAsIDAsIDAsIDApO1xuICAgIHRoaXMudGVtcFRpbWUgPSBgJHt0aGlzLnNlbGVjdGVkSG91cn06JHt0aGlzLnNlbGVjdGVkTWludXRlfWA7XG5cbiAgICB0aGlzLnNlbGVjdGVkRGF0ZSA9IG5ldyBEYXRlKHRoaXMudGVtcFNlbGVjdGVkRGF0ZSk7XG4gIH1cbnNldFRvRW5kT2ZEYXkoKSB7XG4gIHRoaXMuc2VsZWN0ZWRIb3VyID0gJzIzJztcbiAgdGhpcy5zZWxlY3RlZE1pbnV0ZSA9ICc1OSc7XG5cbiAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlLnNldEhvdXJzKDIzLCA1OSwgNTksIDk5OSk7XG4gIHRoaXMudGVtcFRpbWUgPSBgJHt0aGlzLnNlbGVjdGVkSG91cn06JHt0aGlzLnNlbGVjdGVkTWludXRlfWA7XG5cbiAgdGhpcy5zZWxlY3RlZERhdGUgPSBuZXcgRGF0ZSh0aGlzLnRlbXBTZWxlY3RlZERhdGUpO1xufVxuXG4gIHByZXZpb3VzTW9udGgoKSB7XG4gICAgdGhpcy5zZWxlY3RlZE1vbnRoLS07XG4gICAgaWYgKHRoaXMuc2VsZWN0ZWRNb250aCA8IDApIHtcbiAgICAgIHRoaXMuc2VsZWN0ZWRNb250aCA9IDExO1xuICAgICAgdGhpcy5zZWxlY3RlZFllYXItLTtcbiAgICB9XG4gICAgdGhpcy51cGRhdGVUZW1wU2VsZWN0ZWREYXRlKCk7XG4gIH1cblxuICBuZXh0TW9udGgoKSB7XG4gICAgdGhpcy5zZWxlY3RlZE1vbnRoKys7XG4gICAgaWYgKHRoaXMuc2VsZWN0ZWRNb250aCA+IDExKSB7XG4gICAgICB0aGlzLnNlbGVjdGVkTW9udGggPSAwO1xuICAgICAgdGhpcy5zZWxlY3RlZFllYXIrKztcbiAgICB9XG4gICAgdGhpcy51cGRhdGVUZW1wU2VsZWN0ZWREYXRlKCk7XG4gIH1cblxuICBvbkRyb3Bkb3duWWVhckNoYW5nZShldmVudDogRHJvcGRvd25DaGFuZ2VFdmVudCk6IHZvaWQge1xuICAgIHRoaXMuc2VsZWN0ZWRZZWFyID0gZXZlbnQudmFsdWU7XG4gICAgdGhpcy51cGRhdGVUZW1wU2VsZWN0ZWREYXRlKCk7XG4gIH1cblxuICBvbkRyb3Bkb3duTW9udGhDaGFuZ2UoZXZlbnQ6IERyb3Bkb3duQ2hhbmdlRXZlbnQpOiB2b2lkIHtcbiAgICB0aGlzLnNlbGVjdGVkTW9udGggPSB0aGlzLm1vbnRocy5pbmRleE9mKGV2ZW50LnZhbHVlKTtcbiAgICB0aGlzLnVwZGF0ZVRlbXBTZWxlY3RlZERhdGUoKTtcbiAgfVxuXG4gIHVwZGF0ZVRlbXBTZWxlY3RlZERhdGUoKSB7XG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlLnNldE1vbnRoKHRoaXMuc2VsZWN0ZWRNb250aCk7XG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlLnNldEZ1bGxZZWFyKHRoaXMuc2VsZWN0ZWRZZWFyKTtcbiAgfVxuXG4gIGdldERheXNJbk1vbnRoKCk6IChEYXRlIHwgbnVsbClbXSB7XG4gICAgY29uc3QgZGF5czogKERhdGUgfCBudWxsKVtdID0gW107XG4gICAgY29uc3QgeWVhciA9IHRoaXMuc2VsZWN0ZWRZZWFyO1xuICAgIGNvbnN0IG1vbnRoID0gdGhpcy5zZWxlY3RlZE1vbnRoO1xuXG4gICAgY29uc3QgZmlyc3REYXlPZk1vbnRoID0gbmV3IERhdGUoeWVhciwgbW9udGgsIDEpLmdldERheSgpO1xuICAgIGNvbnN0IG9mZnNldCA9IGZpcnN0RGF5T2ZNb250aCA9PT0gMCA/IDYgOiBmaXJzdERheU9mTW9udGggLSAxO1xuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBvZmZzZXQ7IGkrKykge1xuICAgICAgZGF5cy5wdXNoKG51bGwpO1xuICAgIH1cblxuICAgIGNvbnN0IHRvdGFsRGF5cyA9IG5ldyBEYXRlKHllYXIsIG1vbnRoICsgMSwgMCkuZ2V0RGF0ZSgpO1xuICAgIGZvciAobGV0IGkgPSAxOyBpIDw9IHRvdGFsRGF5czsgaSsrKSB7XG4gICAgICBjb25zdCBkYXkgPSBuZXcgRGF0ZSh5ZWFyLCBtb250aCwgaSk7XG4gICAgICBkYXlzLnB1c2goZGF5KTtcbiAgICB9XG4gICAgcmV0dXJuIGRheXM7XG4gIH1cbiBzYW5pdGl6ZURhdGVTdHJpbmcodmFsdWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiB2YWx1ZT8uZW5kc1dpdGgoJ1onKSA/IHZhbHVlLnNsaWNlKDAsIC0xKSA6IHZhbHVlO1xufVxuXG4gIGlzRGlzYWJsZWQoZGF5OiBEYXRlIHwgc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgY29uc3QgZGF5RGF0ZSA9IHRoaXMudG9EYXRlKGRheSk7XG5cbiAgICBpZiAodGhpcy5taW5EYXRlICYmIGRheURhdGUgPCB0aGlzLnN0cmlwVGltZSh0aGlzLnRvRGF0ZSh0aGlzLm1pbkRhdGUpKSlcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIGlmICh0aGlzLm1heERhdGUgJiYgZGF5RGF0ZSA+IHRoaXMuc3RyaXBUaW1lKHRoaXMudG9EYXRlKHRoaXMubWF4RGF0ZSkpKVxuICAgICAgcmV0dXJuIHRydWU7XG5cbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBwcml2YXRlIHN0cmlwVGltZShkYXRlOiBEYXRlIHwgc3RyaW5nKTogRGF0ZSB7XG4gICAgY29uc3QgZCA9IHRoaXMudG9EYXRlKGRhdGUpO1xuICAgIHJldHVybiBuZXcgRGF0ZShkLmdldEZ1bGxZZWFyKCksIGQuZ2V0TW9udGgoKSwgZC5nZXREYXRlKCkpO1xuICB9XG5cbiB0b0RhdGUodmFsdWU6IERhdGUgfCBzdHJpbmcpOiBEYXRlIHtcbiAgaWYgKHZhbHVlIGluc3RhbmNlb2YgRGF0ZSkgcmV0dXJuIHZhbHVlO1xuICByZXR1cm4gbmV3IERhdGUodGhpcy5zYW5pdGl6ZURhdGVTdHJpbmcodmFsdWUpKTtcbn1cblxuXG4gIGlzMjRIb3VyOiBib29sZWFuID0gdHJ1ZTtcblxuICBzZWxlY3RUZW1wb3JhcnlEYXRlKGRheTogRGF0ZSkge1xuICAgIGlmICh0aGlzLmlzRGlzYWJsZWQoZGF5KSkgcmV0dXJuO1xuXG4gICAgY29uc3QgaXNOZXdEYXRlID0gIXRoaXMuaXNTYW1lRGF0ZSh0aGlzLnRlbXBTZWxlY3RlZERhdGUsIGRheSk7XG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlID0gbmV3IERhdGUoZGF5KTtcblxuICAgIGlmICh0aGlzLnNob3dUaW1lKSB7XG4gICAgICBpZiAoaXNOZXdEYXRlKSB7XG4gICAgICAgIGNvbnN0IHRvZGF5ID0gbmV3IERhdGUoKTtcbiAgICAgICAgY29uc3QgaXNUb2RheSA9XG4gICAgICAgICAgZGF5LmdldEZ1bGxZZWFyKCkgPT09IHRvZGF5LmdldEZ1bGxZZWFyKCkgJiZcbiAgICAgICAgICBkYXkuZ2V0TW9udGgoKSA9PT0gdG9kYXkuZ2V0TW9udGgoKSAmJlxuICAgICAgICAgIGRheS5nZXREYXRlKCkgPT09IHRvZGF5LmdldERhdGUoKTtcblxuICAgICAgICBjb25zdCBob3VycyA9IGlzVG9kYXkgPyB0b2RheS5nZXRIb3VycygpIDogMDtcbiAgICAgICAgY29uc3QgbWludXRlcyA9IGlzVG9kYXkgPyB0b2RheS5nZXRNaW51dGVzKCkgOiAwO1xuXG4gICAgICAgIHRoaXMudGVtcFNlbGVjdGVkRGF0ZS5zZXRIb3Vycyhob3VycywgbWludXRlcywgMCwgMCk7XG5cbiAgICAgICAgdGhpcy5zZWxlY3RlZEhvdXIgPSBob3Vycy50b1N0cmluZygpLnBhZFN0YXJ0KDIsICcwJyk7XG4gICAgICAgIHRoaXMuc2VsZWN0ZWRNaW51dGUgPSBtaW51dGVzLnRvU3RyaW5nKCkucGFkU3RhcnQoMiwgJzAnKTtcbiAgICAgICAgdGhpcy50ZW1wVGltZSA9IGAke3RoaXMuc2VsZWN0ZWRIb3VyfToke3RoaXMuc2VsZWN0ZWRNaW51dGV9YDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IFtoLCBtXSA9IHRoaXMudGVtcFRpbWUuc3BsaXQoJzonKTtcbiAgICAgICAgdGhpcy5zZWxlY3RlZEhvdXIgPSBoO1xuICAgICAgICB0aGlzLnNlbGVjdGVkTWludXRlID0gbTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBpc1NlbGVjdGVkKGRheTogRGF0ZSk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAoXG4gICAgICBkYXkuZ2V0RGF0ZSgpID09PSB0aGlzLnRlbXBTZWxlY3RlZERhdGUuZ2V0RGF0ZSgpICYmXG4gICAgICBkYXkuZ2V0TW9udGgoKSA9PT0gdGhpcy50ZW1wU2VsZWN0ZWREYXRlLmdldE1vbnRoKCkgJiZcbiAgICAgIGRheS5nZXRGdWxsWWVhcigpID09PSB0aGlzLnRlbXBTZWxlY3RlZERhdGUuZ2V0RnVsbFllYXIoKVxuICAgICk7XG4gIH1cblxuICBmb3JtYXREYXRlKGRhdGU6IERhdGUsIGZvcm1hdDogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBjb25zdCBkYXkgPSBkYXRlLmdldERhdGUoKS50b1N0cmluZygpLnBhZFN0YXJ0KDIsICcwJyk7XG4gICAgY29uc3QgbW9udGggPSAoZGF0ZS5nZXRNb250aCgpICsgMSkudG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpO1xuICAgIGNvbnN0IHllYXIgPSBkYXRlLmdldEZ1bGxZZWFyKCk7XG5cbiAgICBzd2l0Y2ggKGZvcm1hdCkge1xuICAgICAgY2FzZSAnREQvTU0vWVlZWSc6XG4gICAgICAgIHJldHVybiBgJHtkYXl9LyR7bW9udGh9LyR7eWVhcn1gO1xuICAgICAgY2FzZSAnTU0vREQvWVlZWSc6XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gYCR7bW9udGh9LyR7ZGF5fS8ke3llYXJ9YDtcbiAgICB9XG4gIH1cblxuICBjYW5jZWwoKSB7XG4gICAgdGhpcy5zaG93Q2FsZW5kYXIgPSBmYWxzZTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImRhdGUtcGlja2VyXCI+XG4gIDxkaXYgY2xhc3M9XCJjYWxlbmRhci1jb250YWluZXJcIj5cbiAgICA8aW5wdXRcbiAgICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXG4gICAgICBbdmFsdWVdPVwiZGlzcGxheURhdGVcIlxuICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICAgIChjbGljayk9XCIhZGlzYWJsZWQgJiYgdG9nZ2xlQ2FsZW5kYXIoKVwiXG4gICAgICBjbGFzcz1cInctZnVsbCBibG9ja1wiXG4gICAgICBbc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJiZ0NvbG9yXCJcbiAgICAgIFtzdHlsZS5ib3JkZXJdPVwiYm9yZGVyXCJcbiAgICAgIFtuZ0NsYXNzXT1cIntcbiAgICAgICAgJ2N1cnNvci1ub3QtYWxsb3dlZCc6IGRpc2FibGVkID09PSB0cnVlLFxuICAgICAgICAnY3Vyc29yLXBvaW50ZXInOiBkaXNhYmxlZCA9PT0gZmFsc2VcbiAgICAgIH1cIlxuICAgICAgcmVhZG9ubHlcbiAgICAvPlxuICAgIDx2ZXJiZW4tc3ZnXG4gICAgICAoY2xpY2spPVwiIWRpc2FibGVkICYmIHRvZ2dsZUNhbGVuZGFyKClcIlxuICAgICAgY2xhc3M9XCJpY29uXCJcbiAgICAgIFtpY29uXT1cIidjYWxlbmRhcidcIlxuICAgID48L3ZlcmJlbi1zdmc+XG4gIDwvZGl2PlxuXG4gIDxkaXZcbiAgICAqbmdJZj1cInNob3dDYWxlbmRhclwiXG4gICAgW2FwcE91dFNpZGVDbGlja109XCJzaG93Q2FsZW5kYXJcIlxuICAgIChvdXRTaWRlQ2xpY2spPVwic2hvd0NhbGVuZGFyID0gZmFsc2VcIlxuICAgIGNsYXNzPVwiY2FsZW5kYXJcIlxuICAgIFtzdHlsZS53aWR0aF09XCJkYXRlUGlja2VyV2lkdGhcIlxuICA+XG4gICAgPGRpdiBjbGFzcz1cImNhbGVuZGFyLWhlYWRlclwiPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiF1c2VEcm9wZG93bnM7IGVsc2UgZHJvcGRvd25zXCI+XG4gICAgICAgIDxidXR0b24gKGNsaWNrKT1cInByZXZpb3VzTW9udGgoKVwiPlxuICAgICAgICAgIDx2ZXJiZW4tc3ZnIFt3aWR0aF09XCIyMFwiIFtpY29uXT1cIidjaGV2cm9uLWxlZnQnXCI+PC92ZXJiZW4tc3ZnPlxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPHNwYW4+e3sgbW9udGhzW3NlbGVjdGVkTW9udGhdIH19IHt7IHNlbGVjdGVkWWVhciB9fTwvc3Bhbj5cbiAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwibmV4dE1vbnRoKClcIj5cbiAgICAgICAgICA8dmVyYmVuLXN2ZyBbd2lkdGhdPVwiMjBcIiBbaWNvbl09XCInY2hldnJvbi1yaWdodCdcIj48L3ZlcmJlbi1zdmc+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9uZy1jb250YWluZXI+XG5cbiAgICAgIDxuZy10ZW1wbGF0ZSAjZHJvcGRvd25zPlxuICAgICAgICA8dmVyYmVuLWRyb3AtZG93blxuICAgICAgICAgIFtwbGFjZWhvbGRlcl09XCJ5ZWFyUGxhY2Vob2xkZXJcIlxuICAgICAgICAgIChvbkNoYW5nZSk9XCJvbkRyb3Bkb3duWWVhckNoYW5nZSgkZXZlbnQpXCJcbiAgICAgICAgICBbb3B0aW9uc109XCJ5ZWFyUmFuZ2VcIlxuICAgICAgICAgIFsobmdNb2RlbCldPVwic2VsZWN0ZWRZZWFyXCJcbiAgICAgICAgICBbd2lkdGhdPVwiJzkwcHgnXCJcbiAgICAgICAgPjwvdmVyYmVuLWRyb3AtZG93bj5cblxuICAgICAgICA8dmVyYmVuLWRyb3AtZG93blxuICAgICAgICAgIFtwbGFjZWhvbGRlcl09XCJtb250aFBsYWNlaG9sZGVyXCJcbiAgICAgICAgICAob25DaGFuZ2UpPVwib25Ecm9wZG93bk1vbnRoQ2hhbmdlKCRldmVudClcIlxuICAgICAgICAgIFtvcHRpb25zXT1cIm1vbnRoc1wiXG4gICAgICAgICAgY2xhc3M9XCJkcm9wLWRvd25cIlxuICAgICAgICAgIFsobmdNb2RlbCldPVwic2VsZWN0ZWRNb250aFN0cmluZ1wiXG4gICAgICAgICAgW3dpZHRoXT1cIic5MHB4J1wiXG4gICAgICAgID48L3ZlcmJlbi1kcm9wLWRvd24+XG4gICAgICA8L25nLXRlbXBsYXRlPlxuXG4gXG4gICAgICA8ZGl2IGNsYXNzPVwidGltZS1waWNrZXIgZmxleCBpdGVtcy1jZW50ZXIgZ2FwLTJcIiAqbmdJZj1cInNob3dUaW1lXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJyZWxhdGl2ZVwiPlxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgIGNsYXNzPVwiZmxleCBpdGVtcy1jZW50ZXIgYm94IHJvdW5kZWQgcHgtMiBweS0xIGN1cnNvci1wb2ludGVyXCJcbiAgICAgICAgICAgIChjbGljayk9XCJ0b2dnbGVIb3VyRHJvcGRvd24oKVwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAge3sgc2VsZWN0ZWRIb3VyIH19XG4gICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICA8ZGl2ICpuZ0lmPVwic2hvd0hvdXJPcHRpb25zXCIgY2xhc3M9XCJkcm9wZG93blwiPlxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICBjbGFzcz1cImRyb3Bkb3duLWl0ZW1cIlxuICAgICAgICAgICAgICAqbmdGb3I9XCJsZXQgaCBvZiBob3Vyc1wiXG4gICAgICAgICAgICAgIFtjbGFzcy5hY3RpdmVdPVwiaCA9PT0gc2VsZWN0ZWRIb3VyXCJcbiAgICAgICAgICAgICAgKGNsaWNrKT1cInNlbGVjdEhvdXIoaClcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7eyBoIH19XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPHNwYW4+Ojwvc3Bhbj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwicmVsYXRpdmVcIj5cbiAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjbGFzcz1cImZsZXggaXRlbXMtY2VudGVyIGJveCByb3VuZGVkIHB4LTIgcHktMSBjdXJzb3ItcG9pbnRlclwiXG4gICAgICAgICAgICAoY2xpY2spPVwidG9nZ2xlTWludXRlRHJvcGRvd24oKVwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAge3sgc2VsZWN0ZWRNaW51dGUgfX1cbiAgICAgICAgICA8L2Rpdj5cblxuICAgICAgICAgIDxkaXYgKm5nSWY9XCJzaG93TWludXRlT3B0aW9uc1wiIGNsYXNzPVwiZHJvcGRvd25cIj5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgY2xhc3M9XCJkcm9wZG93bi1pdGVtXCJcbiAgICAgICAgICAgICAgKm5nRm9yPVwibGV0IG0gb2YgbWludXRlc1wiXG4gICAgICAgICAgICAgIFtjbGFzcy5hY3RpdmVdPVwibSA9PT0gc2VsZWN0ZWRNaW51dGVcIlxuICAgICAgICAgICAgICAoY2xpY2spPVwic2VsZWN0TWludXRlKG0pXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge3sgbSB9fVxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgXG4gICAgIDxkaXY+XG4gICAgICAgIDx2ZXJiZW4tdG9vbHRpcFxuICAgICAgICBbdG9wXT1cIictNDBweCdcIlxuICAgICAgICBbdGV4dENvbG9yXT1cIicjMDAwJ1wiXG4gICAgICAgIFtiYWNrZ3JvdW5kQ29sb3JdPVwiJyNEM0QzRDMnXCJcbiAgICAgICAgW2xlZnRdPVwiJzAnXCJcbiAgICAgICAgW3dpZHRoXT1cIicxMDBweCdcIlxuICAgICAgICBbdG9vbHRpcENvbnRlbnRdPVwidG9vbHRpcFRlbXBsYXRlXCJcbiAgICAgICAgI3Rvb2x0aXA+XG4gICAgPHZlcmJlbi1zdmdcbiAgICAgICAgKGNsaWNrKT1cInNldFRvU3RhcnRPZkRheSgpXCJcbiAgICAgICAgY2xhc3M9XCJjdXJzb3ItcG9pbnRlclwiXG4gICAgICAgIFt3aWR0aF09XCIxNFwiXG4gICAgICAgIFtoZWlnaHRdPVwiMTRcIlxuICAgICAgICBbaWNvbl09XCInc3VuJ1wiXG4gICAgICA+PC92ZXJiZW4tc3ZnPlxuICAgICAgPC92ZXJiZW4tdG9vbHRpcD5cbiAgICAgICAgICAgPG5nLXRlbXBsYXRlICN0b29sdGlwVGVtcGxhdGU+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPHAgY2xhc3M9XCJ0ZXh0LXhzXCI+U2V0IHN0YXJ0IG9mIGRheTwvcD5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L25nLXRlbXBsYXRlPlxuICAgICA8L2Rpdj5cbiAgICAgPGRpdj5cbiAgPHZlcmJlbi10b29sdGlwXG4gICAgW3RvcF09XCInLTQwcHgnXCJcbiAgICBbdGV4dENvbG9yXT1cIicjMDAwJ1wiXG4gICAgW2JhY2tncm91bmRDb2xvcl09XCInI0QzRDNEMydcIlxuICAgIFtsZWZ0XT1cIicwJ1wiXG4gICAgW3dpZHRoXT1cIicxMDBweCdcIlxuICAgIFt0b29sdGlwQ29udGVudF09XCJlbmRPZkRheVRvb2x0aXBcIlxuICAgICNlbmRPZkRheVRpcFxuICA+XG4gICAgPHZlcmJlbi1zdmdcbiAgICAgIChjbGljayk9XCJzZXRUb0VuZE9mRGF5KClcIlxuICAgICAgY2xhc3M9XCJjdXJzb3ItcG9pbnRlclwiXG4gICAgICBbd2lkdGhdPVwiMTRcIlxuICAgICAgW2hlaWdodF09XCIxNFwiXG4gICAgICBbaWNvbl09XCInbW9vbidcIlxuICAgID48L3ZlcmJlbi1zdmc+XG4gIDwvdmVyYmVuLXRvb2x0aXA+XG5cbiAgPG5nLXRlbXBsYXRlICNlbmRPZkRheVRvb2x0aXA+XG4gICAgPGRpdj5cbiAgICAgIDxwIGNsYXNzPVwidGV4dC14c1wiPlNldCBlbmQgb2YgZGF5PC9wPlxuICAgIDwvZGl2PlxuICA8L25nLXRlbXBsYXRlPlxuPC9kaXY+XG5cbiAgICAgIDwvZGl2PlxuXG4gICAgPC9kaXY+XG5cbiAgICA8ZGl2IGNsYXNzPVwiY2FsZW5kYXItYm9keVwiPlxuICAgICAgPGRpdiBjbGFzcz1cIndlZWtkYXlzXCI+XG4gICAgICAgIDxzcGFuICpuZ0Zvcj1cImxldCBkYXkgb2Ygd2Vla0RheXNcIj57eyBkYXkgfX08L3NwYW4+XG4gICAgICA8L2Rpdj5cblxuICAgICAgPGRpdiBjbGFzcz1cImRhdGVzXCI+XG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGRheSBvZiBnZXREYXlzSW5Nb250aCgpXCI+XG4gICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgKm5nSWY9XCJkYXk7IGVsc2UgZW1wdHlcIlxuICAgICAgICAgICAgW2NsYXNzLnNlbGVjdGVkXT1cImlzU2VsZWN0ZWQoZGF5KVwiXG4gICAgICAgICAgICBbZGlzYWJsZWRdPVwiaXNEaXNhYmxlZChkYXkpXCJcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cInsgJ2Rpc2FibGVkLWRheSc6IGlzRGlzYWJsZWQoZGF5KSB9XCJcbiAgICAgICAgICAgIChjbGljayk9XCJzZWxlY3RUZW1wb3JhcnlEYXRlKGRheSlcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHt7IGRheS5nZXREYXRlKCkgfX1cbiAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICA8bmctdGVtcGxhdGUgI2VtcHR5PlxuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJlbXB0eS1kYXRlXCI+PC9zcGFuPlxuICAgICAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG5cbiAgICA8ZGl2IGNsYXNzPVwiY2FsZW5kYXItZm9vdGVyXCI+XG4gICAgICA8YnV0dG9uIChjbGljayk9XCJjYW5jZWwoKVwiPkNhbmNlbDwvYnV0dG9uPlxuICAgICAgPGJ1dHRvbiAoY2xpY2spPVwiY29uZmlybSgpXCI+T0s8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
388
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmVyYmVuLW5nLXVpL3NyYy9saWIvY29tcG9uZW50cy9kYXRlLXBpY2tlci9kYXRlLXBpY2tlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tbmctdWkvc3JjL2xpYi9jb21wb25lbnRzL2RhdGUtcGlja2VyL2RhdGUtcGlja2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5GLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7Ozs7QUFjekUsTUFBTSxPQUFPLG1CQUFtQjtJQUNyQixXQUFXLEdBQUcsYUFBYSxDQUFDO0lBQzVCLE1BQU0sR0FBRyxZQUFZLENBQUM7SUFDdEIsT0FBTyxDQUFRO0lBQ2YsT0FBTyxDQUFRO0lBQ2YsUUFBUSxHQUFhLEtBQUssQ0FBQztJQUMzQixPQUFPLEdBQVksTUFBTSxDQUFDO0lBQzFCLE1BQU0sR0FBWSxFQUFFLENBQUM7SUFDckIsWUFBWSxHQUFZLElBQUksQ0FBQztJQUM3QixlQUFlLEdBQVcsZUFBZSxDQUFDO0lBQzFDLGdCQUFnQixHQUFXLGdCQUFnQixDQUFDO0lBQzVDLElBQUksR0FBeUIsSUFBSSxDQUFDO0lBQ2xDLFFBQVEsR0FBWSxLQUFLLENBQUM7SUFFMUIsZUFBZSxHQUFXLE9BQU8sQ0FBQztJQUNsQyxjQUFjLEdBQVksS0FBSyxDQUFDO0lBRS9CLFVBQVUsR0FBRyxJQUFJLFlBQVksRUFBYSxDQUFDO0lBRXJELFNBQVMsR0FBYSxFQUFFLENBQUM7SUFDekIsaUJBQWlCLEdBQWEsRUFBRSxDQUFDO0lBR2pD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QUFjO3NCQUF0QixLQUFLO2dCQUVJLFVBQVU7c0JBQW5CLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgZm9yd2FyZFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJvcGRvd25DaGFuZ2VFdmVudCB9IGZyb20gJ3ZlcmJlbi1uZy11aS9zcmMvbGliL2NvbXBvbmVudHMvZHJvcC1kb3duJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWRhdGUtcGlja2VyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtcGlja2VyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGF0ZS1waWNrZXIuY29tcG9uZW50LmNzcyddLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IERhdGVQaWNrZXJDb21wb25lbnQpLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRGF0ZVBpY2tlckNvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgQElucHV0KCkgcGxhY2Vob2xkZXIgPSAnU2VsZWN0IGRhdGUnO1xuICBASW5wdXQoKSBmb3JtYXQgPSAnTU0vREQvWVlZWSc7XG4gIEBJbnB1dCgpIG1pbkRhdGU/OiBEYXRlO1xuICBASW5wdXQoKSBtYXhEYXRlPzogRGF0ZTtcbiAgQElucHV0KCkgZGlzYWJsZWQ/OiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIGJnQ29sb3I/OiBzdHJpbmcgPSAnI2ZmZic7XG4gIEBJbnB1dCgpIGJvcmRlcj86IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSB1c2VEcm9wZG93bnM6IGJvb2xlYW4gPSB0cnVlO1xuICBASW5wdXQoKSB5ZWFyUGxhY2Vob2xkZXI6IHN0cmluZyA9ICdTZWxlY3QgYSB5ZWFyJztcbiAgQElucHV0KCkgbW9udGhQbGFjZWhvbGRlcjogc3RyaW5nID0gJ1NlbGVjdCBhIG1vbnRoJztcbiAgQElucHV0KCkgZGF0ZTogRGF0ZSB8IG51bGwgfCBzdHJpbmcgPSBudWxsO1xuICBASW5wdXQoKSBzaG93VGltZTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpIGRhdGVQaWNrZXJXaWR0aDogc3RyaW5nID0gJzQwMHB4JztcbiAgQElucHV0KCkgdXNlRGVmYXVsdERhdGU6IGJvb2xlYW4gPSBmYWxzZTsgXG5cbiAgQE91dHB1dCgpIGRhdGVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPERhdGV8bnVsbD4oKTtcblxuICB5ZWFyUmFuZ2U6IG51bWJlcltdID0gW107XG4gIGZpbHRlcmVkWWVhclJhbmdlOiBudW1iZXJbXSA9IFtdO1xuXG5cbiAgc2VsZWN0ZWREYXRlOiBEYXRlIHwgbnVsbCA9IG51bGw7XG4gIHRlbXBTZWxlY3RlZERhdGU6IERhdGUgfCBudWxsID0gbnVsbDtcblxuICBzaG93Q2FsZW5kYXIgPSBmYWxzZTtcblxuICB3ZWVrRGF5cyA9IFsnTW9uJywgJ1R1ZScsICdXZWQnLCAnVGh1JywgJ0ZyaScsICdTYXQnLCAnU3VuJ107XG4gIG1vbnRocyA9IFtcbiAgICAnSmFudWFyeScsICdGZWJydWFyeScsICdNYXJjaCcsICdBcHJpbCcsICdNYXknLCAnSnVuZScsXG4gICAgJ0p1bHknLCAnQXVndXN0JywgJ1NlcHRlbWJlcicsICdPY3RvYmVyJywgJ05vdmVtYmVyJywgJ0RlY2VtYmVyJyxcbiAgXTtcblxuICBzZWxlY3RlZE1vbnRoOiBudW1iZXIgPSAxO1xuICBzZWxlY3RlZE1vbnRoU3RyaW5nOiBzdHJpbmcgPSAnJztcbiAgc2VsZWN0ZWRZZWFyOiBudW1iZXIgPSBuZXcgRGF0ZSgpLmdldEZ1bGxZZWFyKCk7XG5cbiAgcHJpdmF0ZSBvbkNoYW5nZTogYW55ID0gKCkgPT4ge307XG4gIHByaXZhdGUgb25Ub3VjaGVkOiBhbnkgPSAoKSA9PiB7fTtcblxuICB3cml0ZVZhbHVlKHZhbHVlOiBEYXRlIHwgc3RyaW5nIHwgbnVsbCk6IHZvaWQge1xuICAgIGlmICh2YWx1ZSkge1xuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgdmFsdWUgPSB0aGlzLnNhbml0aXplRGF0ZVN0cmluZyh2YWx1ZSk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IHBhcnNlZERhdGUgPSB0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnID8gbmV3IERhdGUodmFsdWUpIDogdmFsdWU7XG4gICAgICB0aGlzLmRhdGUgPSBwYXJzZWREYXRlO1xuXG4gICAgICB0aGlzLnNlbGVjdGVkRGF0ZSA9IG5ldyBEYXRlKHBhcnNlZERhdGUpO1xuICAgICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlID0gbmV3IERhdGUocGFyc2VkRGF0ZSk7XG4gICAgICB0aGlzLnNlbGVjdGVkTW9udGggPSB0aGlzLnNlbGVjdGVkRGF0ZS5nZXRNb250aCgpO1xuICAgICAgdGhpcy5zZWxlY3RlZFllYXIgPSB0aGlzLnNlbGVjdGVkRGF0ZS5nZXRGdWxsWWVhcigpO1xuXG4gICAgICBpZiAodGhpcy5zaG93VGltZSkge1xuICAgICAgICB0aGlzLmluaXRUaW1lRnJvbURhdGUodGhpcy5zZWxlY3RlZERhdGUpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSk6IHZvaWQge1xuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcbiAgfVxuXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xuICB9XG5cbiAgc2V0RGlzYWJsZWRTdGF0ZT8oaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgIHRoaXMuZGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoKSB7XG4gICAgaWYgKHRoaXMuZGF0ZSkge1xuICAgICAgbGV0IGQgPSB0aGlzLmRhdGU7XG4gICAgICBpZiAodHlwZW9mIGQgPT09ICdzdHJpbmcnKSBkID0gdGhpcy5zYW5pdGl6ZURhdGVTdHJpbmcoZCk7XG5cbiAgICAgIGNvbnN0IHBhcnNlZERhdGUgPSBuZXcgRGF0ZShkKTtcbiAgICAgIHRoaXMuc2VsZWN0ZWREYXRlID0gbmV3IERhdGUocGFyc2VkRGF0ZSk7XG4gICAgICB0aGlzLnRlbXBTZWxlY3RlZERhdGUgPSBuZXcgRGF0ZShwYXJzZWREYXRlKTtcbiAgICAgIHRoaXMuc2VsZWN0ZWRNb250aCA9IHRoaXMuc2VsZWN0ZWREYXRlLmdldE1vbnRoKCk7XG4gICAgICB0aGlzLnNlbGVjdGVkWWVhciA9IHRoaXMuc2VsZWN0ZWREYXRlLmdldEZ1bGxZZWFyKCk7XG4gICAgfVxuICB9XG5cbiAgaXNTYW1lRGF0ZShkMTogRGF0ZSwgZDI6IERhdGUpOiBib29sZWFuIHtcbiAgICByZXR1cm4gKFxuICAgICAgZDEuZ2V0RnVsbFllYXIoKSA9PT0gZDIuZ2V0RnVsbFllYXIoKSAmJlxuICAgICAgZDEuZ2V0TW9udGgoKSA9PT0gZDIuZ2V0TW9udGgoKSAmJlxuICAgICAgZDEuZ2V0RGF0ZSgpID09PSBkMi5nZXREYXRlKClcbiAgICApO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgY29uc3QgY3VycmVudFllYXIgPSBuZXcgRGF0ZSgpLmdldEZ1bGxZZWFyKCk7XG4gICAgY29uc3QgZW5kWWVhciA9IGN1cnJlbnRZZWFyICsgMTA7XG4gICAgdGhpcy55ZWFyUmFuZ2UgPSBBcnJheS5mcm9tKFxuICAgICAgeyBsZW5ndGg6IGVuZFllYXIgLSAxOTYwICsgMSB9LFxuICAgICAgKF8sIGkpID0+IDE5NjAgKyBpXG4gICAgKTtcbiAgICB0aGlzLnllYXJSYW5nZS5zb3J0KChhLCBiKSA9PiBiIC0gYSk7XG5cbiAgXG4gICAgaWYgKCF0aGlzLmRhdGUgJiYgdGhpcy51c2VEZWZhdWx0RGF0ZSkge1xuICAgICAgY29uc3Qgbm93ID0gbmV3IERhdGUoKTtcbiAgICAgIGNvbnN0IHBhZCA9IChuOiBudW1iZXIpID0+IG4udG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpO1xuXG4gICAgICBjb25zdCBsb2NhbERhdGVTdHJpbmcgPSBgJHtub3cuZ2V0RnVsbFllYXIoKX0tJHtwYWQoXG4gICAgICAgIG5vdy5nZXRNb250aCgpICsgMVxuICAgICAgKX0tJHtwYWQobm93LmdldERhdGUoKSl9VCR7cGFkKG5vdy5nZXRIb3VycygpKX06JHtwYWQoXG4gICAgICAgIG5vdy5nZXRNaW51dGVzKClcbiAgICAgICl9OiR7cGFkKG5vdy5nZXRTZWNvbmRzKCkpfWA7XG5cbiAgICAgIHRoaXMuc2VsZWN0ZWREYXRlID0gbmV3IERhdGUobG9jYWxEYXRlU3RyaW5nKTtcbiAgICAgIHRoaXMudGVtcFNlbGVjdGVkRGF0ZSA9IG5ldyBEYXRlKGxvY2FsRGF0ZVN0cmluZyk7XG4gICAgICB0aGlzLmRhdGUgPSB0aGlzLnNlbGVjdGVkRGF0ZTtcblxuICAgICAgaWYgKHRoaXMuc2hvd1RpbWUpIHtcbiAgICAgICAgY29uc3QgaG91cnMgPSBub3cuZ2V0SG91cnMoKTtcbiAgICAgICAgY29uc3QgbWludXRlcyA9IG5vdy5nZXRNaW51dGVzKCk7XG5cbiAgICAgICAgdGhpcy5zZWxlY3RlZEhvdXIgPSBob3Vycy50b1N0cmluZygpLnBhZFN0YXJ0KDIsICcwJyk7XG4gICAgICAgIHRoaXMuc2VsZWN0ZWRNaW51dGUgPSBtaW51dGVzLnRvU3RyaW5nKCkucGFkU3RhcnQoMiwgJzAnKTtcbiAgICAgICAgdGhpcy50ZW1wVGltZSA9IGAke3RoaXMuc2VsZWN0ZWRIb3VyfToke3RoaXMuc2VsZWN0ZWRNaW51dGV9YDtcbiAgICAgIH1cblxuICAgICAgdGhpcy5kYXRlQ2hhbmdlLmVtaXQodGhpcy5zZWxlY3RlZERhdGUpO1xuICAgICAgdGhpcy5vbkNoYW5nZShsb2NhbERhdGVTdHJpbmcpO1xuICAgIH1cbiAgfVxuXG4gIGdldCBkaXNwbGF5RGF0ZSgpOiBzdHJpbmcge1xuICAgIGNvbnN0IHBhcnNlZERhdGUgPVxuICAgICAgdHlwZW9mIHRoaXMuZGF0ZSA9PT0gJ3N0cmluZycgPyBuZXcgRGF0ZSh0aGlzLmRhdGUpIDogdGhpcy5kYXRlO1xuICAgIHJldHVybiBwYXJzZWREYXRlID8gdGhpcy5mb3JtYXREYXRlKHBhcnNlZERhdGUsIHRoaXMuZm9ybWF0KSA6ICcnO1xuICB9XG5cbiAgdGVtcFRpbWU6IHN0cmluZyA9ICcnO1xuICBzZWxlY3RlZEhvdXIgPSAnMDAnO1xuICBzZWxlY3RlZE1pbnV0ZSA9ICcwMCc7XG5cbiAgc2hvd0hvdXJPcHRpb25zID0gZmFsc2U7XG4gIHNob3dNaW51dGVPcHRpb25zID0gZmFsc2U7XG5cbiAgaG91cnMgPSBBcnJheS5mcm9tKHsgbGVuZ3RoOiAyNCB9LCAoXywgaSkgPT4gU3RyaW5nKGkpLnBhZFN0YXJ0KDIsICcwJykpO1xuICBtaW51dGVzID0gQXJyYXkuZnJvbSh7IGxlbmd0aDogNjAgfSwgKF8sIGkpID0+IFN0cmluZyhpKS5wYWRTdGFydCgyLCAnMCcpKTtcblxuICB0b2dnbGVIb3VyRHJvcGRvd24oKSB7XG4gICAgdGhpcy5zaG93SG91ck9wdGlvbnMgPSAhdGhpcy5zaG93SG91ck9wdGlvbnM7XG4gICAgdGhpcy5zaG93TWludXRlT3B0aW9ucyA9IGZhbHNlO1xuICB9XG5cbiAgdG9nZ2xlTWludXRlRHJvcGRvd24oKSB7XG4gICAgdGhpcy5zaG93TWludXRlT3B0aW9ucyA9ICF0aGlzLnNob3dNaW51dGVPcHRpb25zO1xuICAgIHRoaXMuc2hvd0hvdXJPcHRpb25zID0gZmFsc2U7XG4gIH1cblxuICBzZWxlY3RIb3VyKGg6IHN0cmluZykge1xuICAgIHRoaXMuc2VsZWN0ZWRIb3VyID0gaDtcbiAgICB0aGlzLnNob3dIb3VyT3B0aW9ucyA9IGZhbHNlO1xuICB9XG5cbiAgc2VsZWN0TWludXRlKG06IHN0cmluZykge1xuICAgIHRoaXMuc2VsZWN0ZWRNaW51dGUgPSBtO1xuICAgIHRoaXMuc2hvd01pbnV0ZU9wdGlvbnMgPSBmYWxzZTtcbiAgfVxuXG4gIHRvZ2dsZUNhbGVuZGFyKCkge1xuICAgIHRoaXMuc2hvd0NhbGVuZGFyID0gIXRoaXMuc2hvd0NhbGVuZGFyO1xuXG5cbiAgICBpZiAodGhpcy5kYXRlKSB7XG4gICAgICB0aGlzLnRlbXBTZWxlY3RlZERhdGUgPSBuZXcgRGF0ZSh0aGlzLmRhdGUpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnRlbXBTZWxlY3RlZERhdGUgPSB0aGlzLnVzZURlZmF1bHREYXRlID8gbmV3IERhdGUoKSA6IG51bGw7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMudGVtcFNlbGVjdGVkRGF0ZSkge1xuICAgICAgdGhpcy5zZWxlY3RlZE1vbnRoID0gdGhpcy50ZW1wU2VsZWN0ZWREYXRlLmdldE1vbnRoKCk7XG4gICAgICB0aGlzLnNlbGVjdGVkTW9udGhTdHJpbmcgPSB0aGlzLm1vbnRoc1t0aGlzLnNlbGVjdGVkTW9udGhdO1xuICAgICAgdGhpcy5zZWxlY3RlZFllYXIgPSB0aGlzLnRlbXBTZWxlY3RlZERhdGUuZ2V0RnVsbFllYXIoKTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5zaG93VGltZSAmJiAhdGhpcy50ZW1wVGltZSkge1xuICAgICAgY29uc3QgdG9kYXkgPSBuZXcgRGF0ZSgpO1xuICAgICAgY29uc3QgaXNUb2RheSA9XG4gICAgICAgIHRoaXMudGVtcFNlbGVjdGVkRGF0ZSAmJlxuICAgICAgICB0aGlzLmlzU2FtZURhdGUodGhpcy50ZW1wU2VsZWN0ZWREYXRlLCB0b2RheSk7XG5cbiAgICAgIGNvbnN0IGhvdXJzID0gaXNUb2RheSA/IHRvZGF5LmdldEhvdXJzKCkgOiAwO1xuICAgICAgY29uc3QgbWludXRlcyA9IGlzVG9kYXkgPyB0b2RheS5nZXRNaW51dGVzKCkgOiAwO1xuXG4gICAgICBpZiAodGhpcy50ZW1wU2VsZWN0ZWREYXRlKSB7XG4gICAgICAgIHRoaXMudGVtcFNlbGVjdGVkRGF0ZS5zZXRIb3Vycyhob3VycywgbWludXRlcywgMCwgMCk7XG4gICAgICB9XG4gICAgICB0aGlzLnNlbGVjdGVkSG91ciA9IGhvdXJzLnRvU3RyaW5nKCkucGFkU3RhcnQoMiwgJzAnKTtcbiAgICAgIHRoaXMuc2VsZWN0ZWRNaW51dGUgPSBtaW51dGVzLnRvU3RyaW5nKCkucGFkU3RhcnQoMiwgJzAnKTtcbiAgICAgIHRoaXMudGVtcFRpbWUgPSBgJHt0aGlzLnNlbGVjdGVkSG91cn06JHt0aGlzLnNlbGVjdGVkTWludXRlfWA7XG4gICAgfVxuICB9XG5cbiAgaW5pdFRpbWVGcm9tRGF0ZShkYXRlOiBEYXRlKSB7XG4gICAgY29uc3QgaG91cnMgPSBkYXRlLmdldEhvdXJzKCk7XG4gICAgY29uc3QgbWludXRlcyA9IGRhdGUuZ2V0TWludXRlcygpO1xuXG4gICAgdGhpcy5zZWxlY3RlZEhvdXIgPSBob3Vycy50b1N0cmluZygpLnBhZFN0YXJ0KDIsICcwJyk7XG4gICAgdGhpcy5zZWxlY3RlZE1pbnV0ZSA9IG1pbnV0ZXMudG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpO1xuICAgIHRoaXMudGVtcFRpbWUgPSBgJHt0aGlzLnNlbGVjdGVkSG91cn06JHt0aGlzLnNlbGVjdGVkTWludXRlfWA7XG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlPy5zZXRIb3Vycyhob3VycywgbWludXRlcywgMCwgMCk7XG4gIH1cbmNsZWFyRGF0ZSgpIHtcbiAgdGhpcy5kYXRlID0gbnVsbDtcbiAgdGhpcy5zZWxlY3RlZERhdGUgPSBudWxsO1xuICB0aGlzLnRlbXBTZWxlY3RlZERhdGUgPSBudWxsO1xuICB0aGlzLnRlbXBUaW1lID0gJyc7XG4gIHRoaXMuc2VsZWN0ZWRIb3VyID0gJzAwJztcbiAgdGhpcy5zZWxlY3RlZE1pbnV0ZSA9ICcwMCc7XG5cblxuICB0aGlzLmRhdGVDaGFuZ2UuZW1pdChudWxsKTtcblxuIFxuICB0aGlzLm9uQ2hhbmdlKG51bGwpO1xuICB0aGlzLm9uVG91Y2hlZCgpO1xuXG5cbiAgdGhpcy5zaG93Q2FsZW5kYXIgPSBmYWxzZTtcbn1cblxuICBmaXhUb1VUQyhkYXRlVmFsdWU6IGFueSkge1xuICAgIGlmICghZGF0ZVZhbHVlKSByZXR1cm4gbnVsbDtcblxuICAgIGNvbnN0IGRhdGUgPSBkYXRlVmFsdWUgaW5zdGFuY2VvZiBEYXRlID8gZGF0ZVZhbHVlIDogbmV3IERhdGUoZGF0ZVZhbHVlKTtcbiAgICBpZiAoaXNOYU4oZGF0ZS5nZXRUaW1lKCkpKSByZXR1cm4gbnVsbDtcblxuICAgIHJldHVybiBuZXcgRGF0ZShcbiAgICAgIERhdGUuVVRDKFxuICAgICAgICBkYXRlLmdldEZ1bGxZZWFyKCksXG4gICAgICAgIGRhdGUuZ2V0TW9udGgoKSxcbiAgICAgICAgZGF0ZS5nZXREYXRlKCksXG4gICAgICAgIGRhdGUuZ2V0SG91cnMoKSxcbiAgICAgICAgZGF0ZS5nZXRNaW51dGVzKCksXG4gICAgICAgIGRhdGUuZ2V0U2Vjb25kcygpLFxuICAgICAgICBkYXRlLmdldE1pbGxpc2Vjb25kcygpXG4gICAgICApXG4gICAgKTtcbiAgfVxuXG4gIGNvbmZpcm0oKSB7XG4gICAgaWYgKCF0aGlzLnRlbXBTZWxlY3RlZERhdGUpIHJldHVybjtcbiAgICBpZiAodGhpcy5pc0Rpc2FibGVkKHRoaXMudGVtcFNlbGVjdGVkRGF0ZSkpIHJldHVybjtcblxuICAgIGNvbnN0IGhvdXJzID0gTnVtYmVyKHRoaXMuc2VsZWN0ZWRIb3VyKTtcbiAgICBjb25zdCBtaW51dGVzID0gTnVtYmVyKHRoaXMuc2VsZWN0ZWRNaW51dGUpO1xuXG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlLnNldEhvdXJzKGhvdXJzLCBtaW51dGVzLCAwLCAwKTtcblxuICAgIHRoaXMuc2VsZWN0ZWREYXRlID0gbmV3IERhdGUodGhpcy50ZW1wU2VsZWN0ZWREYXRlKTtcbiAgICB0aGlzLmRhdGUgPSB0aGlzLnNlbGVjdGVkRGF0ZTtcblxuICAgIGNvbnN0IHBhZCA9IChuOiBudW1iZXIpID0+IG4udG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpO1xuICAgIGNvbnN0IGxvY2FsRGF0ZVN0cmluZyA9IGAke3RoaXMuc2VsZWN0ZWREYXRlLmdldEZ1bGxZZWFyKCl9LSR7cGFkKFxuICAgICAgdGhpcy5zZWxlY3RlZERhdGUuZ2V0TW9udGgoKSArIDFcbiAgICApfS0ke3BhZCh0aGlzLnNlbGVjdGVkRGF0ZS5nZXREYXRlKCkpfVQke3BhZChcbiAgICAgIHRoaXMuc2VsZWN0ZWREYXRlLmdldEhvdXJzKClcbiAgICApfToke3BhZCh0aGlzLnNlbGVjdGVkRGF0ZS5nZXRNaW51dGVzKCkpfToke3BhZChcbiAgICAgIHRoaXMuc2VsZWN0ZWREYXRlLmdldFNlY29uZHMoKVxuICAgICl9YDtcblxuICAgIHRoaXMuZGF0ZUNoYW5nZS5lbWl0KHRoaXMuc2VsZWN0ZWREYXRlKTtcbiAgICB0aGlzLm9uQ2hhbmdlKGxvY2FsRGF0ZVN0cmluZyk7XG4gICAgdGhpcy5vblRvdWNoZWQoKTtcblxuICAgIHRoaXMuc2hvd0NhbGVuZGFyID0gZmFsc2U7XG4gIH1cblxuICBzZXRUb1N0YXJ0T2ZEYXkoKSB7XG4gICAgaWYgKCF0aGlzLnRlbXBTZWxlY3RlZERhdGUpIHJldHVybjtcblxuICAgIHRoaXMuc2VsZWN0ZWRIb3VyID0gJzAwJztcbiAgICB0aGlzLnNlbGVjdGVkTWludXRlID0gJzAwJztcblxuICAgIHRoaXMudGVtcFNlbGVjdGVkRGF0ZS5zZXRIb3VycygwLCAwLCAwLCAwKTtcbiAgICB0aGlzLnRlbXBUaW1lID0gYCR7dGhpcy5zZWxlY3RlZEhvdXJ9OiR7dGhpcy5zZWxlY3RlZE1pbnV0ZX1gO1xuXG4gICAgdGhpcy5zZWxlY3RlZERhdGUgPSBuZXcgRGF0ZSh0aGlzLnRlbXBTZWxlY3RlZERhdGUpO1xuICB9XG5cbiAgc2V0VG9FbmRPZkRheSgpIHtcbiAgICBpZiAoIXRoaXMudGVtcFNlbGVjdGVkRGF0ZSkgcmV0dXJuO1xuXG4gICAgdGhpcy5zZWxlY3RlZEhvdXIgPSAnMjMnO1xuICAgIHRoaXMuc2VsZWN0ZWRNaW51dGUgPSAnNTknO1xuXG4gICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlLnNldEhvdXJzKDIzLCA1OSwgNTksIDk5OSk7XG4gICAgdGhpcy50ZW1wVGltZSA9IGAke3RoaXMuc2VsZWN0ZWRIb3VyfToke3RoaXMuc2VsZWN0ZWRNaW51dGV9YDtcblxuICAgIHRoaXMuc2VsZWN0ZWREYXRlID0gbmV3IERhdGUodGhpcy50ZW1wU2VsZWN0ZWREYXRlKTtcbiAgfVxuXG4gIHByZXZpb3VzTW9udGgoKSB7XG4gICAgdGhpcy5zZWxlY3RlZE1vbnRoLS07XG4gICAgaWYgKHRoaXMuc2VsZWN0ZWRNb250aCA8IDApIHtcbiAgICAgIHRoaXMuc2VsZWN0ZWRNb250aCA9IDExO1xuICAgICAgdGhpcy5zZWxlY3RlZFllYXItLTtcbiAgICB9XG4gICAgdGhpcy51cGRhdGVUZW1wU2VsZWN0ZWREYXRlKCk7XG4gIH1cblxuICBuZXh0TW9udGgoKSB7XG4gICAgdGhpcy5zZWxlY3RlZE1vbnRoKys7XG4gICAgaWYgKHRoaXMuc2VsZWN0ZWRNb250aCA+IDExKSB7XG4gICAgICB0aGlzLnNlbGVjdGVkTW9udGggPSAwO1xuICAgICAgdGhpcy5zZWxlY3RlZFllYXIrKztcbiAgICB9XG4gICAgdGhpcy51cGRhdGVUZW1wU2VsZWN0ZWREYXRlKCk7XG4gIH1cblxuICBvbkRyb3Bkb3duWWVhckNoYW5nZShldmVudDogRHJvcGRvd25DaGFuZ2VFdmVudCk6IHZvaWQge1xuICAgIHRoaXMuc2VsZWN0ZWRZZWFyID0gZXZlbnQudmFsdWU7XG4gICAgdGhpcy51cGRhdGVUZW1wU2VsZWN0ZWREYXRlKCk7XG4gIH1cblxuICBvbkRyb3Bkb3duTW9udGhDaGFuZ2UoZXZlbnQ6IERyb3Bkb3duQ2hhbmdlRXZlbnQpOiB2b2lkIHtcbiAgICB0aGlzLnNlbGVjdGVkTW9udGggPSB0aGlzLm1vbnRocy5pbmRleE9mKGV2ZW50LnZhbHVlKTtcbiAgICB0aGlzLnVwZGF0ZVRlbXBTZWxlY3RlZERhdGUoKTtcbiAgfVxuXG4gIHVwZGF0ZVRlbXBTZWxlY3RlZERhdGUoKSB7XG4gICAgaWYgKCF0aGlzLnRlbXBTZWxlY3RlZERhdGUpIHJldHVybjtcbiAgICB0aGlzLnRlbXBTZWxlY3RlZERhdGUuc2V0TW9udGgodGhpcy5zZWxlY3RlZE1vbnRoKTtcbiAgICB0aGlzLnRlbXBTZWxlY3RlZERhdGUuc2V0RnVsbFllYXIodGhpcy5zZWxlY3RlZFllYXIpO1xuICB9XG5cbiAgZ2V0RGF5c0luTW9udGgoKTogKERhdGUgfCBudWxsKVtdIHtcbiAgICBjb25zdCBkYXlzOiAoRGF0ZSB8IG51bGwpW10gPSBbXTtcbiAgICBjb25zdCB5ZWFyID0gdGhpcy5zZWxlY3RlZFllYXI7XG4gICAgY29uc3QgbW9udGggPSB0aGlzLnNlbGVjdGVkTW9udGg7XG5cbiAgICBjb25zdCBmaXJzdERheU9mTW9udGggPSBuZXcgRGF0ZSh5ZWFyLCBtb250aCwgMSkuZ2V0RGF5KCk7XG4gICAgY29uc3Qgb2Zmc2V0ID0gZmlyc3REYXlPZk1vbnRoID09PSAwID8gNiA6IGZpcnN0RGF5T2ZNb250aCAtIDE7XG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IG9mZnNldDsgaSsrKSB7XG4gICAgICBkYXlzLnB1c2gobnVsbCk7XG4gICAgfVxuXG4gICAgY29uc3QgdG90YWxEYXlzID0gbmV3IERhdGUoeWVhciwgbW9udGggKyAxLCAwKS5nZXREYXRlKCk7XG4gICAgZm9yIChsZXQgaSA9IDE7IGkgPD0gdG90YWxEYXlzOyBpKyspIHtcbiAgICAgIGNvbnN0IGRheSA9IG5ldyBEYXRlKHllYXIsIG1vbnRoLCBpKTtcbiAgICAgIGRheXMucHVzaChkYXkpO1xuICAgIH1cbiAgICByZXR1cm4gZGF5cztcbiAgfVxuXG4gIHNhbml0aXplRGF0ZVN0cmluZyh2YWx1ZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdmFsdWU/LmVuZHNXaXRoKCdaJykgPyB2YWx1ZS5zbGljZSgwLCAtMSkgOiB2YWx1ZTtcbiAgfVxuXG4gIGlzRGlzYWJsZWQoZGF5OiBEYXRlIHwgc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgY29uc3QgZGF5RGF0ZSA9IHRoaXMudG9EYXRlKGRheSk7XG5cbiAgICBpZiAodGhpcy5taW5EYXRlICYmIGRheURhdGUgPCB0aGlzLnN0cmlwVGltZSh0aGlzLnRvRGF0ZSh0aGlzLm1pbkRhdGUpKSlcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIGlmICh0aGlzLm1heERhdGUgJiYgZGF5RGF0ZSA+IHRoaXMuc3RyaXBUaW1lKHRoaXMudG9EYXRlKHRoaXMubWF4RGF0ZSkpKVxuICAgICAgcmV0dXJuIHRydWU7XG5cbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBwcml2YXRlIHN0cmlwVGltZShkYXRlOiBEYXRlIHwgc3RyaW5nKTogRGF0ZSB7XG4gICAgY29uc3QgZCA9IHRoaXMudG9EYXRlKGRhdGUpO1xuICAgIHJldHVybiBuZXcgRGF0ZShkLmdldEZ1bGxZZWFyKCksIGQuZ2V0TW9udGgoKSwgZC5nZXREYXRlKCkpO1xuICB9XG5cbiAgdG9EYXRlKHZhbHVlOiBEYXRlIHwgc3RyaW5nKTogRGF0ZSB7XG4gICAgaWYgKHZhbHVlIGluc3RhbmNlb2YgRGF0ZSkgcmV0dXJuIHZhbHVlO1xuICAgIHJldHVybiBuZXcgRGF0ZSh0aGlzLnNhbml0aXplRGF0ZVN0cmluZyh2YWx1ZSkpO1xuICB9XG5cbiAgaXMyNEhvdXI6IGJvb2xlYW4gPSB0cnVlO1xuXG4gIHNlbGVjdFRlbXBvcmFyeURhdGUoZGF5OiBEYXRlKSB7XG4gICAgaWYgKCF0aGlzLnRlbXBTZWxlY3RlZERhdGUpIHRoaXMudGVtcFNlbGVjdGVkRGF0ZSA9IG5ldyBEYXRlKGRheSk7XG4gICAgaWYgKHRoaXMuaXNEaXNhYmxlZChkYXkpKSByZXR1cm47XG5cbiAgICBjb25zdCBpc05ld0RhdGUgPSAhdGhpcy5pc1NhbWVEYXRlKHRoaXMudGVtcFNlbGVjdGVkRGF0ZSwgZGF5KTtcbiAgICB0aGlzLnRlbXBTZWxlY3RlZERhdGUgPSBuZXcgRGF0ZShkYXkpO1xuXG4gICAgaWYgKHRoaXMuc2hvd1RpbWUpIHtcbiAgICAgIGlmIChpc05ld0RhdGUpIHtcbiAgICAgICAgY29uc3QgdG9kYXkgPSBuZXcgRGF0ZSgpO1xuICAgICAgICBjb25zdCBpc1RvZGF5ID1cbiAgICAgICAgICBkYXkuZ2V0RnVsbFllYXIoKSA9PT0gdG9kYXkuZ2V0RnVsbFllYXIoKSAmJlxuICAgICAgICAgIGRheS5nZXRNb250aCgpID09PSB0b2RheS5nZXRNb250aCgpICYmXG4gICAgICAgICAgZGF5LmdldERhdGUoKSA9PT0gdG9kYXkuZ2V0RGF0ZSgpO1xuXG4gICAgICAgIGNvbnN0IGhvdXJzID0gaXNUb2RheSA/IHRvZGF5LmdldEhvdXJzKCkgOiAwO1xuICAgICAgICBjb25zdCBtaW51dGVzID0gaXNUb2RheSA/IHRvZGF5LmdldE1pbnV0ZXMoKSA6IDA7XG5cbiAgICAgICAgdGhpcy50ZW1wU2VsZWN0ZWREYXRlLnNldEhvdXJzKGhvdXJzLCBtaW51dGVzLCAwLCAwKTtcblxuICAgICAgICB0aGlzLnNlbGVjdGVkSG91ciA9IGhvdXJzLnRvU3RyaW5nKCkucGFkU3RhcnQoMiwgJzAnKTtcbiAgICAgICAgdGhpcy5zZWxlY3RlZE1pbnV0ZSA9IG1pbnV0ZXMudG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpO1xuICAgICAgICB0aGlzLnRlbXBUaW1lID0gYCR7dGhpcy5zZWxlY3RlZEhvdXJ9OiR7dGhpcy5zZWxlY3RlZE1pbnV0ZX1gO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3QgW2gsIG1dID0gdGhpcy50ZW1wVGltZS5zcGxpdCgnOicpO1xuICAgICAgICB0aGlzLnNlbGVjdGVkSG91ciA9IGg7XG4gICAgICAgIHRoaXMuc2VsZWN0ZWRNaW51dGUgPSBtO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGlzU2VsZWN0ZWQoZGF5OiBEYXRlKTogYm9vbGVhbiB7XG4gICAgaWYgKCF0aGlzLnRlbXBTZWxlY3RlZERhdGUpIHJldHVybiBmYWxzZTtcblxuICAgIHJldHVybiAoXG4gICAgICBkYXkuZ2V0RGF0ZSgpID09PSB0aGlzLnRlbXBTZWxlY3RlZERhdGUuZ2V0RGF0ZSgpICYmXG4gICAgICBkYXkuZ2V0TW9udGgoKSA9PT0gdGhpcy50ZW1wU2VsZWN0ZWREYXRlLmdldE1vbnRoKCkgJiZcbiAgICAgIGRheS5nZXRGdWxsWWVhcigpID09PSB0aGlzLnRlbXBTZWxlY3RlZERhdGUuZ2V0RnVsbFllYXIoKVxuICAgICk7XG4gIH1cblxuICBmb3JtYXREYXRlKGRhdGU6IERhdGUsIGZvcm1hdDogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBjb25zdCBkYXkgPSBkYXRlLmdldERhdGUoKS50b1N0cmluZygpLnBhZFN0YXJ0KDIsICcwJyk7XG4gICAgY29uc3QgbW9udGggPSAoZGF0ZS5nZXRNb250aCgpICsgMSkudG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpO1xuICAgIGNvbnN0IHllYXIgPSBkYXRlLmdldEZ1bGxZZWFyKCk7XG5cbiAgICBzd2l0Y2ggKGZvcm1hdCkge1xuICAgICAgY2FzZSAnREQvTU0vWVlZWSc6XG4gICAgICAgIHJldHVybiBgJHtkYXl9LyR7bW9udGh9LyR7eWVhcn1gO1xuICAgICAgY2FzZSAnTU0vREQvWVlZWSc6XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gYCR7bW9udGh9LyR7ZGF5fS8ke3llYXJ9YDtcbiAgICB9XG4gIH1cblxuICBjYW5jZWwoKSB7XG4gICAgdGhpcy5zaG93Q2FsZW5kYXIgPSBmYWxzZTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImRhdGUtcGlja2VyXCI+XG4gIDxkaXYgY2xhc3M9XCJjYWxlbmRhci1jb250YWluZXJcIj5cbiAgICA8aW5wdXRcbiAgICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXG4gICAgICBbdmFsdWVdPVwiZGlzcGxheURhdGVcIlxuICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICAgIChjbGljayk9XCIhZGlzYWJsZWQgJiYgdG9nZ2xlQ2FsZW5kYXIoKVwiXG4gICAgICBjbGFzcz1cInctZnVsbCBibG9ja1wiXG4gICAgICBbc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJiZ0NvbG9yXCJcbiAgICAgIFtzdHlsZS5ib3JkZXJdPVwiYm9yZGVyXCJcbiAgICAgIFtuZ0NsYXNzXT1cIntcbiAgICAgICAgJ2N1cnNvci1ub3QtYWxsb3dlZCc6IGRpc2FibGVkID09PSB0cnVlLFxuICAgICAgICAnY3Vyc29yLXBvaW50ZXInOiBkaXNhYmxlZCA9PT0gZmFsc2VcbiAgICAgIH1cIlxuICAgICAgcmVhZG9ubHlcbiAgICAvPlxuICAgIDx2ZXJiZW4tc3ZnXG4gICAgICAoY2xpY2spPVwiIWRpc2FibGVkICYmIHRvZ2dsZUNhbGVuZGFyKClcIlxuICAgICAgY2xhc3M9XCJpY29uXCJcbiAgICAgIFtpY29uXT1cIidjYWxlbmRhcidcIlxuICAgID48L3ZlcmJlbi1zdmc+XG4gIDwvZGl2PlxuXG4gIDxkaXZcbiAgICAqbmdJZj1cInNob3dDYWxlbmRhclwiXG4gICAgW2FwcE91dFNpZGVDbGlja109XCJzaG93Q2FsZW5kYXJcIlxuICAgIChvdXRTaWRlQ2xpY2spPVwic2hvd0NhbGVuZGFyID0gZmFsc2VcIlxuICAgIGNsYXNzPVwiY2FsZW5kYXJcIlxuICAgIFtzdHlsZS53aWR0aF09XCJkYXRlUGlja2VyV2lkdGhcIlxuICA+XG4gICAgPGRpdiBjbGFzcz1cImNhbGVuZGFyLWhlYWRlclwiPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiF1c2VEcm9wZG93bnM7IGVsc2UgZHJvcGRvd25zXCI+XG4gICAgICAgIDxidXR0b24gKGNsaWNrKT1cInByZXZpb3VzTW9udGgoKVwiPlxuICAgICAgICAgIDx2ZXJiZW4tc3ZnIFt3aWR0aF09XCIyMFwiIFtpY29uXT1cIidjaGV2cm9uLWxlZnQnXCI+PC92ZXJiZW4tc3ZnPlxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPHNwYW4+e3sgbW9udGhzW3NlbGVjdGVkTW9udGhdIH19IHt7IHNlbGVjdGVkWWVhciB9fTwvc3Bhbj5cbiAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwibmV4dE1vbnRoKClcIj5cbiAgICAgICAgICA8dmVyYmVuLXN2ZyBbd2lkdGhdPVwiMjBcIiBbaWNvbl09XCInY2hldnJvbi1yaWdodCdcIj48L3ZlcmJlbi1zdmc+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9uZy1jb250YWluZXI+XG5cbiAgICAgIDxuZy10ZW1wbGF0ZSAjZHJvcGRvd25zPlxuICAgICAgICA8dmVyYmVuLWRyb3AtZG93blxuICAgICAgICAgIFtwbGFjZWhvbGRlcl09XCJ5ZWFyUGxhY2Vob2xkZXJcIlxuICAgICAgICAgIChvbkNoYW5nZSk9XCJvbkRyb3Bkb3duWWVhckNoYW5nZSgkZXZlbnQpXCJcbiAgICAgICAgICBbb3B0aW9uc109XCJ5ZWFyUmFuZ2VcIlxuICAgICAgICAgIFsobmdNb2RlbCldPVwic2VsZWN0ZWRZZWFyXCJcbiAgICAgICAgICBbd2lkdGhdPVwiJzkwcHgnXCJcbiAgICAgICAgPjwvdmVyYmVuLWRyb3AtZG93bj5cblxuICAgICAgICA8dmVyYmVuLWRyb3AtZG93blxuICAgICAgICAgIFtwbGFjZWhvbGRlcl09XCJtb250aFBsYWNlaG9sZGVyXCJcbiAgICAgICAgICAob25DaGFuZ2UpPVwib25Ecm9wZG93bk1vbnRoQ2hhbmdlKCRldmVudClcIlxuICAgICAgICAgIFtvcHRpb25zXT1cIm1vbnRoc1wiXG4gICAgICAgICAgY2xhc3M9XCJkcm9wLWRvd25cIlxuICAgICAgICAgIFsobmdNb2RlbCldPVwic2VsZWN0ZWRNb250aFN0cmluZ1wiXG4gICAgICAgICAgW3dpZHRoXT1cIic5MHB4J1wiXG4gICAgICAgID48L3ZlcmJlbi1kcm9wLWRvd24+XG4gICAgICA8L25nLXRlbXBsYXRlPlxuXG4gXG4gICAgICA8ZGl2IGNsYXNzPVwidGltZS1waWNrZXIgZmxleCBpdGVtcy1jZW50ZXIgZ2FwLTJcIiAqbmdJZj1cInNob3dUaW1lXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJyZWxhdGl2ZVwiPlxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgIGNsYXNzPVwiZmxleCBpdGVtcy1jZW50ZXIgYm94IHJvdW5kZWQgcHgtMiBweS0xIGN1cnNvci1wb2ludGVyXCJcbiAgICAgICAgICAgIChjbGljayk9XCJ0b2dnbGVIb3VyRHJvcGRvd24oKVwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAge3sgc2VsZWN0ZWRIb3VyIH19XG4gICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICA8ZGl2ICpuZ0lmPVwic2hvd0hvdXJPcHRpb25zXCIgY2xhc3M9XCJkcm9wZG93blwiPlxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICBjbGFzcz1cImRyb3Bkb3duLWl0ZW1cIlxuICAgICAgICAgICAgICAqbmdGb3I9XCJsZXQgaCBvZiBob3Vyc1wiXG4gICAgICAgICAgICAgIFtjbGFzcy5hY3RpdmVdPVwiaCA9PT0gc2VsZWN0ZWRIb3VyXCJcbiAgICAgICAgICAgICAgKGNsaWNrKT1cInNlbGVjdEhvdXIoaClcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7eyBoIH19XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPHNwYW4+Ojwvc3Bhbj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwicmVsYXRpdmVcIj5cbiAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjbGFzcz1cImZsZXggaXRlbXMtY2VudGVyIGJveCByb3VuZGVkIHB4LTIgcHktMSBjdXJzb3ItcG9pbnRlclwiXG4gICAgICAgICAgICAoY2xpY2spPVwidG9nZ2xlTWludXRlRHJvcGRvd24oKVwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAge3sgc2VsZWN0ZWRNaW51dGUgfX1cbiAgICAgICAgICA8L2Rpdj5cblxuICAgICAgICAgIDxkaXYgKm5nSWY9XCJzaG93TWludXRlT3B0aW9uc1wiIGNsYXNzPVwiZHJvcGRvd25cIj5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgY2xhc3M9XCJkcm9wZG93bi1pdGVtXCJcbiAgICAgICAgICAgICAgKm5nRm9yPVwibGV0IG0gb2YgbWludXRlc1wiXG4gICAgICAgICAgICAgIFtjbGFzcy5hY3RpdmVdPVwibSA9PT0gc2VsZWN0ZWRNaW51dGVcIlxuICAgICAgICAgICAgICAoY2xpY2spPVwic2VsZWN0TWludXRlKG0pXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge3sgbSB9fVxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgXG4gICAgIDxkaXY+XG4gICAgICAgIDx2ZXJiZW4tdG9vbHRpcFxuICAgICAgICBbdG9wXT1cIictNDBweCdcIlxuICAgICAgICBbdGV4dENvbG9yXT1cIicjMDAwJ1wiXG4gICAgICAgIFtiYWNrZ3JvdW5kQ29sb3JdPVwiJyNEM0QzRDMnXCJcbiAgICAgICAgW2xlZnRdPVwiJzAnXCJcbiAgICAgICAgW3dpZHRoXT1cIicxMDBweCdcIlxuICAgICAgICBbdG9vbHRpcENvbnRlbnRdPVwidG9vbHRpcFRlbXBsYXRlXCJcbiAgICAgICAgI3Rvb2x0aXA+XG4gICAgPHZlcmJlbi1zdmdcbiAgICAgICAgKGNsaWNrKT1cInNldFRvU3RhcnRPZkRheSgpXCJcbiAgICAgICAgY2xhc3M9XCJjdXJzb3ItcG9pbnRlclwiXG4gICAgICAgIFt3aWR0aF09XCIxNFwiXG4gICAgICAgIFtoZWlnaHRdPVwiMTRcIlxuICAgICAgICBbaWNvbl09XCInc3VuJ1wiXG4gICAgICA+PC92ZXJiZW4tc3ZnPlxuICAgICAgPC92ZXJiZW4tdG9vbHRpcD5cbiAgICAgICAgICAgPG5nLXRlbXBsYXRlICN0b29sdGlwVGVtcGxhdGU+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgPHAgY2xhc3M9XCJ0ZXh0LXhzXCI+U2V0IHN0YXJ0IG9mIGRheTwvcD5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L25nLXRlbXBsYXRlPlxuICAgICA8L2Rpdj5cbiAgICAgPGRpdj5cbiAgPHZlcmJlbi10b29sdGlwXG4gICAgW3RvcF09XCInLTQwcHgnXCJcbiAgICBbdGV4dENvbG9yXT1cIicjMDAwJ1wiXG4gICAgW2JhY2tncm91bmRDb2xvcl09XCInI0QzRDNEMydcIlxuICAgIFtsZWZ0XT1cIicwJ1wiXG4gICAgW3dpZHRoXT1cIicxMDBweCdcIlxuICAgIFt0b29sdGlwQ29udGVudF09XCJlbmRPZkRheVRvb2x0aXBcIlxuICAgICNlbmRPZkRheVRpcFxuICA+XG4gICAgPHZlcmJlbi1zdmdcbiAgICAgIChjbGljayk9XCJzZXRUb0VuZE9mRGF5KClcIlxuICAgICAgY2xhc3M9XCJjdXJzb3ItcG9pbnRlclwiXG4gICAgICBbd2lkdGhdPVwiMTRcIlxuICAgICAgW2hlaWdodF09XCIxNFwiXG4gICAgICBbaWNvbl09XCInbW9vbidcIlxuICAgID48L3ZlcmJlbi1zdmc+XG4gICBcbiAgPC92ZXJiZW4tdG9vbHRpcD5cblxuICA8bmctdGVtcGxhdGUgI2VuZE9mRGF5VG9vbHRpcD5cbiAgICA8ZGl2PlxuICAgICAgPHAgY2xhc3M9XCJ0ZXh0LXhzXCI+U2V0IGVuZCBvZiBkYXk8L3A+XG4gICAgPC9kaXY+XG4gIDwvbmctdGVtcGxhdGU+XG5cbjwvZGl2PlxuICAgIDx2ZXJiZW4tdG9vbHRpcFxuICAgIFt0b3BdPVwiJy00MHB4J1wiXG4gICAgW3RleHRDb2xvcl09XCInIzAwMCdcIlxuICAgIFtiYWNrZ3JvdW5kQ29sb3JdPVwiJyNEM0QzRDMnXCJcbiAgICBbbGVmdF09XCInMCdcIlxuICAgIFt3aWR0aF09XCInMTAwcHgnXCJcbiAgICBbdG9vbHRpcENvbnRlbnRdPVwiY2xlYXJUb29sdGlwXCJcbiAgICAjY2xlYXJEYXRlVGlwXG4gID5cbiAgICA8dmVyYmVuLXN2Z1xuICAgICAgKGNsaWNrKT1cImNsZWFyRGF0ZSgpXCJcbiAgICAgIGNsYXNzPVwiY3Vyc29yLXBvaW50ZXJcIlxuICAgICAgW3dpZHRoXT1cIjE0XCJcbiAgICAgIFtoZWlnaHRdPVwiMTRcIlxuICAgICAgW2ljb25dPVwiJ2Nsb3NlJ1wiXG4gICAgPjwvdmVyYmVuLXN2Zz5cbiAgIFxuICA8L3ZlcmJlbi10b29sdGlwPlxuXG4gIDxuZy10ZW1wbGF0ZSAjY2xlYXJUb29sdGlwPlxuICAgIDxkaXY+XG4gICAgICA8cCBjbGFzcz1cInRleHQteHNcIj5jbGVhciBkYXRlPC9wPlxuICAgIDwvZGl2PlxuICA8L25nLXRlbXBsYXRlPlxuICAgICAgPC9kaXY+XG5cbiAgICA8L2Rpdj5cblxuICAgIDxkaXYgY2xhc3M9XCJjYWxlbmRhci1ib2R5XCI+XG4gICAgICA8ZGl2IGNsYXNzPVwid2Vla2RheXNcIj5cbiAgICAgICAgPHNwYW4gKm5nRm9yPVwibGV0IGRheSBvZiB3ZWVrRGF5c1wiPnt7IGRheSB9fTwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuXG4gICAgICA8ZGl2IGNsYXNzPVwiZGF0ZXNcIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgZGF5IG9mIGdldERheXNJbk1vbnRoKClcIj5cbiAgICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgICAqbmdJZj1cImRheTsgZWxzZSBlbXB0eVwiXG4gICAgICAgICAgICBbY2xhc3Muc2VsZWN0ZWRdPVwiaXNTZWxlY3RlZChkYXkpXCJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJpc0Rpc2FibGVkKGRheSlcIlxuICAgICAgICAgICAgW25nQ2xhc3NdPVwieyAnZGlzYWJsZWQtZGF5JzogaXNEaXNhYmxlZChkYXkpIH1cIlxuICAgICAgICAgICAgKGNsaWNrKT1cInNlbGVjdFRlbXBvcmFyeURhdGUoZGF5KVwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAge3sgZGF5LmdldERhdGUoKSB9fVxuICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICAgIDxuZy10ZW1wbGF0ZSAjZW1wdHk+XG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cImVtcHR5LWRhdGVcIj48L3NwYW4+XG4gICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cblxuICAgIDxkaXYgY2xhc3M9XCJjYWxlbmRhci1mb290ZXJcIj5cbiAgICAgIDxidXR0b24gKGNsaWNrKT1cImNhbmNlbCgpXCI+Q2FuY2VsPC9idXR0b24+XG4gICAgICA8YnV0dG9uIChjbGljayk9XCJjb25maXJtKClcIj5PSzwvYnV0dG9uPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -27,13 +27,14 @@ class DatePickerComponent {
|
|
|
27
27
|
monthPlaceholder = 'Select a month';
|
|
28
28
|
date = null;
|
|
29
29
|
showTime = false;
|
|
30
|
+
datePickerWidth = '400px';
|
|
31
|
+
useDefaultDate = false;
|
|
30
32
|
dateChange = new EventEmitter();
|
|
31
33
|
yearRange = [];
|
|
32
34
|
filteredYearRange = [];
|
|
33
|
-
selectedDate =
|
|
34
|
-
tempSelectedDate =
|
|
35
|
+
selectedDate = null;
|
|
36
|
+
tempSelectedDate = null;
|
|
35
37
|
showCalendar = false;
|
|
36
|
-
datePickerWidth = '400px';
|
|
37
38
|
weekDays = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'];
|
|
38
39
|
months = [
|
|
39
40
|
'January', 'February', 'March', 'April', 'May', 'June',
|
|
@@ -91,7 +92,7 @@ class DatePickerComponent {
|
|
|
91
92
|
const endYear = currentYear + 10;
|
|
92
93
|
this.yearRange = Array.from({ length: endYear - 1960 + 1 }, (_, i) => 1960 + i);
|
|
93
94
|
this.yearRange.sort((a, b) => b - a);
|
|
94
|
-
if (!this.date) {
|
|
95
|
+
if (!this.date && this.useDefaultDate) {
|
|
95
96
|
const now = new Date();
|
|
96
97
|
const pad = (n) => n.toString().padStart(2, '0');
|
|
97
98
|
const localDateString = `${now.getFullYear()}-${pad(now.getMonth() + 1)}-${pad(now.getDate())}T${pad(now.getHours())}:${pad(now.getMinutes())}:${pad(now.getSeconds())}`;
|
|
@@ -138,16 +139,26 @@ class DatePickerComponent {
|
|
|
138
139
|
}
|
|
139
140
|
toggleCalendar() {
|
|
140
141
|
this.showCalendar = !this.showCalendar;
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
142
|
+
if (this.date) {
|
|
143
|
+
this.tempSelectedDate = new Date(this.date);
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
this.tempSelectedDate = this.useDefaultDate ? new Date() : null;
|
|
147
|
+
}
|
|
148
|
+
if (this.tempSelectedDate) {
|
|
149
|
+
this.selectedMonth = this.tempSelectedDate.getMonth();
|
|
150
|
+
this.selectedMonthString = this.months[this.selectedMonth];
|
|
151
|
+
this.selectedYear = this.tempSelectedDate.getFullYear();
|
|
152
|
+
}
|
|
145
153
|
if (this.showTime && !this.tempTime) {
|
|
146
154
|
const today = new Date();
|
|
147
|
-
const isToday = this.
|
|
155
|
+
const isToday = this.tempSelectedDate &&
|
|
156
|
+
this.isSameDate(this.tempSelectedDate, today);
|
|
148
157
|
const hours = isToday ? today.getHours() : 0;
|
|
149
158
|
const minutes = isToday ? today.getMinutes() : 0;
|
|
150
|
-
this.tempSelectedDate
|
|
159
|
+
if (this.tempSelectedDate) {
|
|
160
|
+
this.tempSelectedDate.setHours(hours, minutes, 0, 0);
|
|
161
|
+
}
|
|
151
162
|
this.selectedHour = hours.toString().padStart(2, '0');
|
|
152
163
|
this.selectedMinute = minutes.toString().padStart(2, '0');
|
|
153
164
|
this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;
|
|
@@ -159,7 +170,19 @@ class DatePickerComponent {
|
|
|
159
170
|
this.selectedHour = hours.toString().padStart(2, '0');
|
|
160
171
|
this.selectedMinute = minutes.toString().padStart(2, '0');
|
|
161
172
|
this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;
|
|
162
|
-
this.tempSelectedDate
|
|
173
|
+
this.tempSelectedDate?.setHours(hours, minutes, 0, 0);
|
|
174
|
+
}
|
|
175
|
+
clearDate() {
|
|
176
|
+
this.date = null;
|
|
177
|
+
this.selectedDate = null;
|
|
178
|
+
this.tempSelectedDate = null;
|
|
179
|
+
this.tempTime = '';
|
|
180
|
+
this.selectedHour = '00';
|
|
181
|
+
this.selectedMinute = '00';
|
|
182
|
+
this.dateChange.emit(null);
|
|
183
|
+
this.onChange(null);
|
|
184
|
+
this.onTouched();
|
|
185
|
+
this.showCalendar = false;
|
|
163
186
|
}
|
|
164
187
|
fixToUTC(dateValue) {
|
|
165
188
|
if (!dateValue)
|
|
@@ -170,6 +193,8 @@ class DatePickerComponent {
|
|
|
170
193
|
return new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds()));
|
|
171
194
|
}
|
|
172
195
|
confirm() {
|
|
196
|
+
if (!this.tempSelectedDate)
|
|
197
|
+
return;
|
|
173
198
|
if (this.isDisabled(this.tempSelectedDate))
|
|
174
199
|
return;
|
|
175
200
|
const hours = Number(this.selectedHour);
|
|
@@ -185,6 +210,8 @@ class DatePickerComponent {
|
|
|
185
210
|
this.showCalendar = false;
|
|
186
211
|
}
|
|
187
212
|
setToStartOfDay() {
|
|
213
|
+
if (!this.tempSelectedDate)
|
|
214
|
+
return;
|
|
188
215
|
this.selectedHour = '00';
|
|
189
216
|
this.selectedMinute = '00';
|
|
190
217
|
this.tempSelectedDate.setHours(0, 0, 0, 0);
|
|
@@ -192,6 +219,8 @@ class DatePickerComponent {
|
|
|
192
219
|
this.selectedDate = new Date(this.tempSelectedDate);
|
|
193
220
|
}
|
|
194
221
|
setToEndOfDay() {
|
|
222
|
+
if (!this.tempSelectedDate)
|
|
223
|
+
return;
|
|
195
224
|
this.selectedHour = '23';
|
|
196
225
|
this.selectedMinute = '59';
|
|
197
226
|
this.tempSelectedDate.setHours(23, 59, 59, 999);
|
|
@@ -223,6 +252,8 @@ class DatePickerComponent {
|
|
|
223
252
|
this.updateTempSelectedDate();
|
|
224
253
|
}
|
|
225
254
|
updateTempSelectedDate() {
|
|
255
|
+
if (!this.tempSelectedDate)
|
|
256
|
+
return;
|
|
226
257
|
this.tempSelectedDate.setMonth(this.selectedMonth);
|
|
227
258
|
this.tempSelectedDate.setFullYear(this.selectedYear);
|
|
228
259
|
}
|
|
@@ -264,6 +295,8 @@ class DatePickerComponent {
|
|
|
264
295
|
}
|
|
265
296
|
is24Hour = true;
|
|
266
297
|
selectTemporaryDate(day) {
|
|
298
|
+
if (!this.tempSelectedDate)
|
|
299
|
+
this.tempSelectedDate = new Date(day);
|
|
267
300
|
if (this.isDisabled(day))
|
|
268
301
|
return;
|
|
269
302
|
const isNewDate = !this.isSameDate(this.tempSelectedDate, day);
|
|
@@ -289,6 +322,8 @@ class DatePickerComponent {
|
|
|
289
322
|
}
|
|
290
323
|
}
|
|
291
324
|
isSelected(day) {
|
|
325
|
+
if (!this.tempSelectedDate)
|
|
326
|
+
return false;
|
|
292
327
|
return (day.getDate() === this.tempSelectedDate.getDate() &&
|
|
293
328
|
day.getMonth() === this.tempSelectedDate.getMonth() &&
|
|
294
329
|
day.getFullYear() === this.tempSelectedDate.getFullYear());
|
|
@@ -309,13 +344,13 @@ class DatePickerComponent {
|
|
|
309
344
|
this.showCalendar = false;
|
|
310
345
|
}
|
|
311
346
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: DatePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
312
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.10", type: DatePickerComponent, selector: "app-date-picker", inputs: { placeholder: "placeholder", format: "format", minDate: "minDate", maxDate: "maxDate", disabled: "disabled", bgColor: "bgColor", border: "border", useDropdowns: "useDropdowns", yearPlaceholder: "yearPlaceholder", monthPlaceholder: "monthPlaceholder", date: "date", showTime: "showTime", datePickerWidth: "datePickerWidth" }, outputs: { dateChange: "dateChange" }, providers: [
|
|
347
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.10", type: DatePickerComponent, selector: "app-date-picker", inputs: { placeholder: "placeholder", format: "format", minDate: "minDate", maxDate: "maxDate", disabled: "disabled", bgColor: "bgColor", border: "border", useDropdowns: "useDropdowns", yearPlaceholder: "yearPlaceholder", monthPlaceholder: "monthPlaceholder", date: "date", showTime: "showTime", datePickerWidth: "datePickerWidth", useDefaultDate: "useDefaultDate" }, outputs: { dateChange: "dateChange" }, providers: [
|
|
313
348
|
{
|
|
314
349
|
provide: NG_VALUE_ACCESSOR,
|
|
315
350
|
useExisting: forwardRef(() => DatePickerComponent),
|
|
316
351
|
multi: true,
|
|
317
352
|
},
|
|
318
|
-
], usesOnChanges: true, ngImport: i0, template: "<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n</div>\n\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n", styles: [".date-picker{position:relative;width:100%}.calendar-container{position:relative}.icon{position:absolute;top:5px;right:10px;cursor:pointer}input{width:100%;padding:10px;font-size:13px;border:1px solid #ccc;border-radius:4px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed;color:#8080808f}.calendar{position:absolute;top:100%;left:0;border:1px solid #ccc;background-color:#fff;z-index:10;border-radius:4px}.calendar-header{display:flex;justify-content:center;gap:5px;align-items:center;font-size:13px;padding:15px 15px 0}.weekdays,.dates{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px;padding:15px 15px 0;font-size:13px}button{border:none;background:none;cursor:pointer;padding:5px;width:40px;height:40px}button.selected{background-color:#ffe681;color:#000;border-radius:30px}.calendar-footer{display:flex;justify-content:end;gap:10px;padding:4px 15px;color:#000;font-weight:500;font-size:13px}.calendar-footer button{color:#000}.disabled-day{opacity:.4;cursor:not-allowed}.time-picker input{border:1px solid #ccc;border-radius:4px;padding:4px 6px;text-align:center;width:50px;outline:none;height:40px}.time-picker button{border:1px solid #ccc;border-radius:4px;background-color:#f3f3f3;font-size:10px;width:fit-content;height:30px;cursor:pointer}.box{border:1px solid #ccc}::ng-deep .drop-down .verben-drop-down,::ng-deep .drop-down *{font-size:13px!important}.dropdown{position:absolute;top:110%;left:0;width:60px;max-height:120px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:20}.dropdown-item{padding:6px;text-align:center;cursor:pointer}.dropdown-item:hover,.dropdown-item.active{background:#3182ce;color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.SvgComponent, selector: "verben-svg", inputs: ["icon", "width", "height", "fill", "stroke", "type", "size"] }, { kind: "component", type: i4.DropDownComponent, selector: "verben-drop-down", inputs: ["options", "width", "showHorizontalLine", "horizontalLineColor", "optionLabel", "optionSubLabel", "optionValue", "placeholder", "invalidMessage", "errorPosition", "loadMoreCaption", "display", "showClear", "lazyLoad", "selectKey", "styleClass", "group", "multiselect", "filter", "avoidDuplication", "filterBy", "debounceTime", "minChar", "disabled", "required", "load", "asyncLabel", "search"], outputs: ["optionsChange", "onChange", "onClick", "onClear"] }, { kind: "directive", type: i5.OutSideClickDirective, selector: "[appOutSideClick]", inputs: ["appOutSideClick"], outputs: ["outSideClick"] }, { kind: "component", type: i6.TooltipComponent, selector: "verben-tooltip", inputs: ["tooltipContent", "customClass", "backgroundColor", "textColor", "padding", "borderRadius", "zIndex", "border", "width", "top", "bottom", "left", "right"] }] });
|
|
353
|
+
], usesOnChanges: true, ngImport: i0, template: "<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n\n</div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"clearTooltip\"\n #clearDateTip\n >\n <verben-svg\n (click)=\"clearDate()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'close'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #clearTooltip>\n <div>\n <p class=\"text-xs\">clear date</p>\n </div>\n </ng-template>\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n", styles: [".date-picker{position:relative;width:100%}.calendar-container{position:relative}.icon{position:absolute;top:5px;right:10px;cursor:pointer}input{width:100%;padding:10px;font-size:13px;border:1px solid #ccc;border-radius:4px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed;color:#8080808f}.calendar{position:absolute;top:100%;left:0;border:1px solid #ccc;background-color:#fff;z-index:10;border-radius:4px}.calendar-header{display:flex;justify-content:center;gap:5px;align-items:center;font-size:13px;padding:15px 15px 0}.weekdays,.dates{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px;padding:15px 15px 0;font-size:13px}button{border:none;background:none;cursor:pointer;padding:5px;width:40px;height:40px}button.selected{background-color:#ffe681;color:#000;border-radius:30px}.calendar-footer{display:flex;justify-content:end;gap:10px;padding:4px 15px;color:#000;font-weight:500;font-size:13px}.calendar-footer button{color:#000}.disabled-day{opacity:.4;cursor:not-allowed}.time-picker input{border:1px solid #ccc;border-radius:4px;padding:4px 6px;text-align:center;width:50px;outline:none;height:40px}.time-picker button{border:1px solid #ccc;border-radius:4px;background-color:#f3f3f3;font-size:10px;width:fit-content;height:30px;cursor:pointer}.box{border:1px solid #ccc}::ng-deep .drop-down .verben-drop-down,::ng-deep .drop-down *{font-size:13px!important}.dropdown{position:absolute;top:110%;left:0;width:60px;max-height:120px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:20}.dropdown-item{padding:6px;text-align:center;cursor:pointer}.dropdown-item:hover,.dropdown-item.active{background:#3182ce;color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.SvgComponent, selector: "verben-svg", inputs: ["icon", "width", "height", "fill", "stroke", "type", "size"] }, { kind: "component", type: i4.DropDownComponent, selector: "verben-drop-down", inputs: ["options", "width", "showHorizontalLine", "horizontalLineColor", "optionLabel", "optionSubLabel", "optionValue", "placeholder", "invalidMessage", "errorPosition", "loadMoreCaption", "display", "showClear", "lazyLoad", "selectKey", "styleClass", "group", "multiselect", "filter", "avoidDuplication", "filterBy", "debounceTime", "minChar", "disabled", "required", "load", "asyncLabel", "search"], outputs: ["optionsChange", "onChange", "onClick", "onClear"] }, { kind: "directive", type: i5.OutSideClickDirective, selector: "[appOutSideClick]", inputs: ["appOutSideClick"], outputs: ["outSideClick"] }, { kind: "component", type: i6.TooltipComponent, selector: "verben-tooltip", inputs: ["tooltipContent", "customClass", "backgroundColor", "textColor", "padding", "borderRadius", "zIndex", "border", "width", "top", "bottom", "left", "right"] }] });
|
|
319
354
|
}
|
|
320
355
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: DatePickerComponent, decorators: [{
|
|
321
356
|
type: Component,
|
|
@@ -325,7 +360,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
|
|
|
325
360
|
useExisting: forwardRef(() => DatePickerComponent),
|
|
326
361
|
multi: true,
|
|
327
362
|
},
|
|
328
|
-
], template: "<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n</div>\n\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n", styles: [".date-picker{position:relative;width:100%}.calendar-container{position:relative}.icon{position:absolute;top:5px;right:10px;cursor:pointer}input{width:100%;padding:10px;font-size:13px;border:1px solid #ccc;border-radius:4px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed;color:#8080808f}.calendar{position:absolute;top:100%;left:0;border:1px solid #ccc;background-color:#fff;z-index:10;border-radius:4px}.calendar-header{display:flex;justify-content:center;gap:5px;align-items:center;font-size:13px;padding:15px 15px 0}.weekdays,.dates{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px;padding:15px 15px 0;font-size:13px}button{border:none;background:none;cursor:pointer;padding:5px;width:40px;height:40px}button.selected{background-color:#ffe681;color:#000;border-radius:30px}.calendar-footer{display:flex;justify-content:end;gap:10px;padding:4px 15px;color:#000;font-weight:500;font-size:13px}.calendar-footer button{color:#000}.disabled-day{opacity:.4;cursor:not-allowed}.time-picker input{border:1px solid #ccc;border-radius:4px;padding:4px 6px;text-align:center;width:50px;outline:none;height:40px}.time-picker button{border:1px solid #ccc;border-radius:4px;background-color:#f3f3f3;font-size:10px;width:fit-content;height:30px;cursor:pointer}.box{border:1px solid #ccc}::ng-deep .drop-down .verben-drop-down,::ng-deep .drop-down *{font-size:13px!important}.dropdown{position:absolute;top:110%;left:0;width:60px;max-height:120px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:20}.dropdown-item{padding:6px;text-align:center;cursor:pointer}.dropdown-item:hover,.dropdown-item.active{background:#3182ce;color:#fff}\n"] }]
|
|
363
|
+
], template: "<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n\n</div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"clearTooltip\"\n #clearDateTip\n >\n <verben-svg\n (click)=\"clearDate()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'close'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #clearTooltip>\n <div>\n <p class=\"text-xs\">clear date</p>\n </div>\n </ng-template>\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n", styles: [".date-picker{position:relative;width:100%}.calendar-container{position:relative}.icon{position:absolute;top:5px;right:10px;cursor:pointer}input{width:100%;padding:10px;font-size:13px;border:1px solid #ccc;border-radius:4px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed;color:#8080808f}.calendar{position:absolute;top:100%;left:0;border:1px solid #ccc;background-color:#fff;z-index:10;border-radius:4px}.calendar-header{display:flex;justify-content:center;gap:5px;align-items:center;font-size:13px;padding:15px 15px 0}.weekdays,.dates{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:1px;padding:15px 15px 0;font-size:13px}button{border:none;background:none;cursor:pointer;padding:5px;width:40px;height:40px}button.selected{background-color:#ffe681;color:#000;border-radius:30px}.calendar-footer{display:flex;justify-content:end;gap:10px;padding:4px 15px;color:#000;font-weight:500;font-size:13px}.calendar-footer button{color:#000}.disabled-day{opacity:.4;cursor:not-allowed}.time-picker input{border:1px solid #ccc;border-radius:4px;padding:4px 6px;text-align:center;width:50px;outline:none;height:40px}.time-picker button{border:1px solid #ccc;border-radius:4px;background-color:#f3f3f3;font-size:10px;width:fit-content;height:30px;cursor:pointer}.box{border:1px solid #ccc}::ng-deep .drop-down .verben-drop-down,::ng-deep .drop-down *{font-size:13px!important}.dropdown{position:absolute;top:110%;left:0;width:60px;max-height:120px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:20}.dropdown-item{padding:6px;text-align:center;cursor:pointer}.dropdown-item:hover,.dropdown-item.active{background:#3182ce;color:#fff}\n"] }]
|
|
329
364
|
}], propDecorators: { placeholder: [{
|
|
330
365
|
type: Input
|
|
331
366
|
}], format: [{
|
|
@@ -350,10 +385,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
|
|
|
350
385
|
type: Input
|
|
351
386
|
}], showTime: [{
|
|
352
387
|
type: Input
|
|
353
|
-
}], dateChange: [{
|
|
354
|
-
type: Output
|
|
355
388
|
}], datePickerWidth: [{
|
|
356
389
|
type: Input
|
|
390
|
+
}], useDefaultDate: [{
|
|
391
|
+
type: Input
|
|
392
|
+
}], dateChange: [{
|
|
393
|
+
type: Output
|
|
357
394
|
}] } });
|
|
358
395
|
|
|
359
396
|
class DatePickerModule {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"verben-ng-ui-src-lib-components-date-picker.mjs","sources":["../../../projects/verben-ng-ui/src/lib/components/date-picker/date-picker.component.ts","../../../projects/verben-ng-ui/src/lib/components/date-picker/date-picker.component.html","../../../projects/verben-ng-ui/src/lib/components/date-picker/date-picker.module.ts","../../../projects/verben-ng-ui/src/lib/components/date-picker/verben-ng-ui-src-lib-components-date-picker.ts"],"sourcesContent":["import { Component, EventEmitter, Input, Output, forwardRef } from '@angular/core';\nimport { DropdownChangeEvent } from 'verben-ng-ui/src/lib/components/drop-down';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n selector: 'app-date-picker',\n templateUrl: './date-picker.component.html',\n styleUrls: ['./date-picker.component.css'],\n providers: [\n {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => DatePickerComponent),\n multi: true,\n },\n ],\n})\nexport class DatePickerComponent implements ControlValueAccessor {\n @Input() placeholder = 'Select date';\n @Input() format = 'MM/DD/YYYY';\n @Input() minDate?: Date;\n @Input() maxDate?: Date;\n @Input() disabled?: boolean = false;\n @Input() bgColor?: string = '#fff';\n @Input() border?: string = '';\n @Input() useDropdowns: boolean = true;\n @Input() yearPlaceholder: string = 'Select a year';\n @Input() monthPlaceholder: string = 'Select a month';\n @Input() date: Date | null | string = null;\n @Input() showTime: boolean = false;\n @Output() dateChange = new EventEmitter<Date>();\n\n yearRange: number[] = [];\n filteredYearRange: number[] = [];\n selectedDate: Date = new Date();\n tempSelectedDate: Date = new Date();\n showCalendar = false;\n @Input() datePickerWidth:string='400px'\n weekDays = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'];\n months = [\n 'January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December',\n ];\n\n selectedMonth: number = 1;\n selectedMonthString: string = '';\n selectedYear: number = new Date().getFullYear();\n\n private onChange: any = () => {};\n private onTouched: any = () => {};\nwriteValue(value: Date | string | null): void {\n if (value) {\n if (typeof value === 'string') {\n value = this.sanitizeDateString(value);\n }\n\n const parsedDate = typeof value === 'string' ? new Date(value) : value;\n this.date = parsedDate;\n\n this.selectedDate = new Date(parsedDate);\n this.tempSelectedDate = new Date(parsedDate);\n this.selectedMonth = this.selectedDate.getMonth();\n this.selectedYear = this.selectedDate.getFullYear();\n\n if (this.showTime) {\n this.initTimeFromDate(this.selectedDate);\n }\n }\n}\n\n\n registerOnChange(fn: any): void {\n this.onChange = fn;\n }\n\n registerOnTouched(fn: any): void {\n this.onTouched = fn;\n }\n\n setDisabledState?(isDisabled: boolean): void {\n this.disabled = isDisabled;\n }\n\nngOnChanges() {\n if (this.date) {\n let d = this.date;\n if (typeof d === 'string') d = this.sanitizeDateString(d);\n\n const parsedDate = new Date(d);\n this.selectedDate = new Date(parsedDate);\n this.tempSelectedDate = new Date(parsedDate);\n this.selectedMonth = this.selectedDate.getMonth();\n this.selectedYear = this.selectedDate.getFullYear();\n \n \n }\n}\n\n\n isSameDate(d1: Date, d2: Date): boolean {\n return (\n d1.getFullYear() === d2.getFullYear() &&\n d1.getMonth() === d2.getMonth() &&\n d1.getDate() === d2.getDate()\n );\n }\n\n ngOnInit() {\n const currentYear = new Date().getFullYear();\n const endYear = currentYear + 10;\n this.yearRange = Array.from(\n { length: endYear - 1960 + 1 },\n (_, i) => 1960 + i\n );\n this.yearRange.sort((a, b) => b - a);\n\n if (!this.date) {\n const now = new Date();\n const pad = (n: number) => n.toString().padStart(2, '0');\n\n const localDateString = `${now.getFullYear()}-${pad(\n now.getMonth() + 1\n )}-${pad(now.getDate())}T${pad(now.getHours())}:${pad(\n now.getMinutes()\n )}:${pad(now.getSeconds())}`;\n\n this.selectedDate = new Date(localDateString);\n this.tempSelectedDate = new Date(localDateString);\n this.date = this.selectedDate;\n\n if (this.showTime) {\n const hours = now.getHours();\n const minutes = now.getMinutes();\n\n this.selectedHour = hours.toString().padStart(2, '0');\n this.selectedMinute = minutes.toString().padStart(2, '0');\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n }\n\n this.dateChange.emit(this.selectedDate);\n this.onChange(localDateString);\n }\n }\n\n get displayDate(): string {\n const parsedDate =\n typeof this.date === 'string' ? new Date(this.date) : this.date;\n return parsedDate ? this.formatDate(parsedDate, this.format) : '';\n }\n\n tempTime: string = '';\n selectedHour = '00';\n selectedMinute = '00';\n\n showHourOptions = false;\n showMinuteOptions = false;\n\n hours = Array.from({ length: 24 }, (_, i) => String(i).padStart(2, '0'));\n minutes = Array.from({ length: 60 }, (_, i) => String(i).padStart(2, '0'));\n\n toggleHourDropdown() {\n this.showHourOptions = !this.showHourOptions;\n this.showMinuteOptions = false;\n }\n\n toggleMinuteDropdown() {\n this.showMinuteOptions = !this.showMinuteOptions;\n this.showHourOptions = false;\n }\n\n selectHour(h: string) {\n this.selectedHour = h;\n this.showHourOptions = false;\n }\n\n selectMinute(m: string) {\n this.selectedMinute = m;\n this.showMinuteOptions = false;\n }\n\n toggleCalendar() {\n this.showCalendar = !this.showCalendar;\n\n this.tempSelectedDate = new Date(this.date || new Date());\n this.selectedMonth = this.tempSelectedDate.getMonth();\n this.selectedMonthString = this.months[this.selectedMonth];\n this.selectedYear = this.tempSelectedDate.getFullYear();\n\n if (this.showTime && !this.tempTime) {\n const today = new Date();\n const isToday = this.isSameDate(this.tempSelectedDate, today);\n\n const hours = isToday ? today.getHours() : 0;\n const minutes = isToday ? today.getMinutes() : 0;\n\n this.tempSelectedDate.setHours(hours, minutes, 0, 0);\n this.selectedHour = hours.toString().padStart(2, '0');\n this.selectedMinute = minutes.toString().padStart(2, '0');\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n }\n }\n\n initTimeFromDate(date: Date) {\n const hours = date.getHours();\n const minutes = date.getMinutes();\n\n this.selectedHour = hours.toString().padStart(2, '0');\n this.selectedMinute = minutes.toString().padStart(2, '0');\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n this.tempSelectedDate.setHours(hours, minutes, 0, 0);\n }\n\n fixToUTC(dateValue: any) {\n if (!dateValue) return null;\n\n const date = dateValue instanceof Date ? dateValue : new Date(dateValue);\n if (isNaN(date.getTime())) return null;\n\n return new Date(\n Date.UTC(\n date.getFullYear(),\n date.getMonth(),\n date.getDate(),\n date.getHours(),\n date.getMinutes(),\n date.getSeconds(),\n date.getMilliseconds()\n )\n );\n }\n\n confirm() {\n if (this.isDisabled(this.tempSelectedDate)) return;\n\n const hours = Number(this.selectedHour);\n const minutes = Number(this.selectedMinute);\n\n this.tempSelectedDate.setHours(hours, minutes, 0, 0);\n\n this.selectedDate = new Date(this.tempSelectedDate);\n this.date = this.selectedDate;\n\n const pad = (n: number) => n.toString().padStart(2, '0');\n const localDateString = `${this.selectedDate.getFullYear()}-${pad(\n this.selectedDate.getMonth() + 1\n )}-${pad(this.selectedDate.getDate())}T${pad(\n this.selectedDate.getHours()\n )}:${pad(this.selectedDate.getMinutes())}:${pad(\n this.selectedDate.getSeconds()\n )}`;\n\n \n\n this.dateChange.emit(this.selectedDate);\n this.onChange(localDateString);\n this.onTouched();\n\n this.showCalendar = false;\n }\n\n setToStartOfDay() {\n this.selectedHour = '00';\n this.selectedMinute = '00';\n\n this.tempSelectedDate.setHours(0, 0, 0, 0);\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n\n this.selectedDate = new Date(this.tempSelectedDate);\n }\nsetToEndOfDay() {\n this.selectedHour = '23';\n this.selectedMinute = '59';\n\n this.tempSelectedDate.setHours(23, 59, 59, 999);\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n\n this.selectedDate = new Date(this.tempSelectedDate);\n}\n\n previousMonth() {\n this.selectedMonth--;\n if (this.selectedMonth < 0) {\n this.selectedMonth = 11;\n this.selectedYear--;\n }\n this.updateTempSelectedDate();\n }\n\n nextMonth() {\n this.selectedMonth++;\n if (this.selectedMonth > 11) {\n this.selectedMonth = 0;\n this.selectedYear++;\n }\n this.updateTempSelectedDate();\n }\n\n onDropdownYearChange(event: DropdownChangeEvent): void {\n this.selectedYear = event.value;\n this.updateTempSelectedDate();\n }\n\n onDropdownMonthChange(event: DropdownChangeEvent): void {\n this.selectedMonth = this.months.indexOf(event.value);\n this.updateTempSelectedDate();\n }\n\n updateTempSelectedDate() {\n this.tempSelectedDate.setMonth(this.selectedMonth);\n this.tempSelectedDate.setFullYear(this.selectedYear);\n }\n\n getDaysInMonth(): (Date | null)[] {\n const days: (Date | null)[] = [];\n const year = this.selectedYear;\n const month = this.selectedMonth;\n\n const firstDayOfMonth = new Date(year, month, 1).getDay();\n const offset = firstDayOfMonth === 0 ? 6 : firstDayOfMonth - 1;\n\n for (let i = 0; i < offset; i++) {\n days.push(null);\n }\n\n const totalDays = new Date(year, month + 1, 0).getDate();\n for (let i = 1; i <= totalDays; i++) {\n const day = new Date(year, month, i);\n days.push(day);\n }\n return days;\n }\n sanitizeDateString(value: string): string {\n return value?.endsWith('Z') ? value.slice(0, -1) : value;\n}\n\n isDisabled(day: Date | string): boolean {\n const dayDate = this.toDate(day);\n\n if (this.minDate && dayDate < this.stripTime(this.toDate(this.minDate)))\n return true;\n if (this.maxDate && dayDate > this.stripTime(this.toDate(this.maxDate)))\n return true;\n\n return false;\n }\n\n private stripTime(date: Date | string): Date {\n const d = this.toDate(date);\n return new Date(d.getFullYear(), d.getMonth(), d.getDate());\n }\n\n toDate(value: Date | string): Date {\n if (value instanceof Date) return value;\n return new Date(this.sanitizeDateString(value));\n}\n\n\n is24Hour: boolean = true;\n\n selectTemporaryDate(day: Date) {\n if (this.isDisabled(day)) return;\n\n const isNewDate = !this.isSameDate(this.tempSelectedDate, day);\n this.tempSelectedDate = new Date(day);\n\n if (this.showTime) {\n if (isNewDate) {\n const today = new Date();\n const isToday =\n day.getFullYear() === today.getFullYear() &&\n day.getMonth() === today.getMonth() &&\n day.getDate() === today.getDate();\n\n const hours = isToday ? today.getHours() : 0;\n const minutes = isToday ? today.getMinutes() : 0;\n\n this.tempSelectedDate.setHours(hours, minutes, 0, 0);\n\n this.selectedHour = hours.toString().padStart(2, '0');\n this.selectedMinute = minutes.toString().padStart(2, '0');\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n } else {\n const [h, m] = this.tempTime.split(':');\n this.selectedHour = h;\n this.selectedMinute = m;\n }\n }\n }\n\n isSelected(day: Date): boolean {\n return (\n day.getDate() === this.tempSelectedDate.getDate() &&\n day.getMonth() === this.tempSelectedDate.getMonth() &&\n day.getFullYear() === this.tempSelectedDate.getFullYear()\n );\n }\n\n formatDate(date: Date, format: string): string {\n const day = date.getDate().toString().padStart(2, '0');\n const month = (date.getMonth() + 1).toString().padStart(2, '0');\n const year = date.getFullYear();\n\n switch (format) {\n case 'DD/MM/YYYY':\n return `${day}/${month}/${year}`;\n case 'MM/DD/YYYY':\n default:\n return `${month}/${day}/${year}`;\n }\n }\n\n cancel() {\n this.showCalendar = false;\n }\n}\n","<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n</div>\n\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n","import { NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { DatePickerComponent } from './date-picker.component';\nimport { SvgModule } from 'verben-ng-ui/src/lib/components/svg';\nimport { DropDownModule } from 'verben-ng-ui/src/lib/components/drop-down';\nimport { VerbenPopUpModule } from 'verben-ng-ui/src/lib/components/pop-up';\nimport { OutSideClickDirective } from 'verben-ng-ui/src/lib/components/data-view';\nimport { TooltipModule } from 'verben-ng-ui/src/lib/components/tooltip';\n@NgModule({\n declarations: [DatePickerComponent],\n imports: [\n FormsModule,\n CommonModule,\n SvgModule,\n DropDownModule,\n VerbenPopUpModule,\n OutSideClickDirective,\n TooltipModule\n ],\n exports: [DatePickerComponent],\n})\nexport class DatePickerModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;MAgBa,mBAAmB,CAAA;IACrB,WAAW,GAAG,aAAa,CAAC;IAC5B,MAAM,GAAG,YAAY,CAAC;AACtB,IAAA,OAAO,CAAQ;AACf,IAAA,OAAO,CAAQ;IACf,QAAQ,GAAa,KAAK,CAAC;IAC3B,OAAO,GAAY,MAAM,CAAC;IAC1B,MAAM,GAAY,EAAE,CAAC;IACrB,YAAY,GAAY,IAAI,CAAC;IAC7B,eAAe,GAAW,eAAe,CAAC;IAC1C,gBAAgB,GAAW,gBAAgB,CAAC;IAC5C,IAAI,GAAyB,IAAI,CAAC;IAClC,QAAQ,GAAY,KAAK,CAAC;AACzB,IAAA,UAAU,GAAG,IAAI,YAAY,EAAQ,CAAC;IAEhD,SAAS,GAAa,EAAE,CAAC;IACzB,iBAAiB,GAAa,EAAE,CAAC;AACjC,IAAA,YAAY,GAAS,IAAI,IAAI,EAAE,CAAC;AAChC,IAAA,gBAAgB,GAAS,IAAI,IAAI,EAAE,CAAC;IACpC,YAAY,GAAG,KAAK,CAAC;IACb,eAAe,GAAQ,OAAO,CAAA;AACtC,IAAA,QAAQ,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;AAC7D,IAAA,MAAM,GAAG;QACP,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM;QACtD,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU;KACjE,CAAC;IAEF,aAAa,GAAW,CAAC,CAAC;IAC1B,mBAAmB,GAAW,EAAE,CAAC;AACjC,IAAA,YAAY,GAAW,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;AAExC,IAAA,QAAQ,GAAQ,MAAK,GAAG,CAAC;AACzB,IAAA,SAAS,GAAQ,MAAK,GAAG,CAAC;AACpC,IAAA,UAAU,CAAC,KAA2B,EAAA;QACpC,IAAI,KAAK,EAAE;AACT,YAAA,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;AAC7B,gBAAA,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;aACxC;AAED,YAAA,MAAM,UAAU,GAAG,OAAO,KAAK,KAAK,QAAQ,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;AACvE,YAAA,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;YAEvB,IAAI,CAAC,YAAY,GAAG,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC;YACzC,IAAI,CAAC,gBAAgB,GAAG,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC;YAC7C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;YAClD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;AAEpD,YAAA,IAAI,IAAI,CAAC,QAAQ,EAAE;AACjB,gBAAA,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAC1C;SACF;KACF;AAGC,IAAA,gBAAgB,CAAC,EAAO,EAAA;AACtB,QAAA,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;KACpB;AAED,IAAA,iBAAiB,CAAC,EAAO,EAAA;AACvB,QAAA,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;KACrB;AAED,IAAA,gBAAgB,CAAE,UAAmB,EAAA;AACnC,QAAA,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;KAC5B;IAEH,WAAW,GAAA;AACT,QAAA,IAAI,IAAI,CAAC,IAAI,EAAE;AACb,YAAA,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;YAClB,IAAI,OAAO,CAAC,KAAK,QAAQ;AAAE,gBAAA,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;AAE1D,YAAA,MAAM,UAAU,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;YAC/B,IAAI,CAAC,YAAY,GAAG,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC;YACzC,IAAI,CAAC,gBAAgB,GAAG,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC;YAC7C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;YAClD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;SAGrD;KACF;IAGC,UAAU,CAAC,EAAQ,EAAE,EAAQ,EAAA;QAC3B,QACE,EAAE,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC,WAAW,EAAE;AACrC,YAAA,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC,QAAQ,EAAE;YAC/B,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC,OAAO,EAAE,EAC7B;KACH;IAED,QAAQ,GAAA;QACN,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;AAC7C,QAAA,MAAM,OAAO,GAAG,WAAW,GAAG,EAAE,CAAC;AACjC,QAAA,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,IAAI,CACzB,EAAE,MAAM,EAAE,OAAO,GAAG,IAAI,GAAG,CAAC,EAAE,EAC9B,CAAC,CAAC,EAAE,CAAC,KAAK,IAAI,GAAG,CAAC,CACnB,CAAC;AACF,QAAA,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;AAErC,QAAA,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;AACd,YAAA,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;AACvB,YAAA,MAAM,GAAG,GAAG,CAAC,CAAS,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;YAEzD,MAAM,eAAe,GAAG,CAAG,EAAA,GAAG,CAAC,WAAW,EAAE,CAAI,CAAA,EAAA,GAAG,CACjD,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,CACnB,CAAA,CAAA,EAAI,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAA,CAAA,EAAI,GAAG,CACnD,GAAG,CAAC,UAAU,EAAE,CACjB,CAAI,CAAA,EAAA,GAAG,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,CAAA,CAAE,CAAC;YAE7B,IAAI,CAAC,YAAY,GAAG,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC;YAC9C,IAAI,CAAC,gBAAgB,GAAG,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC;AAClD,YAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC;AAE9B,YAAA,IAAI,IAAI,CAAC,QAAQ,EAAE;AACjB,gBAAA,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,EAAE,CAAC;AAC7B,gBAAA,MAAM,OAAO,GAAG,GAAG,CAAC,UAAU,EAAE,CAAC;AAEjC,gBAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AACtD,gBAAA,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC1D,gBAAA,IAAI,CAAC,QAAQ,GAAG,CAAA,EAAG,IAAI,CAAC,YAAY,CAAA,CAAA,EAAI,IAAI,CAAC,cAAc,CAAA,CAAE,CAAC;aAC/D;YAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AACxC,YAAA,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;SAChC;KACF;AAED,IAAA,IAAI,WAAW,GAAA;QACb,MAAM,UAAU,GACd,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;AAClE,QAAA,OAAO,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;KACnE;IAED,QAAQ,GAAW,EAAE,CAAC;IACtB,YAAY,GAAG,IAAI,CAAC;IACpB,cAAc,GAAG,IAAI,CAAC;IAEtB,eAAe,GAAG,KAAK,CAAC;IACxB,iBAAiB,GAAG,KAAK,CAAC;AAE1B,IAAA,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AACzE,IAAA,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;IAE3E,kBAAkB,GAAA;AAChB,QAAA,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;AAC7C,QAAA,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;KAChC;IAED,oBAAoB,GAAA;AAClB,QAAA,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;AACjD,QAAA,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;KAC9B;AAED,IAAA,UAAU,CAAC,CAAS,EAAA;AAClB,QAAA,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;AACtB,QAAA,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;KAC9B;AAED,IAAA,YAAY,CAAC,CAAS,EAAA;AACpB,QAAA,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;KAChC;IAED,cAAc,GAAA;AACZ,QAAA,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;AAEvC,QAAA,IAAI,CAAC,gBAAgB,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC;QAC1D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;QACtD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC3D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC;QAExD,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;AACnC,YAAA,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;AACzB,YAAA,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;AAE9D,YAAA,MAAM,KAAK,GAAG,OAAO,GAAG,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;AAC7C,YAAA,MAAM,OAAO,GAAG,OAAO,GAAG,KAAK,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;AAEjD,YAAA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACrD,YAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AACtD,YAAA,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC1D,YAAA,IAAI,CAAC,QAAQ,GAAG,CAAA,EAAG,IAAI,CAAC,YAAY,CAAA,CAAA,EAAI,IAAI,CAAC,cAAc,CAAA,CAAE,CAAC;SAC/D;KACF;AAED,IAAA,gBAAgB,CAAC,IAAU,EAAA;AACzB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;AAC9B,QAAA,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;AAElC,QAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AACtD,QAAA,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC1D,QAAA,IAAI,CAAC,QAAQ,GAAG,CAAA,EAAG,IAAI,CAAC,YAAY,CAAA,CAAA,EAAI,IAAI,CAAC,cAAc,CAAA,CAAE,CAAC;AAC9D,QAAA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;KACtD;AAED,IAAA,QAAQ,CAAC,SAAc,EAAA;AACrB,QAAA,IAAI,CAAC,SAAS;AAAE,YAAA,OAAO,IAAI,CAAC;AAE5B,QAAA,MAAM,IAAI,GAAG,SAAS,YAAY,IAAI,GAAG,SAAS,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC;AACzE,QAAA,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;AAAE,YAAA,OAAO,IAAI,CAAC;AAEvC,QAAA,OAAO,IAAI,IAAI,CACb,IAAI,CAAC,GAAG,CACN,IAAI,CAAC,WAAW,EAAE,EAClB,IAAI,CAAC,QAAQ,EAAE,EACf,IAAI,CAAC,OAAO,EAAE,EACd,IAAI,CAAC,QAAQ,EAAE,EACf,IAAI,CAAC,UAAU,EAAE,EACjB,IAAI,CAAC,UAAU,EAAE,EACjB,IAAI,CAAC,eAAe,EAAE,CACvB,CACF,CAAC;KACH;IAED,OAAO,GAAA;AACL,QAAA,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC;YAAE,OAAO;QAEnD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACxC,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;AAE5C,QAAA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAErD,IAAI,CAAC,YAAY,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;AACpD,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC;AAE9B,QAAA,MAAM,GAAG,GAAG,CAAC,CAAS,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AACzD,QAAA,MAAM,eAAe,GAAG,CAAG,EAAA,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAA,CAAA,EAAI,GAAG,CAC/D,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,CACjC,CAAA,CAAA,EAAI,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,CAAI,CAAA,EAAA,GAAG,CAC1C,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAC7B,CAAI,CAAA,EAAA,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC,CAAI,CAAA,EAAA,GAAG,CAC7C,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAC/B,EAAE,CAAC;QAIJ,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AACxC,QAAA,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;QAC/B,IAAI,CAAC,SAAS,EAAE,CAAC;AAEjB,QAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;KAC3B;IAED,eAAe,GAAA;AACb,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;AACzB,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;AAE3B,QAAA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC3C,QAAA,IAAI,CAAC,QAAQ,GAAG,CAAA,EAAG,IAAI,CAAC,YAAY,CAAA,CAAA,EAAI,IAAI,CAAC,cAAc,CAAA,CAAE,CAAC;QAE9D,IAAI,CAAC,YAAY,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;KACrD;IACH,aAAa,GAAA;AACX,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;AACzB,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;AAE3B,QAAA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;AAChD,QAAA,IAAI,CAAC,QAAQ,GAAG,CAAA,EAAG,IAAI,CAAC,YAAY,CAAA,CAAA,EAAI,IAAI,CAAC,cAAc,CAAA,CAAE,CAAC;QAE9D,IAAI,CAAC,YAAY,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;KACrD;IAEC,aAAa,GAAA;QACX,IAAI,CAAC,aAAa,EAAE,CAAC;AACrB,QAAA,IAAI,IAAI,CAAC,aAAa,GAAG,CAAC,EAAE;AAC1B,YAAA,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;QACD,IAAI,CAAC,sBAAsB,EAAE,CAAC;KAC/B;IAED,SAAS,GAAA;QACP,IAAI,CAAC,aAAa,EAAE,CAAC;AACrB,QAAA,IAAI,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE;AAC3B,YAAA,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;YACvB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;QACD,IAAI,CAAC,sBAAsB,EAAE,CAAC;KAC/B;AAED,IAAA,oBAAoB,CAAC,KAA0B,EAAA;AAC7C,QAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC;QAChC,IAAI,CAAC,sBAAsB,EAAE,CAAC;KAC/B;AAED,IAAA,qBAAqB,CAAC,KAA0B,EAAA;AAC9C,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACtD,IAAI,CAAC,sBAAsB,EAAE,CAAC;KAC/B;IAED,sBAAsB,GAAA;QACpB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACnD,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;KACtD;IAED,cAAc,GAAA;QACZ,MAAM,IAAI,GAAoB,EAAE,CAAC;AACjC,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC;AAC/B,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;AAEjC,QAAA,MAAM,eAAe,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;AAC1D,QAAA,MAAM,MAAM,GAAG,eAAe,KAAK,CAAC,GAAG,CAAC,GAAG,eAAe,GAAG,CAAC,CAAC;AAE/D,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE;AAC/B,YAAA,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACjB;AAED,QAAA,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;AACzD,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,SAAS,EAAE,CAAC,EAAE,EAAE;YACnC,MAAM,GAAG,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;AACrC,YAAA,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAChB;AACD,QAAA,OAAO,IAAI,CAAC;KACb;AACF,IAAA,kBAAkB,CAAC,KAAa,EAAA;QAC/B,OAAO,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;KAC1D;AAEC,IAAA,UAAU,CAAC,GAAkB,EAAA;QAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;AAEjC,QAAA,IAAI,IAAI,CAAC,OAAO,IAAI,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AACrE,YAAA,OAAO,IAAI,CAAC;AACd,QAAA,IAAI,IAAI,CAAC,OAAO,IAAI,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AACrE,YAAA,OAAO,IAAI,CAAC;AAEd,QAAA,OAAO,KAAK,CAAC;KACd;AAEO,IAAA,SAAS,CAAC,IAAmB,EAAA;QACnC,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;AAC5B,QAAA,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;KAC7D;AAEF,IAAA,MAAM,CAAC,KAAoB,EAAA;QAC1B,IAAI,KAAK,YAAY,IAAI;AAAE,YAAA,OAAO,KAAK,CAAC;QACxC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;KACjD;IAGC,QAAQ,GAAY,IAAI,CAAC;AAEzB,IAAA,mBAAmB,CAAC,GAAS,EAAA;AAC3B,QAAA,IAAI,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;YAAE,OAAO;AAEjC,QAAA,MAAM,SAAS,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,gBAAgB,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC;AAEtC,QAAA,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,SAAS,EAAE;AACb,gBAAA,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;gBACzB,MAAM,OAAO,GACX,GAAG,CAAC,WAAW,EAAE,KAAK,KAAK,CAAC,WAAW,EAAE;AACzC,oBAAA,GAAG,CAAC,QAAQ,EAAE,KAAK,KAAK,CAAC,QAAQ,EAAE;oBACnC,GAAG,CAAC,OAAO,EAAE,KAAK,KAAK,CAAC,OAAO,EAAE,CAAC;AAEpC,gBAAA,MAAM,KAAK,GAAG,OAAO,GAAG,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;AAC7C,gBAAA,MAAM,OAAO,GAAG,OAAO,GAAG,KAAK,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;AAEjD,gBAAA,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAErD,gBAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AACtD,gBAAA,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC1D,gBAAA,IAAI,CAAC,QAAQ,GAAG,CAAA,EAAG,IAAI,CAAC,YAAY,CAAA,CAAA,EAAI,IAAI,CAAC,cAAc,CAAA,CAAE,CAAC;aAC/D;iBAAM;AACL,gBAAA,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;AACxC,gBAAA,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;AACtB,gBAAA,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;aACzB;SACF;KACF;AAED,IAAA,UAAU,CAAC,GAAS,EAAA;QAClB,QACE,GAAG,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE;YACjD,GAAG,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE;YACnD,GAAG,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,EACzD;KACH;IAED,UAAU,CAAC,IAAU,EAAE,MAAc,EAAA;AACnC,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACvD,MAAM,KAAK,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAChE,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAEhC,QAAQ,MAAM;AACZ,YAAA,KAAK,YAAY;AACf,gBAAA,OAAO,GAAG,GAAG,CAAA,CAAA,EAAI,KAAK,CAAI,CAAA,EAAA,IAAI,EAAE,CAAC;AACnC,YAAA,KAAK,YAAY,CAAC;AAClB,YAAA;AACE,gBAAA,OAAO,GAAG,KAAK,CAAA,CAAA,EAAI,GAAG,CAAI,CAAA,EAAA,IAAI,EAAE,CAAC;SACpC;KACF;IAED,MAAM,GAAA;AACJ,QAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;KAC3B;wGA5YU,mBAAmB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;AAAnB,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,IAAA,EAAA,mBAAmB,EARnB,QAAA,EAAA,iBAAA,EAAA,MAAA,EAAA,EAAA,WAAA,EAAA,aAAA,EAAA,MAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,OAAA,EAAA,SAAA,EAAA,QAAA,EAAA,UAAA,EAAA,OAAA,EAAA,SAAA,EAAA,MAAA,EAAA,QAAA,EAAA,YAAA,EAAA,cAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,gBAAA,EAAA,kBAAA,EAAA,IAAA,EAAA,MAAA,EAAA,QAAA,EAAA,UAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,EAAA,OAAA,EAAA,EAAA,UAAA,EAAA,YAAA,EAAA,EAAA,SAAA,EAAA;AACT,YAAA;AACE,gBAAA,OAAO,EAAE,iBAAiB;AAC1B,gBAAA,WAAW,EAAE,UAAU,CAAC,MAAM,mBAAmB,CAAC;AAClD,gBAAA,KAAK,EAAE,IAAI;AACZ,aAAA;AACF,SAAA,EAAA,aAAA,EAAA,IAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,ECdH,ivKA2LA,EAAA,MAAA,EAAA,CAAA,osDAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,eAAA,EAAA,QAAA,EAAA,2CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,qDAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,UAAA,EAAA,SAAA,EAAA,gBAAA,CAAA,EAAA,OAAA,EAAA,CAAA,eAAA,CAAA,EAAA,QAAA,EAAA,CAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,WAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,MAAA,EAAA,CAAA,SAAA,EAAA,cAAA,EAAA,eAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,IAAA,EAAA,QAAA,EAAA,QAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,UAAA,EAAA,UAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,YAAA,EAAA,QAAA,EAAA,YAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,OAAA,EAAA,QAAA,EAAA,MAAA,EAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,iBAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,MAAA,EAAA,CAAA,SAAA,EAAA,OAAA,EAAA,oBAAA,EAAA,qBAAA,EAAA,aAAA,EAAA,gBAAA,EAAA,aAAA,EAAA,aAAA,EAAA,gBAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,SAAA,EAAA,WAAA,EAAA,UAAA,EAAA,WAAA,EAAA,YAAA,EAAA,OAAA,EAAA,aAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,UAAA,EAAA,cAAA,EAAA,SAAA,EAAA,UAAA,EAAA,UAAA,EAAA,MAAA,EAAA,YAAA,EAAA,QAAA,CAAA,EAAA,OAAA,EAAA,CAAA,eAAA,EAAA,UAAA,EAAA,SAAA,EAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,qBAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,MAAA,EAAA,CAAA,iBAAA,CAAA,EAAA,OAAA,EAAA,CAAA,cAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,gBAAA,EAAA,QAAA,EAAA,gBAAA,EAAA,MAAA,EAAA,CAAA,gBAAA,EAAA,aAAA,EAAA,iBAAA,EAAA,WAAA,EAAA,SAAA,EAAA,cAAA,EAAA,QAAA,EAAA,QAAA,EAAA,OAAA,EAAA,KAAA,EAAA,QAAA,EAAA,MAAA,EAAA,OAAA,CAAA,EAAA,CAAA,EAAA,CAAA,CAAA;;4FD3Ka,mBAAmB,EAAA,UAAA,EAAA,CAAA;kBAZ/B,SAAS;AACE,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,iBAAiB,EAGhB,SAAA,EAAA;AACT,wBAAA;AACE,4BAAA,OAAO,EAAE,iBAAiB;AAC1B,4BAAA,WAAW,EAAE,UAAU,CAAC,yBAAyB,CAAC;AAClD,4BAAA,KAAK,EAAE,IAAI;AACZ,yBAAA;AACF,qBAAA,EAAA,QAAA,EAAA,ivKAAA,EAAA,MAAA,EAAA,CAAA,osDAAA,CAAA,EAAA,CAAA;8BAGQ,WAAW,EAAA,CAAA;sBAAnB,KAAK;gBACG,MAAM,EAAA,CAAA;sBAAd,KAAK;gBACG,OAAO,EAAA,CAAA;sBAAf,KAAK;gBACG,OAAO,EAAA,CAAA;sBAAf,KAAK;gBACG,QAAQ,EAAA,CAAA;sBAAhB,KAAK;gBACG,OAAO,EAAA,CAAA;sBAAf,KAAK;gBACG,MAAM,EAAA,CAAA;sBAAd,KAAK;gBACG,YAAY,EAAA,CAAA;sBAApB,KAAK;gBACG,eAAe,EAAA,CAAA;sBAAvB,KAAK;gBACG,gBAAgB,EAAA,CAAA;sBAAxB,KAAK;gBACG,IAAI,EAAA,CAAA;sBAAZ,KAAK;gBACG,QAAQ,EAAA,CAAA;sBAAhB,KAAK;gBACI,UAAU,EAAA,CAAA;sBAAnB,MAAM;gBAOC,eAAe,EAAA,CAAA;sBAAvB,KAAK;;;MEdM,gBAAgB,CAAA;wGAAhB,gBAAgB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA,CAAA;yGAAhB,gBAAgB,EAAA,YAAA,EAAA,CAZZ,mBAAmB,CAAA,EAAA,OAAA,EAAA,CAEhC,WAAW;YACX,YAAY;YACZ,SAAS;YACT,cAAc;YACd,iBAAiB;YACjB,qBAAqB;AACrB,YAAA,aAAa,aAEL,mBAAmB,CAAA,EAAA,CAAA,CAAA;AAElB,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,gBAAgB,YAVzB,WAAW;YACX,YAAY;YACZ,SAAS;YACT,cAAc;YACd,iBAAiB;YAEjB,aAAa,CAAA,EAAA,CAAA,CAAA;;4FAIJ,gBAAgB,EAAA,UAAA,EAAA,CAAA;kBAb5B,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;oBACR,YAAY,EAAE,CAAC,mBAAmB,CAAC;AACnC,oBAAA,OAAO,EAAE;wBACP,WAAW;wBACX,YAAY;wBACZ,SAAS;wBACT,cAAc;wBACd,iBAAiB;wBACjB,qBAAqB;wBACrB,aAAa;AACd,qBAAA;oBACD,OAAO,EAAE,CAAC,mBAAmB,CAAC;AAC/B,iBAAA,CAAA;;;ACrBD;;AAEG;;;;"}
|
|
1
|
+
{"version":3,"file":"verben-ng-ui-src-lib-components-date-picker.mjs","sources":["../../../projects/verben-ng-ui/src/lib/components/date-picker/date-picker.component.ts","../../../projects/verben-ng-ui/src/lib/components/date-picker/date-picker.component.html","../../../projects/verben-ng-ui/src/lib/components/date-picker/date-picker.module.ts","../../../projects/verben-ng-ui/src/lib/components/date-picker/verben-ng-ui-src-lib-components-date-picker.ts"],"sourcesContent":["import { Component, EventEmitter, Input, Output, forwardRef } from '@angular/core';\nimport { DropdownChangeEvent } from 'verben-ng-ui/src/lib/components/drop-down';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n selector: 'app-date-picker',\n templateUrl: './date-picker.component.html',\n styleUrls: ['./date-picker.component.css'],\n providers: [\n {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => DatePickerComponent),\n multi: true,\n },\n ],\n})\nexport class DatePickerComponent implements ControlValueAccessor {\n @Input() placeholder = 'Select date';\n @Input() format = 'MM/DD/YYYY';\n @Input() minDate?: Date;\n @Input() maxDate?: Date;\n @Input() disabled?: boolean = false;\n @Input() bgColor?: string = '#fff';\n @Input() border?: string = '';\n @Input() useDropdowns: boolean = true;\n @Input() yearPlaceholder: string = 'Select a year';\n @Input() monthPlaceholder: string = 'Select a month';\n @Input() date: Date | null | string = null;\n @Input() showTime: boolean = false;\n\n @Input() datePickerWidth: string = '400px';\n @Input() useDefaultDate: boolean = false; \n\n @Output() dateChange = new EventEmitter<Date|null>();\n\n yearRange: number[] = [];\n filteredYearRange: number[] = [];\n\n\n selectedDate: Date | null = null;\n tempSelectedDate: Date | null = null;\n\n showCalendar = false;\n\n weekDays = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'];\n months = [\n 'January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December',\n ];\n\n selectedMonth: number = 1;\n selectedMonthString: string = '';\n selectedYear: number = new Date().getFullYear();\n\n private onChange: any = () => {};\n private onTouched: any = () => {};\n\n writeValue(value: Date | string | null): void {\n if (value) {\n if (typeof value === 'string') {\n value = this.sanitizeDateString(value);\n }\n\n const parsedDate = typeof value === 'string' ? new Date(value) : value;\n this.date = parsedDate;\n\n this.selectedDate = new Date(parsedDate);\n this.tempSelectedDate = new Date(parsedDate);\n this.selectedMonth = this.selectedDate.getMonth();\n this.selectedYear = this.selectedDate.getFullYear();\n\n if (this.showTime) {\n this.initTimeFromDate(this.selectedDate);\n }\n }\n }\n\n registerOnChange(fn: any): void {\n this.onChange = fn;\n }\n\n registerOnTouched(fn: any): void {\n this.onTouched = fn;\n }\n\n setDisabledState?(isDisabled: boolean): void {\n this.disabled = isDisabled;\n }\n\n ngOnChanges() {\n if (this.date) {\n let d = this.date;\n if (typeof d === 'string') d = this.sanitizeDateString(d);\n\n const parsedDate = new Date(d);\n this.selectedDate = new Date(parsedDate);\n this.tempSelectedDate = new Date(parsedDate);\n this.selectedMonth = this.selectedDate.getMonth();\n this.selectedYear = this.selectedDate.getFullYear();\n }\n }\n\n isSameDate(d1: Date, d2: Date): boolean {\n return (\n d1.getFullYear() === d2.getFullYear() &&\n d1.getMonth() === d2.getMonth() &&\n d1.getDate() === d2.getDate()\n );\n }\n\n ngOnInit() {\n const currentYear = new Date().getFullYear();\n const endYear = currentYear + 10;\n this.yearRange = Array.from(\n { length: endYear - 1960 + 1 },\n (_, i) => 1960 + i\n );\n this.yearRange.sort((a, b) => b - a);\n\n \n if (!this.date && this.useDefaultDate) {\n const now = new Date();\n const pad = (n: number) => n.toString().padStart(2, '0');\n\n const localDateString = `${now.getFullYear()}-${pad(\n now.getMonth() + 1\n )}-${pad(now.getDate())}T${pad(now.getHours())}:${pad(\n now.getMinutes()\n )}:${pad(now.getSeconds())}`;\n\n this.selectedDate = new Date(localDateString);\n this.tempSelectedDate = new Date(localDateString);\n this.date = this.selectedDate;\n\n if (this.showTime) {\n const hours = now.getHours();\n const minutes = now.getMinutes();\n\n this.selectedHour = hours.toString().padStart(2, '0');\n this.selectedMinute = minutes.toString().padStart(2, '0');\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n }\n\n this.dateChange.emit(this.selectedDate);\n this.onChange(localDateString);\n }\n }\n\n get displayDate(): string {\n const parsedDate =\n typeof this.date === 'string' ? new Date(this.date) : this.date;\n return parsedDate ? this.formatDate(parsedDate, this.format) : '';\n }\n\n tempTime: string = '';\n selectedHour = '00';\n selectedMinute = '00';\n\n showHourOptions = false;\n showMinuteOptions = false;\n\n hours = Array.from({ length: 24 }, (_, i) => String(i).padStart(2, '0'));\n minutes = Array.from({ length: 60 }, (_, i) => String(i).padStart(2, '0'));\n\n toggleHourDropdown() {\n this.showHourOptions = !this.showHourOptions;\n this.showMinuteOptions = false;\n }\n\n toggleMinuteDropdown() {\n this.showMinuteOptions = !this.showMinuteOptions;\n this.showHourOptions = false;\n }\n\n selectHour(h: string) {\n this.selectedHour = h;\n this.showHourOptions = false;\n }\n\n selectMinute(m: string) {\n this.selectedMinute = m;\n this.showMinuteOptions = false;\n }\n\n toggleCalendar() {\n this.showCalendar = !this.showCalendar;\n\n\n if (this.date) {\n this.tempSelectedDate = new Date(this.date);\n } else {\n this.tempSelectedDate = this.useDefaultDate ? new Date() : null;\n }\n\n if (this.tempSelectedDate) {\n this.selectedMonth = this.tempSelectedDate.getMonth();\n this.selectedMonthString = this.months[this.selectedMonth];\n this.selectedYear = this.tempSelectedDate.getFullYear();\n }\n\n if (this.showTime && !this.tempTime) {\n const today = new Date();\n const isToday =\n this.tempSelectedDate &&\n this.isSameDate(this.tempSelectedDate, today);\n\n const hours = isToday ? today.getHours() : 0;\n const minutes = isToday ? today.getMinutes() : 0;\n\n if (this.tempSelectedDate) {\n this.tempSelectedDate.setHours(hours, minutes, 0, 0);\n }\n this.selectedHour = hours.toString().padStart(2, '0');\n this.selectedMinute = minutes.toString().padStart(2, '0');\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n }\n }\n\n initTimeFromDate(date: Date) {\n const hours = date.getHours();\n const minutes = date.getMinutes();\n\n this.selectedHour = hours.toString().padStart(2, '0');\n this.selectedMinute = minutes.toString().padStart(2, '0');\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n this.tempSelectedDate?.setHours(hours, minutes, 0, 0);\n }\nclearDate() {\n this.date = null;\n this.selectedDate = null;\n this.tempSelectedDate = null;\n this.tempTime = '';\n this.selectedHour = '00';\n this.selectedMinute = '00';\n\n\n this.dateChange.emit(null);\n\n \n this.onChange(null);\n this.onTouched();\n\n\n this.showCalendar = false;\n}\n\n fixToUTC(dateValue: any) {\n if (!dateValue) return null;\n\n const date = dateValue instanceof Date ? dateValue : new Date(dateValue);\n if (isNaN(date.getTime())) return null;\n\n return new Date(\n Date.UTC(\n date.getFullYear(),\n date.getMonth(),\n date.getDate(),\n date.getHours(),\n date.getMinutes(),\n date.getSeconds(),\n date.getMilliseconds()\n )\n );\n }\n\n confirm() {\n if (!this.tempSelectedDate) return;\n if (this.isDisabled(this.tempSelectedDate)) return;\n\n const hours = Number(this.selectedHour);\n const minutes = Number(this.selectedMinute);\n\n this.tempSelectedDate.setHours(hours, minutes, 0, 0);\n\n this.selectedDate = new Date(this.tempSelectedDate);\n this.date = this.selectedDate;\n\n const pad = (n: number) => n.toString().padStart(2, '0');\n const localDateString = `${this.selectedDate.getFullYear()}-${pad(\n this.selectedDate.getMonth() + 1\n )}-${pad(this.selectedDate.getDate())}T${pad(\n this.selectedDate.getHours()\n )}:${pad(this.selectedDate.getMinutes())}:${pad(\n this.selectedDate.getSeconds()\n )}`;\n\n this.dateChange.emit(this.selectedDate);\n this.onChange(localDateString);\n this.onTouched();\n\n this.showCalendar = false;\n }\n\n setToStartOfDay() {\n if (!this.tempSelectedDate) return;\n\n this.selectedHour = '00';\n this.selectedMinute = '00';\n\n this.tempSelectedDate.setHours(0, 0, 0, 0);\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n\n this.selectedDate = new Date(this.tempSelectedDate);\n }\n\n setToEndOfDay() {\n if (!this.tempSelectedDate) return;\n\n this.selectedHour = '23';\n this.selectedMinute = '59';\n\n this.tempSelectedDate.setHours(23, 59, 59, 999);\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n\n this.selectedDate = new Date(this.tempSelectedDate);\n }\n\n previousMonth() {\n this.selectedMonth--;\n if (this.selectedMonth < 0) {\n this.selectedMonth = 11;\n this.selectedYear--;\n }\n this.updateTempSelectedDate();\n }\n\n nextMonth() {\n this.selectedMonth++;\n if (this.selectedMonth > 11) {\n this.selectedMonth = 0;\n this.selectedYear++;\n }\n this.updateTempSelectedDate();\n }\n\n onDropdownYearChange(event: DropdownChangeEvent): void {\n this.selectedYear = event.value;\n this.updateTempSelectedDate();\n }\n\n onDropdownMonthChange(event: DropdownChangeEvent): void {\n this.selectedMonth = this.months.indexOf(event.value);\n this.updateTempSelectedDate();\n }\n\n updateTempSelectedDate() {\n if (!this.tempSelectedDate) return;\n this.tempSelectedDate.setMonth(this.selectedMonth);\n this.tempSelectedDate.setFullYear(this.selectedYear);\n }\n\n getDaysInMonth(): (Date | null)[] {\n const days: (Date | null)[] = [];\n const year = this.selectedYear;\n const month = this.selectedMonth;\n\n const firstDayOfMonth = new Date(year, month, 1).getDay();\n const offset = firstDayOfMonth === 0 ? 6 : firstDayOfMonth - 1;\n\n for (let i = 0; i < offset; i++) {\n days.push(null);\n }\n\n const totalDays = new Date(year, month + 1, 0).getDate();\n for (let i = 1; i <= totalDays; i++) {\n const day = new Date(year, month, i);\n days.push(day);\n }\n return days;\n }\n\n sanitizeDateString(value: string): string {\n return value?.endsWith('Z') ? value.slice(0, -1) : value;\n }\n\n isDisabled(day: Date | string): boolean {\n const dayDate = this.toDate(day);\n\n if (this.minDate && dayDate < this.stripTime(this.toDate(this.minDate)))\n return true;\n if (this.maxDate && dayDate > this.stripTime(this.toDate(this.maxDate)))\n return true;\n\n return false;\n }\n\n private stripTime(date: Date | string): Date {\n const d = this.toDate(date);\n return new Date(d.getFullYear(), d.getMonth(), d.getDate());\n }\n\n toDate(value: Date | string): Date {\n if (value instanceof Date) return value;\n return new Date(this.sanitizeDateString(value));\n }\n\n is24Hour: boolean = true;\n\n selectTemporaryDate(day: Date) {\n if (!this.tempSelectedDate) this.tempSelectedDate = new Date(day);\n if (this.isDisabled(day)) return;\n\n const isNewDate = !this.isSameDate(this.tempSelectedDate, day);\n this.tempSelectedDate = new Date(day);\n\n if (this.showTime) {\n if (isNewDate) {\n const today = new Date();\n const isToday =\n day.getFullYear() === today.getFullYear() &&\n day.getMonth() === today.getMonth() &&\n day.getDate() === today.getDate();\n\n const hours = isToday ? today.getHours() : 0;\n const minutes = isToday ? today.getMinutes() : 0;\n\n this.tempSelectedDate.setHours(hours, minutes, 0, 0);\n\n this.selectedHour = hours.toString().padStart(2, '0');\n this.selectedMinute = minutes.toString().padStart(2, '0');\n this.tempTime = `${this.selectedHour}:${this.selectedMinute}`;\n } else {\n const [h, m] = this.tempTime.split(':');\n this.selectedHour = h;\n this.selectedMinute = m;\n }\n }\n }\n\n isSelected(day: Date): boolean {\n if (!this.tempSelectedDate) return false;\n\n return (\n day.getDate() === this.tempSelectedDate.getDate() &&\n day.getMonth() === this.tempSelectedDate.getMonth() &&\n day.getFullYear() === this.tempSelectedDate.getFullYear()\n );\n }\n\n formatDate(date: Date, format: string): string {\n const day = date.getDate().toString().padStart(2, '0');\n const month = (date.getMonth() + 1).toString().padStart(2, '0');\n const year = date.getFullYear();\n\n switch (format) {\n case 'DD/MM/YYYY':\n return `${day}/${month}/${year}`;\n case 'MM/DD/YYYY':\n default:\n return `${month}/${day}/${year}`;\n }\n }\n\n cancel() {\n this.showCalendar = false;\n }\n}\n","<div class=\"date-picker\">\n <div class=\"calendar-container\">\n <input\n type=\"text\"\n [placeholder]=\"placeholder\"\n [value]=\"displayDate\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && toggleCalendar()\"\n class=\"w-full block\"\n [style.background-color]=\"bgColor\"\n [style.border]=\"border\"\n [ngClass]=\"{\n 'cursor-not-allowed': disabled === true,\n 'cursor-pointer': disabled === false\n }\"\n readonly\n />\n <verben-svg\n (click)=\"!disabled && toggleCalendar()\"\n class=\"icon\"\n [icon]=\"'calendar'\"\n ></verben-svg>\n </div>\n\n <div\n *ngIf=\"showCalendar\"\n [appOutSideClick]=\"showCalendar\"\n (outSideClick)=\"showCalendar = false\"\n class=\"calendar\"\n [style.width]=\"datePickerWidth\"\n >\n <div class=\"calendar-header\">\n <ng-container *ngIf=\"!useDropdowns; else dropdowns\">\n <button (click)=\"previousMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-left'\"></verben-svg>\n </button>\n <span>{{ months[selectedMonth] }} {{ selectedYear }}</span>\n <button (click)=\"nextMonth()\">\n <verben-svg [width]=\"20\" [icon]=\"'chevron-right'\"></verben-svg>\n </button>\n </ng-container>\n\n <ng-template #dropdowns>\n <verben-drop-down\n [placeholder]=\"yearPlaceholder\"\n (onChange)=\"onDropdownYearChange($event)\"\n [options]=\"yearRange\"\n [(ngModel)]=\"selectedYear\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n\n <verben-drop-down\n [placeholder]=\"monthPlaceholder\"\n (onChange)=\"onDropdownMonthChange($event)\"\n [options]=\"months\"\n class=\"drop-down\"\n [(ngModel)]=\"selectedMonthString\"\n [width]=\"'90px'\"\n ></verben-drop-down>\n </ng-template>\n\n \n <div class=\"time-picker flex items-center gap-2\" *ngIf=\"showTime\">\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleHourDropdown()\"\n >\n {{ selectedHour }}\n </div>\n\n <div *ngIf=\"showHourOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let h of hours\"\n [class.active]=\"h === selectedHour\"\n (click)=\"selectHour(h)\"\n >\n {{ h }}\n </div>\n </div>\n </div>\n\n <span>:</span>\n\n <div class=\"relative\">\n <div\n class=\"flex items-center box rounded px-2 py-1 cursor-pointer\"\n (click)=\"toggleMinuteDropdown()\"\n >\n {{ selectedMinute }}\n </div>\n\n <div *ngIf=\"showMinuteOptions\" class=\"dropdown\">\n <div\n class=\"dropdown-item\"\n *ngFor=\"let m of minutes\"\n [class.active]=\"m === selectedMinute\"\n (click)=\"selectMinute(m)\"\n >\n {{ m }}\n </div>\n </div>\n </div>\n \n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"tooltipTemplate\"\n #tooltip>\n <verben-svg\n (click)=\"setToStartOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'sun'\"\n ></verben-svg>\n </verben-tooltip>\n <ng-template #tooltipTemplate>\n <div>\n <p class=\"text-xs\">Set start of day</p>\n </div>\n </ng-template>\n </div>\n <div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"endOfDayTooltip\"\n #endOfDayTip\n >\n <verben-svg\n (click)=\"setToEndOfDay()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'moon'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #endOfDayTooltip>\n <div>\n <p class=\"text-xs\">Set end of day</p>\n </div>\n </ng-template>\n\n</div>\n <verben-tooltip\n [top]=\"'-40px'\"\n [textColor]=\"'#000'\"\n [backgroundColor]=\"'#D3D3D3'\"\n [left]=\"'0'\"\n [width]=\"'100px'\"\n [tooltipContent]=\"clearTooltip\"\n #clearDateTip\n >\n <verben-svg\n (click)=\"clearDate()\"\n class=\"cursor-pointer\"\n [width]=\"14\"\n [height]=\"14\"\n [icon]=\"'close'\"\n ></verben-svg>\n \n </verben-tooltip>\n\n <ng-template #clearTooltip>\n <div>\n <p class=\"text-xs\">clear date</p>\n </div>\n </ng-template>\n </div>\n\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"weekdays\">\n <span *ngFor=\"let day of weekDays\">{{ day }}</span>\n </div>\n\n <div class=\"dates\">\n <ng-container *ngFor=\"let day of getDaysInMonth()\">\n <button\n *ngIf=\"day; else empty\"\n [class.selected]=\"isSelected(day)\"\n [disabled]=\"isDisabled(day)\"\n [ngClass]=\"{ 'disabled-day': isDisabled(day) }\"\n (click)=\"selectTemporaryDate(day)\"\n >\n {{ day.getDate() }}\n </button>\n <ng-template #empty>\n <span class=\"empty-date\"></span>\n </ng-template>\n </ng-container>\n </div>\n </div>\n\n <div class=\"calendar-footer\">\n <button (click)=\"cancel()\">Cancel</button>\n <button (click)=\"confirm()\">OK</button>\n </div>\n </div>\n</div>\n","import { NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { DatePickerComponent } from './date-picker.component';\nimport { SvgModule } from 'verben-ng-ui/src/lib/components/svg';\nimport { DropDownModule } from 'verben-ng-ui/src/lib/components/drop-down';\nimport { VerbenPopUpModule } from 'verben-ng-ui/src/lib/components/pop-up';\nimport { OutSideClickDirective } from 'verben-ng-ui/src/lib/components/data-view';\nimport { TooltipModule } from 'verben-ng-ui/src/lib/components/tooltip';\n@NgModule({\n declarations: [DatePickerComponent],\n imports: [\n FormsModule,\n CommonModule,\n SvgModule,\n DropDownModule,\n VerbenPopUpModule,\n OutSideClickDirective,\n TooltipModule\n ],\n exports: [DatePickerComponent],\n})\nexport class DatePickerModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "verben-ng-ui",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.44",
|
|
4
4
|
"author": "Verbena Logic",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -45,23 +45,17 @@
|
|
|
45
45
|
"esm": "./esm2022/src/lib/control-options/verben-ng-ui-src-lib-control-options.mjs",
|
|
46
46
|
"default": "./fesm2022/verben-ng-ui-src-lib-control-options.mjs"
|
|
47
47
|
},
|
|
48
|
-
"./src/lib/convert-to-number": {
|
|
49
|
-
"types": "./src/lib/convert-to-number/index.d.ts",
|
|
50
|
-
"esm2022": "./esm2022/src/lib/convert-to-number/verben-ng-ui-src-lib-convert-to-number.mjs",
|
|
51
|
-
"esm": "./esm2022/src/lib/convert-to-number/verben-ng-ui-src-lib-convert-to-number.mjs",
|
|
52
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-convert-to-number.mjs"
|
|
53
|
-
},
|
|
54
48
|
"./src/lib/convert-to-integer": {
|
|
55
49
|
"types": "./src/lib/convert-to-integer/index.d.ts",
|
|
56
50
|
"esm2022": "./esm2022/src/lib/convert-to-integer/verben-ng-ui-src-lib-convert-to-integer.mjs",
|
|
57
51
|
"esm": "./esm2022/src/lib/convert-to-integer/verben-ng-ui-src-lib-convert-to-integer.mjs",
|
|
58
52
|
"default": "./fesm2022/verben-ng-ui-src-lib-convert-to-integer.mjs"
|
|
59
53
|
},
|
|
60
|
-
"./src/lib/
|
|
61
|
-
"types": "./src/lib/
|
|
62
|
-
"esm2022": "./esm2022/src/lib/
|
|
63
|
-
"esm": "./esm2022/src/lib/
|
|
64
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-
|
|
54
|
+
"./src/lib/convert-to-number": {
|
|
55
|
+
"types": "./src/lib/convert-to-number/index.d.ts",
|
|
56
|
+
"esm2022": "./esm2022/src/lib/convert-to-number/verben-ng-ui-src-lib-convert-to-number.mjs",
|
|
57
|
+
"esm": "./esm2022/src/lib/convert-to-number/verben-ng-ui-src-lib-convert-to-number.mjs",
|
|
58
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-convert-to-number.mjs"
|
|
65
59
|
},
|
|
66
60
|
"./src/lib/models": {
|
|
67
61
|
"types": "./src/lib/models/index.d.ts",
|
|
@@ -69,6 +63,12 @@
|
|
|
69
63
|
"esm": "./esm2022/src/lib/models/verben-ng-ui-src-lib-models.mjs",
|
|
70
64
|
"default": "./fesm2022/verben-ng-ui-src-lib-models.mjs"
|
|
71
65
|
},
|
|
66
|
+
"./src/lib/email-validator": {
|
|
67
|
+
"types": "./src/lib/email-validator/index.d.ts",
|
|
68
|
+
"esm2022": "./esm2022/src/lib/email-validator/verben-ng-ui-src-lib-email-validator.mjs",
|
|
69
|
+
"esm": "./esm2022/src/lib/email-validator/verben-ng-ui-src-lib-email-validator.mjs",
|
|
70
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-email-validator.mjs"
|
|
71
|
+
},
|
|
72
72
|
"./src/lib/number-range": {
|
|
73
73
|
"types": "./src/lib/number-range/index.d.ts",
|
|
74
74
|
"esm2022": "./esm2022/src/lib/number-range/verben-ng-ui-src-lib-number-range.mjs",
|
|
@@ -99,18 +99,18 @@
|
|
|
99
99
|
"esm": "./esm2022/src/lib/theme-switcher/verben-ng-ui-src-lib-theme-switcher.mjs",
|
|
100
100
|
"default": "./fesm2022/verben-ng-ui-src-lib-theme-switcher.mjs"
|
|
101
101
|
},
|
|
102
|
-
"./src/lib/validate-input": {
|
|
103
|
-
"types": "./src/lib/validate-input/index.d.ts",
|
|
104
|
-
"esm2022": "./esm2022/src/lib/validate-input/verben-ng-ui-src-lib-validate-input.mjs",
|
|
105
|
-
"esm": "./esm2022/src/lib/validate-input/verben-ng-ui-src-lib-validate-input.mjs",
|
|
106
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-validate-input.mjs"
|
|
107
|
-
},
|
|
108
102
|
"./src/lib/validate": {
|
|
109
103
|
"types": "./src/lib/validate/index.d.ts",
|
|
110
104
|
"esm2022": "./esm2022/src/lib/validate/verben-ng-ui-src-lib-validate.mjs",
|
|
111
105
|
"esm": "./esm2022/src/lib/validate/verben-ng-ui-src-lib-validate.mjs",
|
|
112
106
|
"default": "./fesm2022/verben-ng-ui-src-lib-validate.mjs"
|
|
113
107
|
},
|
|
108
|
+
"./src/lib/validate-input": {
|
|
109
|
+
"types": "./src/lib/validate-input/index.d.ts",
|
|
110
|
+
"esm2022": "./esm2022/src/lib/validate-input/verben-ng-ui-src-lib-validate-input.mjs",
|
|
111
|
+
"esm": "./esm2022/src/lib/validate-input/verben-ng-ui-src-lib-validate-input.mjs",
|
|
112
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-validate-input.mjs"
|
|
113
|
+
},
|
|
114
114
|
"./src/lib/verbena-badge": {
|
|
115
115
|
"types": "./src/lib/verbena-badge/index.d.ts",
|
|
116
116
|
"esm2022": "./esm2022/src/lib/verbena-badge/verben-ng-ui-src-lib-verbena-badge.mjs",
|
|
@@ -123,23 +123,23 @@
|
|
|
123
123
|
"esm": "./esm2022/src/lib/verbena-button/verben-ng-ui-src-lib-verbena-button.mjs",
|
|
124
124
|
"default": "./fesm2022/verben-ng-ui-src-lib-verbena-button.mjs"
|
|
125
125
|
},
|
|
126
|
-
"./src/lib/verbena-switch": {
|
|
127
|
-
"types": "./src/lib/verbena-switch/index.d.ts",
|
|
128
|
-
"esm2022": "./esm2022/src/lib/verbena-switch/verben-ng-ui-src-lib-verbena-switch.mjs",
|
|
129
|
-
"esm": "./esm2022/src/lib/verbena-switch/verben-ng-ui-src-lib-verbena-switch.mjs",
|
|
130
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-verbena-switch.mjs"
|
|
131
|
-
},
|
|
132
126
|
"./src/lib/verbena-input": {
|
|
133
127
|
"types": "./src/lib/verbena-input/index.d.ts",
|
|
134
128
|
"esm2022": "./esm2022/src/lib/verbena-input/verben-ng-ui-src-lib-verbena-input.mjs",
|
|
135
129
|
"esm": "./esm2022/src/lib/verbena-input/verben-ng-ui-src-lib-verbena-input.mjs",
|
|
136
130
|
"default": "./fesm2022/verben-ng-ui-src-lib-verbena-input.mjs"
|
|
137
131
|
},
|
|
138
|
-
"./src/lib/
|
|
139
|
-
"types": "./src/lib/
|
|
140
|
-
"esm2022": "./esm2022/src/lib/
|
|
141
|
-
"esm": "./esm2022/src/lib/
|
|
142
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-
|
|
132
|
+
"./src/lib/verbena-switch": {
|
|
133
|
+
"types": "./src/lib/verbena-switch/index.d.ts",
|
|
134
|
+
"esm2022": "./esm2022/src/lib/verbena-switch/verben-ng-ui-src-lib-verbena-switch.mjs",
|
|
135
|
+
"esm": "./esm2022/src/lib/verbena-switch/verben-ng-ui-src-lib-verbena-switch.mjs",
|
|
136
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-verbena-switch.mjs"
|
|
137
|
+
},
|
|
138
|
+
"./src/lib/verbena-textarea": {
|
|
139
|
+
"types": "./src/lib/verbena-textarea/index.d.ts",
|
|
140
|
+
"esm2022": "./esm2022/src/lib/verbena-textarea/verben-ng-ui-src-lib-verbena-textarea.mjs",
|
|
141
|
+
"esm": "./esm2022/src/lib/verbena-textarea/verben-ng-ui-src-lib-verbena-textarea.mjs",
|
|
142
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-verbena-textarea.mjs"
|
|
143
143
|
},
|
|
144
144
|
"./src/lib/components/card": {
|
|
145
145
|
"types": "./src/lib/components/card/index.d.ts",
|
|
@@ -147,11 +147,11 @@
|
|
|
147
147
|
"esm": "./esm2022/src/lib/components/card/verben-ng-ui-src-lib-components-card.mjs",
|
|
148
148
|
"default": "./fesm2022/verben-ng-ui-src-lib-components-card.mjs"
|
|
149
149
|
},
|
|
150
|
-
"./src/lib/components/data-
|
|
151
|
-
"types": "./src/lib/components/data-
|
|
152
|
-
"esm2022": "./esm2022/src/lib/components/data-
|
|
153
|
-
"esm": "./esm2022/src/lib/components/data-
|
|
154
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-components-data-
|
|
150
|
+
"./src/lib/components/card-data-view": {
|
|
151
|
+
"types": "./src/lib/components/card-data-view/index.d.ts",
|
|
152
|
+
"esm2022": "./esm2022/src/lib/components/card-data-view/verben-ng-ui-src-lib-components-card-data-view.mjs",
|
|
153
|
+
"esm": "./esm2022/src/lib/components/card-data-view/verben-ng-ui-src-lib-components-card-data-view.mjs",
|
|
154
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-components-card-data-view.mjs"
|
|
155
155
|
},
|
|
156
156
|
"./src/lib/components/chip": {
|
|
157
157
|
"types": "./src/lib/components/chip/index.d.ts",
|
|
@@ -159,11 +159,11 @@
|
|
|
159
159
|
"esm": "./esm2022/src/lib/components/chip/verben-ng-ui-src-lib-components-chip.mjs",
|
|
160
160
|
"default": "./fesm2022/verben-ng-ui-src-lib-components-chip.mjs"
|
|
161
161
|
},
|
|
162
|
-
"./src/lib/
|
|
163
|
-
"types": "./src/lib/
|
|
164
|
-
"esm2022": "./esm2022/src/lib/
|
|
165
|
-
"esm": "./esm2022/src/lib/
|
|
166
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-
|
|
162
|
+
"./src/lib/components/data-columns": {
|
|
163
|
+
"types": "./src/lib/components/data-columns/index.d.ts",
|
|
164
|
+
"esm2022": "./esm2022/src/lib/components/data-columns/verben-ng-ui-src-lib-components-data-columns.mjs",
|
|
165
|
+
"esm": "./esm2022/src/lib/components/data-columns/verben-ng-ui-src-lib-components-data-columns.mjs",
|
|
166
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-components-data-columns.mjs"
|
|
167
167
|
},
|
|
168
168
|
"./src/lib/components/data-export": {
|
|
169
169
|
"types": "./src/lib/components/data-export/index.d.ts",
|
|
@@ -189,18 +189,18 @@
|
|
|
189
189
|
"esm": "./esm2022/src/lib/components/data-import/verben-ng-ui-src-lib-components-data-import.mjs",
|
|
190
190
|
"default": "./fesm2022/verben-ng-ui-src-lib-components-data-import.mjs"
|
|
191
191
|
},
|
|
192
|
-
"./src/lib/components/data-table": {
|
|
193
|
-
"types": "./src/lib/components/data-table/index.d.ts",
|
|
194
|
-
"esm2022": "./esm2022/src/lib/components/data-table/verben-ng-ui-src-lib-components-data-table.mjs",
|
|
195
|
-
"esm": "./esm2022/src/lib/components/data-table/verben-ng-ui-src-lib-components-data-table.mjs",
|
|
196
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-components-data-table.mjs"
|
|
197
|
-
},
|
|
198
192
|
"./src/lib/components/data-sort": {
|
|
199
193
|
"types": "./src/lib/components/data-sort/index.d.ts",
|
|
200
194
|
"esm2022": "./esm2022/src/lib/components/data-sort/verben-ng-ui-src-lib-components-data-sort.mjs",
|
|
201
195
|
"esm": "./esm2022/src/lib/components/data-sort/verben-ng-ui-src-lib-components-data-sort.mjs",
|
|
202
196
|
"default": "./fesm2022/verben-ng-ui-src-lib-components-data-sort.mjs"
|
|
203
197
|
},
|
|
198
|
+
"./src/lib/components/data-table": {
|
|
199
|
+
"types": "./src/lib/components/data-table/index.d.ts",
|
|
200
|
+
"esm2022": "./esm2022/src/lib/components/data-table/verben-ng-ui-src-lib-components-data-table.mjs",
|
|
201
|
+
"esm": "./esm2022/src/lib/components/data-table/verben-ng-ui-src-lib-components-data-table.mjs",
|
|
202
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-components-data-table.mjs"
|
|
203
|
+
},
|
|
204
204
|
"./src/lib/components/data-view": {
|
|
205
205
|
"types": "./src/lib/components/data-view/index.d.ts",
|
|
206
206
|
"esm2022": "./esm2022/src/lib/components/data-view/verben-ng-ui-src-lib-components-data-view.mjs",
|
|
@@ -237,18 +237,18 @@
|
|
|
237
237
|
"esm": "./esm2022/src/lib/components/image/verben-ng-ui-src-lib-components-image.mjs",
|
|
238
238
|
"default": "./fesm2022/verben-ng-ui-src-lib-components-image.mjs"
|
|
239
239
|
},
|
|
240
|
-
"./src/lib/components/number-input": {
|
|
241
|
-
"types": "./src/lib/components/number-input/index.d.ts",
|
|
242
|
-
"esm2022": "./esm2022/src/lib/components/number-input/verben-ng-ui-src-lib-components-number-input.mjs",
|
|
243
|
-
"esm": "./esm2022/src/lib/components/number-input/verben-ng-ui-src-lib-components-number-input.mjs",
|
|
244
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-components-number-input.mjs"
|
|
245
|
-
},
|
|
246
240
|
"./src/lib/components/notification": {
|
|
247
241
|
"types": "./src/lib/components/notification/index.d.ts",
|
|
248
242
|
"esm2022": "./esm2022/src/lib/components/notification/verben-ng-ui-src-lib-components-notification.mjs",
|
|
249
243
|
"esm": "./esm2022/src/lib/components/notification/verben-ng-ui-src-lib-components-notification.mjs",
|
|
250
244
|
"default": "./fesm2022/verben-ng-ui-src-lib-components-notification.mjs"
|
|
251
245
|
},
|
|
246
|
+
"./src/lib/components/number-input": {
|
|
247
|
+
"types": "./src/lib/components/number-input/index.d.ts",
|
|
248
|
+
"esm2022": "./esm2022/src/lib/components/number-input/verben-ng-ui-src-lib-components-number-input.mjs",
|
|
249
|
+
"esm": "./esm2022/src/lib/components/number-input/verben-ng-ui-src-lib-components-number-input.mjs",
|
|
250
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-components-number-input.mjs"
|
|
251
|
+
},
|
|
252
252
|
"./src/lib/components/pop-up": {
|
|
253
253
|
"types": "./src/lib/components/pop-up/index.d.ts",
|
|
254
254
|
"esm2022": "./esm2022/src/lib/components/pop-up/verben-ng-ui-src-lib-components-pop-up.mjs",
|
|
@@ -309,17 +309,17 @@
|
|
|
309
309
|
"esm": "./esm2022/src/lib/components/verbena-icon/verben-ng-ui-src-lib-components-verbena-icon.mjs",
|
|
310
310
|
"default": "./fesm2022/verben-ng-ui-src-lib-components-verbena-icon.mjs"
|
|
311
311
|
},
|
|
312
|
-
"./src/lib/components/visible-column": {
|
|
313
|
-
"types": "./src/lib/components/visible-column/index.d.ts",
|
|
314
|
-
"esm2022": "./esm2022/src/lib/components/visible-column/verben-ng-ui-src-lib-components-visible-column.mjs",
|
|
315
|
-
"esm": "./esm2022/src/lib/components/visible-column/verben-ng-ui-src-lib-components-visible-column.mjs",
|
|
316
|
-
"default": "./fesm2022/verben-ng-ui-src-lib-components-visible-column.mjs"
|
|
317
|
-
},
|
|
318
312
|
"./src/lib/components/verbena-tab": {
|
|
319
313
|
"types": "./src/lib/components/verbena-tab/index.d.ts",
|
|
320
314
|
"esm2022": "./esm2022/src/lib/components/verbena-tab/verben-ng-ui-src-lib-components-verbena-tab.mjs",
|
|
321
315
|
"esm": "./esm2022/src/lib/components/verbena-tab/verben-ng-ui-src-lib-components-verbena-tab.mjs",
|
|
322
316
|
"default": "./fesm2022/verben-ng-ui-src-lib-components-verbena-tab.mjs"
|
|
317
|
+
},
|
|
318
|
+
"./src/lib/components/visible-column": {
|
|
319
|
+
"types": "./src/lib/components/visible-column/index.d.ts",
|
|
320
|
+
"esm2022": "./esm2022/src/lib/components/visible-column/verben-ng-ui-src-lib-components-visible-column.mjs",
|
|
321
|
+
"esm": "./esm2022/src/lib/components/visible-column/verben-ng-ui-src-lib-components-visible-column.mjs",
|
|
322
|
+
"default": "./fesm2022/verben-ng-ui-src-lib-components-visible-column.mjs"
|
|
323
323
|
}
|
|
324
324
|
}
|
|
325
325
|
}
|
|
@@ -15,13 +15,14 @@ export declare class DatePickerComponent implements ControlValueAccessor {
|
|
|
15
15
|
monthPlaceholder: string;
|
|
16
16
|
date: Date | null | string;
|
|
17
17
|
showTime: boolean;
|
|
18
|
-
|
|
18
|
+
datePickerWidth: string;
|
|
19
|
+
useDefaultDate: boolean;
|
|
20
|
+
dateChange: EventEmitter<Date | null>;
|
|
19
21
|
yearRange: number[];
|
|
20
22
|
filteredYearRange: number[];
|
|
21
|
-
selectedDate: Date;
|
|
22
|
-
tempSelectedDate: Date;
|
|
23
|
+
selectedDate: Date | null;
|
|
24
|
+
tempSelectedDate: Date | null;
|
|
23
25
|
showCalendar: boolean;
|
|
24
|
-
datePickerWidth: string;
|
|
25
26
|
weekDays: string[];
|
|
26
27
|
months: string[];
|
|
27
28
|
selectedMonth: number;
|
|
@@ -50,6 +51,7 @@ export declare class DatePickerComponent implements ControlValueAccessor {
|
|
|
50
51
|
selectMinute(m: string): void;
|
|
51
52
|
toggleCalendar(): void;
|
|
52
53
|
initTimeFromDate(date: Date): void;
|
|
54
|
+
clearDate(): void;
|
|
53
55
|
fixToUTC(dateValue: any): Date | null;
|
|
54
56
|
confirm(): void;
|
|
55
57
|
setToStartOfDay(): void;
|
|
@@ -70,5 +72,5 @@ export declare class DatePickerComponent implements ControlValueAccessor {
|
|
|
70
72
|
formatDate(date: Date, format: string): string;
|
|
71
73
|
cancel(): void;
|
|
72
74
|
static ɵfac: i0.ɵɵFactoryDeclaration<DatePickerComponent, never>;
|
|
73
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DatePickerComponent, "app-date-picker", never, { "placeholder": { "alias": "placeholder"; "required": false; }; "format": { "alias": "format"; "required": false; }; "minDate": { "alias": "minDate"; "required": false; }; "maxDate": { "alias": "maxDate"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "bgColor": { "alias": "bgColor"; "required": false; }; "border": { "alias": "border"; "required": false; }; "useDropdowns": { "alias": "useDropdowns"; "required": false; }; "yearPlaceholder": { "alias": "yearPlaceholder"; "required": false; }; "monthPlaceholder": { "alias": "monthPlaceholder"; "required": false; }; "date": { "alias": "date"; "required": false; }; "showTime": { "alias": "showTime"; "required": false; }; "datePickerWidth": { "alias": "datePickerWidth"; "required": false; }; }, { "dateChange": "dateChange"; }, never, never, false, never>;
|
|
75
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DatePickerComponent, "app-date-picker", never, { "placeholder": { "alias": "placeholder"; "required": false; }; "format": { "alias": "format"; "required": false; }; "minDate": { "alias": "minDate"; "required": false; }; "maxDate": { "alias": "maxDate"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "bgColor": { "alias": "bgColor"; "required": false; }; "border": { "alias": "border"; "required": false; }; "useDropdowns": { "alias": "useDropdowns"; "required": false; }; "yearPlaceholder": { "alias": "yearPlaceholder"; "required": false; }; "monthPlaceholder": { "alias": "monthPlaceholder"; "required": false; }; "date": { "alias": "date"; "required": false; }; "showTime": { "alias": "showTime"; "required": false; }; "datePickerWidth": { "alias": "datePickerWidth"; "required": false; }; "useDefaultDate": { "alias": "useDefaultDate"; "required": false; }; }, { "dateChange": "dateChange"; }, never, never, false, never>;
|
|
74
76
|
}
|