@agorapulse/ui-components 13.0.2 → 13.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,388 +0,0 @@
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"]}
@@ -1,32 +0,0 @@
1
- import { ElementRef, EventEmitter, OnDestroy } from '@angular/core';
2
- import { MatDialog, MatDialogRef } from '@angular/material/dialog';
3
- import { EditTagsModalData } from './model/edit-tags-modal.model';
4
- import * as i0 from "@angular/core";
5
- export declare class EditTagsModalComponent implements OnDestroy {
6
- data: EditTagsModalData;
7
- dialogRef: MatDialogRef<EditTagsModalComponent>;
8
- dialog: MatDialog;
9
- deletedTags: string[];
10
- editTag: EventEmitter<Map<string, string>>;
11
- filteredTags: string[];
12
- savingTags: string[];
13
- tagEditedIndex: number;
14
- tags: string[];
15
- updatedTags: Map<string, string>;
16
- updateStatusByTags: Map<string, boolean>;
17
- tagInput: ElementRef;
18
- private readonly destroy$;
19
- constructor(data: EditTagsModalData, dialogRef: MatDialogRef<EditTagsModalComponent>, dialog: MatDialog);
20
- cancelEdit(): void;
21
- onDone(): void;
22
- onEdit(index: number): void;
23
- onRemove(tag: string): void;
24
- onValidateInput(index: number): void;
25
- onValidate(value: string, index: number): void;
26
- onValidateEnter(event: any, index: number): void;
27
- onSearch(tag: string): void;
28
- updateTagSuccess(tag: string): void;
29
- ngOnDestroy(): void;
30
- static ɵfac: i0.ɵɵFactoryDeclaration<EditTagsModalComponent, never>;
31
- static ɵcmp: i0.ɵɵComponentDeclaration<EditTagsModalComponent, "ng-component", never, {}, {}, never, never>;
32
- }
@@ -1,21 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- export interface EditTagsModalData {
3
- tags$: Observable<string[]>;
4
- updateStatusByTag$: Observable<TagStatus[]>;
5
- translatedString: TranslatedStrings;
6
- }
7
- export interface TagStatus {
8
- tag: string;
9
- loading: boolean;
10
- }
11
- export interface TranslatedStrings {
12
- cancelTooltip: string;
13
- deletedLabel: string;
14
- deleteTooltip?: string;
15
- doneLabel: string;
16
- savedLabel: string;
17
- searchPlaceholder: string;
18
- subtitle: string;
19
- title: string;
20
- validateTooltip: string;
21
- }