@agorapulse/ui-components 0.0.2 → 2.5.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-2.5.2.tgz +0 -0
- package/agorapulse-ui-components.d.ts +4 -3
- package/agorapulse-ui-components.metadata.json +1 -1
- package/assets/{lib-ui-components/icons → icons}/facebook-icon.png +0 -0
- package/assets/{lib-ui-components/icons → icons}/google-icon.png +0 -0
- package/assets/{lib-ui-components/icons → icons}/instagram-icon.png +0 -0
- package/assets/{lib-ui-components/icons → icons}/linkedin-icon.png +0 -0
- package/assets/{lib-ui-components/icons → icons}/pinterest-icon.png +0 -0
- package/assets/{lib-ui-components/icons → icons}/twitter-icon.png +0 -0
- package/assets/{lib-ui-components/icons → icons}/youtube-icon.png +0 -0
- package/assets/{lib-ui-components/img → img}/default-avatar-organization.png +0 -0
- package/assets/{lib-ui-components/img → img}/default-avatar-user.png +0 -0
- package/assets/{lib-ui-components/img → img}/default-avatar.png +0 -0
- package/assets/{lib-ui-components/img → img}/spinner_animation.gif +0 -0
- package/bundles/agorapulse-ui-components.umd.js +386 -9
- package/bundles/agorapulse-ui-components.umd.js.map +1 -1
- package/esm2015/agorapulse-ui-components.js +5 -4
- package/esm2015/src/lib/agorapulse-ui-components.module.js +7 -1
- package/esm2015/src/lib/directives/default-image.directive.js +2 -2
- package/esm2015/src/lib/edit-tag-modal/edit-tags-modal.component.js +2 -2
- package/esm2015/src/lib/neo-timepicker/neo-timepicker.component.js +371 -0
- package/fesm2015/agorapulse-ui-components.js +375 -4
- package/fesm2015/agorapulse-ui-components.js.map +1 -1
- package/package.json +8 -7
- package/src/lib/neo-timepicker/neo-timepicker.component.d.ts +129 -0
- package/agorapulse-ui-components-0.0.2.tgz +0 -0
|
@@ -0,0 +1,371 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, 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
|
+
export class NeoTimepickerComponent {
|
|
10
|
+
constructor(changeDetectorRef) {
|
|
11
|
+
this.changeDetectorRef = changeDetectorRef;
|
|
12
|
+
this.i18n = {
|
|
13
|
+
hourLabel: 'Hour',
|
|
14
|
+
minuteLabel: 'Minute',
|
|
15
|
+
meridianLabel: 'AM/PM',
|
|
16
|
+
doneLabel: 'Done',
|
|
17
|
+
cancelLabel: 'Cancel',
|
|
18
|
+
};
|
|
19
|
+
this.disabled = false;
|
|
20
|
+
this.format = TimeFormat.Default;
|
|
21
|
+
this.invalid = false;
|
|
22
|
+
this.placement = 'bottom';
|
|
23
|
+
this.timeModelChange = new EventEmitter();
|
|
24
|
+
this.meridians = ['AM', 'PM'];
|
|
25
|
+
this.imaskDefault = {
|
|
26
|
+
mask: 'HH:MM',
|
|
27
|
+
blocks: {
|
|
28
|
+
HH: {
|
|
29
|
+
mask: IMask.MaskedRange,
|
|
30
|
+
from: 0,
|
|
31
|
+
to: 23,
|
|
32
|
+
autofix: 'pad',
|
|
33
|
+
},
|
|
34
|
+
MM: {
|
|
35
|
+
mask: IMask.MaskedRange,
|
|
36
|
+
from: 0,
|
|
37
|
+
to: 59,
|
|
38
|
+
autofix: 'pad',
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
this.imaskMeridian = {
|
|
43
|
+
mask: 'HH:MM AMPM',
|
|
44
|
+
blocks: {
|
|
45
|
+
HH: {
|
|
46
|
+
mask: IMask.MaskedRange,
|
|
47
|
+
from: 1,
|
|
48
|
+
to: 12,
|
|
49
|
+
autofix: 'pad',
|
|
50
|
+
},
|
|
51
|
+
MM: {
|
|
52
|
+
mask: IMask.MaskedRange,
|
|
53
|
+
from: 0,
|
|
54
|
+
to: 59,
|
|
55
|
+
autofix: 'pad',
|
|
56
|
+
},
|
|
57
|
+
AMPM: {
|
|
58
|
+
mask: IMask.MaskedEnum,
|
|
59
|
+
enum: ['AM', 'PM']
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
lazy: false,
|
|
63
|
+
prepare: function (str) {
|
|
64
|
+
return str.toUpperCase();
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
this.ENTER_KEY = 'Enter';
|
|
68
|
+
this.ESCAPE_KEY = 'Escape';
|
|
69
|
+
this.FIX_NUMBER = 10;
|
|
70
|
+
this.HOURS_MAX = 24;
|
|
71
|
+
this.HOURS_MERIDIAN_MAX = 12;
|
|
72
|
+
this.MARGIN = 8;
|
|
73
|
+
this.MINUTES_MAX = 60;
|
|
74
|
+
this.TIME_OPTION_HEIGHT = 387;
|
|
75
|
+
this.TIME_PICKER_DEFAULT_WIDTH = 96;
|
|
76
|
+
this.TIME_PICKER_MERIDIAN_WIDTH = 152;
|
|
77
|
+
this.ROW_HEIGHT = 34;
|
|
78
|
+
this.hours = [];
|
|
79
|
+
this.minutes = [];
|
|
80
|
+
this.position = null;
|
|
81
|
+
this.TimeFormat = TimeFormat;
|
|
82
|
+
}
|
|
83
|
+
onKeypress(event) {
|
|
84
|
+
if (this.timepickerOpened) {
|
|
85
|
+
if (event.code === this.ENTER_KEY) {
|
|
86
|
+
this.onSaveSelection();
|
|
87
|
+
}
|
|
88
|
+
if (event.code === this.ESCAPE_KEY) {
|
|
89
|
+
this.onCancelSelection();
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
ngOnInit() {
|
|
94
|
+
this.generateTimeSlots();
|
|
95
|
+
this.onTimeModelChange();
|
|
96
|
+
}
|
|
97
|
+
ngOnChanges(changes) {
|
|
98
|
+
var _a, _b, _c;
|
|
99
|
+
this.generateTimeSlots();
|
|
100
|
+
if ((_a = changes.format) === null || _a === void 0 ? void 0 : _a.currentValue) {
|
|
101
|
+
this.timeFormat = this.format === TimeFormat.Default ? 'HH:mm' : 'hh:mm a';
|
|
102
|
+
if (this.format === TimeFormat.Default && this.meridians.some(meridian => { var _a; return (_a = this.timeModel) === null || _a === void 0 ? void 0 : _a.endsWith(meridian); })) {
|
|
103
|
+
this.timeModel = NeoTimepickerComponent.convert12To24(this.timeModel);
|
|
104
|
+
}
|
|
105
|
+
else if (this.format === TimeFormat.Meridian && this.meridians.every(meridian => { var _a; return !((_a = this.timeModel) === null || _a === void 0 ? void 0 : _a.endsWith(meridian)); })) {
|
|
106
|
+
this.timeModel = NeoTimepickerComponent.convert24To12(this.timeModel);
|
|
107
|
+
}
|
|
108
|
+
setTimeout(() => this.changeDetectorRef.markForCheck());
|
|
109
|
+
}
|
|
110
|
+
if ((_b = changes.placement) === null || _b === void 0 ? void 0 : _b.currentValue) {
|
|
111
|
+
this.updateTimePickerPosition();
|
|
112
|
+
}
|
|
113
|
+
if ((_c = changes.format) === null || _c === void 0 ? void 0 : _c.currentValue) {
|
|
114
|
+
this.updateTimePickerPosition();
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
onOpenTimepicker() {
|
|
118
|
+
this.destroy$ = new Subject();
|
|
119
|
+
this.previousValue = this.timeModel;
|
|
120
|
+
this.timepickerOpened = true;
|
|
121
|
+
this.timepickerClosed = false;
|
|
122
|
+
this.updateTimePickerPosition();
|
|
123
|
+
setTimeout(() => {
|
|
124
|
+
this.updateElementPosition('minute', this.selectedMinute, 'auto');
|
|
125
|
+
this.updateElementPosition('hour', this.selectedHour, 'auto');
|
|
126
|
+
this.updateElementPosition('meridian', this.selectedMeridian, 'auto');
|
|
127
|
+
this.inputBox.nativeElement.focus();
|
|
128
|
+
this.inputBox.nativeElement.select();
|
|
129
|
+
}, 1);
|
|
130
|
+
this.changeDetectorRef.markForCheck();
|
|
131
|
+
}
|
|
132
|
+
onTimepickerOpened() {
|
|
133
|
+
this.hoursScrollObserver$ = this.onObserveElementScroll(this.hourOptions.nativeElement);
|
|
134
|
+
this.minutesScrollObserver$ = this.onObserveElementScroll(this.minutesOptions.nativeElement);
|
|
135
|
+
this.hoursScrollObserver$.subscribe((indexToScroll) => {
|
|
136
|
+
this.updateTimeModel(this.hours[indexToScroll], this.selectedMinute, this.selectedMeridian);
|
|
137
|
+
});
|
|
138
|
+
this.minutesScrollObserver$.subscribe((indexToScroll) => {
|
|
139
|
+
this.updateTimeModel(this.selectedHour, this.minutes[indexToScroll], this.selectedMeridian);
|
|
140
|
+
});
|
|
141
|
+
if (this.format === TimeFormat.Meridian) {
|
|
142
|
+
this.meridiansScrollObserver$ = this.onObserveElementScroll(this.meridiansOptions.nativeElement);
|
|
143
|
+
this.meridiansScrollObserver$.subscribe((indexToScroll) => {
|
|
144
|
+
this.updateTimeModel(this.selectedHour, this.selectedMinute, this.meridians[indexToScroll]);
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
onObserveElementScroll(element) {
|
|
149
|
+
return fromEvent(element, 'scroll').pipe(debounceTime(150), distinctUntilChanged(), takeUntil(this.destroy$), map(() => {
|
|
150
|
+
return Math.round(element.scrollTop / this.ROW_HEIGHT);
|
|
151
|
+
}));
|
|
152
|
+
}
|
|
153
|
+
onTimePickerClosed() {
|
|
154
|
+
this.onCancelSelection();
|
|
155
|
+
this.destroy$.next();
|
|
156
|
+
this.destroy$.complete();
|
|
157
|
+
}
|
|
158
|
+
onTimeModelChange() {
|
|
159
|
+
let date = new Date();
|
|
160
|
+
if (this.timeModel) {
|
|
161
|
+
date = parse(this.timeModel, this.timeFormat, new Date());
|
|
162
|
+
}
|
|
163
|
+
this.timeModel = format(date, this.timeFormat);
|
|
164
|
+
if (!this.previousValue) {
|
|
165
|
+
this.previousValue = this.timeModel;
|
|
166
|
+
}
|
|
167
|
+
let jsHour = date.getHours();
|
|
168
|
+
if (this.format === TimeFormat.Meridian) {
|
|
169
|
+
if (jsHour > 12) {
|
|
170
|
+
jsHour = jsHour - 12;
|
|
171
|
+
}
|
|
172
|
+
// JS doesn't handle well AM/PM hour so 12:53 PM will be 00:53 ...
|
|
173
|
+
if (jsHour == 0) {
|
|
174
|
+
jsHour = 12;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
const hour = NeoTimepickerComponent.toFixed(jsHour.toString(), 10);
|
|
178
|
+
if (hour != this.selectedHour) {
|
|
179
|
+
this.selectedHour = hour;
|
|
180
|
+
this.updateElementPosition('hour', this.selectedHour, 'auto');
|
|
181
|
+
}
|
|
182
|
+
const minute = NeoTimepickerComponent.toFixed(date.getMinutes().toString(), 10);
|
|
183
|
+
if (minute != this.selectedMinute) {
|
|
184
|
+
this.selectedMinute = minute;
|
|
185
|
+
this.updateElementPosition('minute', this.selectedMinute, 'auto');
|
|
186
|
+
}
|
|
187
|
+
if (this.format === TimeFormat.Meridian && this.selectedMeridian !== this.timeModel.split(' ')[1]) {
|
|
188
|
+
this.selectedMeridian = this.timeModel.split(' ')[1];
|
|
189
|
+
this.updateElementPosition('meridian', this.selectedMeridian, 'auto');
|
|
190
|
+
}
|
|
191
|
+
this.changeDetectorRef.markForCheck();
|
|
192
|
+
}
|
|
193
|
+
onSelectHour(hour) {
|
|
194
|
+
this.updateTimeModel(hour, this.selectedMinute, this.selectedMeridian);
|
|
195
|
+
}
|
|
196
|
+
onSelectMinute(minute) {
|
|
197
|
+
this.updateTimeModel(this.selectedHour, minute, this.selectedMeridian);
|
|
198
|
+
}
|
|
199
|
+
onSelectMeridian(meridian) {
|
|
200
|
+
this.updateTimeModel(this.selectedHour, this.selectedMinute, meridian);
|
|
201
|
+
}
|
|
202
|
+
onSaveSelection() {
|
|
203
|
+
this.previousValue = this.timeModel;
|
|
204
|
+
this.timepickerClosed = true;
|
|
205
|
+
this.timepickerOpened = false;
|
|
206
|
+
const timeModelValue = parse(this.timeModel, this.timeFormat, new Date());
|
|
207
|
+
this.timeModelChange.emit({
|
|
208
|
+
hours: timeModelValue.getHours(),
|
|
209
|
+
minutes: timeModelValue.getMinutes(),
|
|
210
|
+
});
|
|
211
|
+
this.changeDetectorRef.markForCheck();
|
|
212
|
+
}
|
|
213
|
+
onCancelSelection() {
|
|
214
|
+
this.timepickerClosed = true;
|
|
215
|
+
this.timepickerOpened = false;
|
|
216
|
+
this.timeModel = this.previousValue;
|
|
217
|
+
this.changeDetectorRef.markForCheck();
|
|
218
|
+
}
|
|
219
|
+
onMaskValidateComplete(value) {
|
|
220
|
+
if (this.timeModel !== value) {
|
|
221
|
+
this.timeModel = value;
|
|
222
|
+
}
|
|
223
|
+
this.onTimeModelChange();
|
|
224
|
+
}
|
|
225
|
+
updateTimeModel(hour, minute, meridian) {
|
|
226
|
+
if (this.format === TimeFormat.Meridian) {
|
|
227
|
+
this.timeModel = `${hour}:${minute} ${meridian}`;
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
this.timeModel = `${hour}:${minute}`;
|
|
231
|
+
}
|
|
232
|
+
this.changeDetectorRef.markForCheck();
|
|
233
|
+
}
|
|
234
|
+
updateElementPosition(elementType, id, scrollBehavior) {
|
|
235
|
+
const element = document.getElementById(`${elementType}-${id}`);
|
|
236
|
+
this.scrollToElement(element, scrollBehavior);
|
|
237
|
+
}
|
|
238
|
+
scrollToElement(element, behavior = 'auto') {
|
|
239
|
+
if (element) {
|
|
240
|
+
setTimeout(() => {
|
|
241
|
+
element.scrollIntoView({
|
|
242
|
+
behavior,
|
|
243
|
+
block: 'center',
|
|
244
|
+
inline: 'center'
|
|
245
|
+
});
|
|
246
|
+
}, 1);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
/**
|
|
250
|
+
* Fullfill minutes and hours arrays like [0, 1, 2 ... 12] and [0, 1, 2, ... 59]
|
|
251
|
+
*/
|
|
252
|
+
generateTimeSlots() {
|
|
253
|
+
this.hours = [];
|
|
254
|
+
this.minutes = [NeoTimepickerComponent.toFixed(0, this.FIX_NUMBER)];
|
|
255
|
+
for (let i = 1; i <= this.HOURS_MERIDIAN_MAX; i++) {
|
|
256
|
+
const indexToAdd = NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER);
|
|
257
|
+
this.hours.push(indexToAdd);
|
|
258
|
+
this.minutes.push(indexToAdd);
|
|
259
|
+
}
|
|
260
|
+
if (this.format === TimeFormat.Default) {
|
|
261
|
+
this.hours = [NeoTimepickerComponent.toFixed(0, this.FIX_NUMBER), ...this.hours];
|
|
262
|
+
for (let i = 13; i < this.HOURS_MAX; i++) {
|
|
263
|
+
this.hours.push(NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER));
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
for (let i = 13; i < this.MINUTES_MAX; i++) {
|
|
267
|
+
this.minutes.push(NeoTimepickerComponent.toFixed(i, this.FIX_NUMBER));
|
|
268
|
+
}
|
|
269
|
+
this.changeDetectorRef.markForCheck();
|
|
270
|
+
}
|
|
271
|
+
updateTimePickerPosition() {
|
|
272
|
+
var _a;
|
|
273
|
+
if ((_a = this.inputBox) === null || _a === void 0 ? void 0 : _a.nativeElement) {
|
|
274
|
+
const inputBoxBounds = this.inputBox.nativeElement.getBoundingClientRect();
|
|
275
|
+
const topPosition = inputBoxBounds.top - this.TIME_OPTION_HEIGHT - this.MARGIN;
|
|
276
|
+
const bottomPosition = inputBoxBounds.top + inputBoxBounds.height;
|
|
277
|
+
const timePickerWidth = this.format === TimeFormat.Meridian ? this.TIME_PICKER_MERIDIAN_WIDTH : this.TIME_PICKER_DEFAULT_WIDTH;
|
|
278
|
+
const shift = (timePickerWidth - inputBoxBounds.width) / 2;
|
|
279
|
+
if (this.placement === 'top') {
|
|
280
|
+
this.position = {
|
|
281
|
+
top: topPosition < 0 ? bottomPosition : topPosition,
|
|
282
|
+
left: inputBoxBounds.left - shift,
|
|
283
|
+
};
|
|
284
|
+
}
|
|
285
|
+
else {
|
|
286
|
+
this.position = {
|
|
287
|
+
top: bottomPosition + this.TIME_OPTION_HEIGHT + this.MARGIN > window.innerHeight ? topPosition : bottomPosition,
|
|
288
|
+
left: inputBoxBounds.left - shift,
|
|
289
|
+
};
|
|
290
|
+
}
|
|
291
|
+
this.changeDetectorRef.markForCheck();
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
static convert12To24(time) {
|
|
295
|
+
const terms = time.split(':');
|
|
296
|
+
const minutes = terms[1].substring(0, 2);
|
|
297
|
+
const meridian = terms[1].trim().slice(-2).toUpperCase();
|
|
298
|
+
let hour = parseInt(terms[0]);
|
|
299
|
+
if (!isNaN(parseInt(terms[0]))) {
|
|
300
|
+
if (meridian === 'PM' && hour < 12) {
|
|
301
|
+
hour = hour + 12;
|
|
302
|
+
}
|
|
303
|
+
if (meridian === 'AM' && hour === 12) {
|
|
304
|
+
hour = 0;
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
return `${hour}:${minutes}`;
|
|
308
|
+
}
|
|
309
|
+
static convert24To12(time) {
|
|
310
|
+
const terms = time.split(':');
|
|
311
|
+
let meridian = 'AM';
|
|
312
|
+
let hour = parseInt(terms[0]);
|
|
313
|
+
let minute = parseInt(terms[1]);
|
|
314
|
+
if (!isNaN(parseInt(terms[0]))) {
|
|
315
|
+
if (hour >= 12) {
|
|
316
|
+
meridian = 'PM';
|
|
317
|
+
if (hour > 12) {
|
|
318
|
+
hour = hour - 12;
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
if (hour === 0) {
|
|
322
|
+
hour = 12;
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
const hourStr = NeoTimepickerComponent.toFixed(hour, 10);
|
|
326
|
+
const minuteStr = NeoTimepickerComponent.toFixed(minute, 10);
|
|
327
|
+
return `${hourStr}:${minuteStr} ${meridian}`;
|
|
328
|
+
}
|
|
329
|
+
/**
|
|
330
|
+
* Return 08 for 8, 06 for 6
|
|
331
|
+
* @param num
|
|
332
|
+
* @param fix
|
|
333
|
+
* @private
|
|
334
|
+
*/
|
|
335
|
+
static toFixed(num, fix) {
|
|
336
|
+
let fixedNum = num.toString();
|
|
337
|
+
if (num < fix) {
|
|
338
|
+
fixedNum = `0${fixedNum}`;
|
|
339
|
+
}
|
|
340
|
+
return fixedNum;
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
NeoTimepickerComponent.decorators = [
|
|
344
|
+
{ type: Component, args: [{
|
|
345
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
346
|
+
selector: 'ap-neo-timepicker',
|
|
347
|
+
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",
|
|
348
|
+
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 red}[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 #fff}[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:#0000}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:initial}[border=transparent]{border:1px solid #0000}[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:#fff;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;grid-gap:8px;gap:8px}.time-picker-options .buttons button{font-weight:700;min-width:80px}"]
|
|
349
|
+
},] }
|
|
350
|
+
];
|
|
351
|
+
/** @nocollapse */
|
|
352
|
+
NeoTimepickerComponent.ctorParameters = () => [
|
|
353
|
+
{ type: ChangeDetectorRef }
|
|
354
|
+
];
|
|
355
|
+
NeoTimepickerComponent.propDecorators = {
|
|
356
|
+
inputBox: [{ type: ViewChild, args: ['inputBox',] }],
|
|
357
|
+
hourOptions: [{ type: ViewChild, args: ['hourOptions',] }],
|
|
358
|
+
minutesOptions: [{ type: ViewChild, args: ['minutesOptions',] }],
|
|
359
|
+
meridiansOptions: [{ type: ViewChild, args: ['meridiansOptions',] }],
|
|
360
|
+
timepicker: [{ type: ViewChild, args: ['timepicker',] }],
|
|
361
|
+
i18n: [{ type: Input }],
|
|
362
|
+
disabled: [{ type: Input }],
|
|
363
|
+
format: [{ type: Input }],
|
|
364
|
+
invalid: [{ type: Input }],
|
|
365
|
+
invalidationMessage: [{ type: Input }],
|
|
366
|
+
placement: [{ type: Input }],
|
|
367
|
+
timeModel: [{ type: Input }],
|
|
368
|
+
timeModelChange: [{ type: Output }],
|
|
369
|
+
onKeypress: [{ type: HostListener, args: ['window:keydown', ['$event'],] }]
|
|
370
|
+
};
|
|
371
|
+
//# 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"],"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"]}
|