@cauca-911/material 18.0.1-beta7 → 18.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. package/esm2022/lib/cauca-date-time-picker/cauca-date-time-picker.component.mjs +184 -0
  2. package/esm2022/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/components/desktop-time-picker/desktop-time-picker.component.mjs +2 -2
  3. package/esm2022/lib/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +365 -0
  4. package/esm2022/lib/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +74 -0
  5. package/esm2022/lib/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +2 -0
  6. package/esm2022/lib/cauca-input-file/cauca-input-file.component.mjs +148 -0
  7. package/esm2022/lib/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +87 -0
  8. package/esm2022/lib/cauca-material.component.mjs +5 -6
  9. package/esm2022/lib/cauca-material.module.mjs +52 -14
  10. package/esm2022/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.mjs +10 -14
  11. package/esm2022/lib/cauca-menu-vertical/cauca-menu-vertical.component.mjs +8 -16
  12. package/esm2022/lib/cauca-simple-dialog/cauca-simple-dialog.component.mjs +10 -14
  13. package/esm2022/lib/cauca-slideshow/cauca-slideshow.component.mjs +6 -6
  14. package/esm2022/public-api.mjs +4 -21
  15. package/fesm2022/cauca-911-material.mjs +822 -2110
  16. package/fesm2022/cauca-911-material.mjs.map +1 -1
  17. package/lib/cauca-date-time-picker/cauca-date-time-picker.component.d.ts +40 -0
  18. package/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/components/dialog-date-time-picker/dialog-date-time-picker.component.d.ts +2 -1
  19. package/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/models/dialog-date-time-picker-data.d.ts +3 -2
  20. package/lib/{inputs/cauca-input-file → cauca-input-file}/cauca-input-file.component.d.ts +1 -1
  21. package/lib/{inputs/cauca-input-multiple-langue → cauca-input-multiple-langue}/cauca-input-multiple-langue.component.d.ts +1 -1
  22. package/lib/cauca-material.component.d.ts +1 -1
  23. package/lib/cauca-material.module.d.ts +14 -4
  24. package/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.d.ts +1 -1
  25. package/lib/cauca-menu-vertical/cauca-menu-vertical.component.d.ts +1 -1
  26. package/lib/cauca-simple-dialog/cauca-simple-dialog.component.d.ts +1 -1
  27. package/lib/cauca-slideshow/cauca-slideshow.component.d.ts +1 -1
  28. package/package.json +2 -3
  29. package/public-api.d.ts +3 -20
  30. package/esm2022/lib/buttons/base-button.mjs +0 -33
  31. package/esm2022/lib/buttons/basic-button/basic-button.component.mjs +0 -64
  32. package/esm2022/lib/buttons/flat-button/flat-button.component.mjs +0 -64
  33. package/esm2022/lib/buttons/icon-button/icon-button.component.mjs +0 -28
  34. package/esm2022/lib/buttons/menu-item/menu-item.component.mjs +0 -68
  35. package/esm2022/lib/buttons/raised-button/raised-button.component.mjs +0 -64
  36. package/esm2022/lib/buttons/stroked-button/stroked-button.component.mjs +0 -71
  37. package/esm2022/lib/dialogs/alert-dialog/alert-dialog.component.mjs +0 -57
  38. package/esm2022/lib/dialogs/confirm-dialog/confirm-dialog.component.mjs +0 -69
  39. package/esm2022/lib/dialogs/services/dialog.service.mjs +0 -52
  40. package/esm2022/lib/inputs/cauca-date-time-picker/cauca-date-time-picker.component.mjs +0 -137
  41. package/esm2022/lib/inputs/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +0 -358
  42. package/esm2022/lib/inputs/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +0 -74
  43. package/esm2022/lib/inputs/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +0 -2
  44. package/esm2022/lib/inputs/cauca-input-file/cauca-input-file.component.mjs +0 -147
  45. package/esm2022/lib/inputs/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +0 -99
  46. package/esm2022/lib/inputs/password/models/password-validation.mjs +0 -13
  47. package/esm2022/lib/inputs/password/password-criteria/password-criteria.component.mjs +0 -49
  48. package/esm2022/lib/inputs/password/password-criteria-viewer/password-criteria-viewer.component.mjs +0 -29
  49. package/esm2022/lib/inputs/password/password-input/password-input.component.mjs +0 -112
  50. package/esm2022/lib/inputs/password/password-selection/password-selection.component.mjs +0 -112
  51. package/esm2022/lib/inputs/password/validators/password-validator.mjs +0 -19
  52. package/esm2022/lib/inputs/select-with-search/select-with-search.component.mjs +0 -157
  53. package/esm2022/lib/layout/expandable-panel/expandable-panel.component.mjs +0 -75
  54. package/esm2022/lib/layout/menu-expandable-panel/menu-expandable-panel.component.mjs +0 -148
  55. package/esm2022/lib/layout/menu-expandable-panel-item/menu-expandable-panel-item.component.mjs +0 -50
  56. package/esm2022/lib/layout/page-title/page-title.component.mjs +0 -86
  57. package/esm2022/lib/notifications/snack-bar/snack-bar.component.mjs +0 -75
  58. package/lib/buttons/base-button.d.ts +0 -21
  59. package/lib/buttons/basic-button/basic-button.component.d.ts +0 -6
  60. package/lib/buttons/flat-button/flat-button.component.d.ts +0 -6
  61. package/lib/buttons/icon-button/icon-button.component.d.ts +0 -6
  62. package/lib/buttons/menu-item/menu-item.component.d.ts +0 -9
  63. package/lib/buttons/raised-button/raised-button.component.d.ts +0 -6
  64. package/lib/buttons/stroked-button/stroked-button.component.d.ts +0 -6
  65. package/lib/dialogs/alert-dialog/alert-dialog.component.d.ts +0 -18
  66. package/lib/dialogs/confirm-dialog/confirm-dialog.component.d.ts +0 -17
  67. package/lib/dialogs/services/dialog.service.d.ts +0 -26
  68. package/lib/inputs/cauca-date-time-picker/cauca-date-time-picker.component.d.ts +0 -29
  69. package/lib/inputs/password/models/password-validation.d.ts +0 -9
  70. package/lib/inputs/password/password-criteria/password-criteria.component.d.ts +0 -9
  71. package/lib/inputs/password/password-criteria-viewer/password-criteria-viewer.component.d.ts +0 -9
  72. package/lib/inputs/password/password-input/password-input.component.d.ts +0 -25
  73. package/lib/inputs/password/password-selection/password-selection.component.d.ts +0 -20
  74. package/lib/inputs/password/validators/password-validator.d.ts +0 -9
  75. package/lib/inputs/select-with-search/select-with-search.component.d.ts +0 -32
  76. package/lib/layout/expandable-panel/expandable-panel.component.d.ts +0 -10
  77. package/lib/layout/menu-expandable-panel/menu-expandable-panel.component.d.ts +0 -29
  78. package/lib/layout/menu-expandable-panel-item/menu-expandable-panel-item.component.d.ts +0 -13
  79. package/lib/layout/page-title/page-title.component.d.ts +0 -11
  80. package/lib/notifications/snack-bar/snack-bar.component.d.ts +0 -17
  81. /package/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/components/desktop-time-picker/desktop-time-picker.component.d.ts +0 -0
  82. /package/lib/{inputs/cauca-date-time-picker → cauca-date-time-picker}/components/mobile-time-picker/mobile-time-picker.component.d.ts +0 -0
@@ -0,0 +1,365 @@
1
+ import { Component, HostListener, Inject, signal } from '@angular/core';
2
+ import { MatNativeDateModule } from '@angular/material/core';
3
+ import { MatDatepickerModule } from '@angular/material/datepicker';
4
+ import { MAT_DIALOG_DATA } from '@angular/material/dialog';
5
+ import { MatListModule } from '@angular/material/list';
6
+ import { CaucaCoreForChildModule } from '@cauca-911/core';
7
+ import { MatButtonModule } from '@angular/material/button';
8
+ import { MatIconModule } from '@angular/material/icon';
9
+ import { CommonModule } from '@angular/common';
10
+ import { MobileTimePickerComponent } from '../mobile-time-picker/mobile-time-picker.component';
11
+ import { DesktopTimePickerComponent } from '../desktop-time-picker/desktop-time-picker.component';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "@angular/material/dialog";
14
+ import * as i2 from "@angular/common";
15
+ import * as i3 from "@ngx-translate/core";
16
+ import * as i4 from "@angular/material/button";
17
+ import * as i5 from "@angular/material/datepicker";
18
+ import * as i6 from "@angular/material/icon";
19
+ const _c0 = (a0, a1) => ({ all: a0, someOptions: a1 });
20
+ function DialogDateTimePickerComponent_Conditional_4_div_0_Template(rf, ctx) { if (rf & 1) {
21
+ const _r1 = i0.ɵɵgetCurrentView();
22
+ i0.ɵɵelementStart(0, "div", 14)(1, "cauca-desktop-time-picker", 15);
23
+ i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_Conditional_4_div_0_Template_cauca_desktop_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r1); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.hourChanged($event)); });
24
+ i0.ɵɵelementEnd()();
25
+ } if (rf & 2) {
26
+ const ctx_r1 = i0.ɵɵnextContext(2);
27
+ i0.ɵɵadvance();
28
+ i0.ɵɵproperty("disabled", i0.ɵɵpureFunction2(3, _c0, ctx_r1.disabled.hours, ctx_r1.disabled.someHours))("options", ctx_r1.hours)("value", ctx_r1.selectedHour);
29
+ } }
30
+ function DialogDateTimePickerComponent_Conditional_4_div_1_Template(rf, ctx) { if (rf & 1) {
31
+ const _r3 = i0.ɵɵgetCurrentView();
32
+ i0.ɵɵelementStart(0, "div", 14)(1, "cauca-mobile-time-picker", 16);
33
+ i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_Conditional_4_div_1_Template_cauca_mobile_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r3); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.hourChanged($event)); });
34
+ i0.ɵɵelementEnd()();
35
+ } if (rf & 2) {
36
+ const ctx_r1 = i0.ɵɵnextContext(2);
37
+ i0.ɵɵadvance();
38
+ i0.ɵɵproperty("options", ctx_r1.hours)("value", ctx_r1.selectedHour);
39
+ } }
40
+ function DialogDateTimePickerComponent_Conditional_4_div_2_Template(rf, ctx) { if (rf & 1) {
41
+ i0.ɵɵelementStart(0, "div", 17);
42
+ i0.ɵɵtext(1, ":");
43
+ i0.ɵɵelementEnd();
44
+ } }
45
+ function DialogDateTimePickerComponent_Conditional_4_div_3_Template(rf, ctx) { if (rf & 1) {
46
+ const _r4 = i0.ɵɵgetCurrentView();
47
+ i0.ɵɵelementStart(0, "div", 18)(1, "cauca-desktop-time-picker", 15);
48
+ i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_Conditional_4_div_3_Template_cauca_desktop_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.minuteChanged($event)); });
49
+ i0.ɵɵelementEnd()();
50
+ } if (rf & 2) {
51
+ const ctx_r1 = i0.ɵɵnextContext(2);
52
+ i0.ɵɵadvance();
53
+ i0.ɵɵproperty("disabled", i0.ɵɵpureFunction2(3, _c0, ctx_r1.disabled.minutes, ctx_r1.disabled.someMinutes))("options", ctx_r1.minutes)("value", ctx_r1.selectedMinute);
54
+ } }
55
+ function DialogDateTimePickerComponent_Conditional_4_div_4_Template(rf, ctx) { if (rf & 1) {
56
+ const _r5 = i0.ɵɵgetCurrentView();
57
+ i0.ɵɵelementStart(0, "div", 18)(1, "cauca-mobile-time-picker", 16);
58
+ i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_Conditional_4_div_4_Template_cauca_mobile_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.minuteChanged($event)); });
59
+ i0.ɵɵelementEnd()();
60
+ } if (rf & 2) {
61
+ const ctx_r1 = i0.ɵɵnextContext(2);
62
+ i0.ɵɵadvance();
63
+ i0.ɵɵproperty("options", ctx_r1.minutes)("value", ctx_r1.selectedMinute);
64
+ } }
65
+ function DialogDateTimePickerComponent_Conditional_4_div_5_Template(rf, ctx) { if (rf & 1) {
66
+ i0.ɵɵelementStart(0, "div", 19);
67
+ i0.ɵɵtext(1, ":");
68
+ i0.ɵɵelementEnd();
69
+ } }
70
+ function DialogDateTimePickerComponent_Conditional_4_div_6_Template(rf, ctx) { if (rf & 1) {
71
+ const _r6 = i0.ɵɵgetCurrentView();
72
+ i0.ɵɵelementStart(0, "div", 20)(1, "cauca-desktop-time-picker", 15);
73
+ i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_Conditional_4_div_6_Template_cauca_desktop_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r6); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.secondChanged($event)); });
74
+ i0.ɵɵelementEnd()();
75
+ } if (rf & 2) {
76
+ const ctx_r1 = i0.ɵɵnextContext(2);
77
+ i0.ɵɵadvance();
78
+ i0.ɵɵproperty("disabled", i0.ɵɵpureFunction2(3, _c0, ctx_r1.disabled.seconds, ctx_r1.disabled.someSeconds))("options", ctx_r1.seconds)("value", ctx_r1.selectedSecond);
79
+ } }
80
+ function DialogDateTimePickerComponent_Conditional_4_div_7_Template(rf, ctx) { if (rf & 1) {
81
+ const _r7 = i0.ɵɵgetCurrentView();
82
+ i0.ɵɵelementStart(0, "div", 20)(1, "cauca-mobile-time-picker", 16);
83
+ i0.ɵɵlistener("valueChange", function DialogDateTimePickerComponent_Conditional_4_div_7_Template_cauca_mobile_time_picker_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r7); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.secondChanged($event)); });
84
+ i0.ɵɵelementEnd()();
85
+ } if (rf & 2) {
86
+ const ctx_r1 = i0.ɵɵnextContext(2);
87
+ i0.ɵɵadvance();
88
+ i0.ɵɵproperty("options", ctx_r1.seconds)("value", ctx_r1.selectedSecond);
89
+ } }
90
+ function DialogDateTimePickerComponent_Conditional_4_Template(rf, ctx) { if (rf & 1) {
91
+ i0.ɵɵtemplate(0, DialogDateTimePickerComponent_Conditional_4_div_0_Template, 2, 6, "div", 9)(1, DialogDateTimePickerComponent_Conditional_4_div_1_Template, 2, 2, "div", 9)(2, DialogDateTimePickerComponent_Conditional_4_div_2_Template, 2, 0, "div", 10)(3, DialogDateTimePickerComponent_Conditional_4_div_3_Template, 2, 6, "div", 11)(4, DialogDateTimePickerComponent_Conditional_4_div_4_Template, 2, 2, "div", 11)(5, DialogDateTimePickerComponent_Conditional_4_div_5_Template, 2, 0, "div", 12)(6, DialogDateTimePickerComponent_Conditional_4_div_6_Template, 2, 6, "div", 13)(7, DialogDateTimePickerComponent_Conditional_4_div_7_Template, 2, 2, "div", 13);
92
+ } if (rf & 2) {
93
+ const ctx_r1 = i0.ɵɵnextContext();
94
+ i0.ɵɵproperty("ngIf", !ctx_r1.showMobileUi);
95
+ i0.ɵɵadvance();
96
+ i0.ɵɵproperty("ngIf", ctx_r1.showMobileUi);
97
+ i0.ɵɵadvance();
98
+ i0.ɵɵproperty("ngIf", ctx_r1.showMobileUi);
99
+ i0.ɵɵadvance();
100
+ i0.ɵɵproperty("ngIf", !ctx_r1.showMobileUi);
101
+ i0.ɵɵadvance();
102
+ i0.ɵɵproperty("ngIf", ctx_r1.showMobileUi);
103
+ i0.ɵɵadvance();
104
+ i0.ɵɵproperty("ngIf", ctx_r1.showSeconds && ctx_r1.showMobileUi);
105
+ i0.ɵɵadvance();
106
+ i0.ɵɵproperty("ngIf", ctx_r1.showSeconds && !ctx_r1.showMobileUi);
107
+ i0.ɵɵadvance();
108
+ i0.ɵɵproperty("ngIf", ctx_r1.showSeconds && ctx_r1.showMobileUi);
109
+ } }
110
+ function DialogDateTimePickerComponent_button_6_mat_icon_1_Template(rf, ctx) { if (rf & 1) {
111
+ i0.ɵɵelementStart(0, "mat-icon");
112
+ i0.ɵɵtext(1, "clear");
113
+ i0.ɵɵelementEnd();
114
+ } }
115
+ function DialogDateTimePickerComponent_button_6_Template(rf, ctx) { if (rf & 1) {
116
+ const _r8 = i0.ɵɵgetCurrentView();
117
+ i0.ɵɵelementStart(0, "button", 6);
118
+ i0.ɵɵlistener("click", function DialogDateTimePickerComponent_button_6_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r8); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.clear()); });
119
+ i0.ɵɵtemplate(1, DialogDateTimePickerComponent_button_6_mat_icon_1_Template, 2, 0, "mat-icon", 7);
120
+ i0.ɵɵtext(2);
121
+ i0.ɵɵpipe(3, "translate");
122
+ i0.ɵɵelementEnd();
123
+ } if (rf & 2) {
124
+ const ctx_r1 = i0.ɵɵnextContext();
125
+ i0.ɵɵadvance();
126
+ i0.ɵɵproperty("ngIf", ctx_r1.showButtonIcons);
127
+ i0.ɵɵadvance();
128
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(3, 2, "material.clear"), " ");
129
+ } }
130
+ function DialogDateTimePickerComponent_mat_icon_8_Template(rf, ctx) { if (rf & 1) {
131
+ i0.ɵɵelementStart(0, "mat-icon");
132
+ i0.ɵɵtext(1, "cancel");
133
+ i0.ɵɵelementEnd();
134
+ } }
135
+ function DialogDateTimePickerComponent_mat_icon_12_Template(rf, ctx) { if (rf & 1) {
136
+ i0.ɵɵelementStart(0, "mat-icon");
137
+ i0.ɵɵtext(1, "check");
138
+ i0.ɵɵelementEnd();
139
+ } }
140
+ export class DialogDateTimePickerComponent {
141
+ constructor(dialogRef, options) {
142
+ this.dialogRef = dialogRef;
143
+ this.options = options;
144
+ this.selectedHour = 0;
145
+ this.selectedMinute = 0;
146
+ this.selectedSecond = 0;
147
+ this.initialDate = null;
148
+ this.selectedDate = null;
149
+ this.minimumDate = new Date();
150
+ this.maximumDate = new Date();
151
+ this.showSeconds = false;
152
+ this.showClearButton = true;
153
+ this.showButtonIcons = true;
154
+ this.hours = [...Array(24).keys()];
155
+ this.minutes = [...Array(60).keys()];
156
+ this.seconds = [...Array(60).keys()];
157
+ this.showMobileUi = false;
158
+ this.showTime = signal(true);
159
+ this.disabled = {
160
+ hours: true,
161
+ someHours: [],
162
+ minutes: true,
163
+ someMinutes: [],
164
+ seconds: true,
165
+ someSeconds: [],
166
+ };
167
+ this.step = {
168
+ hours: 1,
169
+ minutes: 1,
170
+ seconds: 1,
171
+ };
172
+ this.step = options.step || this.step;
173
+ this.showSeconds = options.showSeconds;
174
+ this.showButtonIcons = options.showButtonIcons ?? this.showButtonIcons;
175
+ this.showClearButton = options.showClearButton ?? this.showClearButton;
176
+ this.showTime.set(options.showTime ?? true);
177
+ this.setListHoursMinutes();
178
+ this.initialEachComponentValue(options);
179
+ }
180
+ ngOnInit() {
181
+ this.onWindowWithChange(window.innerWidth);
182
+ }
183
+ onResize(event) {
184
+ this.onWindowWithChange(event.target.innerWidth);
185
+ }
186
+ dateChanged(date) {
187
+ if (date) {
188
+ this.selectedDate = date;
189
+ this.selectedDate.setHours(this.selectedHour);
190
+ this.selectedDate.setMinutes(this.selectedMinute);
191
+ this.selectedDate.setSeconds(this.selectedSecond);
192
+ this.disabled.hours = false;
193
+ this.disabled.someHours = this.hours.filter(hour => this.hourOfSelectedDateIsDisabled(hour));
194
+ }
195
+ else {
196
+ this.selectedDate = null;
197
+ this.disabled.hours = true;
198
+ }
199
+ }
200
+ hourChanged(hour) {
201
+ if (this.disabled.hours || this.disabled.someHours.includes(hour))
202
+ return;
203
+ this.selectedHour = hour;
204
+ this.selectedDate.setHours(hour);
205
+ this.disabled.minutes = false;
206
+ this.disabled.someMinutes = this.minutes.filter(minute => this.minuteOfSelectedDateIsDisabled(minute));
207
+ }
208
+ minuteChanged(minute) {
209
+ if (this.disabled.minutes || this.disabled.someMinutes.includes(minute))
210
+ return;
211
+ this.selectedMinute = minute;
212
+ this.selectedDate.setMinutes(minute);
213
+ this.disabled.seconds = false;
214
+ this.disabled.someSeconds = this.seconds.filter(second => this.secondOfSelectedDateIsDisabled(second));
215
+ }
216
+ secondChanged(second) {
217
+ if (this.disabled.seconds || this.disabled.someSeconds.includes(second))
218
+ return;
219
+ this.selectedSecond = second;
220
+ this.selectedDate.setSeconds(second);
221
+ }
222
+ clear() {
223
+ this.dialogRef.close({
224
+ value: null
225
+ });
226
+ }
227
+ cancel() {
228
+ this.dialogRef.close({
229
+ value: this.initialDate
230
+ });
231
+ }
232
+ confirm() {
233
+ this.dialogRef.close({
234
+ value: this.selectedDate
235
+ });
236
+ }
237
+ onWindowWithChange(width) {
238
+ this.showMobileUi = width && width <= 555;
239
+ }
240
+ hourOfSelectedDateIsDisabled(hour) {
241
+ if (this.selectedDateIsTheMinimumDate()) {
242
+ return hour < this.minimumDate.getHours();
243
+ }
244
+ else if (this.selectedDateIsTheMaximumDate()) {
245
+ return hour > this.maximumDate.getHours();
246
+ }
247
+ return false;
248
+ }
249
+ minuteOfSelectedDateIsDisabled(minute) {
250
+ if (this.selectedDateIsTheMinimumDate() &&
251
+ this.selectedDate.getHours() === this.minimumDate.getHours()) {
252
+ return minute < this.minimumDate.getMinutes();
253
+ }
254
+ else if (this.selectedDateIsTheMaximumDate() &&
255
+ this.selectedDate.getHours() === this.maximumDate.getHours()) {
256
+ return minute > this.maximumDate.getMinutes();
257
+ }
258
+ return false;
259
+ }
260
+ secondOfSelectedDateIsDisabled(second) {
261
+ if (this.selectedDateIsTheMinimumDate() &&
262
+ this.selectedDate.getHours() === this.minimumDate.getHours() &&
263
+ this.selectedDate.getMinutes() === this.minimumDate.getMinutes()) {
264
+ return second < this.minimumDate.getSeconds();
265
+ }
266
+ else if (this.selectedDateIsTheMaximumDate() &&
267
+ this.selectedDate.getMinutes() === this.maximumDate.getMinutes()) {
268
+ return second > this.maximumDate.getSeconds();
269
+ }
270
+ return false;
271
+ }
272
+ initialEachComponentValue(options) {
273
+ this.initialDate = options.selectedDate ? new Date(options.selectedDate) : null;
274
+ this.minimumDate = options.minimumDate ? new Date(options.minimumDate) : null;
275
+ this.maximumDate = options.maximumDate ? new Date(options.maximumDate) : null;
276
+ this.selectedDate = options.selectedDate ? new Date(options.selectedDate) : new Date();
277
+ this.dateChanged(options.selectedDate ? new Date(options.selectedDate) : null);
278
+ this.hourChanged(options.selectedDate ? new Date(options.selectedDate).getHours() : 0);
279
+ this.minuteChanged(options.selectedDate ? new Date(options.selectedDate).getMinutes() : 0);
280
+ this.secondChanged(options.selectedDate ? new Date(options.selectedDate).getSeconds() : 0);
281
+ }
282
+ selectedDateIsTheMinimumDate() {
283
+ return (this.minimumDate &&
284
+ this.selectedDate.getFullYear() === this.minimumDate.getFullYear() &&
285
+ this.selectedDate.getMonth() === this.minimumDate.getMonth() &&
286
+ this.selectedDate.getDate() === this.minimumDate.getDate());
287
+ }
288
+ selectedDateIsTheMaximumDate() {
289
+ return (this.maximumDate &&
290
+ this.selectedDate.getFullYear() === this.maximumDate.getFullYear() &&
291
+ this.selectedDate.getMonth() === this.maximumDate.getMonth() &&
292
+ this.selectedDate.getDate() === this.maximumDate.getDate());
293
+ }
294
+ setListHoursMinutes() {
295
+ this.hours = this.hours.filter(hour => hour % this.step.hours === 0);
296
+ this.minutes = this.minutes.filter(minute => minute % this.step.minutes === 0);
297
+ this.seconds = this.seconds.filter(seconde => seconde % this.step.seconds === 0);
298
+ }
299
+ static { this.ɵfac = function DialogDateTimePickerComponent_Factory(t) { return new (t || DialogDateTimePickerComponent)(i0.ɵɵdirectiveInject(i1.MatDialogRef), i0.ɵɵdirectiveInject(MAT_DIALOG_DATA)); }; }
300
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DialogDateTimePickerComponent, selectors: [["cauca-dialog-date-time-picker"]], hostBindings: function DialogDateTimePickerComponent_HostBindings(rf, ctx) { if (rf & 1) {
301
+ i0.ɵɵlistener("resize", function DialogDateTimePickerComponent_resize_HostBindingHandler($event) { return ctx.onResize($event); }, false, i0.ɵɵresolveWindow);
302
+ } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 15, vars: 14, consts: [["mat-dialog-content", ""], [1, "date-time-picker", 3, "ngClass"], [1, "calendar"], [3, "selectedChange", "minDate", "maxDate", "selected"], ["mat-dialog-actions", "", "align", "end"], ["mat-stroked-button", "", 3, "click", 4, "ngIf"], ["mat-stroked-button", "", 3, "click"], [4, "ngIf"], ["color", "primary", "mat-raised-button", "", "cdkFocusInitial", "", 3, "click"], ["class", "hours", 4, "ngIf"], ["class", "hour-and-minute-separator", 4, "ngIf"], ["class", "minutes", 4, "ngIf"], ["class", "minute-and-second-separator", 4, "ngIf"], ["class", "seconds", 4, "ngIf"], [1, "hours"], [3, "valueChange", "disabled", "options", "value"], [3, "valueChange", "options", "value"], [1, "hour-and-minute-separator"], [1, "minutes"], [1, "minute-and-second-separator"], [1, "seconds"]], template: function DialogDateTimePickerComponent_Template(rf, ctx) { if (rf & 1) {
303
+ i0.ɵɵelementStart(0, "div", 0)(1, "div", 1)(2, "div", 2)(3, "mat-calendar", 3);
304
+ i0.ɵɵlistener("selectedChange", function DialogDateTimePickerComponent_Template_mat_calendar_selectedChange_3_listener($event) { return ctx.dateChanged($event); });
305
+ i0.ɵɵelementEnd()();
306
+ i0.ɵɵtemplate(4, DialogDateTimePickerComponent_Conditional_4_Template, 8, 8);
307
+ i0.ɵɵelementEnd()();
308
+ i0.ɵɵelementStart(5, "div", 4);
309
+ i0.ɵɵtemplate(6, DialogDateTimePickerComponent_button_6_Template, 4, 4, "button", 5);
310
+ i0.ɵɵelementStart(7, "button", 6);
311
+ i0.ɵɵlistener("click", function DialogDateTimePickerComponent_Template_button_click_7_listener() { return ctx.cancel(); });
312
+ i0.ɵɵtemplate(8, DialogDateTimePickerComponent_mat_icon_8_Template, 2, 0, "mat-icon", 7);
313
+ i0.ɵɵtext(9);
314
+ i0.ɵɵpipe(10, "translate");
315
+ i0.ɵɵelementEnd();
316
+ i0.ɵɵelementStart(11, "button", 8);
317
+ i0.ɵɵlistener("click", function DialogDateTimePickerComponent_Template_button_click_11_listener() { return ctx.confirm(); });
318
+ i0.ɵɵtemplate(12, DialogDateTimePickerComponent_mat_icon_12_Template, 2, 0, "mat-icon", 7);
319
+ i0.ɵɵtext(13);
320
+ i0.ɵɵpipe(14, "translate");
321
+ i0.ɵɵelementEnd()();
322
+ } if (rf & 2) {
323
+ i0.ɵɵadvance();
324
+ i0.ɵɵproperty("ngClass", ctx.showSeconds ? "show-seconds" : "hide-seconds");
325
+ i0.ɵɵadvance(2);
326
+ i0.ɵɵproperty("minDate", ctx.minimumDate)("maxDate", ctx.maximumDate)("selected", ctx.selectedDate);
327
+ i0.ɵɵadvance();
328
+ i0.ɵɵconditional(ctx.showTime() ? 4 : -1);
329
+ i0.ɵɵadvance(2);
330
+ i0.ɵɵproperty("ngIf", ctx.showClearButton);
331
+ i0.ɵɵadvance(2);
332
+ i0.ɵɵproperty("ngIf", ctx.showButtonIcons);
333
+ i0.ɵɵadvance();
334
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(10, 10, "material.cancel"), " ");
335
+ i0.ɵɵadvance(3);
336
+ i0.ɵɵproperty("ngIf", ctx.showButtonIcons);
337
+ i0.ɵɵadvance();
338
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(14, 12, "material.ok"), " ");
339
+ } }, dependencies: [CommonModule, i2.NgClass, i2.NgIf, CaucaCoreForChildModule, i3.TranslatePipe, MatButtonModule, i4.MatButton, MatDatepickerModule, i5.MatCalendar, MatIconModule, i6.MatIcon, MatListModule,
340
+ MatNativeDateModule,
341
+ MobileTimePickerComponent,
342
+ DesktopTimePickerComponent], styles: ["div[mat-dialog-actions][_ngcontent-%COMP%]{padding:8px;border-top:1px solid #ccc}div[mat-dialog-actions][_ngcontent-%COMP%] button[_ngcontent-%COMP%]{margin:2px}.date-time-picker[_ngcontent-%COMP%]{display:grid;grid-template-areas:\"calendar hours minutes seconds\";height:350px;overflow:hidden;justify-content:center}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]{overflow:auto;flex:1;max-width:50px;scrollbar-width:none;border-left:1px solid #ccc}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]:first-child{flex:4;max-width:290px;border-left:none}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]:first-child mat-calendar[_ngcontent-%COMP%]{width:290px;height:350px}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]::-webkit-scrollbar{display:none}.date-time-picker[_ngcontent-%COMP%] .mdc-list-item__primary-text{font-family:var(--mat-datepicker-calendar-text-font);font-size:var(--mat-datepicker-calendar-text-size)}.date-time-picker[_ngcontent-%COMP%] .mdc-list-item--activated{background-color:var(--mat-datepicker-calendar-date-selected-state-background-color)}.date-time-picker[_ngcontent-%COMP%] .mdc-list-item--activated .mdc-list-item__primary-text{color:var(--mat-datepicker-calendar-date-selected-state-text-color)}.calendar[_ngcontent-%COMP%]{grid-area:calendar}.hours[_ngcontent-%COMP%]{grid-area:hours}.minutes[_ngcontent-%COMP%]{grid-area:minutes}.seconds[_ngcontent-%COMP%]{grid-area:seconds}.hour-and-minute-separator[_ngcontent-%COMP%]{grid-area:hour-and-minute-separator;display:flex;align-items:center;justify-content:center;font-weight:700}.minute-and-second-separator[_ngcontent-%COMP%]{grid-area:minute-and-second-separator;display:flex;align-items:center;justify-content:center;font-weight:700}@media only screen and (max-width: 555px){.show-seconds[_ngcontent-%COMP%]{grid-template-areas:\"calendar calendar calendar calendar calendar calendar calendar\" \". hours hour-and-minute-separator minutes minute-and-second-separator seconds .\";grid-template-columns:auto 40px 2px 40px 2px 40px auto}.hide-seconds[_ngcontent-%COMP%]{grid-template-areas:\"calendar calendar calendar calendar calendar\" \". hours hour-and-minute-separator minutes .\";grid-template-columns:auto 40px 2px 40px auto}.date-time-picker[_ngcontent-%COMP%]{grid-template-rows:auto auto;height:450px}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]{border-left:none}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]:not(:first-child){height:70px}.date-time-picker[_ngcontent-%COMP%] > div[_ngcontent-%COMP%]:first-child{overflow:initial;flex:4;max-width:290px;border-left:none}}"] }); }
343
+ }
344
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DialogDateTimePickerComponent, [{
345
+ type: Component,
346
+ args: [{ selector: 'cauca-dialog-date-time-picker', standalone: true, imports: [
347
+ CommonModule,
348
+ CaucaCoreForChildModule,
349
+ MatButtonModule,
350
+ MatDatepickerModule,
351
+ MatIconModule,
352
+ MatListModule,
353
+ MatNativeDateModule,
354
+ MobileTimePickerComponent,
355
+ DesktopTimePickerComponent
356
+ ], template: "<div mat-dialog-content>\n <div [ngClass]=\"showSeconds ? 'show-seconds' : 'hide-seconds'\" class=\"date-time-picker\">\n <div class=\"calendar\">\n <mat-calendar\n [minDate]=\"minimumDate\"\n [maxDate]=\"maximumDate\"\n [selected]=\"selectedDate\"\n (selectedChange)=\"dateChanged($event)\"\n ></mat-calendar>\n </div>\n\n @if (showTime()) {\n <div class=\"hours\" *ngIf=\"!showMobileUi\">\n <cauca-desktop-time-picker [disabled]=\"{all: disabled.hours, someOptions: disabled.someHours}\" (valueChange)=\"hourChanged($event)\" [options]=\"hours\" [value]=\"selectedHour\"/>\n </div>\n <div class=\"hours\" *ngIf=\"showMobileUi\">\n <cauca-mobile-time-picker (valueChange)=\"hourChanged($event)\" [options]=\"hours\" [value]=\"selectedHour\" />\n </div>\n \n <div class=\"hour-and-minute-separator\" *ngIf=\"showMobileUi\">:</div>\n \n <div class=\"minutes\" *ngIf=\"!showMobileUi\">\n <cauca-desktop-time-picker [disabled]=\"{all: disabled.minutes, someOptions: disabled.someMinutes}\" (valueChange)=\"minuteChanged($event)\" [options]=\"minutes\" [value]=\"selectedMinute\"/>\n </div>\n <div class=\"minutes\" *ngIf=\"showMobileUi\">\n <cauca-mobile-time-picker (valueChange)=\"minuteChanged($event)\" [options]=\"minutes\" [value]=\"selectedMinute\" />\n </div>\n \n <div class=\"minute-and-second-separator\" *ngIf=\"showSeconds && showMobileUi\">:</div>\n <div class=\"seconds\" *ngIf=\"showSeconds && !showMobileUi\">\n <cauca-desktop-time-picker [disabled]=\"{all: disabled.seconds, someOptions: disabled.someSeconds}\" (valueChange)=\"secondChanged($event)\" [options]=\"seconds\" [value]=\"selectedSecond\"/>\n </div>\n <div class=\"seconds\" *ngIf=\"showSeconds && showMobileUi\">\n <cauca-mobile-time-picker (valueChange)=\"secondChanged($event)\" [options]=\"seconds\" [value]=\"selectedSecond\" />\n </div>\n }\n </div>\n</div>\n\n<div mat-dialog-actions align=\"end\">\n <button mat-stroked-button (click)=\"clear()\" *ngIf=\"showClearButton\">\n <mat-icon *ngIf=\"showButtonIcons\">clear</mat-icon>\n {{'material.clear' | translate}}\n </button>\n <button mat-stroked-button (click)=\"cancel()\">\n <mat-icon *ngIf=\"showButtonIcons\">cancel</mat-icon>\n {{'material.cancel' | translate}}\n </button>\n <button color=\"primary\" mat-raised-button cdkFocusInitial (click)=\"confirm()\">\n <mat-icon *ngIf=\"showButtonIcons\">check</mat-icon>\n {{'material.ok' | translate}}\n </button>\n</div>", styles: ["div[mat-dialog-actions]{padding:8px;border-top:1px solid #ccc}div[mat-dialog-actions] button{margin:2px}.date-time-picker{display:grid;grid-template-areas:\"calendar hours minutes seconds\";height:350px;overflow:hidden;justify-content:center}.date-time-picker>div{overflow:auto;flex:1;max-width:50px;scrollbar-width:none;border-left:1px solid #ccc}.date-time-picker>div:first-child{flex:4;max-width:290px;border-left:none}.date-time-picker>div:first-child mat-calendar{width:290px;height:350px}.date-time-picker>div::-webkit-scrollbar{display:none}.date-time-picker ::ng-deep .mdc-list-item__primary-text{font-family:var(--mat-datepicker-calendar-text-font);font-size:var(--mat-datepicker-calendar-text-size)}.date-time-picker ::ng-deep .mdc-list-item--activated{background-color:var(--mat-datepicker-calendar-date-selected-state-background-color)}.date-time-picker ::ng-deep .mdc-list-item--activated .mdc-list-item__primary-text{color:var(--mat-datepicker-calendar-date-selected-state-text-color)}.calendar{grid-area:calendar}.hours{grid-area:hours}.minutes{grid-area:minutes}.seconds{grid-area:seconds}.hour-and-minute-separator{grid-area:hour-and-minute-separator;display:flex;align-items:center;justify-content:center;font-weight:700}.minute-and-second-separator{grid-area:minute-and-second-separator;display:flex;align-items:center;justify-content:center;font-weight:700}@media only screen and (max-width: 555px){.show-seconds{grid-template-areas:\"calendar calendar calendar calendar calendar calendar calendar\" \". hours hour-and-minute-separator minutes minute-and-second-separator seconds .\";grid-template-columns:auto 40px 2px 40px 2px 40px auto}.hide-seconds{grid-template-areas:\"calendar calendar calendar calendar calendar\" \". hours hour-and-minute-separator minutes .\";grid-template-columns:auto 40px 2px 40px auto}.date-time-picker{grid-template-rows:auto auto;height:450px}.date-time-picker>div{border-left:none}.date-time-picker>div:not(:first-child){height:70px}.date-time-picker>div:first-child{overflow:initial;flex:4;max-width:290px;border-left:none}}\n"] }]
357
+ }], () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
358
+ type: Inject,
359
+ args: [MAT_DIALOG_DATA]
360
+ }] }], { onResize: [{
361
+ type: HostListener,
362
+ args: ['window:resize', ['$event']]
363
+ }] }); })();
364
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DialogDateTimePickerComponent, { className: "DialogDateTimePickerComponent", filePath: "lib\\cauca-date-time-picker\\components\\dialog-date-time-picker\\dialog-date-time-picker.component.ts", lineNumber: 31 }); })();
365
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/cauca-material/src/lib/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.ts","../../../../../../../projects/cauca-material/src/lib/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Inject, OnInit, signal, WritableSignal } from '@angular/core';\nimport { MatNativeDateModule } from '@angular/material/core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { MatListModule } from '@angular/material/list';\nimport { DialogDateTimePickerOptions, DialogDateTimePickerDataDisabled, DialogDateTimePickerDataStep } from '../../models/dialog-date-time-picker-data';\nimport { CaucaCoreForChildModule } from '@cauca-911/core';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { CommonModule } from '@angular/common';\nimport { MobileTimePickerComponent } from '../mobile-time-picker/mobile-time-picker.component';\nimport { DesktopTimePickerComponent } from '../desktop-time-picker/desktop-time-picker.component';\n\n@Component({\n  selector: 'cauca-dialog-date-time-picker',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CaucaCoreForChildModule,\n    MatButtonModule,\n    MatDatepickerModule,\n    MatIconModule,\n    MatListModule,\n    MatNativeDateModule,\n    MobileTimePickerComponent,\n    DesktopTimePickerComponent\n  ],\n  templateUrl: './dialog-date-time-picker.component.html',\n  styleUrl: './dialog-date-time-picker.component.scss'\n})\nexport class DialogDateTimePickerComponent implements OnInit {\n  public selectedHour = 0;\n  public selectedMinute = 0;\n  public selectedSecond = 0;\n  public initialDate: Date = null;\n  public selectedDate: Date = null;\n  public minimumDate = new Date();\n  public maximumDate = new Date();\n  public showSeconds: boolean = false;\n  public showClearButton: boolean = true;\n  public showButtonIcons: boolean = true;\n\n  public hours = [...Array(24).keys()];\n  public minutes = [...Array(60).keys()];\n  public seconds = [...Array(60).keys()];\n  public showMobileUi: boolean = false;\n\n  public showTime: WritableSignal<boolean> = signal(true);\n\n  public disabled: DialogDateTimePickerDataDisabled = {\n    hours: true,\n    someHours: [],\n    minutes: true,\n    someMinutes: [],\n    seconds: true,\n    someSeconds: [],\n  };\n\n  private step: DialogDateTimePickerDataStep = {\n    hours: 1,\n    minutes: 1,\n    seconds: 1,\n  };\n\n  public constructor(\n    public dialogRef: MatDialogRef<DialogDateTimePickerComponent>,\n    @Inject(MAT_DIALOG_DATA) public options: DialogDateTimePickerOptions\n  ) {\n    this.step = options.step || this.step;\n    this.showSeconds = options.showSeconds;\n    this.showButtonIcons = options.showButtonIcons ?? this.showButtonIcons;\n    this.showClearButton = options.showClearButton ?? this.showClearButton;\n    this.showTime.set(options.showTime ?? true);\n    this.setListHoursMinutes();\n    this.initialEachComponentValue(options);\n  }\n\n  public ngOnInit(): void {\n    this.onWindowWithChange(window.innerWidth);\n  }\n\n  @HostListener('window:resize', ['$event'])\n  public onResize(event) {\n    this.onWindowWithChange(event.target.innerWidth);\n  }\n\n  public dateChanged(date: Date): void {\n    if (date) {\n      this.selectedDate = date;\n      this.selectedDate.setHours(this.selectedHour);\n      this.selectedDate.setMinutes(this.selectedMinute);\n      this.selectedDate.setSeconds(this.selectedSecond);\n      this.disabled.hours = false;\n      this.disabled.someHours = this.hours.filter(hour => this.hourOfSelectedDateIsDisabled(hour));\n    } else {\n      this.selectedDate = null;\n      this.disabled.hours = true;\n    }\n  }\n\n  public hourChanged(hour: number): void {\n    if (this.disabled.hours || this.disabled.someHours.includes(hour)) return;\n\n    this.selectedHour = hour;\n    this.selectedDate.setHours(hour);\n    this.disabled.minutes = false;\n    this.disabled.someMinutes = this.minutes.filter(minute => this.minuteOfSelectedDateIsDisabled(minute));\n  }\n\n  public minuteChanged(minute: number): void {\n    if (this.disabled.minutes || this.disabled.someMinutes.includes(minute)) return;\n\n    this.selectedMinute = minute;\n    this.selectedDate.setMinutes(minute);\n    this.disabled.seconds = false;\n    this.disabled.someSeconds = this.seconds.filter(second => this.secondOfSelectedDateIsDisabled(second));\n  }\n\n  public secondChanged(second: number): void {\n    if (this.disabled.seconds || this.disabled.someSeconds.includes(second)) return;\n\n    this.selectedSecond = second;\n    this.selectedDate.setSeconds(second);\n  }\n\n  public clear(): void {\n    this.dialogRef.close({\n      value: null\n    });\n  }\n\n  public cancel(): void {\n    this.dialogRef.close({\n      value: this.initialDate\n    });\n  }\n\n  public confirm(): void {\n    this.dialogRef.close({\n      value: this.selectedDate\n    });\n  }\n\n  private onWindowWithChange(width: number): void {\n    this.showMobileUi = width && width <= 555;\n  }\n\n  private hourOfSelectedDateIsDisabled(hour: number): boolean {\n    if (this.selectedDateIsTheMinimumDate()) {\n      return hour < this.minimumDate.getHours();\n    } else if (this.selectedDateIsTheMaximumDate()) {\n      return hour > this.maximumDate.getHours();\n    }\n\n    return false;\n  }\n\n  private minuteOfSelectedDateIsDisabled(minute: number): boolean {\n    if (\n      this.selectedDateIsTheMinimumDate() &&\n      this.selectedDate.getHours() === this.minimumDate.getHours()\n    ) {\n      return minute < this.minimumDate.getMinutes();\n    } else if (\n      this.selectedDateIsTheMaximumDate() &&\n      this.selectedDate.getHours() === this.maximumDate.getHours()\n    ) {\n      return minute > this.maximumDate.getMinutes();\n    }\n\n    return false;\n  }\n\n  private secondOfSelectedDateIsDisabled(second: number): boolean {\n    if (\n      this.selectedDateIsTheMinimumDate() &&\n      this.selectedDate.getHours() === this.minimumDate.getHours() &&\n      this.selectedDate.getMinutes() === this.minimumDate.getMinutes()\n    ) {\n      return second < this.minimumDate.getSeconds();\n    } else if (\n      this.selectedDateIsTheMaximumDate() &&\n      this.selectedDate.getMinutes() === this.maximumDate.getMinutes()\n    ) {\n      return second > this.maximumDate.getSeconds();\n    }\n\n    return false;\n  }\n\n  private initialEachComponentValue(options: DialogDateTimePickerOptions): void {\n    this.initialDate = options.selectedDate ? new Date(options.selectedDate) : null;\n    this.minimumDate = options.minimumDate ? new Date(options.minimumDate) : null;\n    this.maximumDate = options.maximumDate ? new Date(options.maximumDate) : null;\n    this.selectedDate = options.selectedDate ? new Date(options.selectedDate) : new Date();\n    this.dateChanged(options.selectedDate ? new Date(options.selectedDate) : null);\n    this.hourChanged(options.selectedDate ? new Date(options.selectedDate).getHours() : 0);\n    this.minuteChanged(options.selectedDate ? new Date(options.selectedDate).getMinutes() : 0);\n    this.secondChanged(options.selectedDate ? new Date(options.selectedDate).getSeconds() : 0);\n  }\n\n  private selectedDateIsTheMinimumDate(): boolean {\n    return (\n      this.minimumDate &&\n      this.selectedDate.getFullYear() === this.minimumDate.getFullYear() &&\n      this.selectedDate.getMonth() === this.minimumDate.getMonth() &&\n      this.selectedDate.getDate() === this.minimumDate.getDate()\n    );\n  }\n\n  private selectedDateIsTheMaximumDate(): boolean {\n    return (\n      this.maximumDate &&\n      this.selectedDate.getFullYear() === this.maximumDate.getFullYear() &&\n      this.selectedDate.getMonth() === this.maximumDate.getMonth() &&\n      this.selectedDate.getDate() === this.maximumDate.getDate()\n    );\n  }\n\n  private setListHoursMinutes(): void {\n    this.hours = this.hours.filter(hour => hour % this.step.hours === 0);\n    this.minutes = this.minutes.filter(minute => minute % this.step.minutes === 0);\n    this.seconds = this.seconds.filter(seconde => seconde % this.step.seconds === 0);\n  }\n}\n","<div mat-dialog-content>\n    <div [ngClass]=\"showSeconds ? 'show-seconds' : 'hide-seconds'\" class=\"date-time-picker\">\n        <div class=\"calendar\">\n            <mat-calendar\n                [minDate]=\"minimumDate\"\n                [maxDate]=\"maximumDate\"\n                [selected]=\"selectedDate\"\n                (selectedChange)=\"dateChanged($event)\"\n            ></mat-calendar>\n        </div>\n\n        @if (showTime()) {\n            <div class=\"hours\" *ngIf=\"!showMobileUi\">\n                <cauca-desktop-time-picker [disabled]=\"{all: disabled.hours, someOptions: disabled.someHours}\" (valueChange)=\"hourChanged($event)\" [options]=\"hours\" [value]=\"selectedHour\"/>\n            </div>\n            <div class=\"hours\" *ngIf=\"showMobileUi\">\n                <cauca-mobile-time-picker (valueChange)=\"hourChanged($event)\" [options]=\"hours\" [value]=\"selectedHour\" />\n            </div>\n            \n            <div class=\"hour-and-minute-separator\" *ngIf=\"showMobileUi\">:</div>\n            \n            <div class=\"minutes\" *ngIf=\"!showMobileUi\">\n                <cauca-desktop-time-picker [disabled]=\"{all: disabled.minutes, someOptions: disabled.someMinutes}\" (valueChange)=\"minuteChanged($event)\" [options]=\"minutes\" [value]=\"selectedMinute\"/>\n            </div>\n            <div class=\"minutes\" *ngIf=\"showMobileUi\">\n                <cauca-mobile-time-picker (valueChange)=\"minuteChanged($event)\" [options]=\"minutes\" [value]=\"selectedMinute\" />\n            </div>\n            \n            <div class=\"minute-and-second-separator\" *ngIf=\"showSeconds && showMobileUi\">:</div>\n            <div class=\"seconds\" *ngIf=\"showSeconds && !showMobileUi\">\n                <cauca-desktop-time-picker [disabled]=\"{all: disabled.seconds, someOptions: disabled.someSeconds}\" (valueChange)=\"secondChanged($event)\" [options]=\"seconds\" [value]=\"selectedSecond\"/>\n            </div>\n            <div class=\"seconds\" *ngIf=\"showSeconds && showMobileUi\">\n                <cauca-mobile-time-picker (valueChange)=\"secondChanged($event)\" [options]=\"seconds\" [value]=\"selectedSecond\" />\n            </div>\n        }\n    </div>\n</div>\n\n<div mat-dialog-actions align=\"end\">\n    <button mat-stroked-button (click)=\"clear()\" *ngIf=\"showClearButton\">\n        <mat-icon *ngIf=\"showButtonIcons\">clear</mat-icon>\n        {{'material.clear' | translate}}\n    </button>\n    <button mat-stroked-button (click)=\"cancel()\">\n        <mat-icon *ngIf=\"showButtonIcons\">cancel</mat-icon>\n        {{'material.cancel' | translate}}\n    </button>\n    <button color=\"primary\" mat-raised-button cdkFocusInitial (click)=\"confirm()\">\n        <mat-icon *ngIf=\"showButtonIcons\">check</mat-icon>\n        {{'material.ok' | translate}}\n    </button>\n</div>"]}
@@ -0,0 +1,74 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { MatButtonModule } from '@angular/material/button';
3
+ import { MatFormFieldModule } from '@angular/material/form-field';
4
+ import { MatIconModule } from '@angular/material/icon';
5
+ import { MatInputModule } from '@angular/material/input';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/material/button";
8
+ import * as i2 from "@angular/material/icon";
9
+ export class MobileTimePickerComponent {
10
+ constructor() {
11
+ this.valueChange = new EventEmitter();
12
+ }
13
+ valueUp() {
14
+ const currentIndex = this.options.indexOf(this.value);
15
+ let newValue = 0;
16
+ if (currentIndex === this.options.length - 1) {
17
+ newValue = this.options[0];
18
+ }
19
+ else {
20
+ newValue = this.options[currentIndex + 1];
21
+ }
22
+ this.valueChange.emit(newValue);
23
+ }
24
+ valueDown() {
25
+ const currentIndex = this.options.indexOf(this.value);
26
+ let newValue = 0;
27
+ if (currentIndex === 0) {
28
+ newValue = this.options[this.options.length - 1];
29
+ }
30
+ else {
31
+ newValue = this.options[currentIndex - 1];
32
+ }
33
+ this.valueChange.emit(newValue);
34
+ }
35
+ static { this.ɵfac = function MobileTimePickerComponent_Factory(t) { return new (t || MobileTimePickerComponent)(); }; }
36
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: MobileTimePickerComponent, selectors: [["cauca-mobile-time-picker"]], inputs: { value: "value", options: "options" }, outputs: { valueChange: "valueChange" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 8, vars: 1, consts: [["mat-icon-button", "", 3, "click"]], template: function MobileTimePickerComponent_Template(rf, ctx) { if (rf & 1) {
37
+ i0.ɵɵelementStart(0, "button", 0);
38
+ i0.ɵɵlistener("click", function MobileTimePickerComponent_Template_button_click_0_listener() { return ctx.valueUp(); });
39
+ i0.ɵɵelementStart(1, "mat-icon");
40
+ i0.ɵɵtext(2, "keyboard_arrow_up");
41
+ i0.ɵɵelementEnd()();
42
+ i0.ɵɵelementStart(3, "div");
43
+ i0.ɵɵtext(4);
44
+ i0.ɵɵelementEnd();
45
+ i0.ɵɵelementStart(5, "button", 0);
46
+ i0.ɵɵlistener("click", function MobileTimePickerComponent_Template_button_click_5_listener() { return ctx.valueDown(); });
47
+ i0.ɵɵelementStart(6, "mat-icon");
48
+ i0.ɵɵtext(7, "keyboard_arrow_down");
49
+ i0.ɵɵelementEnd()();
50
+ } if (rf & 2) {
51
+ i0.ɵɵadvance(4);
52
+ i0.ɵɵtextInterpolate1("\n", (ctx.value < 10 ? "0" : "") + ctx.value, "\n");
53
+ } }, dependencies: [MatButtonModule, i1.MatIconButton, MatIconModule, i2.MatIcon, MatFormFieldModule,
54
+ MatInputModule], styles: ["[_nghost-%COMP%]{display:flex;flex-direction:column;align-items:center;justify-content:center;height:70px;font-family:var(--mat-form-field-container-text-font)}.mat-mdc-icon-button[_ngcontent-%COMP%]{height:24px;width:24px;line-height:24px;padding:0}"] }); }
55
+ }
56
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MobileTimePickerComponent, [{
57
+ type: Component,
58
+ args: [{ selector: 'cauca-mobile-time-picker', standalone: true, imports: [
59
+ MatButtonModule,
60
+ MatIconModule,
61
+ MatFormFieldModule,
62
+ MatInputModule
63
+ ], template: "<button mat-icon-button (click)=\"valueUp()\">\n <mat-icon>keyboard_arrow_up</mat-icon>\n</button>\n<div>\n{{(value < 10 ? '0' : '' ) + value}}\n</div>\n<button mat-icon-button (click)=\"valueDown()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n</button>\n", styles: [":host{display:flex;flex-direction:column;align-items:center;justify-content:center;height:70px;font-family:var(--mat-form-field-container-text-font)}.mat-mdc-icon-button{height:24px;width:24px;line-height:24px;padding:0}\n"] }]
64
+ }], null, { value: [{
65
+ type: Input,
66
+ args: [{ required: true }]
67
+ }], options: [{
68
+ type: Input,
69
+ args: [{ required: true }]
70
+ }], valueChange: [{
71
+ type: Output
72
+ }] }); })();
73
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MobileTimePickerComponent, { className: "MobileTimePickerComponent", filePath: "lib\\cauca-date-time-picker\\components\\mobile-time-picker\\mobile-time-picker.component.ts", lineNumber: 19 }); })();
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9iaWxlLXRpbWUtcGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhdWNhLW1hdGVyaWFsL3NyYy9saWIvY2F1Y2EtZGF0ZS10aW1lLXBpY2tlci9jb21wb25lbnRzL21vYmlsZS10aW1lLXBpY2tlci9tb2JpbGUtdGltZS1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2F1Y2EtbWF0ZXJpYWwvc3JjL2xpYi9jYXVjYS1kYXRlLXRpbWUtcGlja2VyL2NvbXBvbmVudHMvbW9iaWxlLXRpbWUtcGlja2VyL21vYmlsZS10aW1lLXBpY2tlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDOzs7O0FBY3pELE1BQU0sT0FBTyx5QkFBeUI7SUFadEM7UUFnQm1CLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztLQXlCM0Q7SUF2QlEsT0FBTztRQUNaLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN0RCxJQUFJLFFBQVEsR0FBRyxDQUFDLENBQUM7UUFDakIsSUFBSSxZQUFZLEtBQUssSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDN0MsUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDN0IsQ0FBQzthQUFNLENBQUM7WUFDTixRQUFRLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDNUMsQ0FBQztRQUVELElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFTSxTQUFTO1FBQ2QsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3RELElBQUksUUFBUSxHQUFHLENBQUMsQ0FBQztRQUNqQixJQUFJLFlBQVksS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN2QixRQUFRLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNuRCxDQUFDO2FBQU0sQ0FBQztZQUNOLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksR0FBRyxDQUFDLENBQUMsQ0FBQztRQUM1QyxDQUFDO1FBRUQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbEMsQ0FBQzswRkE1QlUseUJBQXlCO29FQUF6Qix5QkFBeUI7WUNsQnRDLGlDQUE0QztZQUFwQixzR0FBUyxhQUFTLElBQUM7WUFDdkMsZ0NBQVU7WUFBQSxpQ0FBaUI7WUFDL0IsQUFEK0IsaUJBQVcsRUFDakM7WUFDVCwyQkFBSztZQUNMLFlBQ0E7WUFBQSxpQkFBTTtZQUNOLGlDQUE4QztZQUF0QixzR0FBUyxlQUFXLElBQUM7WUFDekMsZ0NBQVU7WUFBQSxtQ0FBbUI7WUFDakMsQUFEaUMsaUJBQVcsRUFDbkM7O1lBSlQsZUFDQTtZQURBLDBFQUNBOzRCREtJLGVBQWUsb0JBQ2YsYUFBYSxjQUNiLGtCQUFrQjtZQUNsQixjQUFjOztpRkFLTCx5QkFBeUI7Y0FackMsU0FBUzsyQkFDRSwwQkFBMEIsY0FDeEIsSUFBSSxXQUNQO29CQUNQLGVBQWU7b0JBQ2YsYUFBYTtvQkFDYixrQkFBa0I7b0JBQ2xCLGNBQWM7aUJBQ2Y7Z0JBSytCLEtBQUs7a0JBQXBDLEtBQUs7bUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO1lBQ1csT0FBTztrQkFBeEMsS0FBSzttQkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUU7WUFFUixXQUFXO2tCQUEzQixNQUFNOztrRkFKSSx5QkFBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2NhdWNhLW1vYmlsZS10aW1lLXBpY2tlcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXG4gICAgTWF0SW5wdXRNb2R1bGVcbiAgXSxcbiAgdGVtcGxhdGVVcmw6ICcuL21vYmlsZS10aW1lLXBpY2tlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9tb2JpbGUtdGltZS1waWNrZXIuY29tcG9uZW50LnNjc3MnXG59KVxuZXhwb3J0IGNsYXNzIE1vYmlsZVRpbWVQaWNrZXJDb21wb25lbnQge1xuICBASW5wdXQoe3JlcXVpcmVkOiB0cnVlfSkgcHVibGljIHZhbHVlOiBudW1iZXI7XG4gIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIHB1YmxpYyBvcHRpb25zOiBudW1iZXJbXTtcblxuICBAT3V0cHV0KCkgcHVibGljIHZhbHVlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XG5cbiAgcHVibGljIHZhbHVlVXAoKTogdm9pZCB7XG4gICAgY29uc3QgY3VycmVudEluZGV4ID0gdGhpcy5vcHRpb25zLmluZGV4T2YodGhpcy52YWx1ZSk7XG4gICAgbGV0IG5ld1ZhbHVlID0gMDtcbiAgICBpZiAoY3VycmVudEluZGV4ID09PSB0aGlzLm9wdGlvbnMubGVuZ3RoIC0gMSkge1xuICAgICAgbmV3VmFsdWUgPSB0aGlzLm9wdGlvbnNbMF07XG4gICAgfSBlbHNlIHtcbiAgICAgIG5ld1ZhbHVlID0gdGhpcy5vcHRpb25zW2N1cnJlbnRJbmRleCArIDFdO1xuICAgIH1cblxuICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdChuZXdWYWx1ZSk7XG4gIH1cblxuICBwdWJsaWMgdmFsdWVEb3duKCk6IHZvaWQge1xuICAgIGNvbnN0IGN1cnJlbnRJbmRleCA9IHRoaXMub3B0aW9ucy5pbmRleE9mKHRoaXMudmFsdWUpO1xuICAgIGxldCBuZXdWYWx1ZSA9IDA7XG4gICAgaWYgKGN1cnJlbnRJbmRleCA9PT0gMCkge1xuICAgICAgbmV3VmFsdWUgPSB0aGlzLm9wdGlvbnNbdGhpcy5vcHRpb25zLmxlbmd0aCAtIDFdO1xuICAgIH0gZWxzZSB7XG4gICAgICBuZXdWYWx1ZSA9IHRoaXMub3B0aW9uc1tjdXJyZW50SW5kZXggLSAxXTtcbiAgICB9XG5cbiAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQobmV3VmFsdWUpO1xuICB9XG59XG4iLCI8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAoY2xpY2spPVwidmFsdWVVcCgpXCI+XG4gICAgPG1hdC1pY29uPmtleWJvYXJkX2Fycm93X3VwPC9tYXQtaWNvbj5cbjwvYnV0dG9uPlxuPGRpdj5cbnt7KHZhbHVlIDwgMTAgPyAnMCcgOiAnJyApICsgdmFsdWV9fVxuPC9kaXY+XG48YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAoY2xpY2spPVwidmFsdWVEb3duKClcIj5cbiAgICA8bWF0LWljb24+a2V5Ym9hcmRfYXJyb3dfZG93bjwvbWF0LWljb24+XG48L2J1dHRvbj5cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWRhdGUtdGltZS1waWNrZXItZGF0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhdWNhLW1hdGVyaWFsL3NyYy9saWIvY2F1Y2EtZGF0ZS10aW1lLXBpY2tlci9tb2RlbHMvZGlhbG9nLWRhdGUtdGltZS1waWNrZXItZGF0YS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBEaWFsb2dEYXRlVGltZVBpY2tlckRhdGFTdGVwIHtcbiAgICBob3VyczogbnVtYmVyLFxuICAgIG1pbnV0ZXM6IG51bWJlcixcbiAgICBzZWNvbmRzOiBudW1iZXIsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGlhbG9nRGF0ZVRpbWVQaWNrZXJEYXRhRGlzYWJsZWQge1xuICAgIGhvdXJzOiBib29sZWFuLFxuICAgIHNvbWVIb3VyczogbnVtYmVyW10sXG4gICAgbWludXRlczogYm9vbGVhbixcbiAgICBzb21lTWludXRlczogbnVtYmVyW10sXG4gICAgc2Vjb25kczogYm9vbGVhbixcbiAgICBzb21lU2Vjb25kczogbnVtYmVyW10sXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGlhbG9nRGF0ZVRpbWVQaWNrZXJPcHRpb25zIHtcbiAgICBzZWxlY3RlZERhdGU6IERhdGUsXG4gICAgbWluaW11bURhdGU6IERhdGUgfCBudWxsLFxuICAgIG1heGltdW1EYXRlOiBEYXRlIHwgbnVsbCxcbiAgICBzaG93U2Vjb25kczogYm9vbGVhbixcbiAgICBzaG93Q2xlYXJCdXR0b246IGJvb2xlYW4sXG4gICAgc2hvd0J1dHRvbkljb25zOiBib29sZWFuLFxuICAgIHNob3dUaW1lOiBib29sZWFuLFxuICAgIHN0ZXA6IERpYWxvZ0RhdGVUaW1lUGlja2VyRGF0YVN0ZXAsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGlhbG9nRGF0ZVRpbWVQaWNrZXJWYWx1ZSB7XG4gICAgdmFsdWU6IERhdGUsXG59Il19