@norwegian/core-components 6.50.0 → 6.50.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/esm2022/lib/components/datepicker/index.mjs +1 -2
  2. package/esm2022/lib/components/datepicker-combo-new/datepicker-combo-new.component.mjs +371 -0
  3. package/esm2022/lib/components/datepicker-combo-new/datepicker-combo-new.module.mjs +31 -0
  4. package/esm2022/lib/components/datepicker-combo-new/index.mjs +3 -0
  5. package/esm2022/lib/components/datepicker-new/calendar-new/calendar-date.model.mjs +2 -0
  6. package/esm2022/lib/components/datepicker-new/calendar-new/calendar-new.component.mjs +594 -0
  7. package/esm2022/lib/components/datepicker-new/calendar-new/enums/week-start.enum.mjs +6 -0
  8. package/esm2022/lib/components/datepicker-new/calendar-new/models/day.model.mjs +2 -0
  9. package/esm2022/lib/components/datepicker-new/calendar-new/models/select-option.model.mjs +2 -0
  10. package/esm2022/lib/components/datepicker-new/calendar-new/models/week.model.mjs +2 -0
  11. package/esm2022/lib/components/datepicker-new/datepicker-new.component.mjs +571 -0
  12. package/esm2022/lib/components/datepicker-new/datepicker-new.module.mjs +55 -0
  13. package/esm2022/lib/components/datepicker-new/index.mjs +5 -0
  14. package/esm2022/lib/components/datepicker-new/services/calendar.service.mjs +215 -0
  15. package/esm2022/lib/components/index.mjs +3 -1
  16. package/fesm2022/norwegian-core-components.mjs +1790 -11
  17. package/fesm2022/norwegian-core-components.mjs.map +1 -1
  18. package/lib/components/datepicker/index.d.ts +0 -1
  19. package/lib/components/datepicker-combo-new/datepicker-combo-new.component.d.ts +294 -0
  20. package/lib/components/datepicker-combo-new/datepicker-combo-new.module.d.ts +10 -0
  21. package/lib/components/datepicker-combo-new/index.d.ts +2 -0
  22. package/lib/components/datepicker-new/calendar-new/calendar-date.model.d.ts +5 -0
  23. package/lib/components/datepicker-new/calendar-new/calendar-new.component.d.ts +159 -0
  24. package/lib/components/datepicker-new/calendar-new/enums/week-start.enum.d.ts +4 -0
  25. package/lib/components/datepicker-new/calendar-new/models/day.model.d.ts +10 -0
  26. package/lib/components/datepicker-new/calendar-new/models/select-option.model.d.ts +4 -0
  27. package/lib/components/datepicker-new/calendar-new/models/week.model.d.ts +5 -0
  28. package/lib/components/datepicker-new/datepicker-new.component.d.ts +272 -0
  29. package/lib/components/datepicker-new/datepicker-new.module.d.ts +16 -0
  30. package/lib/components/datepicker-new/index.d.ts +4 -0
  31. package/lib/components/datepicker-new/services/calendar.service.d.ts +27 -0
  32. package/lib/components/index.d.ts +2 -0
  33. package/package.json +1 -1
@@ -0,0 +1,571 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { NasComponentBase } from '../../core/base/nas-component.base';
3
+ import { UtcDate } from '../../core/models/utc-date.model';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "../../core/services/date/date-helper.service";
7
+ import * as i3 from "../select/select.component";
8
+ import * as i4 from "../select/option/option.component";
9
+ import * as i5 from "../icon/icon.component";
10
+ import * as i6 from "../../core/directives/nas-class/nas-class.directive";
11
+ import * as i7 from "@angular/forms";
12
+ import * as i8 from "../backdrop/backdrop.component";
13
+ import * as i9 from "./calendar-new/calendar-new.component";
14
+ /**
15
+ * @description
16
+ * Norwegian Date Picker Component | New design | Beta
17
+ */
18
+ export class DatepickerNewComponent extends NasComponentBase {
19
+ get showBackdrop() {
20
+ return this.show && !this.exists(this.disableBackdrop);
21
+ }
22
+ set showBackdrop(value) {
23
+ if (this.show === value) {
24
+ return;
25
+ }
26
+ setTimeout(() => {
27
+ this.show = value;
28
+ });
29
+ }
30
+ /**
31
+ * @property Input
32
+ * @description
33
+ * The lowest date allowed.
34
+ */
35
+ get lowerLimitDate() {
36
+ return this.lowerLimitDateValue;
37
+ }
38
+ set lowerLimitDate(date) {
39
+ this.lowerLimitDateValue = date;
40
+ if (this.dateService.isLessThan(this.selectedDate, date, false, true, true)) {
41
+ this.selectedDate = date;
42
+ }
43
+ }
44
+ /**
45
+ * @property Input
46
+ * @description
47
+ * boolean value to disable or enable the input of the date picker.
48
+ */
49
+ get disabled() {
50
+ return this.disabledValue;
51
+ }
52
+ set disabled(value) {
53
+ this.disabledValue = value;
54
+ if (this.nasFormGroup && this.nasFormControlName) {
55
+ setTimeout(() => {
56
+ const control = this.nasFormGroup.get(this.nasFormControlName);
57
+ if (!control) {
58
+ return;
59
+ }
60
+ if (value) {
61
+ control.disable();
62
+ }
63
+ else {
64
+ control.enable();
65
+ }
66
+ });
67
+ }
68
+ }
69
+ /**
70
+ * @property Input
71
+ * @description
72
+ * An array of times to be added in the time selector.
73
+ */
74
+ get times() {
75
+ return this.timesValue;
76
+ }
77
+ set times(times) {
78
+ if (!times) {
79
+ return;
80
+ }
81
+ this.timesValue = times;
82
+ this.timeOptions = times.map(x => {
83
+ x.year = new Date().getUTCFullYear();
84
+ const option = {
85
+ title: this.datePipe.transform(this.dateService.date(x), this.timeDisplayFormat, 'UTC', this.locale),
86
+ value: this.dateService.date(x).toISOString()
87
+ };
88
+ return option;
89
+ });
90
+ this.dateDisplayFormat = 'mediumDate';
91
+ }
92
+ /**
93
+ * @property Input
94
+ * @description
95
+ * The calendar is open or closed.
96
+ */
97
+ get open() {
98
+ return this.openValue;
99
+ }
100
+ set open(open) {
101
+ if (open === this.openValue) {
102
+ return;
103
+ }
104
+ this.openValue = open;
105
+ if (open) {
106
+ this.openCalendar();
107
+ }
108
+ else {
109
+ this.closeCalendar();
110
+ }
111
+ }
112
+ /**
113
+ * @property Input
114
+ * @description
115
+ * Set selected month.
116
+ */
117
+ get selectedMonth() {
118
+ return this.selectedMonthValue;
119
+ }
120
+ set selectedMonth(month) {
121
+ if (!month) {
122
+ return;
123
+ }
124
+ if (this.dateService.isSameMonth(this.selectedMonthValue, month)) {
125
+ return;
126
+ }
127
+ setTimeout(() => {
128
+ this.selectedMonthValue = month;
129
+ this.selectedMonthChange.emit(month);
130
+ });
131
+ }
132
+ /**
133
+ * @property Input
134
+ * @description
135
+ * Gets or sets the selected Date in the date picker. Setting this date will highlight the date in the date picker
136
+ * and user can change it by clicking from any other enabled dates
137
+ * or by navigating betrween months and selecting from different available month.
138
+ */
139
+ get selectedDate() {
140
+ return this.selectedDateValue;
141
+ }
142
+ set selectedDate(date) {
143
+ if (!date) {
144
+ return;
145
+ }
146
+ if (this.selectedDateValue && this.dateService.isSameDate(this.selectedDateValue, date)) {
147
+ return;
148
+ }
149
+ if (this.selectedTimeValue) {
150
+ date = new UtcDate(date.year, date.month, date.date, this.selectedTimeValue.hours, this.selectedTimeValue.minutes);
151
+ }
152
+ this.selectedDateValue = date;
153
+ if (this.nasFormGroup && this.nasFormControlName) {
154
+ const control = this.nasFormGroup.get(this.nasFormControlName);
155
+ if (control) {
156
+ const calendarDate = {
157
+ model: this.datePipe.transform(this.dateService.date(date), this.dateDisplayFormat, 'UTC', this.locale),
158
+ date: date
159
+ };
160
+ control.patchValue(calendarDate);
161
+ }
162
+ }
163
+ setTimeout(() => {
164
+ this.model = this.datePipe.transform(this.dateService.date(date), this.dateDisplayFormat, 'UTC', this.locale);
165
+ });
166
+ this.selectedDateChange.emit(date);
167
+ if (this.show) {
168
+ this.closeCalendar();
169
+ }
170
+ }
171
+ /**
172
+ * @property Input
173
+ * @description
174
+ * Sets the selected time in the time selector.
175
+ */
176
+ get selectedTime() {
177
+ return this.selectedTimeValue;
178
+ }
179
+ set selectedTime(time) {
180
+ if (!time) {
181
+ return;
182
+ }
183
+ this.selectedTimeValue = time;
184
+ if (this.timeOptions && this.timeOptions.length > 0) {
185
+ const timeOption = this.timeOptions.find(x => x.value === this.dateService.date(time).toISOString());
186
+ if (timeOption) {
187
+ this.selectedTimeOption = timeOption;
188
+ }
189
+ }
190
+ if (this.selectedDate) {
191
+ this.selectedDate = new UtcDate(this.selectedDate.year, this.selectedDate.month, this.selectedDate.date, this.selectedTimeValue.hours, this.selectedTimeValue.minutes);
192
+ }
193
+ else if (this.activeDate) {
194
+ this.selectedDate = new UtcDate(this.activeDate.year, this.activeDate.month, this.activeDate.date, this.selectedTimeValue.hours, this.selectedTimeValue.minutes);
195
+ }
196
+ }
197
+ get activeDate() {
198
+ if (this.selectedDate && this.activeDateValue &&
199
+ this.dateService.isLessThan(this.activeDateValue, this.selectedDate, false, true, true)) {
200
+ return this.activeDateValue;
201
+ }
202
+ if (this.activeDateValue) {
203
+ return this.activeDateValue;
204
+ }
205
+ else if (this.selectedDate) {
206
+ this.activeDateValue = this.selectedDate;
207
+ }
208
+ else {
209
+ const now = new Date();
210
+ this.activeDateValue = new UtcDate(now.getFullYear(), now.getMonth(), now.getDate());
211
+ }
212
+ return this.activeDateValue;
213
+ }
214
+ set activeDate(date) {
215
+ if (this.lowerLimitDate && this.dateService.isLessThan(date, this.lowerLimitDate, false, true, true)) {
216
+ return;
217
+ }
218
+ this.activeDateValue = date;
219
+ clearTimeout(this.activeDateTimeout);
220
+ this.activeDateTimeout = setTimeout(() => {
221
+ this.model = this.datePipe.transform(this.dateService.date(this.selectedDate), this.dateDisplayFormat, 'UTC', this.locale);
222
+ });
223
+ }
224
+ constructor(datePipe, dateService) {
225
+ super('nas-datepicker-new');
226
+ this.datePipe = datePipe;
227
+ this.dateService = dateService;
228
+ this.show = false;
229
+ this.showTimes = false;
230
+ /**
231
+ * @property Input
232
+ * @description
233
+ * The display format of the date when user has selected the date and it is being shown in the input box for the date picker.
234
+ * Please look at the angular Date pipe for valid formats and variations.
235
+ */
236
+ this.dateDisplayFormat = 'EEEE d, MMMM yyyy';
237
+ /**
238
+ * @property Input
239
+ * @description
240
+ * The time display format.
241
+ */
242
+ this.timeDisplayFormat = 'HH:mm';
243
+ /**
244
+ * @property Input
245
+ * @description
246
+ * A locale code for the locale format rules to use. When not supplied, uses the value of LOCALE_ID, which is en-US by default.
247
+ * This requires that registerLocaleData is called with the respective locale.
248
+ */
249
+ this.locale = 'en-US';
250
+ /**
251
+ * @property Output
252
+ * @description
253
+ * Date selected by the user by clicking in date-picker date-box.
254
+ */
255
+ this.selectedDateChange = new EventEmitter();
256
+ /**
257
+ * @property Output
258
+ * @description
259
+ * Month selected by the user by clicking in drop down for month selection or month navigation buttons.
260
+ */
261
+ this.selectedMonthChange = new EventEmitter();
262
+ /**
263
+ * @property Output
264
+ * @description
265
+ * The calendar is open or closed.
266
+ */
267
+ this.openChange = new EventEmitter();
268
+ /**
269
+ * @property Output
270
+ * @description
271
+ * When a user has actively changed the date.
272
+ */
273
+ this.focusOnNextChange = new EventEmitter();
274
+ /**
275
+ * @property Output
276
+ * @description
277
+ * When a user has pressed shift + tab to go to previous control.
278
+ */
279
+ this.focusOnPreviousChange = new EventEmitter();
280
+ this.forceNotOpenCalendar = false;
281
+ }
282
+ ngOnInit() {
283
+ if (this.nasFormGroup && this.nasFormControlName) {
284
+ this.nasFormGroup
285
+ .get(this.nasFormControlName)
286
+ .valueChanges
287
+ .subscribe(value => {
288
+ if (this.model === value?.model) {
289
+ return;
290
+ }
291
+ setTimeout(() => {
292
+ this.model = value?.model;
293
+ this.selectedDateValue = value?.date;
294
+ });
295
+ });
296
+ }
297
+ }
298
+ onInputKeydownShiftTab(event) {
299
+ this.closeCalendar();
300
+ this.focusOnPreviousChange.emit(event);
301
+ }
302
+ onCalendarKeyDown(event) {
303
+ let currentActiveDate = this.activeDate.date;
304
+ let date;
305
+ if (document.activeElement === this.input.nativeElement) {
306
+ event.stopImmediatePropagation();
307
+ }
308
+ switch (event.key) {
309
+ case 'ArrowRight':
310
+ if (this.isActiveElementMonthButtons()) {
311
+ event.preventDefault();
312
+ break;
313
+ }
314
+ currentActiveDate++;
315
+ this.activeDate = this.dateService.utcDate(new Date(Date.UTC(this.activeDate.year, this.activeDate.month, currentActiveDate)));
316
+ this.setFocusOnActiveDateAsync();
317
+ break;
318
+ case 'ArrowLeft':
319
+ if (this.isActiveElementMonthButtons()) {
320
+ event.preventDefault();
321
+ break;
322
+ }
323
+ currentActiveDate--;
324
+ date = this.dateService.utcDate(new Date(Date.UTC(this.activeDate.year, this.activeDate.month, currentActiveDate)));
325
+ if (this.exists(this.disablePastSelection) && this.dateService.isInThePast(date)) {
326
+ break;
327
+ }
328
+ this.activeDate = date;
329
+ this.setFocusOnActiveDateAsync();
330
+ break;
331
+ case 'ArrowUp':
332
+ if (this.isActiveElementMonthButtons()) {
333
+ event.preventDefault();
334
+ break;
335
+ }
336
+ currentActiveDate -= 7;
337
+ date = this.dateService.utcDate(new Date(Date.UTC(this.activeDate.year, this.activeDate.month, currentActiveDate)));
338
+ if (this.exists(this.disablePastSelection) && this.dateService.isInThePast(date)) {
339
+ break;
340
+ }
341
+ this.activeDate = date;
342
+ this.setFocusOnActiveDateAsync();
343
+ event.preventDefault();
344
+ break;
345
+ case 'ArrowDown':
346
+ if (this.isActiveElementMonthButtons()) {
347
+ event.preventDefault();
348
+ break;
349
+ }
350
+ currentActiveDate += 7;
351
+ this.activeDateValue = this.dateService.utcDate(new Date(Date.UTC(this.activeDate.year, this.activeDate.month, currentActiveDate)));
352
+ this.setFocusOnActiveDateAsync();
353
+ event.preventDefault();
354
+ break;
355
+ case 'Escape':
356
+ this.closeCalendar();
357
+ this.forceNotOpenCalendar = true;
358
+ if (this.input) {
359
+ this.input.nativeElement.select();
360
+ }
361
+ break;
362
+ case 'Enter':
363
+ if (this.isActiveElementMonthButtons()) {
364
+ return;
365
+ }
366
+ this.setFocusOnTimeSelectorOrNext(event);
367
+ break;
368
+ }
369
+ }
370
+ onTimeSelectorKeydown(event) {
371
+ if (event.key === 'Tab') {
372
+ if (event.shiftKey) {
373
+ this.openCalendar();
374
+ }
375
+ else {
376
+ this.focusOnNextChange.emit(event);
377
+ }
378
+ event.preventDefault();
379
+ }
380
+ }
381
+ setFocusOnTimeSelectorOrNext(event) {
382
+ if (this.timeOptions) {
383
+ setTimeout(() => {
384
+ const selectElement = this.timeSelector.select.nativeElement;
385
+ if (selectElement) {
386
+ selectElement.focus();
387
+ }
388
+ });
389
+ }
390
+ else {
391
+ this.focusOnNextChange.emit(event);
392
+ }
393
+ this.closeCalendar();
394
+ }
395
+ onMonthChange(currentMonth) {
396
+ this.selectedMonth = currentMonth;
397
+ }
398
+ onMouseDownDatepicker() {
399
+ this.openCalendar();
400
+ }
401
+ openCalendar() {
402
+ if (this.show || this.disabled || this.forceNotOpenCalendar) {
403
+ this.forceNotOpenCalendar = false;
404
+ return;
405
+ }
406
+ setTimeout(() => {
407
+ this.show = true;
408
+ });
409
+ this.activeDate = this.selectedDate;
410
+ clearTimeout(this.openCalendarTimeout);
411
+ this.openCalendarTimeout = setTimeout(() => {
412
+ this.input.nativeElement.select();
413
+ this.openChange.emit(this.show);
414
+ }, 100);
415
+ }
416
+ onTimeSelected(option) {
417
+ this.selectedTime = this.dateService.utcDate(option.value);
418
+ this.focusOnNextChange.emit();
419
+ }
420
+ onTimeSelectorClick() {
421
+ }
422
+ getMainClass() {
423
+ return this.getContainerClass('', [(this.exists(this.timeOptions) && 'has-time'),
424
+ (this.exists(this.compact) && 'compact')]);
425
+ }
426
+ getLabelClass() {
427
+ if (this.exists(this.disabled)) {
428
+ return this.getClass('date-picker-label', ['disabled']);
429
+ }
430
+ else {
431
+ return this.getClass('date-picker-label');
432
+ }
433
+ }
434
+ closeCalendar() {
435
+ setTimeout(() => {
436
+ this.show = false;
437
+ });
438
+ this.openChange.emit(false);
439
+ }
440
+ selectDate(event) {
441
+ if (!this.isModelValid()) {
442
+ return;
443
+ }
444
+ this.activeDate = this.date();
445
+ if (!this.someValidDaysEqualsSelectedDay(this.activeDate)) {
446
+ return;
447
+ }
448
+ this.selectedDate = this.activeDate;
449
+ this.setFocusOnTimeSelectorOrNext(event);
450
+ this.closeCalendar();
451
+ }
452
+ isActiveElementMonthButtons() {
453
+ return document.activeElement === this.calendar.nextMonthRef.nativeElement ||
454
+ document.activeElement === this.calendar.previousMonthRef.nativeElement ||
455
+ this.calendar.monthSelectRef && document.activeElement === this.calendar.monthSelectRef.select.nativeElement;
456
+ }
457
+ setFocusOnActiveDateAsync() {
458
+ setTimeout(() => {
459
+ const elmementToFocus = this.calendar.activeDateCell;
460
+ if (elmementToFocus) {
461
+ elmementToFocus.focus();
462
+ }
463
+ }, 200);
464
+ }
465
+ isModelValid() {
466
+ const timestamp = Date.parse(this.model);
467
+ return isNaN(timestamp) !== true;
468
+ }
469
+ allDays() {
470
+ const allDays = new Array();
471
+ if (this.calendar) {
472
+ this.calendar.weeks.forEach(x => x && x.days.forEach(d => allDays.push(d)));
473
+ }
474
+ return allDays;
475
+ }
476
+ someValidDaysEqualsSelectedDay(selectedDay) {
477
+ return this.allDays()
478
+ .some(x => x
479
+ && this.dateService.isSameDate(this.dateService.utcDate(x.date), selectedDay)
480
+ && (x.isAvailable || !x.isDisabled));
481
+ }
482
+ date() {
483
+ const modelDate = new Date(this.model);
484
+ const modelUtcDate = new UtcDate(modelDate.getFullYear(), modelDate.getMonth(), modelDate.getDate());
485
+ return modelUtcDate;
486
+ }
487
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: DatepickerNewComponent, deps: [{ token: i1.DatePipe }, { token: i2.DateHelper }], target: i0.ɵɵFactoryTarget.Component }); }
488
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.5", type: DatepickerNewComponent, selector: "nas-datepicker-new", inputs: { ariaLabelBackdrop: "ariaLabelBackdrop", disableBackdrop: "disableBackdrop", noAvailableFlightsLabel: "noAvailableFlightsLabel", availableFlightsLabel: "availableFlightsLabel", disablePastSelection: "disablePastSelection", lowerLimitDate: "lowerLimitDate", availability: "availability", availableDates: "availableDates", disabled: "disabled", placeholder: "placeholder", required: "required", ariaDescribedby: "ariaDescribedby", ariaLabel: "ariaLabel", dateDisplayFormat: "dateDisplayFormat", timeDisplayFormat: "timeDisplayFormat", locale: "locale", compact: "compact", nasFormGroup: "nasFormGroup", nasFormControlName: "nasFormControlName", times: "times", open: "open", selectedMonth: "selectedMonth", selectedDate: "selectedDate", selectedTime: "selectedTime", ariaLabelPreviousMonth: "ariaLabelPreviousMonth", ariaLabelNextMonth: "ariaLabelNextMonth" }, outputs: { selectedDateChange: "selectedDateChange", selectedMonthChange: "selectedMonthChange", openChange: "openChange", focusOnNextChange: "focusOnNextChange", focusOnPreviousChange: "focusOnPreviousChange" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "calendar", first: true, predicate: ["calendar"], descendants: true }, { propertyName: "datePickerContent", first: true, predicate: ["datePickerContent"], descendants: true }, { propertyName: "timeSelector", first: true, predicate: ["timeSelector"], descendants: true }, { propertyName: "time", first: true, predicate: ["time"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<label [nasClass]=\"getMainClass()\">\n <div [nasClass]=\"getClass('date-picker-content')\">\n <div [nasClass]=\"getClass('date-picker-wrapper')\">\n <div [nasClass]=\"getClass('controls', show && 'active')\"\n (mousedown)=\"onMouseDownDatepicker()\">\n <div #datePickerContent\n [nasClass]=\"getLabelClass()\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <input #input\n [nasClass]=\"getClass('date-picker')\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [attr.placeholder]=\"placeholder\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n [attr.aria-required]=\"required\"\n [attr.aria-haspopup]=\"true\"\n (keydown.tab)=\"selectDate($event)\"\n (keydown.shift.tab)=\"onInputKeydownShiftTab($event)\"\n (keydown.enter)=\"selectDate($event)\"\n (keydown.arrowdown)=\"onCalendarKeyDown($event)\"\n (keydown.arrowleft)=\"onCalendarKeyDown($event)\"\n (keydown.arrowright)=\"onCalendarKeyDown($event)\"\n (keydown.arrowup)=\"onCalendarKeyDown($event)\"\n (focus)=\"openCalendar()\"\n [(ngModel)]=\"model\" />\n </div>\n <div [nasClass]=\"getClass('calendar-icon')\">\n <nas-icon *ngIf=\"exists(disabled); else regularIcon\"\n [icon]=\"'calendar--disabled'\"\n [ngStyle]=\"{'pointer-events': 'none'}\">\n </nas-icon>\n <ng-template #regularIcon>\n <nas-icon icon=\"calendar\"\n (click)=\"openCalendar()\">\n </nas-icon>\n </ng-template>\n </div>\n <nas-calendar-new #calendar *ngIf=\"show\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlName]=\"nasFormControlName\"\n [dateDisplayFormat]=\"dateDisplayFormat\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [availableFlightsLabel]=\"availableFlightsLabel\"\n [availability]=\"exists(availability)\"\n [availableDates]=\"availableDates\"\n [lowerLimitDate]=\"lowerLimitDate\"\n [disablePastSelection]=\"exists(disablePastSelection)\"\n [locale]=\"locale\"\n [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n [(activeDate)]=\"activeDate\"\n [(selectedDate)]=\"selectedDate\"\n (focusOnNextChange)=\"setFocusOnTimeSelectorOrNext($event)\"\n (keydown)=\"onCalendarKeyDown($event)\"\n (monthChange)=\"onMonthChange($event)\">\n </nas-calendar-new>\n </div>\n <nas-backdrop [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>\n </div>\n</label>\n<div *ngIf=\"timeOptions\"\n [nasClass]=\"getClass('time-selector-wrapper')\">\n <nas-select #timeSelector\n [nasClass]=\"getClass('time-picker')\"\n [selected]=\"selectedTimeOption\"\n (selectedChange)=\"onTimeSelected($event)\"\n (keydown)=\"onTimeSelectorKeydown($event)\">\n <div [nasClass]=\"getClass('arrow')\">\n <div [nasClass]=\"getClass('icon-left')\">\n <nas-icon [type]=\"'arrow-left'\"></nas-icon>\n </div>\n </div>\n <nas-option #time *ngFor=\"let time of timeOptions\"\n [option]=\"time\"></nas-option>\n <div [nasClass]=\"getClass('arrow')\">\n <div [nasClass]=\"getClass('icon-right')\">\n <nas-icon [type]=\"'arrow-right'\"></nas-icon>\n </div>\n </div>\n </nas-select>\n</div>\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<!-- Lag en metode som sender inn value til det klokkeslettet som er valgt -->\n<!-- div som er clickable for hver time? -->\n<!-- input-text-new? -->", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}:host{display:flex}.nas-datepicker-new{position:relative;top:0;left:0;width:100%;height:100%;overflow-x:visible;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 16px;max-height:98vh;overflow-y:visible}.nas-datepicker-new__time-picker{display:flex;gap:12px;justify-content:center}.nas-datepicker-new__date-picker-wrapper{position:relative;padding-bottom:3px;border-bottom:3px solid #c3c3c3}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker{display:block;width:100%;height:35px;padding:0 16px 9px;border:0;border-radius:0;transition:all .2s cubic-bezier(0,0,.1,1);font-family:inherit;outline:0;-webkit-appearance:none;appearance:none;box-sizing:border-box;color:#15273f;font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:400;font-size:16px;line-height:26px;position:relative;z-index:3;background-color:inherit}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker[disabled]{color:#909090;background-color:#fff}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker:-moz-placeholder{line-height:normal}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker::-moz-placeholder{line-height:normal}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker:-ms-input-placeholder{line-height:normal}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker::-webkit-input-placeholder{line-height:normal}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker:focus~.nas-datepicker__input-line{border-color:#15273f}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__calendar-icon{position:absolute;right:15px;top:50%;margin-top:-12px;vertical-align:middle;cursor:pointer;z-index:3}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker-label{padding:9px 16px 0;position:relative;z-index:3;color:#15273f;font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:700;font-size:14px;line-height:20px;background-color:inherit;display:flex}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker-label--disabled{color:#909090}.nas-datepicker-new__date-picker-wrapper nas-calendar{position:absolute;top:75px;vertical-align:middle;right:0px;z-index:4}@media (min-width: 640px){.nas-datepicker-new__date-picker-wrapper nas-calendar{right:-15px}}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__controls{background-color:#fff}.nas-datepicker-new__time-selector-wrapper nas-select{display:flex}.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select{margin-bottom:0;margin-left:3px}.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select:after{bottom:26px}.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select select{border:3px solid #fff;background-color:#fff;height:64px}@media all and (-ms-high-contrast: none),(-ms-high-contrast: active){.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select select{height:60px}}.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select select:focus{border-color:#15273f}.nas-datepicker-new--has-time{padding-right:3px}.nas-datepicker-new nas-spinner{position:absolute;top:300px;left:45%;right:45%}.nas-datepicker-new__backdrop{display:block;position:fixed;z-index:2;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:datepicker-backdrop .7s ease-out both}.nas-datepicker-new--compact{padding:0;margin-bottom:0}@keyframes datepicker-backdrop{0%{opacity:0}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.SelectComponent, selector: "nas-select", inputs: ["id", "inline", "label", "block", "spaceless", "stretch", "compact", "simple", "light", "fill", "error", "errorMessage", "disabled", "autogrow", "cssClass", "nasFormControlName", "nasFormGroup", "options", "selectedValue", "selected"], outputs: ["selectedChange", "keydown"] }, { kind: "component", type: i4.OptionComponent, selector: "nas-option", inputs: ["option"] }, { kind: "component", type: i5.IconComponent, selector: "nas-icon", inputs: ["icon", "type", "isIndicator", "lightCircularBackground", "cssClass"] }, { kind: "directive", type: i6.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8.BackdropComponent, selector: "nas-backdrop", inputs: ["showBackdrop", "ariaLabelBackdrop"], outputs: ["showBackdropChange"] }, { kind: "component", type: i9.CalendarNewComponent, selector: "nas-calendar-new", inputs: ["noAvailableFlightsLabel", "availableFlightsLabel", "disablePastSelection", "lowerLimitDate", "date", "weekStart", "displayWeekNumbers", "availability", "locale", "availableDates", "activeDate", "selectedDate", "nasFormGroup", "nasFormControlName", "dateDisplayFormat", "ariaLabelPreviousMonth", "ariaLabelNextMonth"], outputs: ["monthChange", "focusOnNextChange", "selectedDateChange", "activeDateChange"] }], encapsulation: i0.ViewEncapsulation.None }); }
489
+ }
490
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: DatepickerNewComponent, decorators: [{
491
+ type: Component,
492
+ args: [{ selector: 'nas-datepicker-new', encapsulation: ViewEncapsulation.None, template: "<label [nasClass]=\"getMainClass()\">\n <div [nasClass]=\"getClass('date-picker-content')\">\n <div [nasClass]=\"getClass('date-picker-wrapper')\">\n <div [nasClass]=\"getClass('controls', show && 'active')\"\n (mousedown)=\"onMouseDownDatepicker()\">\n <div #datePickerContent\n [nasClass]=\"getLabelClass()\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <input #input\n [nasClass]=\"getClass('date-picker')\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [attr.placeholder]=\"placeholder\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n [attr.aria-required]=\"required\"\n [attr.aria-haspopup]=\"true\"\n (keydown.tab)=\"selectDate($event)\"\n (keydown.shift.tab)=\"onInputKeydownShiftTab($event)\"\n (keydown.enter)=\"selectDate($event)\"\n (keydown.arrowdown)=\"onCalendarKeyDown($event)\"\n (keydown.arrowleft)=\"onCalendarKeyDown($event)\"\n (keydown.arrowright)=\"onCalendarKeyDown($event)\"\n (keydown.arrowup)=\"onCalendarKeyDown($event)\"\n (focus)=\"openCalendar()\"\n [(ngModel)]=\"model\" />\n </div>\n <div [nasClass]=\"getClass('calendar-icon')\">\n <nas-icon *ngIf=\"exists(disabled); else regularIcon\"\n [icon]=\"'calendar--disabled'\"\n [ngStyle]=\"{'pointer-events': 'none'}\">\n </nas-icon>\n <ng-template #regularIcon>\n <nas-icon icon=\"calendar\"\n (click)=\"openCalendar()\">\n </nas-icon>\n </ng-template>\n </div>\n <nas-calendar-new #calendar *ngIf=\"show\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlName]=\"nasFormControlName\"\n [dateDisplayFormat]=\"dateDisplayFormat\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [availableFlightsLabel]=\"availableFlightsLabel\"\n [availability]=\"exists(availability)\"\n [availableDates]=\"availableDates\"\n [lowerLimitDate]=\"lowerLimitDate\"\n [disablePastSelection]=\"exists(disablePastSelection)\"\n [locale]=\"locale\"\n [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n [(activeDate)]=\"activeDate\"\n [(selectedDate)]=\"selectedDate\"\n (focusOnNextChange)=\"setFocusOnTimeSelectorOrNext($event)\"\n (keydown)=\"onCalendarKeyDown($event)\"\n (monthChange)=\"onMonthChange($event)\">\n </nas-calendar-new>\n </div>\n <nas-backdrop [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>\n </div>\n</label>\n<div *ngIf=\"timeOptions\"\n [nasClass]=\"getClass('time-selector-wrapper')\">\n <nas-select #timeSelector\n [nasClass]=\"getClass('time-picker')\"\n [selected]=\"selectedTimeOption\"\n (selectedChange)=\"onTimeSelected($event)\"\n (keydown)=\"onTimeSelectorKeydown($event)\">\n <div [nasClass]=\"getClass('arrow')\">\n <div [nasClass]=\"getClass('icon-left')\">\n <nas-icon [type]=\"'arrow-left'\"></nas-icon>\n </div>\n </div>\n <nas-option #time *ngFor=\"let time of timeOptions\"\n [option]=\"time\"></nas-option>\n <div [nasClass]=\"getClass('arrow')\">\n <div [nasClass]=\"getClass('icon-right')\">\n <nas-icon [type]=\"'arrow-right'\"></nas-icon>\n </div>\n </div>\n </nas-select>\n</div>\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<!-- Lag en metode som sender inn value til det klokkeslettet som er valgt -->\n<!-- div som er clickable for hver time? -->\n<!-- input-text-new? -->", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}:host{display:flex}.nas-datepicker-new{position:relative;top:0;left:0;width:100%;height:100%;overflow-x:visible;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 16px;max-height:98vh;overflow-y:visible}.nas-datepicker-new__time-picker{display:flex;gap:12px;justify-content:center}.nas-datepicker-new__date-picker-wrapper{position:relative;padding-bottom:3px;border-bottom:3px solid #c3c3c3}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker{display:block;width:100%;height:35px;padding:0 16px 9px;border:0;border-radius:0;transition:all .2s cubic-bezier(0,0,.1,1);font-family:inherit;outline:0;-webkit-appearance:none;appearance:none;box-sizing:border-box;color:#15273f;font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:400;font-size:16px;line-height:26px;position:relative;z-index:3;background-color:inherit}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker[disabled]{color:#909090;background-color:#fff}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker:-moz-placeholder{line-height:normal}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker::-moz-placeholder{line-height:normal}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker:-ms-input-placeholder{line-height:normal}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker::-webkit-input-placeholder{line-height:normal}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker:focus~.nas-datepicker__input-line{border-color:#15273f}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__calendar-icon{position:absolute;right:15px;top:50%;margin-top:-12px;vertical-align:middle;cursor:pointer;z-index:3}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker-label{padding:9px 16px 0;position:relative;z-index:3;color:#15273f;font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:700;font-size:14px;line-height:20px;background-color:inherit;display:flex}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__date-picker-label--disabled{color:#909090}.nas-datepicker-new__date-picker-wrapper nas-calendar{position:absolute;top:75px;vertical-align:middle;right:0px;z-index:4}@media (min-width: 640px){.nas-datepicker-new__date-picker-wrapper nas-calendar{right:-15px}}.nas-datepicker-new__date-picker-wrapper .nas-datepicker-new__controls{background-color:#fff}.nas-datepicker-new__time-selector-wrapper nas-select{display:flex}.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select{margin-bottom:0;margin-left:3px}.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select:after{bottom:26px}.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select select{border:3px solid #fff;background-color:#fff;height:64px}@media all and (-ms-high-contrast: none),(-ms-high-contrast: active){.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select select{height:60px}}.nas-datepicker-new__time-selector-wrapper nas-select ::ng-deep .nas-select select:focus{border-color:#15273f}.nas-datepicker-new--has-time{padding-right:3px}.nas-datepicker-new nas-spinner{position:absolute;top:300px;left:45%;right:45%}.nas-datepicker-new__backdrop{display:block;position:fixed;z-index:2;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:datepicker-backdrop .7s ease-out both}.nas-datepicker-new--compact{padding:0;margin-bottom:0}@keyframes datepicker-backdrop{0%{opacity:0}}\n"] }]
493
+ }], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i2.DateHelper }]; }, propDecorators: { input: [{
494
+ type: ViewChild,
495
+ args: ['input']
496
+ }], calendar: [{
497
+ type: ViewChild,
498
+ args: ['calendar']
499
+ }], datePickerContent: [{
500
+ type: ViewChild,
501
+ args: ['datePickerContent']
502
+ }], timeSelector: [{
503
+ type: ViewChild,
504
+ args: ['timeSelector']
505
+ }], time: [{
506
+ type: ViewChild,
507
+ args: ['time']
508
+ }], ariaLabelBackdrop: [{
509
+ type: Input
510
+ }], disableBackdrop: [{
511
+ type: Input
512
+ }], noAvailableFlightsLabel: [{
513
+ type: Input
514
+ }], availableFlightsLabel: [{
515
+ type: Input
516
+ }], disablePastSelection: [{
517
+ type: Input
518
+ }], lowerLimitDate: [{
519
+ type: Input
520
+ }], availability: [{
521
+ type: Input
522
+ }], availableDates: [{
523
+ type: Input
524
+ }], disabled: [{
525
+ type: Input
526
+ }], placeholder: [{
527
+ type: Input
528
+ }], required: [{
529
+ type: Input
530
+ }], ariaDescribedby: [{
531
+ type: Input
532
+ }], ariaLabel: [{
533
+ type: Input
534
+ }], dateDisplayFormat: [{
535
+ type: Input
536
+ }], timeDisplayFormat: [{
537
+ type: Input
538
+ }], locale: [{
539
+ type: Input
540
+ }], compact: [{
541
+ type: Input
542
+ }], nasFormGroup: [{
543
+ type: Input
544
+ }], nasFormControlName: [{
545
+ type: Input
546
+ }], times: [{
547
+ type: Input
548
+ }], open: [{
549
+ type: Input
550
+ }], selectedMonth: [{
551
+ type: Input
552
+ }], selectedDate: [{
553
+ type: Input
554
+ }], selectedTime: [{
555
+ type: Input
556
+ }], ariaLabelPreviousMonth: [{
557
+ type: Input
558
+ }], ariaLabelNextMonth: [{
559
+ type: Input
560
+ }], selectedDateChange: [{
561
+ type: Output
562
+ }], selectedMonthChange: [{
563
+ type: Output
564
+ }], openChange: [{
565
+ type: Output
566
+ }], focusOnNextChange: [{
567
+ type: Output
568
+ }], focusOnPreviousChange: [{
569
+ type: Output
570
+ }] } });
571
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-new.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/datepicker-new/datepicker-new.component.ts","../../../../../../projects/core-components/src/lib/components/datepicker-new/datepicker-new.component.html"],"names":[],"mappings":"AAKA,OAAO,EACL,SAAS,EAET,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,EACT,iBAAiB,EAElB,MAAM,eAAe,CAAC;AAKvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AAEtE,OAAO,EAAE,OAAO,EAAE,MAAM,kCAAkC,CAAC;;;;;;;;;;;AAK3D;;;GAGG;AAOH,MAAM,OAAO,sBAAuB,SAAQ,gBAAgB;IAO1D,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACzD,CAAC;IACD,IAAI,YAAY,CAAC,KAAc;QAC7B,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE;YACvB,OAAO;SACR;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QACpB,CAAC,CAAC,CAAC;IACL,CAAC;IA2CD;;;;OAIG;IACH,IACI,cAAc;QAChB,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IACD,IAAI,cAAc,CAAC,IAAa;QAC9B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAEhC,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE;YAC3E,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;SAC1B;IACH,CAAC;IAgBD;;;;OAIG;IACH,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAE3B,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAChD,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;gBAE/D,IAAI,CAAC,OAAO,EAAE;oBACZ,OAAO;iBACR;gBAED,IAAI,KAAK,EAAE;oBACT,OAAO,CAAC,OAAO,EAAE,CAAC;iBACnB;qBAAM;oBACL,OAAO,CAAC,MAAM,EAAE,CAAC;iBAClB;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IA8ED;;;;OAIG;IACH,IACI,KAAK;QACP,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IACD,IAAI,KAAK,CAAC,KAAqB;QAC7B,IAAI,CAAC,KAAK,EAAE;YACV,OAAO;SACR;QAED,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC/B,CAAC,CAAC,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC,cAAc,EAAE,CAAC;YACrC,MAAM,MAAM,GAAsB;gBAChC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC;gBACpG,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE;aAC9C,CAAC;YAEF,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,GAAG,YAAY,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACH,IACI,IAAI;QACN,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,IAAI,CAAC,IAAa;QACpB,IAAI,IAAI,KAAK,IAAI,CAAC,SAAS,EAAE;YAC3B,OAAO;SACR;QAED,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAEtB,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;aAAM;YACL,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IAED;;;;OAIG;IACH,IACI,aAAa;QACf,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IACD,IAAI,aAAa,CAAC,KAAc;QAC9B,IAAI,CAAC,KAAK,EAAE;YACV,OAAO;SACR;QAED,IAAI,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,kBAAkB,EAAE,KAAK,CAAC,EAAE;YAChE,OAAO;SACR;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAChC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACH,IACI,YAAY;QACd,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IACD,IAAI,YAAY,CAAC,IAAa;QAC5B,IAAI,CAAC,IAAI,EAAE;YACT,OAAO;SACR;QAED,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,EAAE;YACvF,OAAO;SACR;QAED,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;SACpH;QAED,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAE9B,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAEhD,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAE/D,IAAI,OAAO,EAAE;gBACX,MAAM,YAAY,GAAsB;oBACtC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC;oBACvG,IAAI,EAAE,IAAI;iBACX,CAAC;gBAEF,OAAO,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;aAClC;SACF;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAChH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEnC,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IAED;;;;OAIG;IACH,IACI,YAAY;QACd,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IACD,IAAI,YAAY,CAAC,IAAa;QAC5B,IAAI,CAAC,IAAI,EAAE;YACT,OAAO;SACR;QAED,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAE9B,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;YACnD,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;YAErG,IAAI,UAAU,EAAE;gBACd,IAAI,CAAC,kBAAkB,GAAG,UAAU,CAAC;aACtC;SACF;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,GAAG,IAAI,OAAO,CAC7B,IAAI,CAAC,YAAY,CAAC,IAAI,EACtB,IAAI,CAAC,YAAY,CAAC,KAAK,EACvB,IAAI,CAAC,YAAY,CAAC,IAAI,EACtB,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAC5B,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;SACnC;aAAM,IAAI,IAAI,CAAC,UAAU,EAAE;YAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,OAAO,CAC7B,IAAI,CAAC,UAAU,CAAC,IAAI,EACpB,IAAI,CAAC,UAAU,CAAC,KAAK,EACrB,IAAI,CAAC,UAAU,CAAC,IAAI,EACpB,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAC5B,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAC/B,CAAC;SACH;IACH,CAAC;IAmDD,IAAI,UAAU;QACZ,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,eAAe;YAC3C,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,YAAY,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE;YACzF,OAAO,IAAI,CAAC,eAAe,CAAC;SAC7B;QAED,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,OAAO,IAAI,CAAC,eAAe,CAAC;SAC7B;aAAM,IAAI,IAAI,CAAC,YAAY,EAAE;YAC5B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC;SAC1C;aAAM;YACL,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,IAAI,CAAC,eAAe,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;SACtF;QACD,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IACD,IAAI,UAAU,CAAC,IAAa;QAC1B,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE;YACpG,OAAO;SACR;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAE5B,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAErC,IAAI,CAAC,iBAAiB,GAAG,UAAU,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC7H,CAAC,CAAC,CAAC;IACL,CAAC;IAcD,YACU,QAAkB,EAClB,WAAuB;QAC/B,KAAK,CAAC,oBAAoB,CAAC,CAAC;QAFpB,aAAQ,GAAR,QAAQ,CAAU;QAClB,gBAAW,GAAX,WAAW,CAAY;QAvcjC,SAAI,GAAG,KAAK,CAAC;QAEb,cAAS,GAAG,KAAK,CAAC;QAgJlB;;;;;WAKG;QACM,sBAAiB,GAAG,mBAAmB,CAAC;QAEjD;;;;WAIG;QACM,sBAAiB,GAAG,OAAO,CAAC;QAErC;;;;;WAKG;QACM,WAAM,GAAG,OAAO,CAAC;QAiN1B;;;;WAIG;QACO,uBAAkB,GAAG,IAAI,YAAY,EAAW,CAAC;QAE3D;;;;WAIG;QACO,wBAAmB,GAAG,IAAI,YAAY,EAAW,CAAC;QAE5D;;;;WAIG;QACO,eAAU,GAAG,IAAI,YAAY,EAAW,CAAC;QAEnD;;;;WAIG;QACO,sBAAiB,GAAG,IAAI,YAAY,EAA8B,CAAC;QAE7E;;;;WAIG;QACO,0BAAqB,GAAG,IAAI,YAAY,EAA8B,CAAC;QAyCzE,yBAAoB,GAAG,KAAK,CAAC;IAOrC,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAChD,IAAI,CAAC,YAAY;iBACd,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC;iBAC5B,YAAY;iBACZ,SAAS,CAAC,KAAK,CAAC,EAAE;gBACjB,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE,KAAK,EAAE;oBAC/B,OAAO;iBACR;gBAED,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,KAAK,GAAG,KAAK,EAAE,KAAK,CAAC;oBAC1B,IAAI,CAAC,iBAAiB,GAAG,KAAK,EAAE,IAAI,CAAC;gBACvC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAED,sBAAsB,CAAC,KAAoB;QACzC,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,iBAAiB,CAAC,KAAoB;QACpC,IAAI,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;QAC7C,IAAI,IAAa,CAAC;QAClB,IAAI,QAAQ,CAAC,aAAa,KAAK,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;YACvD,KAAK,CAAC,wBAAwB,EAAE,CAAC;SAClC;QAED,QAAQ,KAAK,CAAC,GAAG,EAAE;YACjB,KAAK,YAAY;gBACf,IAAI,IAAI,CAAC,2BAA2B,EAAE,EAAE;oBACtC,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,MAAM;iBACP;gBAED,iBAAiB,EAAE,CAAC;gBAEpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC;gBAC/H,IAAI,CAAC,yBAAyB,EAAE,CAAC;gBACjC,MAAM;YACR,KAAK,WAAW;gBACd,IAAI,IAAI,CAAC,2BAA2B,EAAE,EAAE;oBACtC,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,MAAM;iBACP;gBAED,iBAAiB,EAAE,CAAC;gBACpB,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC;gBAEpH,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;oBAChF,MAAM;iBACP;gBAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,yBAAyB,EAAE,CAAC;gBACjC,MAAM;YACR,KAAK,SAAS;gBACZ,IAAI,IAAI,CAAC,2BAA2B,EAAE,EAAE;oBACtC,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,MAAM;iBACP;gBAED,iBAAiB,IAAI,CAAC,CAAC;gBACvB,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC;gBAEpH,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;oBAChF,MAAM;iBACP;gBAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,yBAAyB,EAAE,CAAC;gBACjC,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR,KAAK,WAAW;gBACd,IAAI,IAAI,CAAC,2BAA2B,EAAE,EAAE;oBACtC,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,MAAM;iBACP;gBAED,iBAAiB,IAAI,CAAC,CAAC;gBACvB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC;gBAEpI,IAAI,CAAC,yBAAyB,EAAE,CAAC;gBACjC,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,aAAa,EAAE,CAAC;gBAErB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;gBAEjC,IAAI,IAAI,CAAC,KAAK,EAAE;oBACd,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;iBACnC;gBACD,MAAM;YACR,KAAK,OAAO;gBACV,IAAI,IAAI,CAAC,2BAA2B,EAAE,EAAE;oBACtC,OAAO;iBACR;gBAED,IAAI,CAAC,4BAA4B,CAAC,KAAK,CAAC,CAAC;gBACzC,MAAM;SACT;IACH,CAAC;IAED,qBAAqB,CAAC,KAAoB;QACxC,IAAI,KAAK,CAAC,GAAG,KAAK,KAAK,EAAE;YACvB,IAAI,KAAK,CAAC,QAAQ,EAAE;gBAClB,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;iBAAM;gBACL,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACpC;YAED,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;IACH,CAAC;IAED,4BAA4B,CAAC,KAAiC;QAC5D,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,aAAa,CAAC;gBAC7D,IAAI,aAAa,EAAE;oBACjB,aAAa,CAAC,KAAK,EAAE,CAAC;iBACvB;YACH,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACpC;QAED,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,aAAa,CAAC,YAAqB;QACjC,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;IACpC,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC3D,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YAClC,OAAO;SACR;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACnB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC;QAEpC,YAAY,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAEvC,IAAI,CAAC,mBAAmB,GAAG,UAAU,CAAC,GAAG,EAAE;YACzC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;YAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,cAAc,CAAC,MAAyB;QACtC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC3D,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;IAED,mBAAmB;IAEnB,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,iBAAiB,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAM,IAAI,CAAC,WAAW,CAAC,IAAI,UAAU,CAAC;YACrF,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YAC9B,OAAO,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;SACzD;aAAM;YACL,OAAO,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC;SAC3C;IACH,CAAC;IAED,aAAa;QACX,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QACpB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,UAAU,CAAC,KAAoB;QAC7B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE;YACxB,OAAO;SACR;QAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QAE9B,IAAI,CAAC,IAAI,CAAC,8BAA8B,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACzD,OAAO;SACR;QAED,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC;QACpC,IAAI,CAAC,4BAA4B,CAAC,KAAK,CAAC,CAAC;QAEzC,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAEO,2BAA2B;QACjC,OAAO,QAAQ,CAAC,aAAa,KAAK,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,aAAa;YACxE,QAAQ,CAAC,aAAa,KAAK,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,aAAa;YACvE,IAAI,CAAC,QAAQ,CAAC,cAAc,IAAI,QAAQ,CAAC,aAAa,KAAK,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,aAAa,CAAC;IACjH,CAAC;IAEO,yBAAyB;QAC/B,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC;YACrD,IAAI,eAAe,EAAE;gBACnB,eAAe,CAAC,KAAK,EAAE,CAAC;aACzB;QACH,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAEO,YAAY;QAClB,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzC,OAAO,KAAK,CAAC,SAAS,CAAC,KAAK,IAAI,CAAC;IACnC,CAAC;IAEO,OAAO;QACb,MAAM,OAAO,GAAG,IAAI,KAAK,EAAY,CAAC;QAEtC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SAC7E;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAEO,8BAA8B,CAAC,WAAoB;QACzD,OAAO,IAAI,CAAC,OAAO,EAAE;aAClB,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;eACP,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC;eAC1E,CAAC,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;IAC3C,CAAC;IAEO,IAAI;QACV,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,EAAE,SAAS,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC;QACrG,OAAO,YAAY,CAAC;IACtB,CAAC;8GAvsBU,sBAAsB;kGAAtB,sBAAsB,wlDCpCnC,8tHA0FyB;;2FDtDZ,sBAAsB;kBANlC,SAAS;+BACE,oBAAoB,iBAGf,iBAAiB,CAAC,IAAI;wHAsBjB,KAAK;sBAAxB,SAAS;uBAAC,OAAO;gBACK,QAAQ;sBAA9B,SAAS;uBAAC,UAAU;gBACW,iBAAiB;sBAAhD,SAAS;uBAAC,mBAAmB;gBACH,YAAY;sBAAtC,SAAS;uBAAC,cAAc;gBACN,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBAOR,iBAAiB;sBAAzB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAOG,uBAAuB;sBAA/B,KAAK;gBAOG,qBAAqB;sBAA7B,KAAK;gBAOG,oBAAoB;sBAA5B,KAAK;gBAQF,cAAc;sBADjB,KAAK;gBAiBG,YAAY;sBAApB,KAAK;gBAOG,cAAc;sBAAtB,KAAK;gBAQF,QAAQ;sBADX,KAAK;gBA6BG,WAAW;sBAAnB,KAAK;gBAOG,QAAQ;sBAAhB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAOG,iBAAiB;sBAAzB,KAAK;gBAQG,MAAM;sBAAd,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBASG,YAAY;sBAApB,KAAK;gBASG,kBAAkB;sBAA1B,KAAK;gBAQF,KAAK;sBADR,KAAK;gBA6BF,IAAI;sBADP,KAAK;gBAwBF,aAAa;sBADhB,KAAK;gBA2BF,YAAY;sBADf,KAAK;gBAkDF,YAAY;sBADf,KAAK;gBA0CG,sBAAsB;sBAA9B,KAAK;gBAOG,kBAAkB;sBAA1B,KAAK;gBAOI,kBAAkB;sBAA3B,MAAM;gBAOG,mBAAmB;sBAA5B,MAAM;gBAOG,UAAU;sBAAnB,MAAM;gBAOG,iBAAiB;sBAA1B,MAAM;gBAOG,qBAAqB;sBAA9B,MAAM","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\nimport { DatePipe } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  OnInit\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { CalendarNewComponent } from './calendar-new/calendar-new.component';\nimport { DayModel } from './calendar-new/models/day.model';\nimport { SelectOptionModel } from './calendar-new/models/select-option.model';\nimport { NasComponentBase } from '../../core/base/nas-component.base';\nimport { ClassModel } from '../../core/models/class.model';\nimport { UtcDate } from '../../core/models/utc-date.model';\nimport { DateHelper } from '../../core/services/date/date-helper.service';\nimport { SelectComponent } from '../select/select.component';\nimport { CalendarDateModel } from './calendar-new/calendar-date.model';\n\n/**\n * @description\n * Norwegian Date Picker Component | New design | Beta\n */\n@Component({\n  selector: 'nas-datepicker-new',\n  templateUrl: './datepicker-new.component.html',\n  styleUrls: ['./datepicker-new.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class DatepickerNewComponent extends NasComponentBase implements OnInit {\n  timeOptions: Array<SelectOptionModel>;\n  model: string;\n  show = false;\n  selectedTimeOption: SelectOptionModel;\n  showTimes = false;\n\n  get showBackdrop(): boolean {\n    return this.show && !this.exists(this.disableBackdrop);\n  }\n  set showBackdrop(value: boolean) {\n    if (this.show === value) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.show = value;\n    });\n  }\n\n  @ViewChild('input') input: ElementRef;\n  @ViewChild('calendar') calendar: CalendarNewComponent;\n  @ViewChild('datePickerContent') datePickerContent: ElementRef;\n  @ViewChild('timeSelector') timeSelector: SelectComponent;\n  @ViewChild('time') time: SelectComponent;\n\n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' to the backdrops.\n   */\n  @Input() ariaLabelBackdrop: string;\n\n  /**\n   * @property Input\n   * @description\n   * A boolean value when set will disable showing the backdrop on popup open\n   */\n  @Input() disableBackdrop: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Label for no available flights.\n   */\n  @Input() noAvailableFlightsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for available flights.\n   */\n  @Input() availableFlightsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Disable possibility to select dates in the past.\n   */\n  @Input() disablePastSelection: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * The lowest date allowed.\n   */\n  @Input()\n  get lowerLimitDate(): UtcDate {\n    return this.lowerLimitDateValue;\n  }\n  set lowerLimitDate(date: UtcDate) {\n    this.lowerLimitDateValue = date;\n\n    if (this.dateService.isLessThan(this.selectedDate, date, false, true, true)) {\n      this.selectedDate = date;\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Sets the datepicker in availability mode where available dates can be added.\n   */\n  @Input() availability: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * An array with all the available (selectable) dates of the month.\n   */\n  @Input() availableDates: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * boolean value to disable or enable the input of the date picker.\n   */\n  @Input()\n  get disabled() {\n    return this.disabledValue;\n  }\n  set disabled(value: boolean) {\n    this.disabledValue = value;\n\n    if (this.nasFormGroup && this.nasFormControlName) {\n      setTimeout(() => {\n        const control = this.nasFormGroup.get(this.nasFormControlName);\n\n        if (!control) {\n          return;\n        }\n\n        if (value) {\n          control.disable();\n        } else {\n          control.enable();\n        }\n      });\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * A place holder string for the input for date picker.\n   */\n  @Input() placeholder: string;\n\n  /**\n   * @property Input\n   * @description\n   * this will set the required attribute on the input so suer has to date-picker the date.\n   */\n  @Input() required: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Is used to indicate the IDs of the elements that describe the date picker input.\n   */\n  @Input() ariaDescribedby: string;\n\n  /**\n   * @property Input\n   * @description\n   * Aria label for input that enables date-picker popup once clicked. For accessibility web standards.\n   */\n  @Input() ariaLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * The display format of the date when user has selected the date and it is being shown in the input box for the date picker.\n   * Please look at the angular Date pipe for valid formats and variations.\n   */\n  @Input() dateDisplayFormat = 'EEEE d, MMMM yyyy';\n\n  /**\n   * @property Input\n   * @description\n   * The time display format.\n   */\n  @Input() timeDisplayFormat = 'HH:mm';\n\n  /**\n   * @property Input\n   * @description\n   * A locale code for the locale format rules to use. When not supplied, uses the value of LOCALE_ID, which is en-US by default.\n   * This requires that registerLocaleData is called with the respective locale.\n   */\n  @Input() locale = 'en-US';\n\n  /**\n   * @property Input\n   * @description\n   * A modifier to remove the padding and margins around the element.\n   */\n  @Input() compact: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Adds the parent's form group.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It is requiered to be filled if nasFormControlName added.\n   */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the input.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It requiers that the nasFormGroup input is filled.\n   */\n  @Input() nasFormControlName: string;\n\n  /**\n   * @property Input\n   * @description\n   * An array of times to be added in the time selector.\n   */\n  @Input()\n  get times(): Array<UtcDate> {\n    return this.timesValue;\n  }\n  set times(times: Array<UtcDate>) {\n    if (!times) {\n      return;\n    }\n\n    this.timesValue = times;\n    this.timeOptions = times.map(x => {\n      x.year = new Date().getUTCFullYear();\n      const option: SelectOptionModel = {\n        title: this.datePipe.transform(this.dateService.date(x), this.timeDisplayFormat, 'UTC', this.locale),\n        value: this.dateService.date(x).toISOString()\n      };\n\n      return option;\n    });\n\n    this.dateDisplayFormat = 'mediumDate';\n  }\n\n  /**\n   * @property Input\n   * @description\n   * The calendar is open or closed.\n   */\n  @Input()\n  get open(): boolean {\n    return this.openValue;\n  }\n  set open(open: boolean) {\n    if (open === this.openValue) {\n      return;\n    }\n\n    this.openValue = open;\n\n    if (open) {\n      this.openCalendar();\n    } else {\n      this.closeCalendar();\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Set selected month.\n   */\n  @Input()\n  get selectedMonth(): UtcDate {\n    return this.selectedMonthValue;\n  }\n  set selectedMonth(month: UtcDate) {\n    if (!month) {\n      return;\n    }\n\n    if (this.dateService.isSameMonth(this.selectedMonthValue, month)) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.selectedMonthValue = month;\n      this.selectedMonthChange.emit(month);\n    });\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Gets or sets the selected Date in the date picker. Setting this date will highlight the date in the date picker\n   * and user can change it by clicking from any other enabled dates\n   * or by navigating betrween months and selecting from different available month.\n   */\n  @Input()\n  get selectedDate(): UtcDate {\n    return this.selectedDateValue;\n  }\n  set selectedDate(date: UtcDate) {\n    if (!date) {\n      return;\n    }\n\n    if (this.selectedDateValue && this.dateService.isSameDate(this.selectedDateValue, date)) {\n      return;\n    }\n\n    if (this.selectedTimeValue) {\n      date = new UtcDate(date.year, date.month, date.date, this.selectedTimeValue.hours, this.selectedTimeValue.minutes);\n    }\n\n    this.selectedDateValue = date;\n\n    if (this.nasFormGroup && this.nasFormControlName) {\n\n      const control = this.nasFormGroup.get(this.nasFormControlName);\n\n      if (control) {\n        const calendarDate: CalendarDateModel = {\n          model: this.datePipe.transform(this.dateService.date(date), this.dateDisplayFormat, 'UTC', this.locale),\n          date: date\n        };\n\n        control.patchValue(calendarDate);\n      }\n    }\n\n    setTimeout(() => {\n      this.model = this.datePipe.transform(this.dateService.date(date), this.dateDisplayFormat, 'UTC', this.locale);\n    });\n\n    this.selectedDateChange.emit(date);\n\n    if (this.show) {\n      this.closeCalendar();\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Sets the selected time in the time selector.\n   */\n  @Input()\n  get selectedTime(): UtcDate {\n    return this.selectedTimeValue;\n  }\n  set selectedTime(time: UtcDate) {\n    if (!time) {\n      return;\n    }\n\n    this.selectedTimeValue = time;\n\n    if (this.timeOptions && this.timeOptions.length > 0) {\n      const timeOption = this.timeOptions.find(x => x.value === this.dateService.date(time).toISOString());\n\n      if (timeOption) {\n        this.selectedTimeOption = timeOption;\n      }\n    }\n\n    if (this.selectedDate) {\n      this.selectedDate = new UtcDate(\n        this.selectedDate.year,\n        this.selectedDate.month,\n        this.selectedDate.date,\n        this.selectedTimeValue.hours,\n        this.selectedTimeValue.minutes);\n    } else if (this.activeDate) {\n      this.selectedDate = new UtcDate(\n        this.activeDate.year,\n        this.activeDate.month,\n        this.activeDate.date,\n        this.selectedTimeValue.hours,\n        this.selectedTimeValue.minutes\n      );\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the previous month button in the calendar.\n   */\n  @Input() ariaLabelPreviousMonth: string;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the next month button in the calendar.\n   */\n  @Input() ariaLabelNextMonth: string;\n\n  /**\n   * @property Output\n   * @description\n   * Date selected by the user by clicking in date-picker date-box.\n   */\n  @Output() selectedDateChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * Month selected by the user by clicking in drop down for month selection or month navigation buttons.\n   */\n  @Output() selectedMonthChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * The calendar is open or closed.\n   */\n  @Output() openChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * When a user has actively changed the date.\n   */\n  @Output() focusOnNextChange = new EventEmitter<KeyboardEvent | MouseEvent>();\n\n  /**\n   * @property Output\n   * @description\n   * When a user has pressed shift + tab to go to previous control.\n   */\n  @Output() focusOnPreviousChange = new EventEmitter<KeyboardEvent | MouseEvent>();\n\n  get activeDate(): UtcDate {\n    if (this.selectedDate && this.activeDateValue &&\n      this.dateService.isLessThan(this.activeDateValue, this.selectedDate, false, true, true)) {\n      return this.activeDateValue;\n    }\n\n    if (this.activeDateValue) {\n      return this.activeDateValue;\n    } else if (this.selectedDate) {\n      this.activeDateValue = this.selectedDate;\n    } else {\n      const now = new Date();\n      this.activeDateValue = new UtcDate(now.getFullYear(), now.getMonth(), now.getDate());\n    }\n    return this.activeDateValue;\n  }\n  set activeDate(date: UtcDate) {\n    if (this.lowerLimitDate && this.dateService.isLessThan(date, this.lowerLimitDate, false, true, true)) {\n      return;\n    }\n\n    this.activeDateValue = date;\n\n    clearTimeout(this.activeDateTimeout);\n\n    this.activeDateTimeout = setTimeout(() => {\n      this.model = this.datePipe.transform(this.dateService.date(this.selectedDate), this.dateDisplayFormat, 'UTC', this.locale);\n    });\n  }\n\n  private openCalendarTimeout: any;\n  private activeDateTimeout: any;\n  private selectedDateValue: UtcDate;\n  private openValue: boolean;\n  private activeDateValue: UtcDate;\n  private timesValue: Array<UtcDate>;\n  private selectedTimeValue: UtcDate;\n  private selectedMonthValue: UtcDate;\n  private disabledValue: boolean;\n  private forceNotOpenCalendar = false;\n  private lowerLimitDateValue: UtcDate;\n\n  constructor(\n    private datePipe: DatePipe,\n    private dateService: DateHelper) {\n    super('nas-datepicker-new');\n  }\n\n  ngOnInit(): void {\n    if (this.nasFormGroup && this.nasFormControlName) {\n      this.nasFormGroup\n        .get(this.nasFormControlName)\n        .valueChanges\n        .subscribe(value => {\n          if (this.model === value?.model) {\n            return;\n          }\n\n          setTimeout(() => {\n            this.model = value?.model;\n            this.selectedDateValue = value?.date;\n          });\n        });\n    }\n  }\n\n  onInputKeydownShiftTab(event: KeyboardEvent): void {\n    this.closeCalendar();\n    this.focusOnPreviousChange.emit(event);\n  }\n\n  onCalendarKeyDown(event: KeyboardEvent): void {\n    let currentActiveDate = this.activeDate.date;\n    let date: UtcDate;\n    if (document.activeElement === this.input.nativeElement) {\n      event.stopImmediatePropagation();\n    }\n\n    switch (event.key) {\n      case 'ArrowRight':\n        if (this.isActiveElementMonthButtons()) {\n          event.preventDefault();\n          break;\n        }\n\n        currentActiveDate++;\n\n        this.activeDate = this.dateService.utcDate(new Date(Date.UTC(this.activeDate.year, this.activeDate.month, currentActiveDate)));\n        this.setFocusOnActiveDateAsync();\n        break;\n      case 'ArrowLeft':\n        if (this.isActiveElementMonthButtons()) {\n          event.preventDefault();\n          break;\n        }\n\n        currentActiveDate--;\n        date = this.dateService.utcDate(new Date(Date.UTC(this.activeDate.year, this.activeDate.month, currentActiveDate)));\n\n        if (this.exists(this.disablePastSelection) && this.dateService.isInThePast(date)) {\n          break;\n        }\n\n        this.activeDate = date;\n        this.setFocusOnActiveDateAsync();\n        break;\n      case 'ArrowUp':\n        if (this.isActiveElementMonthButtons()) {\n          event.preventDefault();\n          break;\n        }\n\n        currentActiveDate -= 7;\n        date = this.dateService.utcDate(new Date(Date.UTC(this.activeDate.year, this.activeDate.month, currentActiveDate)));\n\n        if (this.exists(this.disablePastSelection) && this.dateService.isInThePast(date)) {\n          break;\n        }\n\n        this.activeDate = date;\n        this.setFocusOnActiveDateAsync();\n        event.preventDefault();\n        break;\n      case 'ArrowDown':\n        if (this.isActiveElementMonthButtons()) {\n          event.preventDefault();\n          break;\n        }\n\n        currentActiveDate += 7;\n        this.activeDateValue = this.dateService.utcDate(new Date(Date.UTC(this.activeDate.year, this.activeDate.month, currentActiveDate)));\n\n        this.setFocusOnActiveDateAsync();\n        event.preventDefault();\n        break;\n      case 'Escape':\n        this.closeCalendar();\n\n        this.forceNotOpenCalendar = true;\n\n        if (this.input) {\n          this.input.nativeElement.select();\n        }\n        break;\n      case 'Enter':\n        if (this.isActiveElementMonthButtons()) {\n          return;\n        }\n\n        this.setFocusOnTimeSelectorOrNext(event);\n        break;\n    }\n  }\n\n  onTimeSelectorKeydown(event: KeyboardEvent): void {\n    if (event.key === 'Tab') {\n      if (event.shiftKey) {\n        this.openCalendar();\n      } else {\n        this.focusOnNextChange.emit(event);\n      }\n\n      event.preventDefault();\n    }\n  }\n\n  setFocusOnTimeSelectorOrNext(event: KeyboardEvent | MouseEvent): void {\n    if (this.timeOptions) {\n      setTimeout(() => {\n        const selectElement = this.timeSelector.select.nativeElement;\n        if (selectElement) {\n          selectElement.focus();\n        }\n      });\n    } else {\n      this.focusOnNextChange.emit(event);\n    }\n\n    this.closeCalendar();\n  }\n\n  onMonthChange(currentMonth: UtcDate): void {\n    this.selectedMonth = currentMonth;\n  }\n\n  onMouseDownDatepicker(): void {\n    this.openCalendar();\n  }\n\n  openCalendar(): void {\n    if (this.show || this.disabled || this.forceNotOpenCalendar) {\n      this.forceNotOpenCalendar = false;\n      return;\n    }\n\n    setTimeout(() => {\n      this.show = true;\n    });\n\n    this.activeDate = this.selectedDate;\n\n    clearTimeout(this.openCalendarTimeout);\n\n    this.openCalendarTimeout = setTimeout(() => {\n      this.input.nativeElement.select();\n      this.openChange.emit(this.show);\n    }, 100);\n  }\n\n  onTimeSelected(option: SelectOptionModel): void {\n    this.selectedTime = this.dateService.utcDate(option.value);\n    this.focusOnNextChange.emit();\n  }\n\n  onTimeSelectorClick(): void {\n\n  }\n\n  getMainClass(): Array<ClassModel> {\n    return this.getContainerClass('', [(this.exists(<any>this.timeOptions) && 'has-time'),\n    (this.exists(this.compact) && 'compact')]);\n  }\n\n  getLabelClass(): ClassModel {\n    if (this.exists(this.disabled)) {\n      return this.getClass('date-picker-label', ['disabled']);\n    } else {\n      return this.getClass('date-picker-label');\n    }\n  }\n\n  closeCalendar(): void {\n    setTimeout(() => {\n      this.show = false;\n    });\n\n    this.openChange.emit(false);\n  }\n\n  selectDate(event: KeyboardEvent): void {\n    if (!this.isModelValid()) {\n      return;\n    }\n\n    this.activeDate = this.date();\n\n    if (!this.someValidDaysEqualsSelectedDay(this.activeDate)) {\n      return;\n    }\n\n    this.selectedDate = this.activeDate;\n    this.setFocusOnTimeSelectorOrNext(event);\n\n    this.closeCalendar();\n  }\n\n  private isActiveElementMonthButtons(): boolean {\n    return document.activeElement === this.calendar.nextMonthRef.nativeElement ||\n      document.activeElement === this.calendar.previousMonthRef.nativeElement ||\n      this.calendar.monthSelectRef && document.activeElement === this.calendar.monthSelectRef.select.nativeElement;\n  }\n\n  private setFocusOnActiveDateAsync(): void {\n    setTimeout(() => {\n      const elmementToFocus = this.calendar.activeDateCell;\n      if (elmementToFocus) {\n        elmementToFocus.focus();\n      }\n    }, 200);\n  }\n\n  private isModelValid(): boolean {\n    const timestamp = Date.parse(this.model);\n    return isNaN(timestamp) !== true;\n  }\n\n  private allDays(): Array<DayModel> {\n    const allDays = new Array<DayModel>();\n\n    if (this.calendar) {\n      this.calendar.weeks.forEach(x => x && x.days.forEach(d => allDays.push(d)));\n    }\n\n    return allDays;\n  }\n\n  private someValidDaysEqualsSelectedDay(selectedDay: UtcDate): boolean {\n    return this.allDays()\n      .some(x => x\n        && this.dateService.isSameDate(this.dateService.utcDate(x.date), selectedDay)\n        && (x.isAvailable || !x.isDisabled));\n  }\n\n  private date(): UtcDate {\n    const modelDate = new Date(this.model);\n    const modelUtcDate = new UtcDate(modelDate.getFullYear(), modelDate.getMonth(), modelDate.getDate());\n    return modelUtcDate;\n  }\n}\n","<label [nasClass]=\"getMainClass()\">\n  <div [nasClass]=\"getClass('date-picker-content')\">\n    <div [nasClass]=\"getClass('date-picker-wrapper')\">\n      <div [nasClass]=\"getClass('controls', show && 'active')\"\n        (mousedown)=\"onMouseDownDatepicker()\">\n        <div #datePickerContent\n          [nasClass]=\"getLabelClass()\">\n          <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n        </div>\n        <input #input\n          [nasClass]=\"getClass('date-picker')\"\n          [required]=\"required\"\n          [disabled]=\"disabled\"\n          [attr.placeholder]=\"placeholder\"\n          [attr.aria-label]=\"ariaLabel\"\n          [attr.aria-describedby]=\"ariaDescribedby\"\n          [attr.aria-required]=\"required\"\n          [attr.aria-haspopup]=\"true\"\n          (keydown.tab)=\"selectDate($event)\"\n          (keydown.shift.tab)=\"onInputKeydownShiftTab($event)\"\n          (keydown.enter)=\"selectDate($event)\"\n          (keydown.arrowdown)=\"onCalendarKeyDown($event)\"\n          (keydown.arrowleft)=\"onCalendarKeyDown($event)\"\n          (keydown.arrowright)=\"onCalendarKeyDown($event)\"\n          (keydown.arrowup)=\"onCalendarKeyDown($event)\"\n          (focus)=\"openCalendar()\"\n          [(ngModel)]=\"model\" />\n      </div>\n      <div [nasClass]=\"getClass('calendar-icon')\">\n        <nas-icon *ngIf=\"exists(disabled); else regularIcon\"\n          [icon]=\"'calendar--disabled'\"\n          [ngStyle]=\"{'pointer-events': 'none'}\">\n        </nas-icon>\n        <ng-template #regularIcon>\n          <nas-icon icon=\"calendar\"\n            (click)=\"openCalendar()\">\n          </nas-icon>\n        </ng-template>\n      </div>\n      <nas-calendar-new #calendar *ngIf=\"show\"\n        [nasFormGroup]=\"nasFormGroup\"\n        [nasFormControlName]=\"nasFormControlName\"\n        [dateDisplayFormat]=\"dateDisplayFormat\"\n        [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n        [availableFlightsLabel]=\"availableFlightsLabel\"\n        [availability]=\"exists(availability)\"\n        [availableDates]=\"availableDates\"\n        [lowerLimitDate]=\"lowerLimitDate\"\n        [disablePastSelection]=\"exists(disablePastSelection)\"\n        [locale]=\"locale\"\n        [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n        [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n        [(activeDate)]=\"activeDate\"\n        [(selectedDate)]=\"selectedDate\"\n        (focusOnNextChange)=\"setFocusOnTimeSelectorOrNext($event)\"\n        (keydown)=\"onCalendarKeyDown($event)\"\n        (monthChange)=\"onMonthChange($event)\">\n      </nas-calendar-new>\n    </div>\n    <nas-backdrop [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n      [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>\n  </div>\n</label>\n<div *ngIf=\"timeOptions\"\n  [nasClass]=\"getClass('time-selector-wrapper')\">\n  <nas-select #timeSelector\n    [nasClass]=\"getClass('time-picker')\"\n    [selected]=\"selectedTimeOption\"\n    (selectedChange)=\"onTimeSelected($event)\"\n    (keydown)=\"onTimeSelectorKeydown($event)\">\n    <div [nasClass]=\"getClass('arrow')\">\n      <div [nasClass]=\"getClass('icon-left')\">\n          <nas-icon [type]=\"'arrow-left'\"></nas-icon>\n      </div>\n    </div>\n    <nas-option #time *ngFor=\"let time of timeOptions\"\n      [option]=\"time\"></nas-option>\n      <div [nasClass]=\"getClass('arrow')\">\n        <div [nasClass]=\"getClass('icon-right')\">\n            <nas-icon [type]=\"'arrow-right'\"></nas-icon>\n        </div>\n    </div>\n  </nas-select>\n</div>\n<ng-template #content>\n  <ng-content></ng-content>\n</ng-template>\n\n<!-- Lag en metode som sender inn value til det klokkeslettet som er valgt -->\n<!-- div som er clickable for hver time? -->\n<!-- input-text-new?  -->"]}