@agorapulse/ui-components 13.0.1 → 13.0.2
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/agorapulse-ui-components-13.0.2.tgz +0 -0
- package/esm2020/index.mjs +2 -1
- package/esm2020/src/lib/add-comment/add-comment.component.mjs +3 -3
- package/esm2020/src/lib/agorapulse-ui-components.module.mjs +18 -6
- package/esm2020/src/lib/avatar/avatar.component.mjs +3 -3
- package/esm2020/src/lib/confirm-modal/confirm-modal.component.mjs +3 -3
- package/esm2020/src/lib/datepicker/datepicker.component.mjs +3 -3
- package/esm2020/src/lib/directives/autosize-textarea.directive.mjs +3 -3
- package/esm2020/src/lib/directives/default-image.directive.mjs +3 -3
- package/esm2020/src/lib/directives/ellipsis.directive.mjs +3 -3
- package/esm2020/src/lib/directives/equal-validator.directive.mjs +3 -3
- package/esm2020/src/lib/directives/frozen-gif.directive.mjs +3 -3
- package/esm2020/src/lib/directives/multi-style-text.directive.mjs +3 -3
- package/esm2020/src/lib/directives/truncate-tooltip.directive.mjs +3 -3
- package/esm2020/src/lib/dots-stepper/dots-stepper.component.mjs +3 -3
- package/esm2020/src/lib/edit-tag-modal/edit-tags-modal.component.mjs +3 -3
- package/esm2020/src/lib/feature-onboarding/feature-onboarding.component.mjs +3 -3
- package/esm2020/src/lib/image-carousel/image-carousel.component.mjs +3 -3
- package/esm2020/src/lib/lead-modal/lead-modal.component.mjs +3 -3
- package/esm2020/src/lib/media-display-overlay/media-display-overlay-dialog.component.mjs +3 -3
- package/esm2020/src/lib/modal/modal.component.mjs +3 -3
- package/esm2020/src/lib/neo-timepicker/neo-timepicker.component.mjs +388 -0
- package/esm2020/src/lib/notification/notification.component.mjs +3 -3
- package/esm2020/src/lib/overlay/overlay-dialog-service.component.mjs +3 -3
- package/esm2020/src/lib/overlay/overlay-dialog.component.mjs +3 -3
- package/esm2020/src/lib/overlay-in-div/overlay-in-div.component.mjs +3 -3
- package/esm2020/src/lib/paginator/paginator-button/paginator-button.component.mjs +3 -3
- package/esm2020/src/lib/paginator/paginator.component.mjs +3 -3
- package/esm2020/src/lib/password-input/password-input.component.mjs +3 -3
- package/esm2020/src/lib/password-strength-bar/password-strength-bar.component.mjs +3 -3
- package/esm2020/src/lib/password-strength-display-bar/password-strength-display-bar.component.mjs +3 -3
- package/esm2020/src/lib/phone-number-input/phone-number-input.component.mjs +3 -3
- package/esm2020/src/lib/places/place-list.component.mjs +3 -3
- package/esm2020/src/lib/places/place.component.mjs +3 -3
- package/esm2020/src/lib/popmenu/popmenu.component.mjs +3 -3
- package/esm2020/src/lib/popmenu/popmenu.directive.mjs +3 -3
- package/esm2020/src/lib/popmenu/popmenu.module.mjs +4 -4
- package/esm2020/src/lib/slide-toggle/slide-toggle.component.mjs +3 -3
- package/esm2020/src/lib/snackbar/snackbar.component.mjs +3 -3
- package/esm2020/src/lib/snackbars-thread/component/snackbars-thread.component.mjs +3 -3
- package/esm2020/src/lib/snackbars-thread/service/snackbars-thread.service.mjs +3 -3
- package/esm2020/src/lib/splashscreen/splashscreen.component.mjs +3 -3
- package/esm2020/src/lib/star-rating/star-rating.component.mjs +3 -3
- package/esm2020/src/lib/stepper/stepper.component.mjs +3 -3
- package/esm2020/src/lib/tags/tag-list.component.mjs +3 -3
- package/esm2020/src/lib/tags/tag.component.mjs +3 -3
- package/esm2020/src/lib/tags-selector/tags-selector.component.mjs +3 -3
- package/esm2020/src/lib/timepicker/timepicker.component.mjs +3 -3
- package/esm2020/src/lib/tooltip-neo/tooltip-neo.component.mjs +3 -3
- package/esm2020/src/lib/tooltip-neo/tooltip-neo.directive.mjs +3 -3
- package/esm2020/src/lib/tooltip-neo/tooltip-neo.service.mjs +3 -3
- package/esm2020/src/lib/try-popup/try-popup.component.mjs +3 -3
- package/fesm2015/agorapulse-ui-components.mjs +541 -151
- package/fesm2015/agorapulse-ui-components.mjs.map +1 -1
- package/fesm2020/agorapulse-ui-components.mjs +539 -151
- package/fesm2020/agorapulse-ui-components.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/package.json +13 -12
- package/src/lib/agorapulse-ui-components.module.d.ts +48 -46
- package/src/lib/neo-timepicker/neo-timepicker.component.d.ts +132 -0
- package/agorapulse-ui-components-13.0.1.tgz +0 -0
|
@@ -0,0 +1,388 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output, ViewChild, } from "@angular/core";
|
|
2
|
+
import format from "date-fns/format";
|
|
3
|
+
import parse from "date-fns/parse";
|
|
4
|
+
import IMask from "imask";
|
|
5
|
+
import { fromEvent, Subject } from "rxjs";
|
|
6
|
+
import { debounceTime, distinctUntilChanged, map, takeUntil, } from "rxjs/operators";
|
|
7
|
+
// FIXME Move these models when we remove the old timepicker
|
|
8
|
+
import { TimeFormat } from "../timepicker/timepicker.component";
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@angular/material/button";
|
|
11
|
+
import * as i2 from "@angular/common";
|
|
12
|
+
import * as i3 from "@angular/forms";
|
|
13
|
+
import * as i4 from "../popmenu/popmenu.directive";
|
|
14
|
+
import * as i5 from "../tooltip-neo/tooltip-neo.directive";
|
|
15
|
+
import * as i6 from "angular-imask";
|
|
16
|
+
export class NeoTimepickerComponent {
|
|
17
|
+
constructor(changeDetectorRef) {
|
|
18
|
+
this.changeDetectorRef = changeDetectorRef;
|
|
19
|
+
this.i18n = {
|
|
20
|
+
hourLabel: 'Hour',
|
|
21
|
+
minuteLabel: 'Minute',
|
|
22
|
+
meridianLabel: 'AM/PM',
|
|
23
|
+
doneLabel: 'Done',
|
|
24
|
+
cancelLabel: 'Cancel',
|
|
25
|
+
};
|
|
26
|
+
this.disabled = false;
|
|
27
|
+
this.format = TimeFormat.Default;
|
|
28
|
+
this.invalid = false;
|
|
29
|
+
this.placement = 'bottom';
|
|
30
|
+
this.timeModelChange = new EventEmitter();
|
|
31
|
+
this.meridians = ['AM', 'PM'];
|
|
32
|
+
this.imaskDefault = {
|
|
33
|
+
mask: 'HH:MM',
|
|
34
|
+
blocks: {
|
|
35
|
+
HH: {
|
|
36
|
+
mask: IMask.MaskedRange,
|
|
37
|
+
from: 0,
|
|
38
|
+
to: 23,
|
|
39
|
+
autofix: 'pad',
|
|
40
|
+
},
|
|
41
|
+
MM: {
|
|
42
|
+
mask: IMask.MaskedRange,
|
|
43
|
+
from: 0,
|
|
44
|
+
to: 59,
|
|
45
|
+
autofix: 'pad',
|
|
46
|
+
},
|
|
47
|
+
},
|
|
48
|
+
};
|
|
49
|
+
this.imaskMeridian = {
|
|
50
|
+
mask: 'HH:MM AMPM',
|
|
51
|
+
blocks: {
|
|
52
|
+
HH: {
|
|
53
|
+
mask: IMask.MaskedRange,
|
|
54
|
+
from: 1,
|
|
55
|
+
to: 12,
|
|
56
|
+
autofix: 'pad',
|
|
57
|
+
},
|
|
58
|
+
MM: {
|
|
59
|
+
mask: IMask.MaskedRange,
|
|
60
|
+
from: 0,
|
|
61
|
+
to: 59,
|
|
62
|
+
autofix: 'pad',
|
|
63
|
+
},
|
|
64
|
+
AMPM: {
|
|
65
|
+
mask: IMask.MaskedEnum,
|
|
66
|
+
enum: ['AM', 'PM']
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
lazy: false,
|
|
70
|
+
prepare: function (str) {
|
|
71
|
+
return str.toUpperCase();
|
|
72
|
+
},
|
|
73
|
+
};
|
|
74
|
+
this.ENTER_KEY = 'Enter';
|
|
75
|
+
this.ESCAPE_KEY = 'Escape';
|
|
76
|
+
this.FIX_NUMBER = 10;
|
|
77
|
+
this.HOURS_MAX = 24;
|
|
78
|
+
this.HOURS_MERIDIAN_MAX = 12;
|
|
79
|
+
this.MARGIN = 8;
|
|
80
|
+
this.MINUTES_MAX = 60;
|
|
81
|
+
this.TIME_OPTION_HEIGHT = 387;
|
|
82
|
+
this.TIME_PICKER_DEFAULT_WIDTH = 96;
|
|
83
|
+
this.TIME_PICKER_MERIDIAN_WIDTH = 152;
|
|
84
|
+
this.ROW_HEIGHT = 34;
|
|
85
|
+
this.hours = [];
|
|
86
|
+
this.minutes = [];
|
|
87
|
+
this.position = null;
|
|
88
|
+
this.TimeFormat = TimeFormat;
|
|
89
|
+
}
|
|
90
|
+
onKeypress(event) {
|
|
91
|
+
if (this.timepickerOpened) {
|
|
92
|
+
if (event.code === this.ENTER_KEY) {
|
|
93
|
+
this.onSaveSelection();
|
|
94
|
+
}
|
|
95
|
+
if (event.code === this.ESCAPE_KEY) {
|
|
96
|
+
this.onCancelSelection();
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
ngOnInit() {
|
|
101
|
+
this.generateTimeSlots();
|
|
102
|
+
this.onTimeModelChange();
|
|
103
|
+
}
|
|
104
|
+
ngOnChanges(changes) {
|
|
105
|
+
this.generateTimeSlots();
|
|
106
|
+
if (changes.format?.currentValue) {
|
|
107
|
+
this.timeFormat = this.format === TimeFormat.Default ? 'HH:mm' : 'hh:mm a';
|
|
108
|
+
if (this.format === TimeFormat.Default && this.meridians.some(meridian => this.timeModel?.endsWith(meridian))) {
|
|
109
|
+
this.timeModel = NeoTimepickerComponent.convert12To24(this.timeModel);
|
|
110
|
+
}
|
|
111
|
+
else if (this.format === TimeFormat.Meridian && this.meridians.every(meridian => !this.timeModel?.endsWith(meridian))) {
|
|
112
|
+
this.timeModel = NeoTimepickerComponent.convert24To12(this.timeModel);
|
|
113
|
+
}
|
|
114
|
+
setTimeout(() => this.changeDetectorRef.markForCheck());
|
|
115
|
+
}
|
|
116
|
+
if (changes.placement?.currentValue) {
|
|
117
|
+
this.updateTimePickerPosition();
|
|
118
|
+
}
|
|
119
|
+
if (changes.format?.currentValue) {
|
|
120
|
+
this.updateTimePickerPosition();
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
onOpenTimepicker() {
|
|
124
|
+
this.destroy$ = new Subject();
|
|
125
|
+
this.previousValue = this.timeModel;
|
|
126
|
+
this.timepickerOpened = true;
|
|
127
|
+
this.timepickerClosed = false;
|
|
128
|
+
this.updateTimePickerPosition();
|
|
129
|
+
setTimeout(() => {
|
|
130
|
+
this.updateElementPosition('minute', this.selectedMinute, 'auto');
|
|
131
|
+
this.updateElementPosition('hour', this.selectedHour, 'auto');
|
|
132
|
+
this.updateElementPosition('meridian', this.selectedMeridian, 'auto');
|
|
133
|
+
this.inputBox.nativeElement.focus();
|
|
134
|
+
this.inputBox.nativeElement.select();
|
|
135
|
+
}, 1);
|
|
136
|
+
this.changeDetectorRef.markForCheck();
|
|
137
|
+
}
|
|
138
|
+
onTimepickerOpened() {
|
|
139
|
+
this.hoursScrollObserver$ = this.onObserveElementScroll(this.hourOptions.nativeElement);
|
|
140
|
+
this.minutesScrollObserver$ = this.onObserveElementScroll(this.minutesOptions.nativeElement);
|
|
141
|
+
this.hoursScrollObserver$.subscribe((indexToScroll) => {
|
|
142
|
+
this.updateTimeModel(this.hours[indexToScroll], this.selectedMinute, this.selectedMeridian);
|
|
143
|
+
});
|
|
144
|
+
this.minutesScrollObserver$.subscribe((indexToScroll) => {
|
|
145
|
+
this.updateTimeModel(this.selectedHour, this.minutes[indexToScroll], this.selectedMeridian);
|
|
146
|
+
});
|
|
147
|
+
if (this.format === TimeFormat.Meridian) {
|
|
148
|
+
this.meridiansScrollObserver$ = this.onObserveElementScroll(this.meridiansOptions.nativeElement);
|
|
149
|
+
this.meridiansScrollObserver$.subscribe((indexToScroll) => {
|
|
150
|
+
this.updateTimeModel(this.selectedHour, this.selectedMinute, this.meridians[indexToScroll]);
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
onObserveElementScroll(element) {
|
|
155
|
+
return fromEvent(element, 'scroll').pipe(debounceTime(150), distinctUntilChanged(), takeUntil(this.destroy$), map(() => {
|
|
156
|
+
return Math.round(element.scrollTop / this.ROW_HEIGHT);
|
|
157
|
+
}));
|
|
158
|
+
}
|
|
159
|
+
onTimePickerClosed() {
|
|
160
|
+
this.onCancelSelection();
|
|
161
|
+
this.destroy$.next();
|
|
162
|
+
this.destroy$.complete();
|
|
163
|
+
}
|
|
164
|
+
onTimeModelChange() {
|
|
165
|
+
let date = new Date();
|
|
166
|
+
if (this.timeModel) {
|
|
167
|
+
date = parse(this.timeModel, this.timeFormat, new Date());
|
|
168
|
+
}
|
|
169
|
+
this.timeModel = format(date, this.timeFormat);
|
|
170
|
+
if (!this.previousValue) {
|
|
171
|
+
this.previousValue = this.timeModel;
|
|
172
|
+
}
|
|
173
|
+
let jsHour = date.getHours();
|
|
174
|
+
if (this.format === TimeFormat.Meridian) {
|
|
175
|
+
if (jsHour > 12) {
|
|
176
|
+
jsHour = jsHour - 12;
|
|
177
|
+
}
|
|
178
|
+
// JS doesn't handle well AM/PM hour so 12:53 PM will be 00:53 ...
|
|
179
|
+
if (jsHour == 0) {
|
|
180
|
+
jsHour = 12;
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
const hour = NeoTimepickerComponent.toFixed(jsHour.toString(), 10);
|
|
184
|
+
if (hour != this.selectedHour) {
|
|
185
|
+
this.selectedHour = hour;
|
|
186
|
+
this.updateElementPosition('hour', this.selectedHour, 'auto');
|
|
187
|
+
}
|
|
188
|
+
const minute = NeoTimepickerComponent.toFixed(date.getMinutes().toString(), 10);
|
|
189
|
+
if (minute != this.selectedMinute) {
|
|
190
|
+
this.selectedMinute = minute;
|
|
191
|
+
this.updateElementPosition('minute', this.selectedMinute, 'auto');
|
|
192
|
+
}
|
|
193
|
+
if (this.format === TimeFormat.Meridian && this.selectedMeridian !== this.timeModel.split(' ')[1]) {
|
|
194
|
+
this.selectedMeridian = this.timeModel.split(' ')[1];
|
|
195
|
+
this.updateElementPosition('meridian', this.selectedMeridian, 'auto');
|
|
196
|
+
}
|
|
197
|
+
this.changeDetectorRef.markForCheck();
|
|
198
|
+
}
|
|
199
|
+
onSelectHour(hour) {
|
|
200
|
+
this.updateTimeModel(hour, this.selectedMinute, this.selectedMeridian);
|
|
201
|
+
}
|
|
202
|
+
onSelectMinute(minute) {
|
|
203
|
+
this.updateTimeModel(this.selectedHour, minute, this.selectedMeridian);
|
|
204
|
+
}
|
|
205
|
+
onSelectMeridian(meridian) {
|
|
206
|
+
this.updateTimeModel(this.selectedHour, this.selectedMinute, meridian);
|
|
207
|
+
}
|
|
208
|
+
onSaveSelection() {
|
|
209
|
+
this.previousValue = this.timeModel;
|
|
210
|
+
this.timepickerClosed = true;
|
|
211
|
+
this.timepickerOpened = false;
|
|
212
|
+
const timeModelValue = parse(this.timeModel, this.timeFormat, new Date());
|
|
213
|
+
this.timeModelChange.emit({
|
|
214
|
+
hours: timeModelValue.getHours(),
|
|
215
|
+
minutes: timeModelValue.getMinutes(),
|
|
216
|
+
});
|
|
217
|
+
this.changeDetectorRef.markForCheck();
|
|
218
|
+
}
|
|
219
|
+
onCancelSelection() {
|
|
220
|
+
this.timepickerClosed = true;
|
|
221
|
+
this.timepickerOpened = false;
|
|
222
|
+
this.timeModel = this.previousValue;
|
|
223
|
+
this.changeDetectorRef.markForCheck();
|
|
224
|
+
}
|
|
225
|
+
onMaskValidateComplete(value) {
|
|
226
|
+
if (this.timeModel !== value) {
|
|
227
|
+
this.timeModel = value;
|
|
228
|
+
}
|
|
229
|
+
this.onTimeModelChange();
|
|
230
|
+
}
|
|
231
|
+
updateTimeModel(hour, minute, meridian) {
|
|
232
|
+
if (this.format === TimeFormat.Meridian) {
|
|
233
|
+
this.timeModel = `${hour}:${minute} ${meridian}`;
|
|
234
|
+
}
|
|
235
|
+
else {
|
|
236
|
+
this.timeModel = `${hour}:${minute}`;
|
|
237
|
+
}
|
|
238
|
+
this.changeDetectorRef.markForCheck();
|
|
239
|
+
}
|
|
240
|
+
updateElementPosition(elementType, id, scrollBehavior) {
|
|
241
|
+
const element = document.getElementById(`${elementType}-${id}`);
|
|
242
|
+
this.scrollToElement(element, scrollBehavior);
|
|
243
|
+
}
|
|
244
|
+
scrollToElement(element, behavior = 'auto') {
|
|
245
|
+
if (element) {
|
|
246
|
+
setTimeout(() => {
|
|
247
|
+
element.scrollIntoView({
|
|
248
|
+
behavior,
|
|
249
|
+
block: 'center',
|
|
250
|
+
inline: 'center'
|
|
251
|
+
});
|
|
252
|
+
}, 1);
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
/**
|
|
256
|
+
* Fullfill minutes and hours arrays like [0, 1, 2 ... 12] and [0, 1, 2, ... 59]
|
|
257
|
+
*/
|
|
258
|
+
generateTimeSlots() {
|
|
259
|
+
this.hours = [];
|
|
260
|
+
this.minutes = [NeoTimepickerComponent.toFixed(0, this.FIX_NUMBER)];
|
|
261
|
+
for (let i = 1; i <= this.HOURS_MERIDIAN_MAX; i++) {
|
|
262
|
+
const indexToAdd = NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER);
|
|
263
|
+
this.hours.push(indexToAdd);
|
|
264
|
+
this.minutes.push(indexToAdd);
|
|
265
|
+
}
|
|
266
|
+
if (this.format === TimeFormat.Default) {
|
|
267
|
+
this.hours = [NeoTimepickerComponent.toFixed(0, this.FIX_NUMBER), ...this.hours];
|
|
268
|
+
for (let i = 13; i < this.HOURS_MAX; i++) {
|
|
269
|
+
this.hours.push(NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER));
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
for (let i = 13; i < this.MINUTES_MAX; i++) {
|
|
273
|
+
this.minutes.push(NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER));
|
|
274
|
+
}
|
|
275
|
+
this.changeDetectorRef.markForCheck();
|
|
276
|
+
}
|
|
277
|
+
updateTimePickerPosition() {
|
|
278
|
+
if (this.inputBox?.nativeElement) {
|
|
279
|
+
const inputBoxBounds = this.inputBox.nativeElement.getBoundingClientRect();
|
|
280
|
+
const topPosition = inputBoxBounds.top - this.TIME_OPTION_HEIGHT - this.MARGIN;
|
|
281
|
+
const bottomPosition = inputBoxBounds.top + inputBoxBounds.height;
|
|
282
|
+
const timePickerWidth = this.format === TimeFormat.Meridian ? this.TIME_PICKER_MERIDIAN_WIDTH : this.TIME_PICKER_DEFAULT_WIDTH;
|
|
283
|
+
const shift = (timePickerWidth - inputBoxBounds.width) / 2;
|
|
284
|
+
if (this.placement === 'top') {
|
|
285
|
+
this.position = {
|
|
286
|
+
top: topPosition < 0 ? bottomPosition : topPosition,
|
|
287
|
+
left: inputBoxBounds.left - shift,
|
|
288
|
+
};
|
|
289
|
+
}
|
|
290
|
+
else {
|
|
291
|
+
this.position = {
|
|
292
|
+
top: bottomPosition + this.TIME_OPTION_HEIGHT + this.MARGIN > window.innerHeight ? topPosition : bottomPosition,
|
|
293
|
+
left: inputBoxBounds.left - shift,
|
|
294
|
+
};
|
|
295
|
+
}
|
|
296
|
+
this.changeDetectorRef.markForCheck();
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
static convert12To24(time) {
|
|
300
|
+
const terms = time.split(':');
|
|
301
|
+
const minutes = terms[1].substring(0, 2);
|
|
302
|
+
const meridian = terms[1].trim().slice(-2).toUpperCase();
|
|
303
|
+
let hour = parseInt(terms[0]);
|
|
304
|
+
if (!isNaN(parseInt(terms[0]))) {
|
|
305
|
+
if (meridian === 'PM' && hour < 12) {
|
|
306
|
+
hour = hour + 12;
|
|
307
|
+
}
|
|
308
|
+
if (meridian === 'AM' && hour === 12) {
|
|
309
|
+
hour = 0;
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
return `${hour}:${minutes}`;
|
|
313
|
+
}
|
|
314
|
+
static convert24To12(time) {
|
|
315
|
+
const terms = time.split(':');
|
|
316
|
+
let meridian = 'AM';
|
|
317
|
+
let hour = parseInt(terms[0]);
|
|
318
|
+
let minute = parseInt(terms[1]);
|
|
319
|
+
if (!isNaN(parseInt(terms[0]))) {
|
|
320
|
+
if (hour >= 12) {
|
|
321
|
+
meridian = 'PM';
|
|
322
|
+
if (hour > 12) {
|
|
323
|
+
hour = hour - 12;
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
if (hour === 0) {
|
|
327
|
+
hour = 12;
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
const hourStr = NeoTimepickerComponent.toFixed(hour, 10);
|
|
331
|
+
const minuteStr = NeoTimepickerComponent.toFixed(minute, 10);
|
|
332
|
+
return `${hourStr}:${minuteStr} ${meridian}`;
|
|
333
|
+
}
|
|
334
|
+
/**
|
|
335
|
+
* Return 08 for 8, 06 for 6
|
|
336
|
+
* @param num
|
|
337
|
+
* @param fix
|
|
338
|
+
* @private
|
|
339
|
+
*/
|
|
340
|
+
static toFixed(num, fix) {
|
|
341
|
+
let fixedNum = num.toString();
|
|
342
|
+
if (num < fix) {
|
|
343
|
+
fixedNum = `0${fixedNum}`;
|
|
344
|
+
}
|
|
345
|
+
return fixedNum;
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
/** @nocollapse */ /** @nocollapse */ NeoTimepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: NeoTimepickerComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
349
|
+
/** @nocollapse */ /** @nocollapse */ NeoTimepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: NeoTimepickerComponent, selector: "ap-neo-timepicker", inputs: { i18n: "i18n", disabled: "disabled", format: "format", invalid: "invalid", invalidationMessage: "invalidationMessage", placement: "placement", timeModel: "timeModel" }, outputs: { timeModelChange: "timeModelChange" }, host: { listeners: { "window:keydown": "onKeypress($event)" } }, viewQueries: [{ propertyName: "inputBox", first: true, predicate: ["inputBox"], descendants: true }, { propertyName: "hourOptions", first: true, predicate: ["hourOptions"], descendants: true }, { propertyName: "minutesOptions", first: true, predicate: ["minutesOptions"], descendants: true }, { propertyName: "meridiansOptions", first: true, predicate: ["meridiansOptions"], descendants: true }, { propertyName: "timepicker", first: true, predicate: ["timepicker"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"time-picker-container\">\n <ng-template #timeOptionsTemplate>\n <div class=\"time-picker-options\"\n [class.meridian]=\"format === TimeFormat.Meridian\"\n *ngIf=\"timepickerOpened\"\n #timepicker\n >\n <div class=\"header\">\n <span> {{ i18n.hourLabel }} </span>\n <span> {{ i18n.minuteLabel }} </span>\n <span *ngIf=\"format === TimeFormat.Meridian\"> {{ i18n.meridianLabel }} </span>\n </div>\n <div class=\"content\">\n <div class=\"selector\">\n <span>:</span>\n <span *ngIf=\"format === TimeFormat.Meridian\"></span>\n </div>\n <div class=\"options\"\n #hourOptions>\n <div class=\"invisible-block\"></div>\n <div *ngFor=\"let hour of hours;\"\n class=\"option\"\n [id]=\"'hour-' + hour\"\n [class.selected]=\"hour === selectedHour\"\n (click)=\"onSelectHour(hour)\">\n {{ hour }}\n </div>\n <div class=\"invisible-block\"></div>\n </div>\n <div class=\"divider\"></div>\n <div class=\"options\"\n #minutesOptions>\n <div class=\"invisible-block\"></div>\n <div *ngFor=\"let minute of minutes;\"\n class=\"option\"\n [id]=\"'minute-' + minute\"\n [class.selected]=\"minute === selectedMinute\"\n (click)=\"onSelectMinute(minute)\">\n {{ minute }}\n </div>\n <div class=\"invisible-block\"></div>\n </div>\n <div *ngIf=\"format === TimeFormat.Meridian\"\n class=\"divider\"></div>\n <div *ngIf=\"format === TimeFormat.Meridian\"\n class=\"options\"\n #meridiansOptions>\n <div class=\"invisible-block\"></div>\n <div *ngFor=\"let meridian of meridians;\"\n class=\"option\"\n [id]=\"'meridian-' + meridian\"\n [class.selected]=\"selectedMeridian === meridian\"\n (click)=\"onSelectMeridian(meridian)\">\n {{ meridian }}\n </div>\n <div class=\"invisible-block\"></div>\n </div>\n </div>\n <div class=\"buttons\">\n <button mat-flat-button\n class=\"full-width\"\n color=\"primary\"\n (click)=\"onSaveSelection()\">\n {{ i18n.doneLabel }}\n </button>\n <button mat-flat-button\n class=\"full-width\"\n (click)=\"onCancelSelection()\">\n {{ i18n.cancelLabel }}\n </button>\n </div>\n </div>\n </ng-template>\n <input #inputBox\n class=\"time-input\"\n placement=\"bottom right\"\n color=\"secondary\"\n [class.active]=\"timepickerOpened\"\n [class.invalid]=\"invalid\"\n [apPopmenu]=\"timeOptionsTemplate\"\n [apPopmenuBackground]=\"false\"\n [apPopmenuBorder]=\"false\"\n [apPopmenuDisabled]=\"timepickerOpened\"\n [apTooltipNeo]=\"{content: invalidationMessage, display: invalidationMessage && invalid}\"\n [close]=\"timepickerClosed\"\n [disabled]=\"disabled\"\n [imask]=\"format === TimeFormat.Meridian ? imaskMeridian : imaskDefault\"\n [(ngModel)]=\"timeModel\"\n [pointer]=\"true\"\n [position]=\"position\"\n [rounded]=\"true\"\n [shadow]=\"false\"\n (click)=\"onOpenTimepicker()\"\n (complete)=\"onMaskValidateComplete($event)\"\n (menuClosed)=\"onTimePickerClosed()\"\n (menuOpened)=\"onTimepickerOpened()\">\n</div>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}.time-picker-container{display:flex}.time-input{width:80px;max-width:80px;text-align:center;padding:0;margin:0;height:36px;line-height:24px}.time-input.active{border-color:#178dfe}.time-picker-options{display:flex;flex-direction:column;width:96px;margin-top:8px;max-width:96px;height:379px;background:white;border-radius:4px;overflow:hidden;box-shadow:0 3px 10px #00000014}.time-picker-options.meridian{width:152px;max-width:152px}.time-picker-options .header{display:flex;align-items:center;min-height:29px;border-bottom:1px solid #eaecef;color:#344563;font-size:12px;line-height:18px}.time-picker-options .header>span{flex:1;text-align:center}.time-picker-options .content{display:flex;position:relative;min-height:252px;overflow:hidden}.time-picker-options .content .selector{display:flex;justify-content:space-evenly;align-items:center;background-color:#f9f9fa;border-top:1px solid #eaecef;border-bottom:1px solid #eaecef;width:100%;height:34px;position:absolute;top:50%;transform:translateY(-50%);z-index:4;box-sizing:border-box}.time-picker-options .content .divider{height:100%;width:1px;background:#eaecef}.time-picker-options .content .options{flex:1;height:100%;overflow-y:scroll;z-index:5;scroll-snap-type:y mandatory;-ms-overflow-style:none;scrollbar-width:none}.time-picker-options .content .options::-webkit-scrollbar{display:none}.time-picker-options .content .options .invisible-block{min-height:109px;max-height:109px;width:100%}.time-picker-options .content .options .option{min-height:34px;display:flex;z-index:5;justify-content:center;align-items:center;font-size:14px;line-height:17px;color:#aeb5c1;scroll-snap-align:center;padding-block:1px;box-sizing:border-box}.time-picker-options .content .options .option:hover{color:#178dfe;cursor:pointer}.time-picker-options .content .options .option.selected{color:#344563!important}.time-picker-options .content .meridian{flex:1;display:flex;flex-direction:column;justify-content:center}.time-picker-options .content .meridian>div{min-height:34px;display:flex;justify-content:center;align-items:center;font-size:14px;line-height:17px;color:#aeb5c1;scroll-snap-align:center}.time-picker-options .buttons{display:flex;flex-direction:column;padding:8px;min-height:96px;border-top:1px solid #eaecef;gap:8px}.time-picker-options .buttons button{font-weight:700;min-width:80px}\n"], components: [{ type: i1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.PopmenuDirective, selector: "[apPopmenu]", inputs: ["apPopmenuBorder", "apPopmenuDisabled", "apPopmenuBackground", "arrow", "arrowOffset", "arrowPosition", "close", "hasBackdrop", "offset", "placement", "pointer", "apPopmenu", "position", "rounded", "shadow", "options"], outputs: ["menuClosed", "menuOpened"] }, { type: i5.TooltipNeoDirective, selector: "[apTooltipNeo]", inputs: ["apTooltipNeo"] }, { type: i6.IMaskDirective, selector: "[imask]", inputs: ["imaskElement", "imask", "unmask"], outputs: ["accept", "complete"], exportAs: ["imask"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
350
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: NeoTimepickerComponent, decorators: [{
|
|
351
|
+
type: Component,
|
|
352
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'ap-neo-timepicker', template: "<div class=\"time-picker-container\">\n <ng-template #timeOptionsTemplate>\n <div class=\"time-picker-options\"\n [class.meridian]=\"format === TimeFormat.Meridian\"\n *ngIf=\"timepickerOpened\"\n #timepicker\n >\n <div class=\"header\">\n <span> {{ i18n.hourLabel }} </span>\n <span> {{ i18n.minuteLabel }} </span>\n <span *ngIf=\"format === TimeFormat.Meridian\"> {{ i18n.meridianLabel }} </span>\n </div>\n <div class=\"content\">\n <div class=\"selector\">\n <span>:</span>\n <span *ngIf=\"format === TimeFormat.Meridian\"></span>\n </div>\n <div class=\"options\"\n #hourOptions>\n <div class=\"invisible-block\"></div>\n <div *ngFor=\"let hour of hours;\"\n class=\"option\"\n [id]=\"'hour-' + hour\"\n [class.selected]=\"hour === selectedHour\"\n (click)=\"onSelectHour(hour)\">\n {{ hour }}\n </div>\n <div class=\"invisible-block\"></div>\n </div>\n <div class=\"divider\"></div>\n <div class=\"options\"\n #minutesOptions>\n <div class=\"invisible-block\"></div>\n <div *ngFor=\"let minute of minutes;\"\n class=\"option\"\n [id]=\"'minute-' + minute\"\n [class.selected]=\"minute === selectedMinute\"\n (click)=\"onSelectMinute(minute)\">\n {{ minute }}\n </div>\n <div class=\"invisible-block\"></div>\n </div>\n <div *ngIf=\"format === TimeFormat.Meridian\"\n class=\"divider\"></div>\n <div *ngIf=\"format === TimeFormat.Meridian\"\n class=\"options\"\n #meridiansOptions>\n <div class=\"invisible-block\"></div>\n <div *ngFor=\"let meridian of meridians;\"\n class=\"option\"\n [id]=\"'meridian-' + meridian\"\n [class.selected]=\"selectedMeridian === meridian\"\n (click)=\"onSelectMeridian(meridian)\">\n {{ meridian }}\n </div>\n <div class=\"invisible-block\"></div>\n </div>\n </div>\n <div class=\"buttons\">\n <button mat-flat-button\n class=\"full-width\"\n color=\"primary\"\n (click)=\"onSaveSelection()\">\n {{ i18n.doneLabel }}\n </button>\n <button mat-flat-button\n class=\"full-width\"\n (click)=\"onCancelSelection()\">\n {{ i18n.cancelLabel }}\n </button>\n </div>\n </div>\n </ng-template>\n <input #inputBox\n class=\"time-input\"\n placement=\"bottom right\"\n color=\"secondary\"\n [class.active]=\"timepickerOpened\"\n [class.invalid]=\"invalid\"\n [apPopmenu]=\"timeOptionsTemplate\"\n [apPopmenuBackground]=\"false\"\n [apPopmenuBorder]=\"false\"\n [apPopmenuDisabled]=\"timepickerOpened\"\n [apTooltipNeo]=\"{content: invalidationMessage, display: invalidationMessage && invalid}\"\n [close]=\"timepickerClosed\"\n [disabled]=\"disabled\"\n [imask]=\"format === TimeFormat.Meridian ? imaskMeridian : imaskDefault\"\n [(ngModel)]=\"timeModel\"\n [pointer]=\"true\"\n [position]=\"position\"\n [rounded]=\"true\"\n [shadow]=\"false\"\n (click)=\"onOpenTimepicker()\"\n (complete)=\"onMaskValidateComplete($event)\"\n (menuClosed)=\"onTimePickerClosed()\"\n (menuOpened)=\"onTimepickerOpened()\">\n</div>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}.time-picker-container{display:flex}.time-input{width:80px;max-width:80px;text-align:center;padding:0;margin:0;height:36px;line-height:24px}.time-input.active{border-color:#178dfe}.time-picker-options{display:flex;flex-direction:column;width:96px;margin-top:8px;max-width:96px;height:379px;background:white;border-radius:4px;overflow:hidden;box-shadow:0 3px 10px #00000014}.time-picker-options.meridian{width:152px;max-width:152px}.time-picker-options .header{display:flex;align-items:center;min-height:29px;border-bottom:1px solid #eaecef;color:#344563;font-size:12px;line-height:18px}.time-picker-options .header>span{flex:1;text-align:center}.time-picker-options .content{display:flex;position:relative;min-height:252px;overflow:hidden}.time-picker-options .content .selector{display:flex;justify-content:space-evenly;align-items:center;background-color:#f9f9fa;border-top:1px solid #eaecef;border-bottom:1px solid #eaecef;width:100%;height:34px;position:absolute;top:50%;transform:translateY(-50%);z-index:4;box-sizing:border-box}.time-picker-options .content .divider{height:100%;width:1px;background:#eaecef}.time-picker-options .content .options{flex:1;height:100%;overflow-y:scroll;z-index:5;scroll-snap-type:y mandatory;-ms-overflow-style:none;scrollbar-width:none}.time-picker-options .content .options::-webkit-scrollbar{display:none}.time-picker-options .content .options .invisible-block{min-height:109px;max-height:109px;width:100%}.time-picker-options .content .options .option{min-height:34px;display:flex;z-index:5;justify-content:center;align-items:center;font-size:14px;line-height:17px;color:#aeb5c1;scroll-snap-align:center;padding-block:1px;box-sizing:border-box}.time-picker-options .content .options .option:hover{color:#178dfe;cursor:pointer}.time-picker-options .content .options .option.selected{color:#344563!important}.time-picker-options .content .meridian{flex:1;display:flex;flex-direction:column;justify-content:center}.time-picker-options .content .meridian>div{min-height:34px;display:flex;justify-content:center;align-items:center;font-size:14px;line-height:17px;color:#aeb5c1;scroll-snap-align:center}.time-picker-options .buttons{display:flex;flex-direction:column;padding:8px;min-height:96px;border-top:1px solid #eaecef;gap:8px}.time-picker-options .buttons button{font-weight:700;min-width:80px}\n"] }]
|
|
353
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { inputBox: [{
|
|
354
|
+
type: ViewChild,
|
|
355
|
+
args: ['inputBox']
|
|
356
|
+
}], hourOptions: [{
|
|
357
|
+
type: ViewChild,
|
|
358
|
+
args: ['hourOptions']
|
|
359
|
+
}], minutesOptions: [{
|
|
360
|
+
type: ViewChild,
|
|
361
|
+
args: ['minutesOptions']
|
|
362
|
+
}], meridiansOptions: [{
|
|
363
|
+
type: ViewChild,
|
|
364
|
+
args: ['meridiansOptions']
|
|
365
|
+
}], timepicker: [{
|
|
366
|
+
type: ViewChild,
|
|
367
|
+
args: ['timepicker']
|
|
368
|
+
}], i18n: [{
|
|
369
|
+
type: Input
|
|
370
|
+
}], disabled: [{
|
|
371
|
+
type: Input
|
|
372
|
+
}], format: [{
|
|
373
|
+
type: Input
|
|
374
|
+
}], invalid: [{
|
|
375
|
+
type: Input
|
|
376
|
+
}], invalidationMessage: [{
|
|
377
|
+
type: Input
|
|
378
|
+
}], placement: [{
|
|
379
|
+
type: Input
|
|
380
|
+
}], timeModel: [{
|
|
381
|
+
type: Input
|
|
382
|
+
}], timeModelChange: [{
|
|
383
|
+
type: Output
|
|
384
|
+
}], onKeypress: [{
|
|
385
|
+
type: HostListener,
|
|
386
|
+
args: ['window:keydown', ['$event']]
|
|
387
|
+
}] } });
|
|
388
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"neo-timepicker.component.js","sourceRoot":"","sources":["../../../../../../libs/ui-components/src/lib/neo-timepicker/neo-timepicker.component.ts","../../../../../../libs/ui-components/src/lib/neo-timepicker/neo-timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    ViewChild,\n} from \"@angular/core\";\nimport format from \"date-fns/format\";\nimport parse from \"date-fns/parse\";\nimport IMask from \"imask\";\nimport { fromEvent, Observable, Subject } from \"rxjs\";\nimport {\n    debounceTime,\n    distinctUntilChanged,\n    map,\n    takeUntil,\n} from \"rxjs/operators\";\n// FIXME Move these models when we remove the old timepicker\nimport { Time, TimeFormat } from \"../timepicker/timepicker.component\";\n\nexport interface TimePickerTranslatedStrings {\n    hourLabel: string;\n    minuteLabel: string;\n    meridianLabel: string;\n    doneLabel: string;\n    cancelLabel: string;\n}\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ap-neo-timepicker',\n    templateUrl: './neo-timepicker.component.html',\n    styleUrls: ['./neo-timepicker.component.scss']\n})\nexport class NeoTimepickerComponent implements OnInit, OnChanges {\n\n    @ViewChild('inputBox') inputBox: ElementRef;\n    @ViewChild('hourOptions') hourOptions: ElementRef;\n    @ViewChild('minutesOptions') minutesOptions: ElementRef;\n    @ViewChild('meridiansOptions') meridiansOptions: ElementRef;\n    @ViewChild('timepicker') timepicker: ElementRef;\n\n    @Input() i18n: TimePickerTranslatedStrings = {\n        hourLabel: 'Hour',\n        minuteLabel: 'Minute',\n        meridianLabel: 'AM/PM',\n        doneLabel: 'Done',\n        cancelLabel: 'Cancel',\n    };\n    @Input() disabled: boolean = false;\n    @Input() format: TimeFormat = TimeFormat.Default;\n    @Input() invalid: boolean = false;\n    @Input() invalidationMessage: string;\n    @Input() placement: 'top' | 'bottom' = 'bottom';\n    @Input() timeModel: string;\n\n    @Output() timeModelChange: EventEmitter<Time> = new EventEmitter<Time>();\n\n    readonly meridians: string[] = ['AM', 'PM'];\n    readonly imaskDefault = {\n        mask: 'HH:MM',\n        blocks: {\n            HH: {\n                mask: IMask.MaskedRange,\n                from: 0,\n                to: 23,\n                autofix: 'pad',\n            },\n            MM: {\n                mask: IMask.MaskedRange,\n                from: 0,\n                to: 59,\n                autofix: 'pad',\n            },\n        },\n    };\n    readonly imaskMeridian = {\n        mask: 'HH:MM AMPM',\n        blocks: {\n            HH: {\n                mask: IMask.MaskedRange,\n                from: 1,\n                to: 12,\n                autofix: 'pad',\n            },\n            MM: {\n                mask: IMask.MaskedRange,\n                from: 0,\n                to: 59,\n                autofix: 'pad',\n            },\n            AMPM: {\n                mask: IMask.MaskedEnum,\n                enum: ['AM', 'PM']\n            }\n        },\n        lazy: false,\n        prepare: function (str) {\n            return str.toUpperCase();\n        },\n    };\n\n    readonly ENTER_KEY: string = 'Enter';\n    readonly ESCAPE_KEY: string = 'Escape';\n    readonly FIX_NUMBER: number = 10;\n    readonly HOURS_MAX: number = 24;\n    readonly HOURS_MERIDIAN_MAX: number = 12;\n    readonly MARGIN: number = 8;\n    readonly MINUTES_MAX: number = 60;\n    readonly TIME_OPTION_HEIGHT: number = 387;\n    readonly TIME_PICKER_DEFAULT_WIDTH: number = 96;\n    readonly TIME_PICKER_MERIDIAN_WIDTH: number = 152;\n    readonly ROW_HEIGHT: number = 34;\n\n    destroy$: Subject<void>;\n    hours: string[] = [];\n    hoursScrollObserver$: Observable<number>;\n    meridiansScrollObserver$: Observable<number>;\n    minutesScrollObserver$: Observable<number>;\n    minutes: string[] = [];\n    position: { top: number, left: number } = null;\n    previousValue: string;\n    selectedHour: string;\n    selectedMinute: string;\n    selectedMeridian: string;\n    timepickerClosed: boolean;\n    timepickerOpened: boolean;\n    TimeFormat = TimeFormat;\n    timeFormat: string;\n\n    @HostListener('window:keydown', ['$event'])\n    onKeypress(event: KeyboardEvent) {\n        if (this.timepickerOpened) {\n            if (event.code === this.ENTER_KEY) {\n                this.onSaveSelection();\n            }\n\n            if (event.code === this.ESCAPE_KEY) {\n                this.onCancelSelection();\n            }\n        }\n    }\n\n    constructor(public changeDetectorRef: ChangeDetectorRef) {}\n\n    ngOnInit(): void {\n        this.generateTimeSlots();\n        this.onTimeModelChange();\n    }\n\n    ngOnChanges(changes: any): void {\n        this.generateTimeSlots();\n        if (changes.format?.currentValue) {\n            this.timeFormat = this.format === TimeFormat.Default ? 'HH:mm' : 'hh:mm a';\n            if (this.format === TimeFormat.Default && this.meridians.some(meridian => this.timeModel?.endsWith(meridian))) {\n                this.timeModel = NeoTimepickerComponent.convert12To24(this.timeModel);\n            } else if (this.format === TimeFormat.Meridian && this.meridians.every(meridian => !this.timeModel?.endsWith(meridian))) {\n                this.timeModel = NeoTimepickerComponent.convert24To12(this.timeModel);\n            }\n            setTimeout(() => this.changeDetectorRef.markForCheck());\n        }\n        if (changes.placement?.currentValue) {\n            this.updateTimePickerPosition();\n        }\n        if (changes.format?.currentValue) {\n            this.updateTimePickerPosition();\n        }\n    }\n\n    onOpenTimepicker(): void {\n        this.destroy$ = new Subject<void>();\n        this.previousValue = this.timeModel;\n        this.timepickerOpened = true;\n        this.timepickerClosed = false;\n        this.updateTimePickerPosition();\n\n        setTimeout(() => {\n            this.updateElementPosition('minute', this.selectedMinute, 'auto');\n            this.updateElementPosition('hour', this.selectedHour, 'auto');\n            this.updateElementPosition('meridian', this.selectedMeridian, 'auto');\n            this.inputBox.nativeElement.focus();\n            this.inputBox.nativeElement.select();\n        }, 1)\n        this.changeDetectorRef.markForCheck();\n    }\n\n    onTimepickerOpened(): void {\n        this.hoursScrollObserver$ = this.onObserveElementScroll(this.hourOptions.nativeElement);\n        this.minutesScrollObserver$ = this.onObserveElementScroll(this.minutesOptions.nativeElement);\n\n        this.hoursScrollObserver$.subscribe((indexToScroll) => {\n            this.updateTimeModel(this.hours[indexToScroll], this.selectedMinute, this.selectedMeridian);\n        })\n        this.minutesScrollObserver$.subscribe((indexToScroll) => {\n            this.updateTimeModel(this.selectedHour, this.minutes[indexToScroll], this.selectedMeridian);\n        })\n\n        if (this.format === TimeFormat.Meridian) {\n            this.meridiansScrollObserver$ = this.onObserveElementScroll(this.meridiansOptions.nativeElement);\n            this.meridiansScrollObserver$.subscribe((indexToScroll) => {\n                this.updateTimeModel(this.selectedHour, this.selectedMinute, this.meridians[indexToScroll]);\n            })\n        }\n\n    }\n\n    onObserveElementScroll(element: HTMLElement): Observable<number> {\n        return fromEvent(element, 'scroll').pipe(\n            debounceTime(150),\n            distinctUntilChanged(),\n            takeUntil(this.destroy$),\n            map(() => {\n                return Math.round(element.scrollTop / this.ROW_HEIGHT);\n            })\n        )\n    }\n\n    onTimePickerClosed(): void {\n        this.onCancelSelection();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    onTimeModelChange(): void {\n        let date = new Date();\n        if (this.timeModel) {\n            date = parse(this.timeModel, this.timeFormat, new Date());\n        }\n        this.timeModel = format(date, this.timeFormat);\n        if (!this.previousValue) {\n            this.previousValue = this.timeModel;\n        }\n        let jsHour = date.getHours();\n        if (this.format === TimeFormat.Meridian) {\n            if (jsHour > 12) {\n                jsHour = jsHour - 12;\n            }\n            // JS doesn't handle well AM/PM hour so 12:53 PM will be 00:53 ...\n            if (jsHour == 0) {\n                jsHour = 12;\n            }\n        }\n\n        const hour = NeoTimepickerComponent.toFixed(jsHour.toString(), 10);\n        if (hour != this.selectedHour) {\n            this.selectedHour = hour;\n            this.updateElementPosition('hour', this.selectedHour, 'auto');\n        }\n\n        const minute = NeoTimepickerComponent.toFixed(date.getMinutes().toString(), 10);\n        if (minute != this.selectedMinute) {\n            this.selectedMinute = minute;\n            this.updateElementPosition('minute', this.selectedMinute, 'auto');\n        }\n\n        if (this.format === TimeFormat.Meridian && this.selectedMeridian !== this.timeModel.split(' ')[1]) {\n            this.selectedMeridian = this.timeModel.split(' ')[1];\n            this.updateElementPosition('meridian', this.selectedMeridian, 'auto');\n        }\n\n        this.changeDetectorRef.markForCheck();\n    }\n\n    onSelectHour(hour: string): void {\n        this.updateTimeModel(hour, this.selectedMinute, this.selectedMeridian);\n    }\n\n    onSelectMinute(minute: string): void {\n        this.updateTimeModel(this.selectedHour, minute, this.selectedMeridian);\n    }\n\n    onSelectMeridian(meridian: string): void {\n        this.updateTimeModel(this.selectedHour, this.selectedMinute, meridian);\n    }\n\n    onSaveSelection(): void {\n        this.previousValue = this.timeModel;\n        this.timepickerClosed = true;\n        this.timepickerOpened = false;\n        const timeModelValue = parse(this.timeModel, this.timeFormat, new Date());\n        this.timeModelChange.emit({\n            hours: timeModelValue.getHours(),\n            minutes: timeModelValue.getMinutes(),\n        })\n        this.changeDetectorRef.markForCheck();\n    }\n\n    onCancelSelection(): void {\n        this.timepickerClosed = true;\n        this.timepickerOpened = false;\n        this.timeModel = this.previousValue;\n        this.changeDetectorRef.markForCheck();\n    }\n\n    onMaskValidateComplete(value) {\n        if (this.timeModel !== value) {\n            this.timeModel = value;\n        }\n        this.onTimeModelChange();\n    }\n\n    updateTimeModel(hour: string, minute: string, meridian?: string): void {\n        if (this.format === TimeFormat.Meridian) {\n            this.timeModel = `${hour}:${minute} ${meridian}`;\n        } else {\n            this.timeModel = `${hour}:${minute}`;\n        }\n        this.changeDetectorRef.markForCheck();\n    }\n\n    private updateElementPosition(elementType: 'hour' | 'minute' | 'meridian', id: string, scrollBehavior: 'auto' | 'smooth') {\n        const element = document.getElementById(`${elementType}-${id}`);\n        this.scrollToElement(\n            element,\n            scrollBehavior\n        );\n    }\n\n    private scrollToElement(element: HTMLElement, behavior: 'auto' | 'smooth' = 'auto') {\n        if (element) {\n            setTimeout(() => {\n                element.scrollIntoView({\n                    behavior,\n                    block: 'center',\n                    inline: 'center'\n                });\n            }, 1)\n        }\n    }\n\n    /**\n     * Fullfill minutes and hours arrays like [0, 1, 2 ... 12] and [0, 1, 2, ... 59]\n     */\n    private generateTimeSlots(): void {\n        this.hours = [];\n        this.minutes = [NeoTimepickerComponent.toFixed(0, this.FIX_NUMBER)];\n        for (let i = 1; i <= this.HOURS_MERIDIAN_MAX; i++) {\n            const indexToAdd = NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER);\n            this.hours.push(indexToAdd);\n            this.minutes.push(indexToAdd);\n        }\n        if (this.format === TimeFormat.Default) {\n            this.hours = [NeoTimepickerComponent.toFixed(0, this.FIX_NUMBER), ...this.hours];\n            for (let i = 13; i < this.HOURS_MAX; i++) {\n                this.hours.push(NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER))\n            }\n        }\n        for (let i = 13; i < this.MINUTES_MAX; i++) {\n            this.minutes.push(NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER));\n        }\n        this.changeDetectorRef.markForCheck();\n    }\n\n    private updateTimePickerPosition() {\n        if (this.inputBox?.nativeElement) {\n            const inputBoxBounds = this.inputBox.nativeElement.getBoundingClientRect();\n            const topPosition = inputBoxBounds.top - this.TIME_OPTION_HEIGHT - this.MARGIN;\n            const bottomPosition = inputBoxBounds.top + inputBoxBounds.height;\n            const timePickerWidth = this.format === TimeFormat.Meridian ? this.TIME_PICKER_MERIDIAN_WIDTH: this.TIME_PICKER_DEFAULT_WIDTH;\n            const shift = (timePickerWidth - inputBoxBounds.width) / 2;\n\n            if (this.placement === 'top') {\n                this.position = {\n                    top: topPosition < 0 ? bottomPosition : topPosition,\n                    left: inputBoxBounds.left - shift,\n                };\n            } else {\n                this.position = {\n                    top: bottomPosition + this.TIME_OPTION_HEIGHT + this.MARGIN > window.innerHeight ? topPosition : bottomPosition,\n                    left: inputBoxBounds.left - shift,\n                };\n            }\n            this.changeDetectorRef.markForCheck();\n        }\n    }\n\n    private static convert12To24(time): string {\n        const terms = time.split(':');\n        const minutes = terms[1].substring(0, 2);\n        const meridian = terms[1].trim().slice(-2).toUpperCase();\n        let hour = parseInt(terms[0]);\n        if (!isNaN(parseInt(terms[0]))) {\n            if (meridian === 'PM' && hour < 12) {\n                hour = hour + 12;\n            }\n            if (meridian === 'AM' && hour === 12) {\n                hour = 0;\n            }\n        }\n        return `${hour}:${minutes}`;\n    }\n\n    private static convert24To12(time): string {\n        const terms = time.split(':');\n        let meridian = 'AM';\n        let hour = parseInt(terms[0]);\n        let minute = parseInt(terms[1]);\n        if (!isNaN(parseInt(terms[0]))) {\n            if (hour >= 12) {\n                meridian = 'PM';\n                if (hour > 12) {\n                    hour = hour - 12;\n                }\n            }\n            if (hour === 0) {\n                hour = 12;\n            }\n        }\n        const hourStr = NeoTimepickerComponent.toFixed(hour, 10);\n        const minuteStr = NeoTimepickerComponent.toFixed(minute, 10);\n        return `${hourStr}:${minuteStr} ${meridian}`;\n    }\n\n    /**\n     * Return 08 for 8, 06 for 6\n     * @param num\n     * @param fix\n     * @private\n     */\n    private static toFixed(num, fix): string {\n        let fixedNum: string = num.toString();\n        if (num < fix) {\n            fixedNum = `0${fixedNum}`;\n        }\n        return fixedNum;\n    }\n\n}\n","<div class=\"time-picker-container\">\n    <ng-template #timeOptionsTemplate>\n        <div class=\"time-picker-options\"\n             [class.meridian]=\"format === TimeFormat.Meridian\"\n             *ngIf=\"timepickerOpened\"\n             #timepicker\n        >\n            <div class=\"header\">\n                <span> {{ i18n.hourLabel }} </span>\n                <span> {{ i18n.minuteLabel }} </span>\n                <span *ngIf=\"format === TimeFormat.Meridian\"> {{ i18n.meridianLabel }} </span>\n            </div>\n            <div class=\"content\">\n                <div class=\"selector\">\n                    <span>:</span>\n                    <span *ngIf=\"format === TimeFormat.Meridian\"></span>\n                </div>\n                <div class=\"options\"\n                    #hourOptions>\n                    <div class=\"invisible-block\"></div>\n                    <div *ngFor=\"let hour of hours;\"\n                        class=\"option\"\n                        [id]=\"'hour-' + hour\"\n                        [class.selected]=\"hour === selectedHour\"\n                        (click)=\"onSelectHour(hour)\">\n                        {{ hour }}\n                    </div>\n                    <div class=\"invisible-block\"></div>\n                </div>\n                <div class=\"divider\"></div>\n                <div class=\"options\"\n                     #minutesOptions>\n                    <div class=\"invisible-block\"></div>\n                    <div *ngFor=\"let minute of minutes;\"\n                         class=\"option\"\n                         [id]=\"'minute-' + minute\"\n                         [class.selected]=\"minute === selectedMinute\"\n                         (click)=\"onSelectMinute(minute)\">\n                        {{ minute }}\n                    </div>\n                    <div class=\"invisible-block\"></div>\n                </div>\n                <div *ngIf=\"format === TimeFormat.Meridian\"\n                     class=\"divider\"></div>\n                <div *ngIf=\"format === TimeFormat.Meridian\"\n                     class=\"options\"\n                     #meridiansOptions>\n                    <div class=\"invisible-block\"></div>\n                    <div *ngFor=\"let meridian of meridians;\"\n                         class=\"option\"\n                         [id]=\"'meridian-' + meridian\"\n                         [class.selected]=\"selectedMeridian === meridian\"\n                         (click)=\"onSelectMeridian(meridian)\">\n                        {{ meridian }}\n                    </div>\n                    <div class=\"invisible-block\"></div>\n                </div>\n            </div>\n            <div class=\"buttons\">\n                <button mat-flat-button\n                        class=\"full-width\"\n                        color=\"primary\"\n                        (click)=\"onSaveSelection()\">\n                    {{ i18n.doneLabel }}\n                </button>\n                <button mat-flat-button\n                        class=\"full-width\"\n                        (click)=\"onCancelSelection()\">\n                    {{ i18n.cancelLabel }}\n                </button>\n            </div>\n        </div>\n    </ng-template>\n    <input #inputBox\n           class=\"time-input\"\n           placement=\"bottom right\"\n           color=\"secondary\"\n           [class.active]=\"timepickerOpened\"\n           [class.invalid]=\"invalid\"\n           [apPopmenu]=\"timeOptionsTemplate\"\n           [apPopmenuBackground]=\"false\"\n           [apPopmenuBorder]=\"false\"\n           [apPopmenuDisabled]=\"timepickerOpened\"\n           [apTooltipNeo]=\"{content: invalidationMessage, display: invalidationMessage && invalid}\"\n           [close]=\"timepickerClosed\"\n           [disabled]=\"disabled\"\n           [imask]=\"format === TimeFormat.Meridian ? imaskMeridian : imaskDefault\"\n           [(ngModel)]=\"timeModel\"\n           [pointer]=\"true\"\n           [position]=\"position\"\n           [rounded]=\"true\"\n           [shadow]=\"false\"\n           (click)=\"onOpenTimepicker()\"\n           (complete)=\"onMaskValidateComplete($event)\"\n           (menuClosed)=\"onTimePickerClosed()\"\n           (menuOpened)=\"onTimepickerOpened()\">\n</div>\n"]}
|
|
@@ -6,9 +6,9 @@ export class NotificationComponent {
|
|
|
6
6
|
this.type = 'info';
|
|
7
7
|
}
|
|
8
8
|
}
|
|
9
|
-
/** @nocollapse */ /** @nocollapse */ NotificationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
10
|
-
/** @nocollapse */ /** @nocollapse */ NotificationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
9
|
+
/** @nocollapse */ /** @nocollapse */ NotificationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: NotificationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
+
/** @nocollapse */ /** @nocollapse */ NotificationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: NotificationComponent, selector: "ap-notification", inputs: { type: "type" }, ngImport: i0, template: "<div\n class=\"main\"\n [ngClass]=\"{'warning': type === 'warning', 'error': type === 'error', 'success': type === 'success'}\">\n <span class=\"border\"></span>\n <span class=\"icon\">\n <ng-content select=\"[icon]\"></ng-content>\n </span>\n <ng-content select=\"[text]\"></ng-content>\n</div>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}:host{display:block}.main{display:flex;font-size:14px;line-height:17px;align-items:center;background:#eff5fc;color:#178dfe;padding:8px 16px 8px 8px;border-radius:4px}.main .border{align-self:stretch;border:2px solid #178dfe;border-radius:4px;margin-right:8px}.main .icon{margin-right:8px}.main.warning{background-color:#fffde9;color:#858fa1}.main.warning .border{border-color:#ffe91f}.main.error{background-color:#fde7e7;color:#e81313}.main.error .border{border-color:#e81313}.main.success{background-color:#ecf7ed;color:#45b854}.main.success .border{border-color:#45b854}.main.full-width{width:100%}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: NotificationComponent, decorators: [{
|
|
12
12
|
type: Component,
|
|
13
13
|
args: [{ selector: 'ap-notification', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"main\"\n [ngClass]=\"{'warning': type === 'warning', 'error': type === 'error', 'success': type === 'success'}\">\n <span class=\"border\"></span>\n <span class=\"icon\">\n <ng-content select=\"[icon]\"></ng-content>\n </span>\n <ng-content select=\"[text]\"></ng-content>\n</div>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}:host{display:block}.main{display:flex;font-size:14px;line-height:17px;align-items:center;background:#eff5fc;color:#178dfe;padding:8px 16px 8px 8px;border-radius:4px}.main .border{align-self:stretch;border:2px solid #178dfe;border-radius:4px;margin-right:8px}.main .icon{margin-right:8px}.main.warning{background-color:#fffde9;color:#858fa1}.main.warning .border{border-color:#ffe91f}.main.error{background-color:#fde7e7;color:#e81313}.main.error .border{border-color:#e81313}.main.success{background-color:#ecf7ed;color:#45b854}.main.success .border{border-color:#45b854}.main.full-width{width:100%}\n"] }]
|
|
14
14
|
}], propDecorators: { type: [{
|
|
@@ -53,9 +53,9 @@ export class OverlayDialogService {
|
|
|
53
53
|
return overlayConfig;
|
|
54
54
|
}
|
|
55
55
|
}
|
|
56
|
-
/** @nocollapse */ /** @nocollapse */ OverlayDialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
57
|
-
/** @nocollapse */ /** @nocollapse */ OverlayDialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.
|
|
58
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
56
|
+
/** @nocollapse */ /** @nocollapse */ OverlayDialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: OverlayDialogService, deps: [{ token: i0.Injector }, { token: i1.Overlay }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
57
|
+
/** @nocollapse */ /** @nocollapse */ OverlayDialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: OverlayDialogService });
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: OverlayDialogService, decorators: [{
|
|
59
59
|
type: Injectable
|
|
60
60
|
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.Overlay }]; } });
|
|
61
61
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS1kaWFsb2ctc2VydmljZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvc3JjL2xpYi9vdmVybGF5L292ZXJsYXktZGlhbG9nLXNlcnZpY2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBZSxVQUFVLEVBQVcsTUFBTSxlQUFlLENBQUM7QUFDakUsT0FBTyxFQUFVLGFBQWEsRUFBYSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hFLE9BQU8sRUFBQyxlQUFlLEVBQUUsY0FBYyxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDcEUsT0FBTyxFQUNILFlBQVksRUFDWixzQkFBc0IsRUFDdEIsZ0JBQWdCLEVBQ25CLE1BQU0sNEJBQTRCLENBQUM7OztBQVNwQyxNQUFNLGNBQWMsR0FBeUI7SUFDekMsV0FBVyxFQUFFLElBQUk7SUFDakIsYUFBYSxFQUFFLGVBQWU7SUFDOUIsVUFBVSxFQUFFLDhCQUE4QjtJQUMxQyxRQUFRLEVBQUUsSUFBSTtDQUNqQixDQUFDO0FBR0YsTUFBTSxPQUFPLG9CQUFvQjtJQUU3QixZQUNZLFFBQWtCLEVBQ2xCLE9BQWdCO1FBRGhCLGFBQVEsR0FBUixRQUFRLENBQVU7UUFDbEIsWUFBTyxHQUFQLE9BQU8sQ0FBUztJQUFJLENBQUM7SUFFakMsSUFBSSxDQUFDLFNBQStCLEVBQUU7UUFDbEMsTUFBTSxZQUFZLEdBQUcsRUFBRSxHQUFHLGNBQWMsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUFDO1FBQ3RELE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDcEQsTUFBTSxTQUFTLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNuRCxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxVQUFVLEVBQUUsWUFBWSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBRXpGLE9BQU8sU0FBUyxDQUFDO0lBQ3JCLENBQUM7SUFFTyxhQUFhLENBQUMsTUFBNEI7UUFDOUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3BELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVPLHFCQUFxQixDQUFDLFVBQXNCLEVBQUUsTUFBNEIsRUFBRSxTQUEyQjtRQUMzRyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUMsQ0FBQztRQUV4RCxNQUFNLGVBQWUsR0FBRyxJQUFJLGVBQWUsQ0FBQyxzQkFBc0IsRUFBRSxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDcEYsTUFBTSxZQUFZLEdBQXlDLFVBQVUsQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUM7UUFFOUYsT0FBTyxZQUFZLENBQUMsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFFTyxjQUFjLENBQUMsTUFBNEIsRUFBRSxTQUEyQjtRQUM1RSxNQUFNLGVBQWUsR0FBRyxJQUFJLE9BQU8sRUFBRSxDQUFDO1FBRXRDLGVBQWUsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDakQsZUFBZSxDQUFDLEdBQUcsQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRW5ELE9BQU8sSUFBSSxjQUFjLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxlQUFlLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRU8sZ0JBQWdCLENBQUMsTUFBNEI7UUFDakQsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRTthQUMzQyxNQUFNLEVBQUU7YUFDUixrQkFBa0IsRUFBRTthQUNwQixnQkFBZ0IsRUFBRSxDQUFDO1FBRXhCLE1BQU0sYUFBYSxHQUFHLElBQUksYUFBYSxDQUFDO1lBQ3BDLFdBQVcsRUFBRSxNQUFNLENBQUMsV0FBVztZQUMvQixhQUFhLEVBQUUsTUFBTSxDQUFDLGFBQWE7WUFDbkMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxVQUFVO1lBQzdCLGNBQWMsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLEtBQUssRUFBRTtZQUNyRCxnQkFBZ0I7U0FDbkIsQ0FBQyxDQUFDO1FBRUgsT0FBTyxhQUFhLENBQUM7SUFDekIsQ0FBQzs7dUpBckRRLG9CQUFvQjsySkFBcEIsb0JBQW9COzJGQUFwQixvQkFBb0I7a0JBRGhDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudFJlZiwgSW5qZWN0YWJsZSwgSW5qZWN0b3J9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtPdmVybGF5LCBPdmVybGF5Q29uZmlnLCBPdmVybGF5UmVmfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQge0NvbXBvbmVudFBvcnRhbCwgUG9ydGFsSW5qZWN0b3J9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHtcbiAgICBPVkVSTEFZX0RBVEEsXG4gICAgT3ZlcmxheURpYWxvZ0NvbXBvbmVudCxcbiAgICBPdmVybGF5RGlhbG9nUmVmXG59IGZyb20gJy4vb3ZlcmxheS1kaWFsb2cuY29tcG9uZW50JztcblxuaW50ZXJmYWNlIE92ZXJsYXl3RGlhbG9nQ29uZmlnIHtcbiAgICBwYW5lbENsYXNzPzogc3RyaW5nO1xuICAgIGhhc0JhY2tkcm9wPzogYm9vbGVhbjtcbiAgICBiYWNrZHJvcENsYXNzPzogc3RyaW5nO1xuICAgIHRlbXBsYXRlPzogYW55O1xufVxuXG5jb25zdCBERUZBVUxUX0NPTkZJRzogT3ZlcmxheXdEaWFsb2dDb25maWcgPSB7XG4gICAgaGFzQmFja2Ryb3A6IHRydWUsXG4gICAgYmFja2Ryb3BDbGFzczogJ2RhcmstYmFja2Ryb3AnLFxuICAgIHBhbmVsQ2xhc3M6ICd0bS1maWxlLXByZXZpZXctZGlhbG9nLXBhbmVsJyxcbiAgICB0ZW1wbGF0ZTogbnVsbFxufTtcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIE92ZXJsYXlEaWFsb2dTZXJ2aWNlIHtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIGluamVjdG9yOiBJbmplY3RvcixcbiAgICAgICAgcHJpdmF0ZSBvdmVybGF5OiBPdmVybGF5KSB7IH1cblxuICAgIG9wZW4oY29uZmlnOiBPdmVybGF5d0RpYWxvZ0NvbmZpZyA9IHt9KSB7XG4gICAgICAgIGNvbnN0IGRpYWxvZ0NvbmZpZyA9IHsgLi4uREVGQVVMVF9DT05GSUcsIC4uLmNvbmZpZyB9O1xuICAgICAgICBjb25zdCBvdmVybGF5UmVmID0gdGhpcy5jcmVhdGVPdmVybGF5KGRpYWxvZ0NvbmZpZyk7XG4gICAgICAgIGNvbnN0IGRpYWxvZ1JlZiA9IG5ldyBPdmVybGF5RGlhbG9nUmVmKG92ZXJsYXlSZWYpO1xuICAgICAgICBjb25zdCBvdmVybGF5Q29tcG9uZW50ID0gdGhpcy5hdHRhY2hEaWFsb2dDb250YWluZXIob3ZlcmxheVJlZiwgZGlhbG9nQ29uZmlnLCBkaWFsb2dSZWYpO1xuXG4gICAgICAgIHJldHVybiBkaWFsb2dSZWY7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjcmVhdGVPdmVybGF5KGNvbmZpZzogT3ZlcmxheXdEaWFsb2dDb25maWcpIHtcbiAgICAgICAgY29uc3Qgb3ZlcmxheUNvbmZpZyA9IHRoaXMuZ2V0T3ZlcmxheUNvbmZpZyhjb25maWcpO1xuICAgICAgICByZXR1cm4gdGhpcy5vdmVybGF5LmNyZWF0ZShvdmVybGF5Q29uZmlnKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGF0dGFjaERpYWxvZ0NvbnRhaW5lcihvdmVybGF5UmVmOiBPdmVybGF5UmVmLCBjb25maWc6IE92ZXJsYXl3RGlhbG9nQ29uZmlnLCBkaWFsb2dSZWY6IE92ZXJsYXlEaWFsb2dSZWYpIHtcbiAgICAgICAgY29uc3QgaW5qZWN0b3IgPSB0aGlzLmNyZWF0ZUluamVjdG9yKGNvbmZpZywgZGlhbG9nUmVmKTtcblxuICAgICAgICBjb25zdCBjb250YWluZXJQb3J0YWwgPSBuZXcgQ29tcG9uZW50UG9ydGFsKE92ZXJsYXlEaWFsb2dDb21wb25lbnQsIG51bGwsIGluamVjdG9yKTtcbiAgICAgICAgY29uc3QgY29udGFpbmVyUmVmOiBDb21wb25lbnRSZWY8T3ZlcmxheURpYWxvZ0NvbXBvbmVudD4gPSBvdmVybGF5UmVmLmF0dGFjaChjb250YWluZXJQb3J0YWwpO1xuXG4gICAgICAgIHJldHVybiBjb250YWluZXJSZWYuaW5zdGFuY2U7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjcmVhdGVJbmplY3Rvcihjb25maWc6IE92ZXJsYXl3RGlhbG9nQ29uZmlnLCBkaWFsb2dSZWY6IE92ZXJsYXlEaWFsb2dSZWYpOiBQb3J0YWxJbmplY3RvciB7XG4gICAgICAgIGNvbnN0IGluamVjdGlvblRva2VucyA9IG5ldyBXZWFrTWFwKCk7XG5cbiAgICAgICAgaW5qZWN0aW9uVG9rZW5zLnNldChPdmVybGF5RGlhbG9nUmVmLCBkaWFsb2dSZWYpO1xuICAgICAgICBpbmplY3Rpb25Ub2tlbnMuc2V0KE9WRVJMQVlfREFUQSwgY29uZmlnLnRlbXBsYXRlKTtcblxuICAgICAgICByZXR1cm4gbmV3IFBvcnRhbEluamVjdG9yKHRoaXMuaW5qZWN0b3IsIGluamVjdGlvblRva2Vucyk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXRPdmVybGF5Q29uZmlnKGNvbmZpZzogT3ZlcmxheXdEaWFsb2dDb25maWcpOiBPdmVybGF5Q29uZmlnIHtcbiAgICAgICAgY29uc3QgcG9zaXRpb25TdHJhdGVneSA9IHRoaXMub3ZlcmxheS5wb3NpdGlvbigpXG4gICAgICAgICAgICAuZ2xvYmFsKClcbiAgICAgICAgICAgIC5jZW50ZXJIb3Jpem9udGFsbHkoKVxuICAgICAgICAgICAgLmNlbnRlclZlcnRpY2FsbHkoKTtcblxuICAgICAgICBjb25zdCBvdmVybGF5Q29uZmlnID0gbmV3IE92ZXJsYXlDb25maWcoe1xuICAgICAgICAgICAgaGFzQmFja2Ryb3A6IGNvbmZpZy5oYXNCYWNrZHJvcCxcbiAgICAgICAgICAgIGJhY2tkcm9wQ2xhc3M6IGNvbmZpZy5iYWNrZHJvcENsYXNzLFxuICAgICAgICAgICAgcGFuZWxDbGFzczogY29uZmlnLnBhbmVsQ2xhc3MsXG4gICAgICAgICAgICBzY3JvbGxTdHJhdGVneTogdGhpcy5vdmVybGF5LnNjcm9sbFN0cmF0ZWdpZXMuYmxvY2soKSxcbiAgICAgICAgICAgIHBvc2l0aW9uU3RyYXRlZ3lcbiAgICAgICAgfSk7XG5cbiAgICAgICAgcmV0dXJuIG92ZXJsYXlDb25maWc7XG4gICAgfVxufVxuIl19
|