@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.
- package/esm2022/lib/components/datepicker/index.mjs +1 -2
- package/esm2022/lib/components/datepicker-combo-new/datepicker-combo-new.component.mjs +371 -0
- package/esm2022/lib/components/datepicker-combo-new/datepicker-combo-new.module.mjs +31 -0
- package/esm2022/lib/components/datepicker-combo-new/index.mjs +3 -0
- package/esm2022/lib/components/datepicker-new/calendar-new/calendar-date.model.mjs +2 -0
- package/esm2022/lib/components/datepicker-new/calendar-new/calendar-new.component.mjs +594 -0
- package/esm2022/lib/components/datepicker-new/calendar-new/enums/week-start.enum.mjs +6 -0
- package/esm2022/lib/components/datepicker-new/calendar-new/models/day.model.mjs +2 -0
- package/esm2022/lib/components/datepicker-new/calendar-new/models/select-option.model.mjs +2 -0
- package/esm2022/lib/components/datepicker-new/calendar-new/models/week.model.mjs +2 -0
- package/esm2022/lib/components/datepicker-new/datepicker-new.component.mjs +571 -0
- package/esm2022/lib/components/datepicker-new/datepicker-new.module.mjs +55 -0
- package/esm2022/lib/components/datepicker-new/index.mjs +5 -0
- package/esm2022/lib/components/datepicker-new/services/calendar.service.mjs +215 -0
- package/esm2022/lib/components/index.mjs +3 -1
- package/fesm2022/norwegian-core-components.mjs +1790 -11
- package/fesm2022/norwegian-core-components.mjs.map +1 -1
- package/lib/components/datepicker/index.d.ts +0 -1
- package/lib/components/datepicker-combo-new/datepicker-combo-new.component.d.ts +294 -0
- package/lib/components/datepicker-combo-new/datepicker-combo-new.module.d.ts +10 -0
- package/lib/components/datepicker-combo-new/index.d.ts +2 -0
- package/lib/components/datepicker-new/calendar-new/calendar-date.model.d.ts +5 -0
- package/lib/components/datepicker-new/calendar-new/calendar-new.component.d.ts +159 -0
- package/lib/components/datepicker-new/calendar-new/enums/week-start.enum.d.ts +4 -0
- package/lib/components/datepicker-new/calendar-new/models/day.model.d.ts +10 -0
- package/lib/components/datepicker-new/calendar-new/models/select-option.model.d.ts +4 -0
- package/lib/components/datepicker-new/calendar-new/models/week.model.d.ts +5 -0
- package/lib/components/datepicker-new/datepicker-new.component.d.ts +272 -0
- package/lib/components/datepicker-new/datepicker-new.module.d.ts +16 -0
- package/lib/components/datepicker-new/index.d.ts +4 -0
- package/lib/components/datepicker-new/services/calendar.service.d.ts +27 -0
- package/lib/components/index.d.ts +2 -0
- 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":"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","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?  -->"]}
|