@norwegian/core-components 6.51.3 → 6.52.0

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/assets/documentation/filter-new/filter-new.md +0 -0
  2. package/esm2022/lib/components/airport-select-new/airport-select-new.component.mjs +2 -2
  3. package/esm2022/lib/components/alert/alert.component.mjs +2 -2
  4. package/esm2022/lib/components/datepicker-combo-new/datepicker-combo-new.component.mjs +1 -1
  5. package/esm2022/lib/components/filter/index.mjs +1 -2
  6. package/esm2022/lib/components/filter-new/enums/trip-type.enum.mjs +8 -0
  7. package/esm2022/lib/components/filter-new/filter-new.component.mjs +1328 -0
  8. package/esm2022/lib/components/filter-new/filter-new.module.mjs +101 -0
  9. package/esm2022/lib/components/filter-new/index.mjs +4 -0
  10. package/esm2022/lib/components/index.mjs +3 -1
  11. package/esm2022/lib/components/number-field-new/number-field-new.component.mjs +3 -3
  12. package/esm2022/lib/components/passenger-select/index.mjs +1 -3
  13. package/esm2022/lib/components/passenger-select-new/enums/passenger-type.enum.mjs +9 -0
  14. package/esm2022/lib/components/passenger-select-new/index.mjs +5 -0
  15. package/esm2022/lib/components/passenger-select-new/models/passengers.model.mjs +2 -0
  16. package/esm2022/lib/components/passenger-select-new/passenger-select-new.component.mjs +417 -0
  17. package/esm2022/lib/components/passenger-select-new/passenger-select-new.module.mjs +28 -0
  18. package/fesm2022/norwegian-core-components.mjs +8664 -6835
  19. package/fesm2022/norwegian-core-components.mjs.map +1 -1
  20. package/lib/components/datepicker-combo-new/datepicker-combo-new.component.d.ts +2 -2
  21. package/lib/components/filter/index.d.ts +0 -1
  22. package/lib/components/filter-new/enums/trip-type.enum.d.ts +6 -0
  23. package/lib/components/filter-new/filter-new.component.d.ts +829 -0
  24. package/lib/components/filter-new/filter-new.module.d.ts +27 -0
  25. package/lib/components/filter-new/index.d.ts +3 -0
  26. package/lib/components/index.d.ts +2 -0
  27. package/lib/components/passenger-select/index.d.ts +0 -2
  28. package/lib/components/passenger-select-new/enums/passenger-type.enum.d.ts +7 -0
  29. package/lib/components/passenger-select-new/index.d.ts +4 -0
  30. package/lib/components/passenger-select-new/models/passengers.model.d.ts +10 -0
  31. package/lib/components/passenger-select-new/passenger-select-new.component.d.ts +141 -0
  32. package/lib/components/passenger-select-new/passenger-select-new.module.d.ts +10 -0
  33. package/package.json +1 -1
@@ -0,0 +1,1328 @@
1
+ /**
2
+ * @license
3
+ * Copyright Norwegian Air Shuttle. All Rights Reserved.
4
+ */
5
+ import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
6
+ import { BehaviorSubject } from 'rxjs';
7
+ import { TripType } from './enums/trip-type.enum';
8
+ import { NasComponentBase } from '../../core/base/nas-component.base';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../core/services/device/device-helper.service";
11
+ import * as i2 from "../../core/services/sort/sort.service";
12
+ import * as i3 from "../../core/services/abandoned-basket/abandoned-basket.service";
13
+ import * as i4 from "../../core/services/date/date-helper.service";
14
+ import * as i5 from "@angular/common";
15
+ import * as i6 from "../../core/directives/nas-class/nas-class.directive";
16
+ import * as i7 from "../accordion/accordion.component";
17
+ import * as i8 from "../icon/icon.component";
18
+ import * as i9 from "@angular/forms";
19
+ import * as i10 from "../subsidy-discount/subsidy-discount.component";
20
+ import * as i11 from "../suggestions/suggestions.component";
21
+ import * as i12 from "../airport-select-new/airport-select-new.component";
22
+ import * as i13 from "../datepicker-combo-new/datepicker-combo-new.component";
23
+ import * as i14 from "../button-new/button-new.component";
24
+ import * as i15 from "../passenger-select-new/passenger-select-new.component";
25
+ import * as i16 from "../radio-new/radio-new.component";
26
+ /**
27
+ * @description
28
+ * Norwegian Filter Component | New design | Beta
29
+ */
30
+ export class FilterNewComponent extends NasComponentBase {
31
+ get outboundOpen() {
32
+ return this.outboundOpenValue;
33
+ }
34
+ set outboundOpen(value) {
35
+ if (this.outboundOpenValue === value) {
36
+ return;
37
+ }
38
+ if (value) {
39
+ this.closeDropdowns();
40
+ if (this.airportSelect) {
41
+ this.airportSelect.originOpen = false;
42
+ this.airportSelect.destinationOpen = false;
43
+ }
44
+ }
45
+ this.outboundOpenValue = value;
46
+ this.outboundOpenChange.emit(value);
47
+ }
48
+ get inboundOpen() {
49
+ return this.inboundOpenValue;
50
+ }
51
+ set inboundOpen(value) {
52
+ if (this.inboundOpenValue === value) {
53
+ return;
54
+ }
55
+ if (value) {
56
+ this.closeDropdowns();
57
+ if (this.airportSelect) {
58
+ this.airportSelect.originOpen = false;
59
+ this.airportSelect.destinationOpen = false;
60
+ }
61
+ }
62
+ clearTimeout(this.inboundOpenTimeout);
63
+ this.inboundOpenTimeout = setTimeout(() => {
64
+ this.inboundOpenValue = value;
65
+ });
66
+ this.inboundOpenChange.emit(value);
67
+ }
68
+ /**
69
+ * @property Input
70
+ * @description
71
+ * An array of different passenger types that will be displayed.
72
+ */
73
+ get passengers() {
74
+ return this.passengersValue;
75
+ }
76
+ set passengers(value) {
77
+ if (!value) {
78
+ return;
79
+ }
80
+ this.passengersValue = value;
81
+ this.passengersChange.emit(value);
82
+ }
83
+ /**
84
+ * @property Input
85
+ * @description
86
+ * Indicates if the edit search of accordion should be expended on mobile screen sizes.
87
+ */
88
+ get expandedAccordionMobile() {
89
+ return this.expandedAccordionMobileValue;
90
+ }
91
+ set expandedAccordionMobile(value) {
92
+ if (value === this.expandedAccordionMobileValue) {
93
+ return;
94
+ }
95
+ this.expandedAccordionMobileValue = value;
96
+ }
97
+ get closestAirports() {
98
+ return this.closestAirportsValue;
99
+ }
100
+ set closestAirports(airports) {
101
+ if (!airports || airports.length < 1) {
102
+ return;
103
+ }
104
+ this.closestAirportsValue = airports;
105
+ if (this.exists(this.overrideOrigin)) {
106
+ this.originAirportCode = airports[0].code;
107
+ }
108
+ }
109
+ /**
110
+ * @property Input
111
+ * @required
112
+ * @description
113
+ * All airports that will be populated into the dropdown lists.
114
+ * If displayLatestSearches is true, it will try to get the latest searches from the abandoned basket.
115
+ */
116
+ get airports() {
117
+ return this.airportsValue;
118
+ }
119
+ set airports(airports) {
120
+ this.airportsValue = airports;
121
+ if (this.exists(this.displayLatestSearches)) {
122
+ const abandonedBasket = this.abandonedBasketService.getAll();
123
+ this.setLatestSearches(abandonedBasket, this.airports);
124
+ }
125
+ }
126
+ /**
127
+ * @property Input
128
+ * @description
129
+ * Sets and gets the selected trip type.
130
+ */
131
+ get tripType() {
132
+ return this.tripTypeValue;
133
+ }
134
+ set tripType(tripType) {
135
+ if (tripType === this.tripTypeValue) {
136
+ return;
137
+ }
138
+ this.tripTypeValue = tripType;
139
+ this.tripTypeChange.emit(this.tripType);
140
+ }
141
+ /**
142
+ * @property Input
143
+ * @description
144
+ * Sets and gets whether the selected transit type is direct only or not.
145
+ */
146
+ get directOnly() {
147
+ return this.directOnlyValue;
148
+ }
149
+ set directOnly(directOnly) {
150
+ if (directOnly === this.directOnlyValue) {
151
+ return;
152
+ }
153
+ this.directOnlyValue = directOnly;
154
+ this.directOnlyChange.emit(this.directOnly);
155
+ }
156
+ /**
157
+ * @property Input
158
+ * @description
159
+ * Selected datefor outbound calendar.
160
+ */
161
+ get outboundSelectedDate() {
162
+ return this.outboundSelectedDateValue;
163
+ }
164
+ set outboundSelectedDate(date) {
165
+ if (!date) {
166
+ return;
167
+ }
168
+ setTimeout(() => {
169
+ this.outboundSelectedDateValue = date;
170
+ this.outboundSelectedDateChange.emit(date);
171
+ });
172
+ }
173
+ /**
174
+ * @property Input
175
+ * @description
176
+ * Selected datefor inbound calendar.
177
+ */
178
+ get inboundSelectedDate() {
179
+ return this.inboundSelectedDateValue;
180
+ }
181
+ set inboundSelectedDate(date) {
182
+ if (!date) {
183
+ return;
184
+ }
185
+ setTimeout(() => {
186
+ this.inboundSelectedDateValue = date;
187
+ this.inboundSelectedDateChange.emit(date);
188
+ });
189
+ }
190
+ get inboundSelectedMonth() {
191
+ return this.inboundSelectedMonthValue;
192
+ }
193
+ set inboundSelectedMonth(month) {
194
+ if (this.dateService.isSameMonth(month, this.inboundSelectedMonthValue)) {
195
+ return;
196
+ }
197
+ setTimeout(() => {
198
+ this.inboundMonthChange.emit(month);
199
+ this.inboundSelectedMonthValue = month;
200
+ });
201
+ }
202
+ constructor(deviceHelper, sortService, abandonedBasketService, dateService, elementRef, changeDetector) {
203
+ super('nas-filter-new');
204
+ this.deviceHelper = deviceHelper;
205
+ this.sortService = sortService;
206
+ this.abandonedBasketService = abandonedBasketService;
207
+ this.dateService = dateService;
208
+ this.elementRef = elementRef;
209
+ this.changeDetector = changeDetector;
210
+ this.displaySummary = true;
211
+ this.containerWidth = new BehaviorSubject(0);
212
+ this.maximize = false;
213
+ this.isNasGroupValid = false;
214
+ this.inlineFlex = 0;
215
+ this.openPassengerSelect = false;
216
+ this.openTransitTypeSelect = false;
217
+ /**
218
+ * @property Input
219
+ * @description
220
+ * A separator for the filter summary that is dispayed if minimizeOnMobile is true.
221
+ *
222
+ * ### Example
223
+ * 1 traveller, round trip and direct/transit
224
+ */
225
+ this.defaultSummarySeparator = '';
226
+ /**
227
+ * A separator for the filter summary is are dispayed if minimizeOnMobile is true.
228
+ *
229
+ * ### Example
230
+ * 1 traveller, round trip and direct/transit
231
+ */
232
+ this.lastSummarySeparator = '';
233
+ /**
234
+ * @property Input
235
+ * @description
236
+ * A placeholder that will appear on the origin airport input field.
237
+ */
238
+ this.placeholderOrigin = '';
239
+ /**
240
+ * @property Input
241
+ * @description
242
+ * A placeholder that will appear on the destination airport input field.
243
+ */
244
+ this.placeholderDestination = '';
245
+ /**
246
+ * @property Output
247
+ * @description
248
+ * An event that is fired every time the origin dropdown selector opens or closes.
249
+ */
250
+ this.originOpenChange = new EventEmitter();
251
+ /**
252
+ * @property Output
253
+ * @description
254
+ * An event that is fired every time the origin dropdown selector opens or closes.
255
+ */
256
+ this.destinationOpenChange = new EventEmitter();
257
+ /**
258
+ * @property Output
259
+ * @description
260
+ * An event that is fired every time the passenger select dropdown opens or closes.
261
+ */
262
+ this.passengerSelectOpenChange = new EventEmitter();
263
+ /**
264
+ * @property Output
265
+ * @description
266
+ * An event that is fired every time the selected origin airport changes.
267
+ */
268
+ this.originChange = new EventEmitter();
269
+ /**
270
+ * @property Output
271
+ * @description
272
+ * An event that is fired every time the selected destination airport changes.
273
+ */
274
+ this.destinationChange = new EventEmitter();
275
+ /**
276
+ * @property Output
277
+ * @description
278
+ * An event that is fired every time a passenger selection change is performed.
279
+ */
280
+ this.passengersChange = new EventEmitter();
281
+ /**
282
+ * @property Output
283
+ * @description
284
+ * Sets and gets the selected trip type.
285
+ */
286
+ this.tripTypeChange = new EventEmitter();
287
+ /**
288
+ * @property Output
289
+ * @description
290
+ * Sets and gets whether the selected transit type is direct only or not.
291
+ */
292
+ this.directOnlyChange = new EventEmitter();
293
+ /**
294
+ * @property Input
295
+ * @description
296
+ * 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.
297
+ * Please look at the angular Date pipe for valid formats and variations.
298
+ */
299
+ this.dateDisplayFormat = 'EEE d, MMM';
300
+ /**
301
+ * @property Input
302
+ * @description
303
+ * The time display format.
304
+ */
305
+ this.timeDisplayFormat = 'HH:mm';
306
+ /**
307
+ * @property Input
308
+ * @description
309
+ * 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.
310
+ * This requires that registerLocaleData is called with the respective locale.
311
+ */
312
+ this.locale = 'en-GB';
313
+ /**
314
+ * @property Input
315
+ * @description
316
+ * Will display the destination input, set this to false to remove it. It's true by default.
317
+ */
318
+ this.enableDestinationSelect = true;
319
+ /**
320
+ * @property Input
321
+ * @description
322
+ * Will display passenger select, set this to false to remove it. It's true by default.
323
+ */
324
+ this.enablePassengersSelect = true;
325
+ /**
326
+ * @property Input
327
+ * @description
328
+ * Will display the trip switch, set this to false to remove it. It's true by default.
329
+ */
330
+ this.enableTripSwitch = true;
331
+ /**
332
+ * @property Input
333
+ * @description
334
+ * Will display the transit switch, set this to false to remove it. It's true by default.
335
+ */
336
+ this.enableTransitSwitch = true;
337
+ /**
338
+ * @property Output
339
+ * @description
340
+ * When selected datehas been changed on the outbound calendar.
341
+ */
342
+ this.outboundSelectedDateChange = new EventEmitter();
343
+ /**
344
+ * @property Output
345
+ * @description
346
+ * When selected datehas been changed on the inbound calendar.
347
+ */
348
+ this.inboundSelectedDateChange = new EventEmitter();
349
+ /**
350
+ * @property Output
351
+ * @description
352
+ * Outbound datepicker is open or closed.
353
+ */
354
+ this.outboundOpenChange = new EventEmitter();
355
+ /**
356
+ * @property Output
357
+ * @description
358
+ * Inbound datepicker is open or closed.
359
+ */
360
+ this.inboundOpenChange = new EventEmitter();
361
+ /**
362
+ * @property Output
363
+ * @description
364
+ * Outbound calendar changes month.
365
+ */
366
+ this.outboundMonthChange = new EventEmitter();
367
+ /**
368
+ * @property Output
369
+ * @description
370
+ * Inbound calendar changes month.
371
+ */
372
+ this.inboundMonthChange = new EventEmitter();
373
+ /**
374
+ * @property Output
375
+ * @description
376
+ * When a user has actively changed the date.
377
+ */
378
+ this.focusOnNextChange = new EventEmitter();
379
+ /**
380
+ * @property Output
381
+ * @description
382
+ * The geolocation of the user. Will be emitted if 'enableSuggestions' is true.
383
+ */
384
+ this.positionChange = new EventEmitter();
385
+ /**
386
+ * @property Output
387
+ * @description
388
+ * An even that is fired every time the info button on the subsidy discount is clicked.
389
+ */
390
+ this.subsidyDiscountInfoClick = new EventEmitter();
391
+ this.outboundOpenValue = false;
392
+ this.inboundOpenValue = false;
393
+ this.passengersValue = new Array();
394
+ this.nativeElement = elementRef.nativeElement;
395
+ }
396
+ ngOnInit() {
397
+ if (!this.nasFormGroup) {
398
+ return;
399
+ }
400
+ this.nasFormGroup.statusChanges.subscribe((x) => {
401
+ setTimeout(() => {
402
+ this.isNasGroupValid = /true/i.test(x);
403
+ });
404
+ });
405
+ if (this.nasFormControlNameDirectOnly) {
406
+ const directOnlyControl = this.nasFormGroup.get(this.nasFormControlNameDirectOnly);
407
+ if (directOnlyControl) {
408
+ this.directOnly = directOnlyControl.value;
409
+ }
410
+ }
411
+ if (this.nasFormControlNameTripType) {
412
+ const tripTypeControl = this.nasFormGroup.get(this.nasFormControlNameTripType);
413
+ if (tripTypeControl) {
414
+ this.tripType = tripTypeControl.value;
415
+ this.inboundDisabled = tripTypeControl.value === TripType.oneWay;
416
+ if (this.nasFormControlNameInbound) {
417
+ const inboundControl = this.nasFormGroup.get(this.nasFormControlNameInbound);
418
+ if (inboundControl && this.inboundDisabled) {
419
+ inboundControl.disable();
420
+ }
421
+ }
422
+ tripTypeControl.valueChanges.subscribe((value) => {
423
+ this.inboundDisabled = value === TripType.oneWay;
424
+ this.tripType = value;
425
+ });
426
+ }
427
+ }
428
+ if (this.nasFormControlNameDirectOnly) {
429
+ const directOnlyControl = this.nasFormGroup.get(this.nasFormControlNameDirectOnly);
430
+ if (directOnlyControl) {
431
+ directOnlyControl.valueChanges.subscribe((value) => {
432
+ this.directOnly = value;
433
+ });
434
+ }
435
+ }
436
+ }
437
+ ngAfterViewChecked() {
438
+ this.containerWidth.next(this.container.nativeElement.offsetWidth);
439
+ window.onresize = () => {
440
+ this.containerWidth.next(this.container.nativeElement.offsetWidth);
441
+ };
442
+ this.setInlineFlexWidth();
443
+ }
444
+ onSubsidyDiscountInfoClick() {
445
+ this.subsidyDiscountInfoClick.emit();
446
+ }
447
+ onSubsidyDiscountSelectChange(model) {
448
+ if (!this.nasFormGroup || !this.nasFormControlNameSubsidyDiscount) {
449
+ return;
450
+ }
451
+ const subsidyDiscountControl = this.nasFormGroup.get(this.nasFormControlNameSubsidyDiscount);
452
+ subsidyDiscountControl.patchValue(model);
453
+ }
454
+ getClosestAirports(position) {
455
+ this.positionChange.emit(position);
456
+ }
457
+ getFilterClass(element, modifiersInput) {
458
+ let modifiers = modifiersInput || new Array();
459
+ if (typeof modifiersInput === 'string' ||
460
+ modifiersInput instanceof String) {
461
+ modifiers = [modifiersInput];
462
+ }
463
+ const widths = [];
464
+ if (this.deviceHelper.isWidthTablet(this.containerWidth.getValue())) {
465
+ widths.push('md');
466
+ }
467
+ if (this.deviceHelper.isWidthDesktop(this.containerWidth.getValue())) {
468
+ widths.push('lg');
469
+ }
470
+ modifiers = [...modifiers, ...widths];
471
+ return this.getClass(element, modifiers);
472
+ }
473
+ getAirportSelectClass() {
474
+ return this.getClass('airport-select-new', [
475
+ this.deviceHelper.isWidthDesktop(this.containerWidth.getValue()) && 'lg',
476
+ this.deviceHelper.isWidthTablet(this.containerWidth.getValue()) && 'md',
477
+ this.exists(this.enableDatepickers) && 'no-border',
478
+ ]);
479
+ }
480
+ getSuggestions() {
481
+ const suggestions = Array.from(new Set([
482
+ ...(this.latestSearchesOrigin
483
+ ? this.latestSearchesOrigin.filter((x) => x.code !== this.originAirportCode)
484
+ : []),
485
+ ...(this.closestAirports
486
+ ? this.closestAirports.filter((x) => x.code !== this.originAirportCode)
487
+ : []),
488
+ ]));
489
+ return suggestions.slice(0, 3);
490
+ }
491
+ getDatePickersClass() {
492
+ return this.getFilterClass('date-combo-new', [
493
+ this.exists(this.minimize) && 'minimized',
494
+ this.containerWidth.getValue() > 500 && 'side-by-side',
495
+ ]);
496
+ }
497
+ getTravelDetailsClass(element, modifiersInput) {
498
+ let modifiers = modifiersInput || new Array();
499
+ if (typeof modifiersInput === 'string' ||
500
+ modifiersInput instanceof String) {
501
+ modifiers = [modifiersInput];
502
+ }
503
+ const widths = [
504
+ this.deviceHelper.isWidthTablet(this.containerWidth.getValue()) && 'md',
505
+ this.deviceHelper.isWidthDesktop(this.containerWidth.getValue()) && 'lg',
506
+ ];
507
+ modifiers = [...modifiers, ...widths];
508
+ const travelDetailsBase = new NasComponentBase('travel-details');
509
+ return travelDetailsBase.getClass(element, modifiers);
510
+ }
511
+ onInboundMonthChange(month) {
512
+ this.inboundMonthChange.emit(month);
513
+ }
514
+ onOutboundMonthChange(month) {
515
+ this.outboundMonthChange.emit(month);
516
+ }
517
+ onPassengersSelectFocusOnPrevious() {
518
+ if (this.isMobileDisplay()) {
519
+ this.onTransitSwitchOpen(true);
520
+ this.focusAsync(this.transitSwitch.toggleElement);
521
+ }
522
+ else if (this.isTabletDisplay()) {
523
+ this.selectPreviousControl();
524
+ }
525
+ }
526
+ passengerKeyDown(event) {
527
+ switch (event.key) {
528
+ case 'Tab':
529
+ if (event.shiftKey) {
530
+ if (this.isMobileDisplay() || this.isTabletDisplay()) {
531
+ break;
532
+ }
533
+ this.focusOnAirportSelectBackwards();
534
+ break;
535
+ }
536
+ if (this.isMobileDisplay()) {
537
+ if (this.subsidyDiscounts && this.subsidyDiscounts.length > 0) {
538
+ this.subsidyDiscount.infoButton.button.nativeElement.focus();
539
+ }
540
+ else {
541
+ this.focusOnNextChange.emit();
542
+ }
543
+ }
544
+ break;
545
+ case 'Enter':
546
+ if (event.shiftKey || this.isMobileDisplay()) {
547
+ break;
548
+ }
549
+ if (document.activeElement ===
550
+ this.passengerSelectDropdown.toggleElement.nativeElement) {
551
+ if (this.passengerSelectDropdown.open) {
552
+ this.onTripSwitchOpen(true);
553
+ this.focusAsync(this.tripSwitch.toggleElement);
554
+ }
555
+ else {
556
+ this.onPassengerSelectOpen();
557
+ }
558
+ }
559
+ break;
560
+ case 'Escape':
561
+ this.onPassengerSelectOpen();
562
+ event.preventDefault();
563
+ this.setFocusOnNativeElement(this.passengerSelectDropdown.toggleElement);
564
+ break;
565
+ }
566
+ }
567
+ onTripSwitchKeyDown(event) {
568
+ switch (event.key) {
569
+ case 'ArrowRight':
570
+ if (document.activeElement === this.tripTypeRoundTrip.nativeElement) {
571
+ this.tripTypeOneway.nativeElement.focus();
572
+ }
573
+ break;
574
+ case 'ArrowLeft':
575
+ if (document.activeElement === this.tripTypeOneway.nativeElement) {
576
+ this.tripTypeRoundTrip.nativeElement.focus();
577
+ }
578
+ break;
579
+ case 'Tab':
580
+ case 'Enter':
581
+ if (event.shiftKey) {
582
+ event.preventDefault();
583
+ if (this.isMobileDisplay() || !this.passengerSelectDropdown) {
584
+ this.selectPreviousControl();
585
+ }
586
+ else {
587
+ this.onPassengerSelectOpen();
588
+ this.focusAsync(this.passengerSelectDropdown.toggleElement);
589
+ }
590
+ }
591
+ else {
592
+ if (event.key === 'Tab') {
593
+ this.onTransitSwitchOpen(true);
594
+ }
595
+ else {
596
+ if (this.tripSwitch.open) {
597
+ this.onTransitSwitchOpen(true);
598
+ this.focusAsync(this.transitSwitch.toggleElement);
599
+ }
600
+ else {
601
+ this.onTripSwitchOpen(true);
602
+ }
603
+ }
604
+ }
605
+ break;
606
+ case 'Escape':
607
+ this.onTripSwitchOpen(false);
608
+ this.setFocusOnNativeElement(this.tripSwitch.toggleElement);
609
+ break;
610
+ }
611
+ }
612
+ transitKeyDown(event) {
613
+ switch (event.key) {
614
+ case 'ArrowRight':
615
+ if (document.activeElement === this.transitTypeTransit.nativeElement) {
616
+ this.transitTypeDirectOnly.nativeElement.focus();
617
+ }
618
+ break;
619
+ case 'ArrowLeft':
620
+ if (document.activeElement === this.transitTypeDirectOnly.nativeElement) {
621
+ this.transitTypeTransit.nativeElement.focus();
622
+ }
623
+ break;
624
+ case 'Tab':
625
+ case 'Enter':
626
+ if (event.shiftKey) {
627
+ event.preventDefault();
628
+ this.onTripSwitchOpen(true);
629
+ this.focusAsync(this.tripSwitch.toggleElement);
630
+ }
631
+ else {
632
+ if (this.isMobileDisplay()) {
633
+ this.onPassengerSelectOpen();
634
+ this.focusAsync(this.passengerSelectDropdown.toggleElement);
635
+ }
636
+ else {
637
+ this.onTransitSwitchOpen(!this.transitSwitch.open);
638
+ if (this.subsidyDiscounts && this.subsidyDiscounts.length > 0) {
639
+ this.subsidyDiscount.infoButton.button.nativeElement.focus();
640
+ }
641
+ else {
642
+ this.focusOnNextChange.emit();
643
+ }
644
+ }
645
+ if (event.key === 'Tab') {
646
+ event.preventDefault();
647
+ }
648
+ }
649
+ break;
650
+ case 'Escape':
651
+ this.onTransitSwitchOpen(false);
652
+ event.preventDefault();
653
+ this.setFocusOnNativeElement(this.transitSwitch.toggleElement);
654
+ break;
655
+ }
656
+ }
657
+ onSubsidyDiscountInfoButtonKeydown(event) {
658
+ switch (event.key) {
659
+ case 'Tab':
660
+ if (event.shiftKey) {
661
+ if (this.isMobileDisplay()) {
662
+ this.focusAsync(this.passengerSelectDropdown.toggleElement);
663
+ }
664
+ else {
665
+ this.focusAsync(this.transitSwitch.toggleElement);
666
+ }
667
+ event.preventDefault();
668
+ }
669
+ break;
670
+ default:
671
+ break;
672
+ }
673
+ }
674
+ onPassengersSelectFocusOnNext() {
675
+ if (this.isMobileDisplay()) {
676
+ this.passengerSelectDropdown.toggle();
677
+ }
678
+ else {
679
+ this.onTripSwitchOpen(true);
680
+ this.focusAsync(this.tripSwitch.toggleElement);
681
+ }
682
+ }
683
+ focusAsync(refElement) {
684
+ clearTimeout(this.focusAsyncTimout);
685
+ this.focusAsyncTimout = setTimeout(() => this.setFocusOnNativeElement(refElement));
686
+ }
687
+ onDatepickerFocusOnPrevious(event) {
688
+ event.preventDefault();
689
+ this.focusOnAirportSelectBackwards();
690
+ }
691
+ selectPreviousControl() {
692
+ if (this.datepickerCombo) {
693
+ if (this.datepickerCombo.outboundOnly) {
694
+ this.outboundOpen = true;
695
+ }
696
+ else {
697
+ this.inboundOpen = true;
698
+ }
699
+ }
700
+ else if (this.airportSelect) {
701
+ if (this.exists(this.airportSelect.combo)) {
702
+ this.airportSelect.onDestinationOpen(true);
703
+ if (this.airportSelect.airportSelectDropdownDestination) {
704
+ this.focusAsync(this.airportSelect.airportSelectDropdownDestination.input);
705
+ }
706
+ }
707
+ else {
708
+ this.airportSelect.onOriginOpen(true);
709
+ if (this.airportSelect.airportSelectDropdownOrigin) {
710
+ this.focusAsync(this.airportSelect.airportSelectDropdownOrigin.input);
711
+ }
712
+ }
713
+ }
714
+ }
715
+ onFocusOnNextChange(event) {
716
+ if (this.isMobileDisplay() && this.tripSwitch) {
717
+ this.onTripSwitchOpen(true);
718
+ this.focusAsync(this.tripSwitch.toggleElement);
719
+ }
720
+ else if (this.isTabletDisplay()) {
721
+ if (this.passengerSelectDropdown) {
722
+ event.preventDefault();
723
+ setTimeout(() => {
724
+ this.onPassengerSelectOpen();
725
+ this.setFocusOnNativeElement(this.passengerSelectDropdown.toggleElement);
726
+ });
727
+ }
728
+ else if (this.tripSwitch) {
729
+ this.onTripSwitchOpen(true);
730
+ this.focusAsync(this.tripSwitch.toggleElement);
731
+ }
732
+ }
733
+ }
734
+ isMobileDisplay() {
735
+ return this.deviceHelper.isWidthMobile(this.containerWidth.getValue());
736
+ }
737
+ isTabletDisplay() {
738
+ return this.deviceHelper.isWidthTablet(this.containerWidth.getValue());
739
+ }
740
+ onOriginOpen(open) {
741
+ if (this.passengerSelectDropdown) {
742
+ this.passengerSelectDropdown.open = false;
743
+ }
744
+ if (this.tripSwitch) {
745
+ this.tripSwitch.open = false;
746
+ }
747
+ if (this.transitSwitch) {
748
+ this.transitSwitch.open = false;
749
+ }
750
+ if (this.datepickerCombo) {
751
+ this.datepickerCombo.inboundOpen = false;
752
+ this.datepickerCombo.outboundOpen = false;
753
+ }
754
+ if (this.airportSelect && !this.airportSelect.originOpen) {
755
+ this.updateMaximize();
756
+ }
757
+ this.originOpenChange.emit(open);
758
+ this.changeDetector.detectChanges();
759
+ }
760
+ validateAirportValues() {
761
+ if (!this.airportSelect) {
762
+ return false;
763
+ }
764
+ const originSnapshot = this.airportSelect.origin;
765
+ const destinationSnapshot = this.airportSelect.destination;
766
+ if (originSnapshot &&
767
+ destinationSnapshot &&
768
+ originSnapshot.code &&
769
+ originSnapshot.code.length &&
770
+ destinationSnapshot.code &&
771
+ destinationSnapshot.code.length) {
772
+ return true;
773
+ }
774
+ return false;
775
+ }
776
+ updateMaximize() {
777
+ setTimeout(() => {
778
+ this.maximize = this.validateAirportValues();
779
+ });
780
+ }
781
+ onDestinationOpen(open) {
782
+ if (this.passengerSelectDropdown) {
783
+ this.passengerSelectDropdown.open = false;
784
+ }
785
+ if (this.tripSwitch) {
786
+ this.tripSwitch.open = false;
787
+ }
788
+ if (this.transitSwitch) {
789
+ this.transitSwitch.open = false;
790
+ }
791
+ if (this.datepickerCombo) {
792
+ this.datepickerCombo.inboundOpen = false;
793
+ this.datepickerCombo.outboundOpen = false;
794
+ }
795
+ if (this.airportSelect && !this.airportSelect.destinationOpen) {
796
+ this.updateMaximize();
797
+ }
798
+ this.destinationOpenChange.emit(open);
799
+ }
800
+ onPassengerSelectOpen() {
801
+ this.openPassengerSelect = true;
802
+ if (this.airportSelect) {
803
+ this.airportSelect.originOpen = false;
804
+ this.airportSelect.destinationOpen = false;
805
+ }
806
+ if (this.tripSwitch) {
807
+ this.tripSwitch.open = false;
808
+ }
809
+ if (this.transitSwitch) {
810
+ this.transitSwitch.open = false;
811
+ }
812
+ if (this.datepickerCombo) {
813
+ if (this.datepickerCombo.inboundOpen) {
814
+ this.datepickerCombo.inboundOpen = false;
815
+ }
816
+ if (this.datepickerCombo.outboundOpen) {
817
+ this.datepickerCombo.outboundOpen = false;
818
+ }
819
+ }
820
+ this.passengerSelectOpenChange.emit(this.openPassengerSelect);
821
+ if (this.openPassengerSelect) {
822
+ setTimeout(() => {
823
+ if (this.passengerSelect?.numberFields.first) {
824
+ this.passengerSelect.numberFields.first.input.nativeElement.focus();
825
+ }
826
+ }, 300);
827
+ }
828
+ }
829
+ onTripSwitchOpen(open) {
830
+ clearTimeout(this.tripSwitchFocusTimeout);
831
+ if (this.passengerSelectDropdown) {
832
+ setTimeout(() => {
833
+ this.passengerSelectDropdown.open = false;
834
+ });
835
+ }
836
+ if (this.transitSwitch) {
837
+ this.transitSwitch.open = false;
838
+ }
839
+ if (this.airportSelect) {
840
+ this.airportSelect.originOpen = false;
841
+ this.airportSelect.destinationOpen = false;
842
+ }
843
+ if (this.datepickerCombo) {
844
+ this.datepickerCombo.inboundOpen = false;
845
+ this.datepickerCombo.outboundOpen = false;
846
+ }
847
+ this.tripSwitch.open = open;
848
+ if (open) {
849
+ this.tripSwitchFocusTimeout = setTimeout(() => {
850
+ this.tripTypeRoundTrip.nativeElement.focus();
851
+ }, 200);
852
+ }
853
+ }
854
+ onTransitSwitchOpen(open) {
855
+ this.openTransitTypeSelect = !this.openTransitTypeSelect;
856
+ clearTimeout(this.transitSwitchFocusTimeout);
857
+ if (this.passengerSelectDropdown) {
858
+ this.passengerSelectDropdown.open = false;
859
+ }
860
+ if (this.tripSwitch) {
861
+ this.tripSwitch.open = false;
862
+ }
863
+ if (this.airportSelect) {
864
+ this.airportSelect.originOpen = false;
865
+ this.airportSelect.destinationOpen = false;
866
+ }
867
+ if (this.datepickerCombo) {
868
+ this.datepickerCombo.inboundOpen = false;
869
+ this.datepickerCombo.outboundOpen = false;
870
+ }
871
+ if (this.transitSwitch) {
872
+ this.transitSwitch.open = open;
873
+ }
874
+ if (open) {
875
+ this.transitSwitchFocusTimeout = setTimeout(() => {
876
+ this.transitTypeTransit.nativeElement.focus();
877
+ }, 200);
878
+ }
879
+ }
880
+ onOriginChange(airport) {
881
+ this.originChange.emit(airport);
882
+ }
883
+ setSelectedOriginAirport(airport) {
884
+ if (!airport) {
885
+ return;
886
+ }
887
+ this.onOriginChange(airport);
888
+ if (this.originAirportCode === airport.code) {
889
+ return;
890
+ }
891
+ this.originAirportCode = airport.code;
892
+ this.changeDetector.detectChanges();
893
+ }
894
+ onDestinationChange(airport) {
895
+ this.destinationChange.emit(airport);
896
+ }
897
+ setFocusOnPassengerSelect(event) {
898
+ this.minimize = false;
899
+ if (this.isMobileDisplay()) {
900
+ if (this.datepickerCombo) {
901
+ event.preventDefault();
902
+ this.outboundOpen = true;
903
+ this.focusAsync(this.datepickerCombo.datepickerOutbound.input);
904
+ }
905
+ else if (this.tripSwitch) {
906
+ event.preventDefault();
907
+ this.onTripSwitchOpen(true);
908
+ this.focusAsync(this.tripSwitch.toggleElement);
909
+ }
910
+ }
911
+ else if (this.isTabletDisplay() && this.datepickerCombo) {
912
+ setTimeout(() => {
913
+ this.outboundOpen = true;
914
+ });
915
+ }
916
+ else {
917
+ if (this.passengerSelectDropdown) {
918
+ this.onPassengerSelectOpen();
919
+ const currentElementRef = this.passengerSelectDropdown.toggleElement;
920
+ setTimeout(() => this.setFocusOnNativeElement(currentElementRef));
921
+ }
922
+ else if (this.tripSwitch) {
923
+ this.onTripSwitchOpen(true);
924
+ this.tripSwitch.toggleElement.nativeElement.focus();
925
+ }
926
+ }
927
+ }
928
+ setFocusOnNativeElement(element) {
929
+ element.nativeElement.focus();
930
+ }
931
+ onTripTypeChange(tripType) {
932
+ setTimeout(() => {
933
+ if (this.tripSwitch) {
934
+ this.tripSwitch.open = false;
935
+ }
936
+ });
937
+ this.tripType = tripType;
938
+ if (this.nasFormGroup && this.nasFormControlNameTripType) {
939
+ const tripSwitchControl = this.nasFormGroup.get(this.nasFormControlNameTripType);
940
+ tripSwitchControl.patchValue(tripType);
941
+ }
942
+ }
943
+ onTransitChange(directOnly) {
944
+ setTimeout(() => {
945
+ if (this.transitSwitch) {
946
+ this.transitSwitch.open = false;
947
+ }
948
+ });
949
+ this.directOnly = directOnly;
950
+ if (this.nasFormGroup && this.nasFormControlNameDirectOnly) {
951
+ const tripTypeControl = this.nasFormGroup.get(this.nasFormControlNameDirectOnly);
952
+ tripTypeControl.patchValue(directOnly);
953
+ }
954
+ this.openTransitTypeSelect = !this.openTransitTypeSelect;
955
+ }
956
+ getTravelDetailsTripSwitchIconClass(modifiers) {
957
+ const iconMediumBase = new NasComponentBase('icon-medium');
958
+ return [
959
+ iconMediumBase.getClass('', modifiers),
960
+ this.getTravelDetailsClass('icon'),
961
+ ];
962
+ }
963
+ getTripSwitchLabel() {
964
+ return this.tripType === TripType.twoWayReturn
965
+ ? this.tripSwitchRoundTripLabel
966
+ : this.tripSwitchOneWayLabel;
967
+ }
968
+ getTransitLabel() {
969
+ return this.directOnly ? this.directOnlyLabel : this.directTransitLabel;
970
+ }
971
+ onAccordionToggleChange(expanded) {
972
+ this.displaySummary = !expanded;
973
+ }
974
+ getSummary() {
975
+ return (`${this.passengerSelectLabel}${this.defaultSummarySeparator}` +
976
+ `${this.getTripSwitchLabel().toLowerCase()}${this.lastSummarySeparator}${this.getTransitLabel().toLowerCase()}`);
977
+ }
978
+ shouldMaximize() {
979
+ if (!this.exists(this.minimize)) {
980
+ return true;
981
+ }
982
+ else if (this.airportSelect &&
983
+ this.enableDestinationSelect &&
984
+ this.airportSelect.origin &&
985
+ this.airportSelect.origin.code &&
986
+ this.airportSelect.destination &&
987
+ this.airportSelect.destination.code) {
988
+ return true;
989
+ }
990
+ else if (this.airportSelect &&
991
+ !this.enableDestinationSelect &&
992
+ this.airportSelect.origin &&
993
+ this.airportSelect.origin.code) {
994
+ return true;
995
+ }
996
+ else if (this.airportSelect &&
997
+ (this.airportSelect.originOpen || this.airportSelect.destinationOpen)) {
998
+ return this.maximize;
999
+ }
1000
+ else if (this.exists(this.minimize)) {
1001
+ if (this.maximize) {
1002
+ if (this.nasFormGroup) {
1003
+ return this.isNasGroupValid;
1004
+ }
1005
+ return true;
1006
+ }
1007
+ else {
1008
+ return false;
1009
+ }
1010
+ }
1011
+ }
1012
+ focusOnAirportSelectBackwards() {
1013
+ if (this.exists(this.airportSelect.combo)) {
1014
+ this.airportSelect.onDestinationOpen(true);
1015
+ setTimeout(() => {
1016
+ this.airportSelect.airportSelectDropdownDestination.input.nativeElement.focus();
1017
+ }, 100);
1018
+ }
1019
+ else {
1020
+ this.airportSelect.onOriginOpen(true);
1021
+ this.focusAsync(this.airportSelect.airportSelectDropdownOrigin.input);
1022
+ }
1023
+ }
1024
+ setLatestSearches(abandonedBasket, airports) {
1025
+ if (!abandonedBasket || !airports) {
1026
+ return;
1027
+ }
1028
+ const unique = new Array();
1029
+ for (const item of abandonedBasket) {
1030
+ if (!unique.some((x) => x.destinationCode === item.destinationCode)) {
1031
+ unique.push(item);
1032
+ }
1033
+ }
1034
+ const originCodes = unique.map((x) => x.originCode);
1035
+ const destinationCodes = unique.map((x) => x.destinationCode);
1036
+ const latestSearchesOrigin = airports.filter((airport) => unique.some((x) => x.originCode.toLowerCase() === airport.code.toLowerCase()));
1037
+ const latestSearchesDestination = airports.filter((airport) => unique.some((x) => x.destinationCode.toLowerCase() === airport.code.toLowerCase()));
1038
+ const code = 'code';
1039
+ this.latestSearchesOrigin = this.sortService
1040
+ .sortByObject(latestSearchesOrigin, originCodes, code)
1041
+ .slice(0, 3);
1042
+ if (this.latestSearchesOrigin &&
1043
+ this.latestSearchesOrigin.length > 0 &&
1044
+ this.exists(this.overrideOrigin)) {
1045
+ this.originAirportCode = this.latestSearchesOrigin[0].code;
1046
+ }
1047
+ this.latestSearchesDestination = this.sortService
1048
+ .sortByObject(latestSearchesDestination, destinationCodes, code)
1049
+ .slice(0, 3);
1050
+ }
1051
+ closeDropdowns() {
1052
+ if (this.passengerSelectDropdown) {
1053
+ this.passengerSelectDropdown.open = false;
1054
+ }
1055
+ if (this.tripSwitch) {
1056
+ this.tripSwitch.open = false;
1057
+ }
1058
+ if (this.transitSwitch) {
1059
+ this.transitSwitch.open = false;
1060
+ }
1061
+ }
1062
+ setInlineFlexWidth() {
1063
+ this.inlineFlex = this.container.nativeElement.offsetWidth > 290 ? this.container.nativeElement.offsetWidth : 0;
1064
+ }
1065
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: FilterNewComponent, deps: [{ token: i1.DeviceHelper }, { token: i2.SortService }, { token: i3.AbandonedBasketService }, { token: i4.DateHelper }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
1066
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.5", type: FilterNewComponent, selector: "nas-filter-new", inputs: { airportRelations: "airportRelations", ariaLabelClear: "ariaLabelClear", ariaLabelSubtract: "ariaLabelSubtract", ariaLabelBackdrop: "ariaLabelBackdrop", ariaLabelAdd: "ariaLabelAdd", allowedOriginAirports: "allowedOriginAirports", allowedDestinationAirports: "allowedDestinationAirports", displayLatestSearches: "displayLatestSearches", useSwitch: "useSwitch", displayClosestAirports: "displayClosestAirports", originAirportCode: "originAirportCode", destinationAirportCode: "destinationAirportCode", passengerSelectLabel: "passengerSelectLabel", maxPaxCount: "maxPaxCount", passengers: "passengers", minAdultCount: "minAdultCount", tripSwitchRoundTripLabel: "tripSwitchRoundTripLabel", tripSwitchOneWayLabel: "tripSwitchOneWayLabel", directOnlyLabel: "directOnlyLabel", directTransitLabel: "directTransitLabel", minimizeOnMobile: "minimizeOnMobile", expandedAccordionMobile: "expandedAccordionMobile", defaultSummarySeparator: "defaultSummarySeparator", lastSummarySeparator: "lastSummarySeparator", passengerSelectTitle: "passengerSelectTitle", passengerSelectAdultsLabel: "passengerSelectAdultsLabel", passengerSelectYouthsLabel: "passengerSelectYouthsLabel", passengerSelectYoungAdultsLabel: "passengerSelectYoungAdultsLabel", passengerSelectChildrenLabel: "passengerSelectChildrenLabel", passengerSelectInfantsLabel: "passengerSelectInfantsLabel", groupBookingLabel: "groupBookingLabel", allAirportsLabel: "allAirportsLabel", latestSearchesLabel: "latestSearchesLabel", closestAirportsLabel: "closestAirportsLabel", selectOriginFirstLabel: "selectOriginFirstLabel", labelOrigin: "labelOrigin", placeholderOrigin: "placeholderOrigin", labelDestination: "labelDestination", geolocationLabel: "geolocationLabel", geolocationBlockedLabel: "geolocationBlockedLabel", placeholderDestination: "placeholderDestination", keepSelection: "keepSelection", editSearchTitle: "editSearchTitle", nasFormGroup: "nasFormGroup", nasFormControlNameOrigin: "nasFormControlNameOrigin", nasFormControlNameDestination: "nasFormControlNameDestination", nasFormControlNameTripType: "nasFormControlNameTripType", nasFormControlNameDirectOnly: "nasFormControlNameDirectOnly", nasFormControlNameOutbound: "nasFormControlNameOutbound", nasFormControlNameInbound: "nasFormControlNameInbound", nasFormControlGroupBooking: "nasFormControlGroupBooking", nasFormControlNameSubsidyDiscount: "nasFormControlNameSubsidyDiscount", overrideOrigin: "overrideOrigin", enableSuggestions: "enableSuggestions", closestAirports: "closestAirports", minimize: "minimize", airports: "airports", tripType: "tripType", directOnly: "directOnly", groupBookingLimit: "groupBookingLimit", subsidyDiscounts: "subsidyDiscounts", selectedSubsidyDiscount: "selectedSubsidyDiscount", subsidyDiscountLabel: "subsidyDiscountLabel", ariaLabelPreviousMonth: "ariaLabelPreviousMonth", ariaLabelNextMonth: "ariaLabelNextMonth", noAvailableFlightsLabel: "noAvailableFlightsLabel", availableFlightsLabel: "availableFlightsLabel", disablePastSelection: "disablePastSelection", outboundLabel: "outboundLabel", inboundLabel: "inboundLabel", availability: "availability", outboundAvailableDates: "outboundAvailableDates", inboundAvailableDates: "inboundAvailableDates", times: "times", dateDisplayFormat: "dateDisplayFormat", timeDisplayFormat: "timeDisplayFormat", locale: "locale", compact: "compact", outboundDisabled: "outboundDisabled", inboundDisabled: "inboundDisabled", enableDatepickers: "enableDatepickers", minimizingLabel: "minimizingLabel", maximizingLabel: "maximizingLabel", directOnlyMobileLabel: "directOnlyMobileLabel", orLabel: "orLabel", passengersTitleLabel: "passengersTitleLabel", invalidDestinationText: "invalidDestinationText", outboundSelectedDate: "outboundSelectedDate", inboundSelectedDate: "inboundSelectedDate", enableDestinationSelect: "enableDestinationSelect", enablePassengersSelect: "enablePassengersSelect", enableTripSwitch: "enableTripSwitch", enableTransitSwitch: "enableTransitSwitch" }, outputs: { originOpenChange: "originOpenChange", destinationOpenChange: "destinationOpenChange", passengerSelectOpenChange: "passengerSelectOpenChange", originChange: "originChange", destinationChange: "destinationChange", passengersChange: "passengersChange", tripTypeChange: "tripTypeChange", directOnlyChange: "directOnlyChange", outboundSelectedDateChange: "outboundSelectedDateChange", inboundSelectedDateChange: "inboundSelectedDateChange", outboundOpenChange: "outboundOpenChange", inboundOpenChange: "inboundOpenChange", outboundMonthChange: "outboundMonthChange", inboundMonthChange: "inboundMonthChange", focusOnNextChange: "focusOnNextChange", positionChange: "positionChange", subsidyDiscountInfoClick: "subsidyDiscountInfoClick" }, viewQueries: [{ propertyName: "passengerSelectDropdown", first: true, predicate: ["passengerSelectDropdown"], descendants: true }, { propertyName: "passengerSelect", first: true, predicate: ["passengerSelect"], descendants: true }, { propertyName: "tripSwitch", first: true, predicate: ["tripSwitch"], descendants: true }, { propertyName: "transitSwitch", first: true, predicate: ["transitSwitch"], descendants: true }, { propertyName: "airportSelect", first: true, predicate: ["airportSelect"], descendants: true }, { propertyName: "datepickerCombo", first: true, predicate: ["datepickerCombo"], descendants: true }, { propertyName: "container", first: true, predicate: ["container"], descendants: true }, { propertyName: "tripTypeOneway", first: true, predicate: ["tripTypeOneway"], descendants: true }, { propertyName: "tripTypeRoundTrip", first: true, predicate: ["tripTypeRoundTrip"], descendants: true }, { propertyName: "transitTypeDirectOnly", first: true, predicate: ["transitTypeDirectOnly"], descendants: true }, { propertyName: "transitTypeTransit", first: true, predicate: ["transitTypeTransit"], descendants: true }, { propertyName: "subsidyDiscount", first: true, predicate: ["subsidyDiscount"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<nas-accordion *ngIf=\"deviceHelper?.isMobile() && exists(minimizeOnMobile); else filterTemplate\"\n simple\n containerOnToggle\n transparent\n [expanded]=\"expandedAccordionMobile\"\n [title]=\"editSearchTitle\"\n (toggleChange)=\"onAccordionToggleChange($event)\">\n <ng-container *ngTemplateOutlet=\"filterTemplate\"></ng-container>\n</nas-accordion>\n<div class=\"container\"\n *ngIf=\"deviceHelper?.isMobile() && exists(minimizeOnMobile) && displaySummary\">{{getSummary()}}</div>\n\n<ng-template #filterTemplate>\n <div #container\n [nasClass]=\"getContainerClass()\">\n <div [nasClass]=\"getFilterClass('filters', [exists(minimize) && 'minimized', maximize && 'maximize'])\">\n <ng-container *ngIf=\"airports?.length > 0\">\n <nas-airport-select-new *ngIf=\"airports && airportRelations && (enableDestinationSelect)\"\n #airportSelect\n combo\n [ariaLabelClear]=\"ariaLabelClear\" \n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlNameOrigin]=\"nasFormControlNameOrigin\"\n [nasFormControlNameDestination]=\"nasFormControlNameDestination\"\n [useSwitch]=\"useSwitch\"\n [nasClass]=\"getAirportSelectClass()\"\n [airports]=\"airports\"\n [allowedOriginAiports]=\"allowedOriginAirports\"\n [allowedDestinationAirports]=\"allowedDestinationAirports\"\n [airportRelations]=\"airportRelations\"\n [latestSearchesOrigin]=\"latestSearchesOrigin\"\n [latestSearchesDestination]=\"latestSearchesDestination\"\n [displayLatestSearches]=\"displayLatestSearches\"\n [displayClosestAirports]=\"displayClosestAirports\"\n [originAirportCode]=\"originAirportCode\"\n [destinationAirportCode]=\"destinationAirportCode\"\n [allAirportsLabel]=\"allAirportsLabel\"\n [latestSearchesLabel]=\"latestSearchesLabel\"\n [closestAirportsLabel]=\"closestAirportsLabel\"\n [closestAirports]=\"closestAirports\"\n [selectOriginFirstLabel]=\"selectOriginFirstLabel\"\n [labelOrigin]=\"labelOrigin\"\n [placeholderOrigin]=\"placeholderOrigin\"\n [labelDestination]=\"labelDestination\"\n [geolocationLabel]=\"geolocationLabel\"\n [geolocationBlockedLabel]=\"geolocationBlockedLabel\"\n [placeholderDestination]=\"placeholderDestination\"\n [keepSelection]=\"keepSelection\"\n [invalidDestinationText]=\"invalidDestinationText\"\n (originChange)=\"setSelectedOriginAirport($event)\"\n (destinationChange)=\"onDestinationChange($event)\"\n (focusOnNext)=\"setFocusOnPassengerSelect($event)\"\n (originOpenChange)=\"onOriginOpen($event)\"\n (destinationOpenChange)=\"onDestinationOpen($event)\"\n (positionChange)=\"getClosestAirports($event)\"></nas-airport-select-new>\n <nas-airport-select-new *ngIf=\"airports && (!enableDestinationSelect)\"\n #airportSelect\n [ariaLabelClear]=\"ariaLabelClear\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlNameOrigin]=\"nasFormControlNameOrigin\"\n [useSwitch]=\"useSwitch\"\n [nasClass]=\"getClass('airport-origin-select')\"\n [airports]=\"airports\"\n [allowedOriginAiports]=\"allowedOriginAirports\"\n [airportRelations]=\"airportRelations\"\n [latestSearchesOrigin]=\"latestSearchesOrigin\"\n [displayLatestSearches]=\"displayLatestSearches\"\n [displayClosestAirports]=\"displayClosestAirports\"\n [originAirportCode]=\"originAirportCode\"\n [allAirportsLabel]=\"allAirportsLabel\"\n [latestSearchesLabel]=\"latestSearchesLabel\"\n [closestAirportsLabel]=\"closestAirportsLabel\"\n [closestAirports]=\"closestAirports\"\n [selectOriginFirstLabel]=\"selectOriginFirstLabel\"\n [labelOrigin]=\"labelOrigin\"\n [placeholderOrigin]=\"placeholderOrigin\"\n [geolocationLabel]=\"geolocationLabel\"\n [geolocationBlockedLabel]=\"geolocationBlockedLabel\"\n [keepSelection]=\"keepSelection\"\n (originChange)=\"setSelectedOriginAirport($event)\"\n (focusOnNext)=\"setFocusOnPassengerSelect($event)\"\n (originOpenChange)=\"onOriginOpen($event)\"\n (positionChange)=\"getClosestAirports($event)\"></nas-airport-select-new>\n <nas-suggestions *ngIf=\"(closestAirports || latestSearchesOrigin) && exists(enableSuggestions)\"\n [nasClass]=\"getFilterClass('suggestions')\"\n [suggestions]=\"getSuggestions()\"\n [orLabel]=\"orLabel\"\n (airportSelect)=\"setSelectedOriginAirport($event)\"></nas-suggestions>\n </ng-container>\n <ng-container *ngIf=\"shouldMaximize()\">\n <div [nasClass]=\"!enableDestinationSelect ? getClass('origin-combined') :\n getTravelDetailsClass('', ['combined', exists(enableDatepickers) && 'no-border', exists(minimize) && 'minimized'])\">\n <ng-container *ngIf=\"enablePassengersSelect\">\n <button (click)=\"onPassengerSelectOpen($event)\" [nasClass]=\"getClass('passengers-button', openPassengerSelect && 'active')\">\n <div [nasClass]=\"getClass('label')\">\n <p [nasClass]=\"getClass('button-title')\">{{passengersTitleLabel}}</p>\n <p>{{passengerSelectLabel}}</p>\n </div>\n <div [nasClass]=\"getClass('traveler-icon')\"><nas-icon [icon]=\"'my-profile-compact'\" [type]=\"'small'\"></nas-icon></div>\n </button>\n <!-- <nas-dropdown #passengerSelectDropdown\n *ngIf=\"passengers?.length > 0\"\n [nasClass]=\"getTravelDetailsClass('dropdown', 'passengers')\"\n [cssClass]=\"getTravelDetailsClass('dropdown')\"\n [label]=\"passengerSelectLabel\"\n [labelStyle]=\"{'width': '102px'}\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n (openChange)=\"onPassengerSelectOpen($event)\"\n (keydown)=\"passengerKeyDown($event)\"> -->\n <div *ngIf=\"openPassengerSelect\">\n <nas-passenger-select-new\n [ariaLabelAdd]=\"ariaLabelAdd\"\n [ariaLabelSubtract]=\"ariaLabelSubtract\"\n [adultsLabel]=\"passengerSelectAdultsLabel\"\n [youthsLabel]=\"passengerSelectYouthsLabel\"\n [youngAdultsLabel]=\"passengerSelectYoungAdultsLabel\"\n [childrenLabel]=\"passengerSelectChildrenLabel\"\n [infantsLabel]=\"passengerSelectInfantsLabel\"\n [maxPaxCount]=\"maxPaxCount\"\n [minAdultCount]=\"minAdultCount\"\n [title]=\"passengerSelectTitle\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlGroupBooking]=\"nasFormControlGroupBooking\"\n [groupBookingLabel]=\"groupBookingLabel\"\n [groupBookingLimit]=\"groupBookingLimit\"\n (focusOnNext)=\"onPassengersSelectFocusOnNext()\"\n (focusOnPrevious)=\"onPassengersSelectFocusOnPrevious()\"\n [(passengers)]=\"passengers\"></nas-passenger-select-new>\n <nas-button-new *ngIf=\"this.openPassengerSelect\" light block \n [disabled]=\"passengers[0].count === 0 && passengers[1].count === 0 && passengers[2].count === 0\" (click)=\"openPassengerSelect = false\">\n Done\n </nas-button-new>\n </div>\n </ng-container>\n <ng-container *ngIf=\"enableTripSwitch\">\n <form [nasClass]=\"getClass('radio')\">\n <nas-radio-new #tripTypeRoundTrip [name]=\"'tripType'\" [value]=\"2\" [checked]=\"true\" (checkedChange)=\"onTripTypeChange(2)\">\n {{tripSwitchRoundTripLabel}}\n </nas-radio-new>\n <nas-radio-new #tripTypeOneway [name]=\"'tripType'\" [value]=\"1\" (checkedChange)=\"onTripTypeChange(1)\">\n {{tripSwitchOneWayLabel}}\n </nas-radio-new>\n </form>\n </ng-container>\n <div *ngIf=\"exists(enableDatepickers)\"\n [nasClass]=\"getDatePickersClass()\">\n <nas-datepicker-combo-new #datepickerCombo\n compact\n [inlineFlex]=\"inlineFlex\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlNameOutbound]=\"nasFormControlNameOutbound\"\n [nasFormControlNameInbound]=\"nasFormControlNameInbound\"\n [availability]=\"availability\"\n [availableFlightsLabel]=\"availableFlightsLabel\"\n [dateDisplayFormat]=\"dateDisplayFormat\"\n [disablePastSelection]=\"disablePastSelection\"\n [locale]=\"locale\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [inboundAvailableDates]=\"inboundAvailableDates\"\n [inboundLabel]=\"inboundLabel\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [outboundAvailableDates]=\"outboundAvailableDates\"\n [outboundLabel]=\"outboundLabel\"\n [timeDisplayFormat]=\"timeDisplayFormat\"\n [times]=\"times\"\n [outboundDisabled]=\"outboundDisabled\"\n [inboundDisabled]=\"inboundDisabled\"\n [outboundOnly]=\"tripType === 1\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n (focusOnNextChange)=\"onFocusOnNextChange($event)\"\n (focusOnPreviousChange)=\"onDatepickerFocusOnPrevious($event)\"\n (inboundMonthChange)=\"onInboundMonthChange($event)\"\n (outboundMonthChange)=\"onOutboundMonthChange($event)\"\n [(outboundOpen)]=\"outboundOpen\"\n [(inboundOpen)]=\"inboundOpen\"\n [(inboundSelectedDate)]=\"inboundSelectedDate\"\n [(outboundSelectedDate)]=\"outboundSelectedDate\">\n </nas-datepicker-combo-new>\n </div>\n <ng-container *ngIf=\"enableTransitSwitch\">\n <nas-button-new *ngIf=\"directOnlyLabel && directTransitLabel\"\n #transitSwitch\n block\n light\n [iconType]=\"'chevron-down'\"\n [label]=\"getTransitLabel()\"\n [nasClass]=\"getClass('transit', openTransitTypeSelect && 'active')\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n (click)=\"onTransitSwitchOpen($event)\"\n (keydown)=\"transitKeyDown($event)\">{{ getTransitLabel() }}\n </nas-button-new>\n <div *ngIf=\"openTransitTypeSelect\" [nasClass]=\"getClass('transit-type')\">\n <button [nasClass]=\"getTravelDetailsClass('action', directOnly && 'active')\"\n type=\"button\"\n #transitTypeDirectOnly\n (click)=\"onTransitChange(true)\">{{ directOnlyLabel }}\n </button>\n <button type=\"button\"\n #transitTypeTransit\n [nasClass]=\"getTravelDetailsClass('action', !directOnly && 'active')\"\n (click)=\"onTransitChange(false)\">{{ directTransitLabel }}\n </button>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"subsidyDiscounts && subsidyDiscounts.length > 0\"\n [nasClass]=\"getFilterClass('subsidy-discount')\">\n <nas-subsidy-discount #subsidyDiscount\n [discounts]=\"subsidyDiscounts\"\n [selectedDiscount]=\"selectedSubsidyDiscount\"\n [label]=\"subsidyDiscountLabel\"\n (infoButtonClick)=\"onSubsidyDiscountInfoClick()\"\n (discountSelectChange)=\"onSubsidyDiscountSelectChange($event)\"\n (infoButtonKeydown)=\"onSubsidyDiscountInfoButtonKeydown($event)\"></nas-subsidy-discount>\n </div>\n </ng-container>\n </div>\n </div>\n</ng-template>", 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)}}.nas-filter-new{position:relative;z-index:6}.nas-filter-new ::ng-deep .nas-filter-new__transit .nas-button-new__content{gap:0;justify-content:space-between;font-weight:400}.nas-filter-new ::ng-deep .nas-filter-new__transit--active .nas-button-new__icon{transform:rotate(180deg)}.nas-filter-new ::ng-deep .nas-filter-new__transit--active .nas-button-new{background-color:#ebf4ff}.nas-filter-new__title{margin-top:24px;font-size:28px;line-height:34px}@media screen and (min-width: 640px){.nas-filter-new__title{font-size:32px;line-height:38px}}.nas-filter-new__title--md{margin-top:60px}.nas-filter-new__radio{display:flex;gap:24px;padding:12px}.nas-filter-new__passengers-button{display:flex;justify-content:space-between;background-color:#fff;border:2px solid #6f6f6f;padding:9px 14px;width:100%}.nas-filter-new__passengers-button--active{background-color:#ebf4ff!important}.nas-filter-new__label{flex-direction:column;text-align:left}.nas-filter-new__label p{margin:0}.nas-filter-new__button-title{font-weight:700;font-size:14px}.nas-filter-new__traveler-icon{transform:scale(.85);margin-top:12px}.nas-filter-new__transit-type{border:2px solid #15273f}.nas-filter-new__transit-type button:first-child{border-bottom:2px solid #E9E7E4}.nas-filter-new__filters{margin-top:12px}.nas-filter-new__filters .nas-filter-new__date-combo{order:2;flex:1;z-index:2}.nas-filter-new__filters--minimized .nas-filter-new__airport-select:after{content:\"\";position:absolute;bottom:-3px;left:0px;width:100%;border-bottom:3px solid #c3c3c3}.nas-filter-new__filters--maximize .nas-filter-new__airport-select-new:after{display:none}.nas-filter-new__filters--md .nas-filter-new__date-combo{flex:0 0 100%}.nas-filter-new__filters--lg{align-items:stretch}.nas-filter-new__filters--lg .nas-filter-new__date-combo{order:3;flex:0 0 100%;z-index:1}.nas-filter-new__filters--lg .nas-filter-new__suggestions{order:3}.nas-filter-new__filters--lg .nas-filter-new__filters--minimized .nas-filter-new__airport-select{margin-right:0;flex:0 1 100%}.nas-filter-new__filters--lg .nas-filter-new__filters--maximize .nas-filter-new__airport-select{margin-right:3px;flex:auto}.nas-filter-new__filters--lg.nas-filter-new__filters--maximize .nas-filter-new__date-combo{border-bottom:3px solid #c3c3c3}.nas-filter-new__suggestions{flex-basis:100%;position:relative;margin-top:3px}.nas-filter-new__airport-select{order:0;flex:0 0 100%;position:relative}.nas-filter-new__airport-select--lg{width:0;margin:0 3px 0 0;flex:1 1 auto}.nas-filter-new__toggler{font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:400;font-size:18px;line-height:26px;color:#15273f;margin-top:6px;z-index:1}.nas-filter-new__toggler .nas-filter-new__toggle-action{cursor:pointer;margin-top:2px;float:right}.nas-filter-new__toggler .nas-filter-new__direct-only{display:inline-block}.travel-details{position:relative;margin:0;z-index:1}.travel-details__list{margin-top:12px}.travel-details__list-item{display:flex;align-items:center;justify-content:space-between;padding:6px 0 0}.travel-details__list-item:not(:last-child){padding:6px 0 9px;border-bottom:2px solid #f1f1f1}.travel-details__label{flex-grow:2;margin:0 6px 0 0}.travel-details__title{font-size:18px;line-height:26px;display:block;min-width:124px}.travel-details__title--small{font-size:16px;line-height:26px;margin:0}.travel-details__action{padding:12px;width:100%;background-color:#fff;font-weight:700}.travel-details__action:hover,.travel-details__action:focus{background-color:#f8f8f8}.travel-details__action--border{border-bottom:2px solid #f1f1f1}.travel-details__action:focus{outline:none;z-index:1}.travel-details__icon{margin-bottom:9px}.travel-details__dropdown{margin-right:0}.travel-details__dropdown:after{content:\"\";position:absolute;bottom:-3px;left:0px;width:100%;border-bottom:3px solid #c3c3c3}.travel-details__dropdown--trip-type{order:1;flex:1;margin-right:3px;margin-bottom:3px}.travel-details__dropdown--transit-type{order:2;flex:1;margin-bottom:3px}.travel-details__dropdown--passengers{order:3;flex:1 0 100%;margin-bottom:3px}.travel-details__dropdown--md.travel-details__dropdown--trip-type{order:2;flex:1;margin-right:3px}.travel-details__dropdown--md.travel-details__dropdown--transit-type{order:3;flex:1}.travel-details__dropdown--md.travel-details__dropdown--passengers{order:1;flex:1;margin-right:3px}.travel-details__dropdown--lg.travel-details__dropdown--trip-type{order:2;flex:1 1 auto;margin-right:3px}.travel-details__dropdown--lg.travel-details__dropdown--transit-type{order:3;flex:1 1 auto}.travel-details__dropdown--lg.travel-details__dropdown--passengers{order:1;flex:1 1 auto;margin-right:3px}.travel-details__dropdown--lg:focus{outline:none}.travel-details__dropdown--lg:after{display:none}.travel-details__transit-icon{position:relative;display:flex;justify-content:center;width:calc(100% - 48px);margin:12px auto;height:24px;background-color:inherit}.travel-details__transit-icon:before{content:\"\";position:absolute;height:2px;left:0;width:100%;top:calc(50% - 1px);background-color:currentColor}.travel-details__transit-icon:after{content:\"\";position:absolute;width:10px;height:10px;right:0;top:calc(50% - 5px);border-top:2px solid currentColor;border-right:2px solid currentColor;transform:rotate(45deg)}.travel-details__transit-icon-stop{position:relative;top:calc(50% - 5px);width:10px;height:10px;border:2px solid currentColor;border-radius:50%;background-color:inherit}.travel-details--combined{order:3;flex:0 0 100%}.travel-details--combined.travel-details--md:after{content:\"\";position:absolute;bottom:-6px;left:0px;width:100%;border-bottom:3px solid #c3c3c3}.travel-details--combined.travel-details--md .travel-details__dropdown{margin:0 3px 0 0}.travel-details--combined.travel-details--md .travel-details__dropdown:last-child{margin:0}.travel-details--combined.travel-details--md .dropdown__toggle{height:calc(100% - 3px);margin:0;padding-left:16px;padding-right:16px}.travel-details--combined.travel-details--lg{order:2;flex:0 0 auto;margin:0 0 0 -3px;padding-left:3px;z-index:2}.travel-details--combined.travel-details--lg:after{content:\"\";position:absolute;bottom:-3px;left:0px;width:100%;border-bottom:3px solid #c3c3c3}.travel-details--combined.travel-details--lg .dropdown__toggle{height:inherit}@media (min-width: 1000px){.travel-details--no-border:after{border-bottom:none}}::ng-deep .nas-passenger-select-new__list-item{padding:6px 16px!important}::ng-deep .nas-radio-new{margin:0!important}::ng-deep .nas-button-new{margin-top:6px}::ng-deep .nas-checkbox-new{background-color:#f1f1f1;padding:12px;width:100%;padding-left:42px!important;margin-bottom:12px!important}::ng-deep .nas-checkbox-new__indicator{left:12px!important}::ng-deep .nas-filter-new__filters .travel-details--no-border:after{display:none}::ng-deep .nas-filter-new__filters .nas-filter-new__date-combo .nas-datepicker__date-picker-wrapper{border-bottom:none!important}::ng-deep .nas-filter-new__filters .nas-filter-new__date-combo--side-by-side .nas-datepicker-combo-new__separator{display:block;border-bottom:none!important}::ng-deep .nas-filter-new__filters .nas-airport-select-new__input-line{border-top:none!important}::ng-deep .nas-filter-new__filters .nas-airport-select-new-combo__separator{border-bottom:none!important}::ng-deep .nas-filter-new__filters .nas-dropdown__toggle{height:64px!important}::ng-deep .nas-filter-new__filters .nas-datepicker-combo-new__separator{display:none}::ng-deep .nas-filter-new__filters--lg .nas-dropdown__toggle{display:flex}::ng-deep .nas-filter-new__filters--lg .nas-filter-new__date-combo .nas-datepicker__date-picker-wrapper{border-bottom:3px solid #c3c3c3}::ng-deep .nas-filter-new__filters--lg .nas-airport-select-new__input-line{border-top:3px solid #c3c3c3!important}::ng-deep .nas-filter-new__filters--lg .nas-datepicker-combo-new__separator{border-bottom:3px solid #c3c3c3!important}::ng-deep .nas-filter-new__filters--lg .nas-airport-select-new-combo__separator{border-bottom:3px solid #c3c3c3!important}::ng-deep .nas-filter-new__rotate{transform:rotate(180deg)}::ng-deep .nas-filter-new__rotate-enter,::ng-deep .nas-filter-new__rotate-leave-active{transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden}::ng-deep .nas-filter-new__rotate-enter{animation:flip-in .55s ease both}::ng-deep .nas-filter-new__rotate-leave-active{animation:flip-out .2s ease-out both}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new__input-line{border-top:none}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new-combo__separator{border-top:none}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new__results-wrapper{margin-top:0}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new__results{top:-3px}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new__icon{bottom:18px}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new:after{display:none}::ng-deep .nas-filter-new__airport-select .nas-airport-select-new__input-line{display:none}::ng-deep .nas-filter-new__airport-origin-select{width:100%;max-width:100%}::ng-deep .nas-filter-new__airport-origin-select .nas-airport-select-new:only-child{max-width:100%}@media (min-width: 640px){::ng-deep .nas-filter-new__airport-origin-select{max-width:360px;flex:auto;margin-right:3px}::ng-deep .nas-filter-new__airport-origin-select .nas-airport-select-new:only-child{width:auto;max-width:360px}}::ng-deep .nas-filter-new__origin-combined{border-bottom:3px solid #c3c3c3;order:3;flex:0 0 100%;display:flex;flex-wrap:wrap}@media (min-width: 1000px){::ng-deep .nas-filter-new__origin-combined{display:flex;flex:none}::ng-deep .nas-filter-new__origin-combined .nas-dropdown__toggle nas-icon{float:none!important}}::ng-deep .nas-filter-new__subsidy-discount{order:3}::ng-deep .nas-filter-new__subsidy-discount .nas-subsidy-discount{margin-top:16px}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }, { kind: "component", type: i7.AccordionComponent, selector: "nas-accordion", inputs: ["expanded", "title", "badge", "icon", "simple", "spaced", "small", "inverted", "containerOnToggle", "nopadding", "transparent", "approve", "primary", "warning", "badgeInfo", "badgeSuccess", "badgeWarning", "badgeError", "cssClass", "cssStyle"], outputs: ["toggleChange"] }, { kind: "component", type: i8.IconComponent, selector: "nas-icon", inputs: ["icon", "type", "isIndicator", "lightCircularBackground", "cssClass"] }, { kind: "directive", type: i9.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i9.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i10.SubsidyDiscountComponent, selector: "nas-subsidy-discount", inputs: ["label", "icon", "selectedDiscount", "discounts"], outputs: ["infoButtonClick", "infoButtonKeydown", "discountSelectChange"] }, { kind: "component", type: i11.SuggestionsComponent, selector: "nas-suggestions", inputs: ["suggestions", "orLabel"], outputs: ["airportSelect"] }, { kind: "component", type: i12.AirportSelectNewComponent, selector: "nas-airport-select-new", inputs: ["airports", "airportRelations", "latestSearchesOrigin", "latestSearchesDestination", "closestAirports", "allowedOriginAiports", "allowedDestinationAirports", "displayLatestSearches", "displayClosestAirports", "combo", "useSwitch", "allAirportsLabel", "latestSearchesLabel", "closestAirportsLabel", "geolocationLabel", "geolocationBlockedLabel", "selectOriginFirstLabel", "invalidDestinationText", "labelOrigin", "placeholderOrigin", "labelDestination", "placeholderDestination", "keepSelection", "nasFormControlNameOrigin", "nasFormControlNameDestination", "nasFormGroup", "originAirportCode", "destinationAirportCode", "ariaLabelClear", "ariaLabelBackdrop"], outputs: ["originChange", "originOpenChange", "destinationChange", "destinationOpenChange", "focusOnNext", "positionChange"] }, { kind: "component", type: i13.DatepickerComboNewComponent, selector: "nas-datepicker-combo-new", inputs: ["ariaLabelBackdrop", "outboundOpen", "inboundOpen", "noAvailableFlightsLabel", "availableFlightsLabel", "disablePastSelection", "outboundDisabled", "inboundDisabled", "outboundOnly", "outboundLabel", "inboundLabel", "availability", "outboundAvailableDates", "inboundAvailableDates", "times", "dateDisplayFormat", "timeDisplayFormat", "locale", "compact", "nasFormGroup", "nasFormControlNameOutbound", "nasFormControlNameInbound", "outboundSelectedDate", "inboundSelectedDate", "disableBackdrop", "outboundSelectedTime", "inboundSelectedTime", "ariaLabelPreviousMonth", "ariaLabelNextMonth", "inboundLowerLimitDateOffset", "inlineFlex"], outputs: ["outboundSelectedDateChange", "inboundSelectedDateChange", "outboundOpenChange", "inboundOpenChange", "outboundMonthChange", "inboundMonthChange", "focusOnNextChange", "focusOnPreviousChange"] }, { kind: "component", type: i14.ButtonNewComponent, selector: "nas-button-new", inputs: ["primary", "secondary", "link", "light", "large", "block", "flex", "compact", "right", "spaceless", "href", "trackingvalue", "canContinueOnDisabled", "disabled", "type", "cssClass", "ariaLabel", "cssStyle", "tabindex", "overrideBaseCssClass", "useRouterLink", "id", "target", "icon", "iconLeft", "iconType", "buttonlink"], outputs: ["clickChange"] }, { kind: "component", type: i15.PassengerSelectNewComponent, selector: "nas-passenger-select-new", inputs: ["passengers", "maxPaxCount", "minAdultCount", "groupBookingLimit", "title", "adultsLabel", "childrenLabel", "infantsLabel", "youthsLabel", "youngAdultsLabel", "groupBookingLabel", "nasFormGroup", "nasFormControlGroupBooking", "ariaLabelSubtract", "ariaLabelAdd"], outputs: ["passengersChange", "focusOnNext", "focusOnPrevious"] }, { kind: "component", type: i16.RadioNewComponent, selector: "nas-radio-new", inputs: ["id", "value", "name", "error", "disabled", "strong", "block", "spaceless", "tabIndex", "required", "aria-label", "aria-describedby", "aria-labelledby", "checked", "nasFormControlName", "nasFormGroup"], outputs: ["checkedChange"] }] }); }
1067
+ }
1068
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: FilterNewComponent, decorators: [{
1069
+ type: Component,
1070
+ args: [{ selector: 'nas-filter-new', template: "<nas-accordion *ngIf=\"deviceHelper?.isMobile() && exists(minimizeOnMobile); else filterTemplate\"\n simple\n containerOnToggle\n transparent\n [expanded]=\"expandedAccordionMobile\"\n [title]=\"editSearchTitle\"\n (toggleChange)=\"onAccordionToggleChange($event)\">\n <ng-container *ngTemplateOutlet=\"filterTemplate\"></ng-container>\n</nas-accordion>\n<div class=\"container\"\n *ngIf=\"deviceHelper?.isMobile() && exists(minimizeOnMobile) && displaySummary\">{{getSummary()}}</div>\n\n<ng-template #filterTemplate>\n <div #container\n [nasClass]=\"getContainerClass()\">\n <div [nasClass]=\"getFilterClass('filters', [exists(minimize) && 'minimized', maximize && 'maximize'])\">\n <ng-container *ngIf=\"airports?.length > 0\">\n <nas-airport-select-new *ngIf=\"airports && airportRelations && (enableDestinationSelect)\"\n #airportSelect\n combo\n [ariaLabelClear]=\"ariaLabelClear\" \n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlNameOrigin]=\"nasFormControlNameOrigin\"\n [nasFormControlNameDestination]=\"nasFormControlNameDestination\"\n [useSwitch]=\"useSwitch\"\n [nasClass]=\"getAirportSelectClass()\"\n [airports]=\"airports\"\n [allowedOriginAiports]=\"allowedOriginAirports\"\n [allowedDestinationAirports]=\"allowedDestinationAirports\"\n [airportRelations]=\"airportRelations\"\n [latestSearchesOrigin]=\"latestSearchesOrigin\"\n [latestSearchesDestination]=\"latestSearchesDestination\"\n [displayLatestSearches]=\"displayLatestSearches\"\n [displayClosestAirports]=\"displayClosestAirports\"\n [originAirportCode]=\"originAirportCode\"\n [destinationAirportCode]=\"destinationAirportCode\"\n [allAirportsLabel]=\"allAirportsLabel\"\n [latestSearchesLabel]=\"latestSearchesLabel\"\n [closestAirportsLabel]=\"closestAirportsLabel\"\n [closestAirports]=\"closestAirports\"\n [selectOriginFirstLabel]=\"selectOriginFirstLabel\"\n [labelOrigin]=\"labelOrigin\"\n [placeholderOrigin]=\"placeholderOrigin\"\n [labelDestination]=\"labelDestination\"\n [geolocationLabel]=\"geolocationLabel\"\n [geolocationBlockedLabel]=\"geolocationBlockedLabel\"\n [placeholderDestination]=\"placeholderDestination\"\n [keepSelection]=\"keepSelection\"\n [invalidDestinationText]=\"invalidDestinationText\"\n (originChange)=\"setSelectedOriginAirport($event)\"\n (destinationChange)=\"onDestinationChange($event)\"\n (focusOnNext)=\"setFocusOnPassengerSelect($event)\"\n (originOpenChange)=\"onOriginOpen($event)\"\n (destinationOpenChange)=\"onDestinationOpen($event)\"\n (positionChange)=\"getClosestAirports($event)\"></nas-airport-select-new>\n <nas-airport-select-new *ngIf=\"airports && (!enableDestinationSelect)\"\n #airportSelect\n [ariaLabelClear]=\"ariaLabelClear\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlNameOrigin]=\"nasFormControlNameOrigin\"\n [useSwitch]=\"useSwitch\"\n [nasClass]=\"getClass('airport-origin-select')\"\n [airports]=\"airports\"\n [allowedOriginAiports]=\"allowedOriginAirports\"\n [airportRelations]=\"airportRelations\"\n [latestSearchesOrigin]=\"latestSearchesOrigin\"\n [displayLatestSearches]=\"displayLatestSearches\"\n [displayClosestAirports]=\"displayClosestAirports\"\n [originAirportCode]=\"originAirportCode\"\n [allAirportsLabel]=\"allAirportsLabel\"\n [latestSearchesLabel]=\"latestSearchesLabel\"\n [closestAirportsLabel]=\"closestAirportsLabel\"\n [closestAirports]=\"closestAirports\"\n [selectOriginFirstLabel]=\"selectOriginFirstLabel\"\n [labelOrigin]=\"labelOrigin\"\n [placeholderOrigin]=\"placeholderOrigin\"\n [geolocationLabel]=\"geolocationLabel\"\n [geolocationBlockedLabel]=\"geolocationBlockedLabel\"\n [keepSelection]=\"keepSelection\"\n (originChange)=\"setSelectedOriginAirport($event)\"\n (focusOnNext)=\"setFocusOnPassengerSelect($event)\"\n (originOpenChange)=\"onOriginOpen($event)\"\n (positionChange)=\"getClosestAirports($event)\"></nas-airport-select-new>\n <nas-suggestions *ngIf=\"(closestAirports || latestSearchesOrigin) && exists(enableSuggestions)\"\n [nasClass]=\"getFilterClass('suggestions')\"\n [suggestions]=\"getSuggestions()\"\n [orLabel]=\"orLabel\"\n (airportSelect)=\"setSelectedOriginAirport($event)\"></nas-suggestions>\n </ng-container>\n <ng-container *ngIf=\"shouldMaximize()\">\n <div [nasClass]=\"!enableDestinationSelect ? getClass('origin-combined') :\n getTravelDetailsClass('', ['combined', exists(enableDatepickers) && 'no-border', exists(minimize) && 'minimized'])\">\n <ng-container *ngIf=\"enablePassengersSelect\">\n <button (click)=\"onPassengerSelectOpen($event)\" [nasClass]=\"getClass('passengers-button', openPassengerSelect && 'active')\">\n <div [nasClass]=\"getClass('label')\">\n <p [nasClass]=\"getClass('button-title')\">{{passengersTitleLabel}}</p>\n <p>{{passengerSelectLabel}}</p>\n </div>\n <div [nasClass]=\"getClass('traveler-icon')\"><nas-icon [icon]=\"'my-profile-compact'\" [type]=\"'small'\"></nas-icon></div>\n </button>\n <!-- <nas-dropdown #passengerSelectDropdown\n *ngIf=\"passengers?.length > 0\"\n [nasClass]=\"getTravelDetailsClass('dropdown', 'passengers')\"\n [cssClass]=\"getTravelDetailsClass('dropdown')\"\n [label]=\"passengerSelectLabel\"\n [labelStyle]=\"{'width': '102px'}\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n (openChange)=\"onPassengerSelectOpen($event)\"\n (keydown)=\"passengerKeyDown($event)\"> -->\n <div *ngIf=\"openPassengerSelect\">\n <nas-passenger-select-new\n [ariaLabelAdd]=\"ariaLabelAdd\"\n [ariaLabelSubtract]=\"ariaLabelSubtract\"\n [adultsLabel]=\"passengerSelectAdultsLabel\"\n [youthsLabel]=\"passengerSelectYouthsLabel\"\n [youngAdultsLabel]=\"passengerSelectYoungAdultsLabel\"\n [childrenLabel]=\"passengerSelectChildrenLabel\"\n [infantsLabel]=\"passengerSelectInfantsLabel\"\n [maxPaxCount]=\"maxPaxCount\"\n [minAdultCount]=\"minAdultCount\"\n [title]=\"passengerSelectTitle\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlGroupBooking]=\"nasFormControlGroupBooking\"\n [groupBookingLabel]=\"groupBookingLabel\"\n [groupBookingLimit]=\"groupBookingLimit\"\n (focusOnNext)=\"onPassengersSelectFocusOnNext()\"\n (focusOnPrevious)=\"onPassengersSelectFocusOnPrevious()\"\n [(passengers)]=\"passengers\"></nas-passenger-select-new>\n <nas-button-new *ngIf=\"this.openPassengerSelect\" light block \n [disabled]=\"passengers[0].count === 0 && passengers[1].count === 0 && passengers[2].count === 0\" (click)=\"openPassengerSelect = false\">\n Done\n </nas-button-new>\n </div>\n </ng-container>\n <ng-container *ngIf=\"enableTripSwitch\">\n <form [nasClass]=\"getClass('radio')\">\n <nas-radio-new #tripTypeRoundTrip [name]=\"'tripType'\" [value]=\"2\" [checked]=\"true\" (checkedChange)=\"onTripTypeChange(2)\">\n {{tripSwitchRoundTripLabel}}\n </nas-radio-new>\n <nas-radio-new #tripTypeOneway [name]=\"'tripType'\" [value]=\"1\" (checkedChange)=\"onTripTypeChange(1)\">\n {{tripSwitchOneWayLabel}}\n </nas-radio-new>\n </form>\n </ng-container>\n <div *ngIf=\"exists(enableDatepickers)\"\n [nasClass]=\"getDatePickersClass()\">\n <nas-datepicker-combo-new #datepickerCombo\n compact\n [inlineFlex]=\"inlineFlex\"\n [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlNameOutbound]=\"nasFormControlNameOutbound\"\n [nasFormControlNameInbound]=\"nasFormControlNameInbound\"\n [availability]=\"availability\"\n [availableFlightsLabel]=\"availableFlightsLabel\"\n [dateDisplayFormat]=\"dateDisplayFormat\"\n [disablePastSelection]=\"disablePastSelection\"\n [locale]=\"locale\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [inboundAvailableDates]=\"inboundAvailableDates\"\n [inboundLabel]=\"inboundLabel\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [outboundAvailableDates]=\"outboundAvailableDates\"\n [outboundLabel]=\"outboundLabel\"\n [timeDisplayFormat]=\"timeDisplayFormat\"\n [times]=\"times\"\n [outboundDisabled]=\"outboundDisabled\"\n [inboundDisabled]=\"inboundDisabled\"\n [outboundOnly]=\"tripType === 1\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n (focusOnNextChange)=\"onFocusOnNextChange($event)\"\n (focusOnPreviousChange)=\"onDatepickerFocusOnPrevious($event)\"\n (inboundMonthChange)=\"onInboundMonthChange($event)\"\n (outboundMonthChange)=\"onOutboundMonthChange($event)\"\n [(outboundOpen)]=\"outboundOpen\"\n [(inboundOpen)]=\"inboundOpen\"\n [(inboundSelectedDate)]=\"inboundSelectedDate\"\n [(outboundSelectedDate)]=\"outboundSelectedDate\">\n </nas-datepicker-combo-new>\n </div>\n <ng-container *ngIf=\"enableTransitSwitch\">\n <nas-button-new *ngIf=\"directOnlyLabel && directTransitLabel\"\n #transitSwitch\n block\n light\n [iconType]=\"'chevron-down'\"\n [label]=\"getTransitLabel()\"\n [nasClass]=\"getClass('transit', openTransitTypeSelect && 'active')\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n (click)=\"onTransitSwitchOpen($event)\"\n (keydown)=\"transitKeyDown($event)\">{{ getTransitLabel() }}\n </nas-button-new>\n <div *ngIf=\"openTransitTypeSelect\" [nasClass]=\"getClass('transit-type')\">\n <button [nasClass]=\"getTravelDetailsClass('action', directOnly && 'active')\"\n type=\"button\"\n #transitTypeDirectOnly\n (click)=\"onTransitChange(true)\">{{ directOnlyLabel }}\n </button>\n <button type=\"button\"\n #transitTypeTransit\n [nasClass]=\"getTravelDetailsClass('action', !directOnly && 'active')\"\n (click)=\"onTransitChange(false)\">{{ directTransitLabel }}\n </button>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"subsidyDiscounts && subsidyDiscounts.length > 0\"\n [nasClass]=\"getFilterClass('subsidy-discount')\">\n <nas-subsidy-discount #subsidyDiscount\n [discounts]=\"subsidyDiscounts\"\n [selectedDiscount]=\"selectedSubsidyDiscount\"\n [label]=\"subsidyDiscountLabel\"\n (infoButtonClick)=\"onSubsidyDiscountInfoClick()\"\n (discountSelectChange)=\"onSubsidyDiscountSelectChange($event)\"\n (infoButtonKeydown)=\"onSubsidyDiscountInfoButtonKeydown($event)\"></nas-subsidy-discount>\n </div>\n </ng-container>\n </div>\n </div>\n</ng-template>", 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)}}.nas-filter-new{position:relative;z-index:6}.nas-filter-new ::ng-deep .nas-filter-new__transit .nas-button-new__content{gap:0;justify-content:space-between;font-weight:400}.nas-filter-new ::ng-deep .nas-filter-new__transit--active .nas-button-new__icon{transform:rotate(180deg)}.nas-filter-new ::ng-deep .nas-filter-new__transit--active .nas-button-new{background-color:#ebf4ff}.nas-filter-new__title{margin-top:24px;font-size:28px;line-height:34px}@media screen and (min-width: 640px){.nas-filter-new__title{font-size:32px;line-height:38px}}.nas-filter-new__title--md{margin-top:60px}.nas-filter-new__radio{display:flex;gap:24px;padding:12px}.nas-filter-new__passengers-button{display:flex;justify-content:space-between;background-color:#fff;border:2px solid #6f6f6f;padding:9px 14px;width:100%}.nas-filter-new__passengers-button--active{background-color:#ebf4ff!important}.nas-filter-new__label{flex-direction:column;text-align:left}.nas-filter-new__label p{margin:0}.nas-filter-new__button-title{font-weight:700;font-size:14px}.nas-filter-new__traveler-icon{transform:scale(.85);margin-top:12px}.nas-filter-new__transit-type{border:2px solid #15273f}.nas-filter-new__transit-type button:first-child{border-bottom:2px solid #E9E7E4}.nas-filter-new__filters{margin-top:12px}.nas-filter-new__filters .nas-filter-new__date-combo{order:2;flex:1;z-index:2}.nas-filter-new__filters--minimized .nas-filter-new__airport-select:after{content:\"\";position:absolute;bottom:-3px;left:0px;width:100%;border-bottom:3px solid #c3c3c3}.nas-filter-new__filters--maximize .nas-filter-new__airport-select-new:after{display:none}.nas-filter-new__filters--md .nas-filter-new__date-combo{flex:0 0 100%}.nas-filter-new__filters--lg{align-items:stretch}.nas-filter-new__filters--lg .nas-filter-new__date-combo{order:3;flex:0 0 100%;z-index:1}.nas-filter-new__filters--lg .nas-filter-new__suggestions{order:3}.nas-filter-new__filters--lg .nas-filter-new__filters--minimized .nas-filter-new__airport-select{margin-right:0;flex:0 1 100%}.nas-filter-new__filters--lg .nas-filter-new__filters--maximize .nas-filter-new__airport-select{margin-right:3px;flex:auto}.nas-filter-new__filters--lg.nas-filter-new__filters--maximize .nas-filter-new__date-combo{border-bottom:3px solid #c3c3c3}.nas-filter-new__suggestions{flex-basis:100%;position:relative;margin-top:3px}.nas-filter-new__airport-select{order:0;flex:0 0 100%;position:relative}.nas-filter-new__airport-select--lg{width:0;margin:0 3px 0 0;flex:1 1 auto}.nas-filter-new__toggler{font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:400;font-size:18px;line-height:26px;color:#15273f;margin-top:6px;z-index:1}.nas-filter-new__toggler .nas-filter-new__toggle-action{cursor:pointer;margin-top:2px;float:right}.nas-filter-new__toggler .nas-filter-new__direct-only{display:inline-block}.travel-details{position:relative;margin:0;z-index:1}.travel-details__list{margin-top:12px}.travel-details__list-item{display:flex;align-items:center;justify-content:space-between;padding:6px 0 0}.travel-details__list-item:not(:last-child){padding:6px 0 9px;border-bottom:2px solid #f1f1f1}.travel-details__label{flex-grow:2;margin:0 6px 0 0}.travel-details__title{font-size:18px;line-height:26px;display:block;min-width:124px}.travel-details__title--small{font-size:16px;line-height:26px;margin:0}.travel-details__action{padding:12px;width:100%;background-color:#fff;font-weight:700}.travel-details__action:hover,.travel-details__action:focus{background-color:#f8f8f8}.travel-details__action--border{border-bottom:2px solid #f1f1f1}.travel-details__action:focus{outline:none;z-index:1}.travel-details__icon{margin-bottom:9px}.travel-details__dropdown{margin-right:0}.travel-details__dropdown:after{content:\"\";position:absolute;bottom:-3px;left:0px;width:100%;border-bottom:3px solid #c3c3c3}.travel-details__dropdown--trip-type{order:1;flex:1;margin-right:3px;margin-bottom:3px}.travel-details__dropdown--transit-type{order:2;flex:1;margin-bottom:3px}.travel-details__dropdown--passengers{order:3;flex:1 0 100%;margin-bottom:3px}.travel-details__dropdown--md.travel-details__dropdown--trip-type{order:2;flex:1;margin-right:3px}.travel-details__dropdown--md.travel-details__dropdown--transit-type{order:3;flex:1}.travel-details__dropdown--md.travel-details__dropdown--passengers{order:1;flex:1;margin-right:3px}.travel-details__dropdown--lg.travel-details__dropdown--trip-type{order:2;flex:1 1 auto;margin-right:3px}.travel-details__dropdown--lg.travel-details__dropdown--transit-type{order:3;flex:1 1 auto}.travel-details__dropdown--lg.travel-details__dropdown--passengers{order:1;flex:1 1 auto;margin-right:3px}.travel-details__dropdown--lg:focus{outline:none}.travel-details__dropdown--lg:after{display:none}.travel-details__transit-icon{position:relative;display:flex;justify-content:center;width:calc(100% - 48px);margin:12px auto;height:24px;background-color:inherit}.travel-details__transit-icon:before{content:\"\";position:absolute;height:2px;left:0;width:100%;top:calc(50% - 1px);background-color:currentColor}.travel-details__transit-icon:after{content:\"\";position:absolute;width:10px;height:10px;right:0;top:calc(50% - 5px);border-top:2px solid currentColor;border-right:2px solid currentColor;transform:rotate(45deg)}.travel-details__transit-icon-stop{position:relative;top:calc(50% - 5px);width:10px;height:10px;border:2px solid currentColor;border-radius:50%;background-color:inherit}.travel-details--combined{order:3;flex:0 0 100%}.travel-details--combined.travel-details--md:after{content:\"\";position:absolute;bottom:-6px;left:0px;width:100%;border-bottom:3px solid #c3c3c3}.travel-details--combined.travel-details--md .travel-details__dropdown{margin:0 3px 0 0}.travel-details--combined.travel-details--md .travel-details__dropdown:last-child{margin:0}.travel-details--combined.travel-details--md .dropdown__toggle{height:calc(100% - 3px);margin:0;padding-left:16px;padding-right:16px}.travel-details--combined.travel-details--lg{order:2;flex:0 0 auto;margin:0 0 0 -3px;padding-left:3px;z-index:2}.travel-details--combined.travel-details--lg:after{content:\"\";position:absolute;bottom:-3px;left:0px;width:100%;border-bottom:3px solid #c3c3c3}.travel-details--combined.travel-details--lg .dropdown__toggle{height:inherit}@media (min-width: 1000px){.travel-details--no-border:after{border-bottom:none}}::ng-deep .nas-passenger-select-new__list-item{padding:6px 16px!important}::ng-deep .nas-radio-new{margin:0!important}::ng-deep .nas-button-new{margin-top:6px}::ng-deep .nas-checkbox-new{background-color:#f1f1f1;padding:12px;width:100%;padding-left:42px!important;margin-bottom:12px!important}::ng-deep .nas-checkbox-new__indicator{left:12px!important}::ng-deep .nas-filter-new__filters .travel-details--no-border:after{display:none}::ng-deep .nas-filter-new__filters .nas-filter-new__date-combo .nas-datepicker__date-picker-wrapper{border-bottom:none!important}::ng-deep .nas-filter-new__filters .nas-filter-new__date-combo--side-by-side .nas-datepicker-combo-new__separator{display:block;border-bottom:none!important}::ng-deep .nas-filter-new__filters .nas-airport-select-new__input-line{border-top:none!important}::ng-deep .nas-filter-new__filters .nas-airport-select-new-combo__separator{border-bottom:none!important}::ng-deep .nas-filter-new__filters .nas-dropdown__toggle{height:64px!important}::ng-deep .nas-filter-new__filters .nas-datepicker-combo-new__separator{display:none}::ng-deep .nas-filter-new__filters--lg .nas-dropdown__toggle{display:flex}::ng-deep .nas-filter-new__filters--lg .nas-filter-new__date-combo .nas-datepicker__date-picker-wrapper{border-bottom:3px solid #c3c3c3}::ng-deep .nas-filter-new__filters--lg .nas-airport-select-new__input-line{border-top:3px solid #c3c3c3!important}::ng-deep .nas-filter-new__filters--lg .nas-datepicker-combo-new__separator{border-bottom:3px solid #c3c3c3!important}::ng-deep .nas-filter-new__filters--lg .nas-airport-select-new-combo__separator{border-bottom:3px solid #c3c3c3!important}::ng-deep .nas-filter-new__rotate{transform:rotate(180deg)}::ng-deep .nas-filter-new__rotate-enter,::ng-deep .nas-filter-new__rotate-leave-active{transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden}::ng-deep .nas-filter-new__rotate-enter{animation:flip-in .55s ease both}::ng-deep .nas-filter-new__rotate-leave-active{animation:flip-out .2s ease-out both}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new__input-line{border-top:none}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new-combo__separator{border-top:none}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new__results-wrapper{margin-top:0}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new__results{top:-3px}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new__icon{bottom:18px}::ng-deep .nas-filter-new__airport-select--no-border .nas-airport-select-new:after{display:none}::ng-deep .nas-filter-new__airport-select .nas-airport-select-new__input-line{display:none}::ng-deep .nas-filter-new__airport-origin-select{width:100%;max-width:100%}::ng-deep .nas-filter-new__airport-origin-select .nas-airport-select-new:only-child{max-width:100%}@media (min-width: 640px){::ng-deep .nas-filter-new__airport-origin-select{max-width:360px;flex:auto;margin-right:3px}::ng-deep .nas-filter-new__airport-origin-select .nas-airport-select-new:only-child{width:auto;max-width:360px}}::ng-deep .nas-filter-new__origin-combined{border-bottom:3px solid #c3c3c3;order:3;flex:0 0 100%;display:flex;flex-wrap:wrap}@media (min-width: 1000px){::ng-deep .nas-filter-new__origin-combined{display:flex;flex:none}::ng-deep .nas-filter-new__origin-combined .nas-dropdown__toggle nas-icon{float:none!important}}::ng-deep .nas-filter-new__subsidy-discount{order:3}::ng-deep .nas-filter-new__subsidy-discount .nas-subsidy-discount{margin-top:16px}\n"] }]
1071
+ }], ctorParameters: function () { return [{ type: i1.DeviceHelper }, { type: i2.SortService }, { type: i3.AbandonedBasketService }, { type: i4.DateHelper }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { passengerSelectDropdown: [{
1072
+ type: ViewChild,
1073
+ args: ['passengerSelectDropdown']
1074
+ }], passengerSelect: [{
1075
+ type: ViewChild,
1076
+ args: ['passengerSelect']
1077
+ }], tripSwitch: [{
1078
+ type: ViewChild,
1079
+ args: ['tripSwitch']
1080
+ }], transitSwitch: [{
1081
+ type: ViewChild,
1082
+ args: ['transitSwitch']
1083
+ }], airportSelect: [{
1084
+ type: ViewChild,
1085
+ args: ['airportSelect']
1086
+ }], datepickerCombo: [{
1087
+ type: ViewChild,
1088
+ args: ['datepickerCombo']
1089
+ }], container: [{
1090
+ type: ViewChild,
1091
+ args: ['container']
1092
+ }], tripTypeOneway: [{
1093
+ type: ViewChild,
1094
+ args: ['tripTypeOneway']
1095
+ }], tripTypeRoundTrip: [{
1096
+ type: ViewChild,
1097
+ args: ['tripTypeRoundTrip']
1098
+ }], transitTypeDirectOnly: [{
1099
+ type: ViewChild,
1100
+ args: ['transitTypeDirectOnly']
1101
+ }], transitTypeTransit: [{
1102
+ type: ViewChild,
1103
+ args: ['transitTypeTransit']
1104
+ }], subsidyDiscount: [{
1105
+ type: ViewChild,
1106
+ args: ['subsidyDiscount']
1107
+ }], airportRelations: [{
1108
+ type: Input
1109
+ }], ariaLabelClear: [{
1110
+ type: Input
1111
+ }], ariaLabelSubtract: [{
1112
+ type: Input
1113
+ }], ariaLabelBackdrop: [{
1114
+ type: Input
1115
+ }], ariaLabelAdd: [{
1116
+ type: Input
1117
+ }], allowedOriginAirports: [{
1118
+ type: Input
1119
+ }], allowedDestinationAirports: [{
1120
+ type: Input
1121
+ }], displayLatestSearches: [{
1122
+ type: Input
1123
+ }], useSwitch: [{
1124
+ type: Input
1125
+ }], displayClosestAirports: [{
1126
+ type: Input
1127
+ }], originAirportCode: [{
1128
+ type: Input
1129
+ }], destinationAirportCode: [{
1130
+ type: Input
1131
+ }], passengerSelectLabel: [{
1132
+ type: Input
1133
+ }], maxPaxCount: [{
1134
+ type: Input
1135
+ }], passengers: [{
1136
+ type: Input
1137
+ }], minAdultCount: [{
1138
+ type: Input
1139
+ }], tripSwitchRoundTripLabel: [{
1140
+ type: Input
1141
+ }], tripSwitchOneWayLabel: [{
1142
+ type: Input
1143
+ }], directOnlyLabel: [{
1144
+ type: Input
1145
+ }], directTransitLabel: [{
1146
+ type: Input
1147
+ }], minimizeOnMobile: [{
1148
+ type: Input
1149
+ }], expandedAccordionMobile: [{
1150
+ type: Input
1151
+ }], defaultSummarySeparator: [{
1152
+ type: Input
1153
+ }], lastSummarySeparator: [{
1154
+ type: Input
1155
+ }], passengerSelectTitle: [{
1156
+ type: Input
1157
+ }], passengerSelectAdultsLabel: [{
1158
+ type: Input
1159
+ }], passengerSelectYouthsLabel: [{
1160
+ type: Input
1161
+ }], passengerSelectYoungAdultsLabel: [{
1162
+ type: Input
1163
+ }], passengerSelectChildrenLabel: [{
1164
+ type: Input
1165
+ }], passengerSelectInfantsLabel: [{
1166
+ type: Input
1167
+ }], groupBookingLabel: [{
1168
+ type: Input
1169
+ }], allAirportsLabel: [{
1170
+ type: Input
1171
+ }], latestSearchesLabel: [{
1172
+ type: Input
1173
+ }], closestAirportsLabel: [{
1174
+ type: Input
1175
+ }], selectOriginFirstLabel: [{
1176
+ type: Input
1177
+ }], labelOrigin: [{
1178
+ type: Input
1179
+ }], placeholderOrigin: [{
1180
+ type: Input
1181
+ }], labelDestination: [{
1182
+ type: Input
1183
+ }], geolocationLabel: [{
1184
+ type: Input
1185
+ }], geolocationBlockedLabel: [{
1186
+ type: Input
1187
+ }], placeholderDestination: [{
1188
+ type: Input
1189
+ }], keepSelection: [{
1190
+ type: Input
1191
+ }], editSearchTitle: [{
1192
+ type: Input
1193
+ }], nasFormGroup: [{
1194
+ type: Input
1195
+ }], nasFormControlNameOrigin: [{
1196
+ type: Input
1197
+ }], nasFormControlNameDestination: [{
1198
+ type: Input
1199
+ }], nasFormControlNameTripType: [{
1200
+ type: Input
1201
+ }], nasFormControlNameDirectOnly: [{
1202
+ type: Input
1203
+ }], nasFormControlNameOutbound: [{
1204
+ type: Input
1205
+ }], nasFormControlNameInbound: [{
1206
+ type: Input
1207
+ }], nasFormControlGroupBooking: [{
1208
+ type: Input
1209
+ }], nasFormControlNameSubsidyDiscount: [{
1210
+ type: Input
1211
+ }], overrideOrigin: [{
1212
+ type: Input
1213
+ }], enableSuggestions: [{
1214
+ type: Input
1215
+ }], closestAirports: [{
1216
+ type: Input
1217
+ }], minimize: [{
1218
+ type: Input
1219
+ }], airports: [{
1220
+ type: Input
1221
+ }], tripType: [{
1222
+ type: Input
1223
+ }], directOnly: [{
1224
+ type: Input
1225
+ }], groupBookingLimit: [{
1226
+ type: Input
1227
+ }], subsidyDiscounts: [{
1228
+ type: Input
1229
+ }], selectedSubsidyDiscount: [{
1230
+ type: Input
1231
+ }], subsidyDiscountLabel: [{
1232
+ type: Input
1233
+ }], ariaLabelPreviousMonth: [{
1234
+ type: Input
1235
+ }], ariaLabelNextMonth: [{
1236
+ type: Input
1237
+ }], originOpenChange: [{
1238
+ type: Output
1239
+ }], destinationOpenChange: [{
1240
+ type: Output
1241
+ }], passengerSelectOpenChange: [{
1242
+ type: Output
1243
+ }], originChange: [{
1244
+ type: Output
1245
+ }], destinationChange: [{
1246
+ type: Output
1247
+ }], passengersChange: [{
1248
+ type: Output
1249
+ }], tripTypeChange: [{
1250
+ type: Output
1251
+ }], directOnlyChange: [{
1252
+ type: Output
1253
+ }], noAvailableFlightsLabel: [{
1254
+ type: Input
1255
+ }], availableFlightsLabel: [{
1256
+ type: Input
1257
+ }], disablePastSelection: [{
1258
+ type: Input
1259
+ }], outboundLabel: [{
1260
+ type: Input
1261
+ }], inboundLabel: [{
1262
+ type: Input
1263
+ }], availability: [{
1264
+ type: Input
1265
+ }], outboundAvailableDates: [{
1266
+ type: Input
1267
+ }], inboundAvailableDates: [{
1268
+ type: Input
1269
+ }], times: [{
1270
+ type: Input
1271
+ }], dateDisplayFormat: [{
1272
+ type: Input
1273
+ }], timeDisplayFormat: [{
1274
+ type: Input
1275
+ }], locale: [{
1276
+ type: Input
1277
+ }], compact: [{
1278
+ type: Input
1279
+ }], outboundDisabled: [{
1280
+ type: Input
1281
+ }], inboundDisabled: [{
1282
+ type: Input
1283
+ }], enableDatepickers: [{
1284
+ type: Input
1285
+ }], minimizingLabel: [{
1286
+ type: Input
1287
+ }], maximizingLabel: [{
1288
+ type: Input
1289
+ }], directOnlyMobileLabel: [{
1290
+ type: Input
1291
+ }], orLabel: [{
1292
+ type: Input
1293
+ }], passengersTitleLabel: [{
1294
+ type: Input
1295
+ }], invalidDestinationText: [{
1296
+ type: Input
1297
+ }], outboundSelectedDate: [{
1298
+ type: Input
1299
+ }], inboundSelectedDate: [{
1300
+ type: Input
1301
+ }], enableDestinationSelect: [{
1302
+ type: Input
1303
+ }], enablePassengersSelect: [{
1304
+ type: Input
1305
+ }], enableTripSwitch: [{
1306
+ type: Input
1307
+ }], enableTransitSwitch: [{
1308
+ type: Input
1309
+ }], outboundSelectedDateChange: [{
1310
+ type: Output
1311
+ }], inboundSelectedDateChange: [{
1312
+ type: Output
1313
+ }], outboundOpenChange: [{
1314
+ type: Output
1315
+ }], inboundOpenChange: [{
1316
+ type: Output
1317
+ }], outboundMonthChange: [{
1318
+ type: Output
1319
+ }], inboundMonthChange: [{
1320
+ type: Output
1321
+ }], focusOnNextChange: [{
1322
+ type: Output
1323
+ }], positionChange: [{
1324
+ type: Output
1325
+ }], subsidyDiscountInfoClick: [{
1326
+ type: Output
1327
+ }] } });
1328
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-new.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/filter-new/filter-new.component.ts","../../../../../../projects/core-components/src/lib/components/filter-new/filter-new.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\n\nimport {\n  AfterViewChecked,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { BehaviorSubject } from 'rxjs';\nimport { TripType } from './enums/trip-type.enum';\nimport { NasComponentBase } from '../../core/base/nas-component.base';\nimport { AbandonedBasketItemModel } from '../../core/models/abandoned-basket-item.model';\nimport { ClassModel } from '../../core/models/class.model';\nimport { UtcDate } from '../../core/models/utc-date.model';\nimport { AbandonedBasketService } from '../../core/services/abandoned-basket/abandoned-basket.service';\nimport { DateHelper } from '../../core/services/date/date-helper.service';\nimport { DeviceHelper } from '../../core/services/device/device-helper.service';\nimport { SortService } from '../../core/services/sort/sort.service';\nimport { AirportModel } from '../airport-select-new/models/airport.model';\nimport { DropdownComponent } from '../dropdown/dropdown.component';\nimport { PassengersModel } from '../passenger-select/models/passengers.model';\nimport { SubsidyDiscountModel } from '../subsidy-discount/models/subsidy-discount.model';\nimport { PassengerSelectComponent } from '../passenger-select/passenger-select.component';\nimport { SubsidyDiscountComponent } from '../subsidy-discount/subsidy-discount.component';\nimport { DatepickerComboNewComponent } from '../datepicker-combo-new/datepicker-combo-new.component';\nimport { AirportSelectNewComponent } from '../airport-select-new/airport-select-new.component';\n\n/**\n * @description\n * Norwegian Filter Component | New design | Beta\n */\n@Component({\n  selector: 'nas-filter-new',\n  templateUrl: './filter-new.component.html',\n  styleUrls: ['./filter-new.component.scss'],\n})\nexport class FilterNewComponent\n  extends NasComponentBase\n  implements OnInit, AfterViewChecked\n{\n  @ViewChild('passengerSelectDropdown')\n  passengerSelectDropdown: DropdownComponent;\n  @ViewChild('passengerSelect') passengerSelect: PassengerSelectComponent;\n  @ViewChild('tripSwitch') tripSwitch: DropdownComponent;\n  @ViewChild('transitSwitch') transitSwitch: DropdownComponent;\n  @ViewChild('airportSelect') airportSelect: AirportSelectNewComponent;\n  @ViewChild('datepickerCombo') datepickerCombo: DatepickerComboNewComponent;\n  @ViewChild('container') container: ElementRef;\n  @ViewChild('tripTypeOneway') tripTypeOneway: ElementRef;\n  @ViewChild('tripTypeRoundTrip') tripTypeRoundTrip: ElementRef;\n  @ViewChild('transitTypeDirectOnly') transitTypeDirectOnly: ElementRef;\n  @ViewChild('transitTypeTransit') transitTypeTransit: ElementRef;\n  @ViewChild('subsidyDiscount') subsidyDiscount: SubsidyDiscountComponent;\n\n  latestSearchesOrigin: Array<AirportModel>;\n  latestSearchesDestination: Array<AirportModel>;\n  displaySummary = true;\n  nativeElement: HTMLElement;\n  inboundLowerLimitDate: UtcDate;\n  containerWidth = new BehaviorSubject<number>(0);\n  maximize = false;\n  isNasGroupValid = false;\n  inlineFlex = 0;\n  openPassengerSelect = false;\n  openTransitTypeSelect = false;\n\n  get outboundOpen(): boolean {\n    return this.outboundOpenValue;\n  }\n  set outboundOpen(value: boolean) {\n    if (this.outboundOpenValue === value) {\n      return;\n    }\n\n    if (value) {\n      this.closeDropdowns();\n\n      if (this.airportSelect) {\n        this.airportSelect.originOpen = false;\n        this.airportSelect.destinationOpen = false;\n      }\n    }\n\n    this.outboundOpenValue = value;\n    this.outboundOpenChange.emit(value);\n  }\n\n  get inboundOpen(): boolean {\n    return this.inboundOpenValue;\n  }\n  set inboundOpen(value: boolean) {\n    if (this.inboundOpenValue === value) {\n      return;\n    }\n\n    if (value) {\n      this.closeDropdowns();\n\n      if (this.airportSelect) {\n        this.airportSelect.originOpen = false;\n        this.airportSelect.destinationOpen = false;\n      }\n    }\n\n    clearTimeout(this.inboundOpenTimeout as number);\n\n    this.inboundOpenTimeout = setTimeout(() => {\n      this.inboundOpenValue = value;\n    });\n\n    this.inboundOpenChange.emit(value);\n  }\n\n  private inboundOpenTimeout: any;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * A record containing keys with all airport codes with corresponding array of airport codes connected to the key.\n   */\n  @Input() airportRelations: Record<string, Array<string>>;\n\n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' on the clear button inside the airport select inputs.\n   */\n  @Input() ariaLabelClear: string;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the subtract buttons.\n   */\n  @Input() ariaLabelSubtract: string;\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   * ARIA label for the add buttons.\n   */\n  @Input() ariaLabelAdd: string;\n\n  /**\n   * @property Input\n   * @description\n   * A list of airports that should be displayed in the origin dropdown.\n   * If not included, all airports will be displayed.\n   */\n  @Input() allowedOriginAirports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of airports that are restricted for destination airports. It will default to airports if not set.\n   */\n  @Input() allowedDestinationAirports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * A boolean indicating if airports that the user allready has searh for should be displayed.\n   */\n  @Input() displayLatestSearches: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Display switch UI to interchange origin and destination airport.\n   */\n  @Input() useSwitch?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * A boolean indicating if airports that are close to the user should be displayed.\n   */\n  @Input() displayClosestAirports: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * The airport code of the origin airport. It will set the selected origin airport based on this value.\n   */\n  @Input() originAirportCode: string;\n\n  /**\n   * @property Input\n   * @description\n   * The airport code of the destination airport. It will set the selected destination airport based on this value.\n   */\n  @Input() destinationAirportCode: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will be added to the passenger select dropdown.\n   */\n  @Input() passengerSelectLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * The total maximum amount of passengers in the passenger select dropdown.\n   */\n  @Input() maxPaxCount: number;\n\n  /**\n   * @property Input\n   * @description\n   * An array of different passenger types that will be displayed.\n   */\n  @Input()\n  get passengers(): Array<PassengersModel> {\n    return this.passengersValue;\n  }\n  set passengers(value: Array<PassengersModel>) {\n    if (!value) {\n      return;\n    }\n\n    this.passengersValue = value;\n    this.passengersChange.emit(value);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * The minimum amount of adults that can be selected in the passenger select dropdown.\n   */\n  @Input() minAdultCount: number;\n\n  /**\n   * @property Input\n   * @description\n   * A label for round trip selection in the trip switch dropdown.\n   */\n  @Input() tripSwitchRoundTripLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for one way selection in the trip switch dropdown.\n   */\n  @Input() tripSwitchOneWayLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for direct only selection in the transit switch dropdown.\n   */\n  @Input() directOnlyLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for both direct and transit selection in the transit switch dropdown.\n   */\n  @Input() directTransitLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Indicates if the filter should be minimized on mobile screen sizes.\n   */\n  @Input() minimizeOnMobile?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Indicates if the edit search of accordion should be expended on mobile screen sizes.\n   */\n  @Input()\n  get expandedAccordionMobile() {\n    return this.expandedAccordionMobileValue;\n  }\n  set expandedAccordionMobile(value: boolean) {\n    if (value === this.expandedAccordionMobileValue) {\n      return;\n    }\n\n    this.expandedAccordionMobileValue = value;\n  }\n\n  /**\n   * @property Input\n   * @description\n   * A separator for the filter summary that is dispayed if minimizeOnMobile is true.\n   *\n   * ### Example\n   * 1 traveller, round trip and direct/transit\n   */\n  @Input() defaultSummarySeparator = '';\n\n  /**\n   * A separator for the filter summary is are dispayed if minimizeOnMobile is true.\n   *\n   * ### Example\n   * 1 traveller, round trip and direct/transit\n   */\n  @Input() lastSummarySeparator = '';\n\n  /**\n   * @property Input\n   * @description\n   * A title that will be added to the passenger select dropdown.\n   */\n  @Input() passengerSelectTitle: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the adults passenger type in the passenger select dropdown.\n   */\n  @Input() passengerSelectAdultsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the youths passenger type in the passenger select dropdown.\n   */\n  @Input() passengerSelectYouthsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the young adults passenger type in the passenger select dropdown.\n   */\n  @Input() passengerSelectYoungAdultsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the children passenger type in the passenger select dropdown.\n   */\n  @Input() passengerSelectChildrenLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the infants passenger type in the passenger select dropdown.\n   */\n  @Input() passengerSelectInfantsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear when total number of selected passengers exceeds the group booking limit\n   */\n  @Input() groupBookingLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of all airports in the airport select drop down lists.\n   */\n  @Input() allAirportsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of the latest searches in the airport select drop down lists.\n   */\n  @Input() latestSearchesLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of the closest airports in the airport select drop down lists.\n   */\n  @Input() closestAirportsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in the destination input field in the airport select, if the\n   * user tries to select a destination airport without selecting an origin airport.\n   */\n  @Input() selectOriginFirstLabel: string;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * A label that will appear on top of the origin airport input field.\n   */\n  @Input() labelOrigin: string;\n\n  /**\n   * @property Input\n   * @description\n   * A placeholder that will appear on the origin airport input field.\n   */\n  @Input() placeholderOrigin = '';\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * A label that will appear on top of the destination airport input field.\n   */\n  @Input() labelDestination: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in my location in the drop down list in airport select.\n   */\n  @Input() geolocationLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in my location, in the drop down list in airport select if user has denied geolocation.\n   */\n  @Input() geolocationBlockedLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A placeholder that will appear on the destination airport input field.\n   */\n  @Input() placeholderDestination = '';\n\n  /**\n   * @property Input\n   * @description\n   * A modifier that will allow always keeping the selected airport.\n   * The last selected airport will be shown once user clears the selection and blur.\n   */\n  @Input() keepSelection: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * A title that will be assigned to edit search accordion.\n   */\n  @Input() editSearchTitle: string;\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() nasFormControlNameOrigin: string;\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() nasFormControlNameDestination: string;\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() nasFormControlNameTripType: string;\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() nasFormControlNameDirectOnly: string;\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() nasFormControlNameOutbound: string;\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() nasFormControlNameInbound: string;\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() nasFormControlGroupBooking: string;\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() nasFormControlNameSubsidyDiscount: string;\n\n  /**\n   * @property Input\n   * @description\n   * Make latest searches and geolocation override default value in the origin airport selector.\n   */\n  @Input() overrideOrigin?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * This will make the filter display suggested airports based on geolocation and latest searches.\n   */\n  @Input() enableSuggestions?: boolean;\n\n  @Input()\n  get closestAirports() {\n    return this.closestAirportsValue;\n  }\n  set closestAirports(airports: Array<AirportModel>) {\n    if (!airports || airports.length < 1) {\n      return;\n    }\n\n    this.closestAirportsValue = airports;\n\n    if (this.exists(this.overrideOrigin)) {\n      this.originAirportCode = airports[0].code;\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * This will only display airport selection. When a city pair is selected, the rest of the filter will be visible.\n   */\n  @Input() minimize?: boolean;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * All airports that will be populated into the dropdown lists.\n   * If displayLatestSearches is true, it will try to get the latest searches from the abandoned basket.\n   */\n  @Input()\n  get airports() {\n    return this.airportsValue;\n  }\n  set airports(airports: Array<AirportModel>) {\n    this.airportsValue = airports;\n\n    if (this.exists(this.displayLatestSearches)) {\n      const abandonedBasket = this.abandonedBasketService.getAll();\n      this.setLatestSearches(abandonedBasket, this.airports);\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Sets and gets the selected trip type.\n   */\n  @Input()\n  get tripType() {\n    return this.tripTypeValue;\n  }\n  set tripType(tripType: TripType) {\n    if (tripType === this.tripTypeValue) {\n      return;\n    }\n\n    this.tripTypeValue = tripType;\n    this.tripTypeChange.emit(this.tripType);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Sets and gets whether the selected transit type is direct only or not.\n   */\n  @Input()\n  get directOnly() {\n    return this.directOnlyValue;\n  }\n  set directOnly(directOnly: boolean) {\n    if (directOnly === this.directOnlyValue) {\n      return;\n    }\n\n    this.directOnlyValue = directOnly;\n    this.directOnlyChange.emit(this.directOnly);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * The limit for when the total amount of passengers exceeds to be a group booking.\n   */\n  @Input() groupBookingLimit: number;\n\n  /**\n   * @property Input\n   * @description\n   * Subsidy discounts\n   */\n  @Input() subsidyDiscounts: Array<SubsidyDiscountModel>;\n\n  /**\n   * @property Input\n   * @description\n   * Selected subsidy discount\n   */\n  @Input() selectedSubsidyDiscount: SubsidyDiscountModel;\n\n  /**\n   * @property Input\n   * @description\n   * Subsidy discount label\n   */\n  @Input() subsidyDiscountLabel: string;\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   * An event that is fired every time the origin dropdown selector opens or closes.\n   */\n  @Output() originOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the origin dropdown selector opens or closes.\n   */\n  @Output() destinationOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the passenger select dropdown opens or closes.\n   */\n  @Output() passengerSelectOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the selected origin airport changes.\n   */\n  @Output() originChange = new EventEmitter<AirportModel>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the selected destination airport changes.\n   */\n  @Output() destinationChange = new EventEmitter<AirportModel>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a passenger selection change is performed.\n   */\n  @Output() passengersChange = new EventEmitter<Array<PassengersModel>>();\n\n  /**\n   * @property Output\n   * @description\n   * Sets and gets the selected trip type.\n   */\n  @Output() tripTypeChange = new EventEmitter<TripType>();\n\n  /**\n   * @property Output\n   * @description\n   * Sets and gets whether the selected transit type is direct only or not.\n   */\n  @Output() directOnlyChange = new EventEmitter<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   * Label for outbound datepicker.\n   */\n  @Input() outboundLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for inbound datepicker.\n   */\n  @Input() inboundLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets the datepickers in availability mode where available dates can be added.\n   */\n  @Input() availability: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Available dates for outbound calendar.\n   */\n  @Input() outboundAvailableDates: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * Available dates for inbound calendar.\n   */\n  @Input() inboundAvailableDates: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * If set, Enables the time dropdown selector alongside datepicker.\n   */\n  @Input() times: Array<UtcDate>;\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 = 'EEE d, MMM';\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-GB';\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   * Disable possibility to select outbound dates.\n   */\n  @Input() outboundDisabled: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Disable possibility to select inbound dates.\n   */\n  @Input() inboundDisabled: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Show/Add date picker combo into the filter if set to true.\n   */\n  @Input() enableDatepickers: boolean;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * Label for the toggle icon for minimizing filter.\n   */\n  @Input() minimizingLabel: string;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * Label for the toggle icon for maximizing filter.\n   */\n  @Input() maximizingLabel: string;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * Label for the toggling transit type when filter is minimized.\n   */\n  @Input() directOnlyMobileLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for 'or' in the suggestioned airports.\n   */\n  @Input() orLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for 'Travelers' in the passengers select button.\n   */\n  @Input() passengersTitleLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A text that appears in the destinations dropdown list when origin airport is not set.\n   */\n  @Input() invalidDestinationText: string;\n\n  /**\n   * @property Input\n   * @description\n   * Selected datefor outbound calendar.\n   */\n  @Input()\n  get outboundSelectedDate() {\n    return this.outboundSelectedDateValue;\n  }\n  set outboundSelectedDate(date: UtcDate) {\n    if (!date) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.outboundSelectedDateValue = date;\n      this.outboundSelectedDateChange.emit(date);\n    });\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Selected datefor inbound calendar.\n   */\n  @Input()\n  get inboundSelectedDate() {\n    return this.inboundSelectedDateValue;\n  }\n  set inboundSelectedDate(date: UtcDate) {\n    if (!date) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.inboundSelectedDateValue = date;\n      this.inboundSelectedDateChange.emit(date);\n    });\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Will display the destination input, set this to false to remove it. It's true by default.\n   */\n  @Input() enableDestinationSelect = true;\n\n  /**\n   * @property Input\n   * @description\n   * Will display passenger select, set this to false to remove it. It's true by default.\n   */\n  @Input() enablePassengersSelect = true;\n\n  /**\n   * @property Input\n   * @description\n   * Will display the trip switch, set this to false to remove it. It's true by default.\n   */\n  @Input() enableTripSwitch = true;\n\n  /**\n   * @property Input\n   * @description\n   * Will display the transit switch, set this to false to remove it. It's true by default.\n   */\n  @Input() enableTransitSwitch = true;\n\n  /**\n   * @property Output\n   * @description\n   * When selected datehas been changed on the outbound calendar.\n   */\n  @Output() outboundSelectedDateChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * When selected datehas been changed on the inbound calendar.\n   */\n  @Output() inboundSelectedDateChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * Outbound datepicker is open or closed.\n   */\n  @Output() outboundOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * Inbound datepicker is open or closed.\n   */\n  @Output() inboundOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * Outbound calendar changes month.\n   */\n  @Output() outboundMonthChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * Inbound calendar changes month.\n   */\n  @Output() inboundMonthChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * When a user has actively changed the date.\n   */\n  @Output() focusOnNextChange = new EventEmitter();\n\n  /**\n   * @property Output\n   * @description\n   * The geolocation of the user. Will be emitted if 'enableSuggestions' is true.\n   */\n  @Output() positionChange = new EventEmitter<GeolocationPosition>();\n\n  /**\n   * @property Output\n   * @description\n   * An even that is fired every time the info button on the subsidy discount is clicked.\n   */\n  @Output() subsidyDiscountInfoClick = new EventEmitter();\n\n  get inboundSelectedMonth(): UtcDate {\n    return this.inboundSelectedMonthValue;\n  }\n  set inboundSelectedMonth(month: UtcDate) {\n    if (this.dateService.isSameMonth(month, this.inboundSelectedMonthValue)) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.inboundMonthChange.emit(month);\n      this.inboundSelectedMonthValue = month;\n    });\n  }\n\n  private outboundSelectedDateValue: UtcDate;\n  private inboundSelectedDateValue: UtcDate;\n  private inboundSelectedMonthValue: UtcDate;\n  private airportsValue: Array<AirportModel>;\n  private tripTypeValue: TripType;\n  private directOnlyValue: boolean;\n  private expandedAccordionMobileValue: boolean;\n  private closestAirportsValue: Array<AirportModel>;\n  private outboundOpenValue = false;\n  private inboundOpenValue = false;\n  private passengersValue = new Array<PassengersModel>();\n  private focusAsyncTimout: any;\n  private transitSwitchFocusTimeout: any;\n  private tripSwitchFocusTimeout: any;\n\n  constructor(\n    public deviceHelper: DeviceHelper,\n    private sortService: SortService,\n    private abandonedBasketService: AbandonedBasketService,\n    private dateService: DateHelper,\n    public elementRef: ElementRef,\n    private changeDetector: ChangeDetectorRef\n  ) {\n    super('nas-filter-new');\n    this.nativeElement = elementRef.nativeElement as HTMLElement;\n  }\n\n  ngOnInit(): void {\n    if (!this.nasFormGroup) {\n      return;\n    }\n\n    this.nasFormGroup.statusChanges.subscribe((x) => {\n      setTimeout(() => {\n        this.isNasGroupValid = /true/i.test(x);\n      });\n    });\n\n    if (this.nasFormControlNameDirectOnly) {\n      const directOnlyControl = this.nasFormGroup.get(\n        this.nasFormControlNameDirectOnly\n      );\n\n      if (directOnlyControl) {\n        this.directOnly = directOnlyControl.value;\n      }\n    }\n\n    if (this.nasFormControlNameTripType) {\n      const tripTypeControl = this.nasFormGroup.get(\n        this.nasFormControlNameTripType\n      );\n\n      if (tripTypeControl) {\n        this.tripType = tripTypeControl.value;\n        this.inboundDisabled = tripTypeControl.value === TripType.oneWay;\n\n        if (this.nasFormControlNameInbound) {\n          const inboundControl = this.nasFormGroup.get(\n            this.nasFormControlNameInbound\n          );\n\n          if (inboundControl && this.inboundDisabled) {\n            inboundControl.disable();\n          }\n        }\n\n        tripTypeControl.valueChanges.subscribe((value: TripType) => {\n          this.inboundDisabled = value === TripType.oneWay;\n          this.tripType = value;\n        });\n      }\n    }\n\n    if (this.nasFormControlNameDirectOnly) {\n      const directOnlyControl = this.nasFormGroup.get(\n        this.nasFormControlNameDirectOnly\n      );\n      if (directOnlyControl) {\n        directOnlyControl.valueChanges.subscribe((value: boolean) => {\n          this.directOnly = value;\n        });\n      }\n    }\n  }\n\n  ngAfterViewChecked(): void {\n    this.containerWidth.next(\n      (this.container.nativeElement as HTMLElement).offsetWidth\n    );\n\n    window.onresize = () => {\n      this.containerWidth.next(\n        (this.container.nativeElement as HTMLElement).offsetWidth\n      );\n    };\n    this.setInlineFlexWidth();\n  }\n\n  onSubsidyDiscountInfoClick(): void {\n    this.subsidyDiscountInfoClick.emit();\n  }\n\n  onSubsidyDiscountSelectChange(model: SubsidyDiscountModel): void {\n    if (!this.nasFormGroup || !this.nasFormControlNameSubsidyDiscount) {\n      return;\n    }\n\n    const subsidyDiscountControl = this.nasFormGroup.get(\n      this.nasFormControlNameSubsidyDiscount\n    );\n    subsidyDiscountControl.patchValue(model);\n  }\n\n  getClosestAirports(position: GeolocationPosition): void {\n    this.positionChange.emit(position);\n  }\n\n  getFilterClass(element?: string, modifiersInput?: any): ClassModel {\n    let modifiers = modifiersInput || new Array<string>();\n\n    if (\n      typeof modifiersInput === 'string' ||\n      modifiersInput instanceof String\n    ) {\n      modifiers = [modifiersInput];\n    }\n\n    const widths = [];\n\n    if (this.deviceHelper.isWidthTablet(this.containerWidth.getValue())) {\n      widths.push('md');\n    }\n\n    if (this.deviceHelper.isWidthDesktop(this.containerWidth.getValue())) {\n      widths.push('lg');\n    }\n\n    modifiers = [...modifiers, ...widths];\n\n    return this.getClass(element, modifiers);\n  }\n\n  getAirportSelectClass(): ClassModel {\n    return this.getClass('airport-select-new', [\n      this.deviceHelper.isWidthDesktop(this.containerWidth.getValue()) && 'lg',\n      this.deviceHelper.isWidthTablet(this.containerWidth.getValue()) && 'md',\n      this.exists(this.enableDatepickers) && 'no-border',\n    ]);\n  }\n\n  getSuggestions(): Array<AirportModel> {\n    const suggestions = Array.from(\n      new Set([\n        ...(this.latestSearchesOrigin\n          ? this.latestSearchesOrigin.filter(\n              (x) => x.code !== this.originAirportCode\n            )\n          : []),\n        ...(this.closestAirports\n          ? this.closestAirports.filter(\n              (x) => x.code !== this.originAirportCode\n            )\n          : []),\n      ])\n    );\n\n    return suggestions.slice(0, 3);\n  }\n\n  getDatePickersClass(): ClassModel {\n    return this.getFilterClass('date-combo-new', [\n      this.exists(this.minimize) && 'minimized',\n      this.containerWidth.getValue() > 500 && 'side-by-side',\n    ]);\n  }\n\n  getTravelDetailsClass(element?: string, modifiersInput?: any): ClassModel {\n    let modifiers = modifiersInput || new Array<string>();\n\n    if (\n      typeof modifiersInput === 'string' ||\n      modifiersInput instanceof String\n    ) {\n      modifiers = [modifiersInput];\n    }\n\n    const widths = [\n      this.deviceHelper.isWidthTablet(this.containerWidth.getValue()) && 'md',\n      this.deviceHelper.isWidthDesktop(this.containerWidth.getValue()) && 'lg',\n    ];\n\n    modifiers = [...modifiers, ...widths];\n\n    const travelDetailsBase = new NasComponentBase('travel-details');\n    return travelDetailsBase.getClass(element, modifiers);\n  }\n\n  onInboundMonthChange(month: UtcDate): void {\n    this.inboundMonthChange.emit(month);\n  }\n  onOutboundMonthChange(month: UtcDate): void {\n    this.outboundMonthChange.emit(month);\n  }\n\n  onPassengersSelectFocusOnPrevious(): void {\n    if (this.isMobileDisplay()) {\n      this.onTransitSwitchOpen(true);\n      this.focusAsync(this.transitSwitch.toggleElement);\n    } else if (this.isTabletDisplay()) {\n      this.selectPreviousControl();\n    }\n  }\n\n  passengerKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Tab':\n        if (event.shiftKey) {\n          if (this.isMobileDisplay() || this.isTabletDisplay()) {\n            break;\n          }\n\n          this.focusOnAirportSelectBackwards();\n          break;\n        }\n\n        if (this.isMobileDisplay()) {\n          if (this.subsidyDiscounts && this.subsidyDiscounts.length > 0) {\n            this.subsidyDiscount.infoButton.button.nativeElement.focus();\n          } else {\n            this.focusOnNextChange.emit();\n          }\n        }\n        break;\n      case 'Enter':\n        if (event.shiftKey || this.isMobileDisplay()) {\n          break;\n        }\n        if (\n          document.activeElement ===\n          this.passengerSelectDropdown.toggleElement.nativeElement\n        ) {\n          if (this.passengerSelectDropdown.open) {\n            this.onTripSwitchOpen(true);\n            this.focusAsync(this.tripSwitch.toggleElement);\n          } else {\n            this.onPassengerSelectOpen();\n          }\n        }\n        break;\n      case 'Escape':\n        this.onPassengerSelectOpen();\n        event.preventDefault();\n        this.setFocusOnNativeElement(\n          this.passengerSelectDropdown.toggleElement\n        );\n        break;\n    }\n  }\n\n  onTripSwitchKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'ArrowRight':\n        if (document.activeElement === this.tripTypeRoundTrip.nativeElement) {\n          this.tripTypeOneway.nativeElement.focus();\n        }\n        break;\n      case 'ArrowLeft':\n        if (document.activeElement === this.tripTypeOneway.nativeElement) {\n          this.tripTypeRoundTrip.nativeElement.focus();\n        }\n        break;\n      case 'Tab':\n      case 'Enter':\n        if (event.shiftKey) {\n          event.preventDefault();\n\n          if (this.isMobileDisplay() || !this.passengerSelectDropdown) {\n            this.selectPreviousControl();\n          } else {\n            this.onPassengerSelectOpen();\n            this.focusAsync(this.passengerSelectDropdown.toggleElement);\n          }\n        } else {\n          if (event.key === 'Tab') {\n            this.onTransitSwitchOpen(true);\n          } else {\n            if (this.tripSwitch.open) {\n              this.onTransitSwitchOpen(true);\n              this.focusAsync(this.transitSwitch.toggleElement);\n            } else {\n              this.onTripSwitchOpen(true);\n            }\n          }\n        }\n        break;\n\n      case 'Escape':\n        this.onTripSwitchOpen(false);\n        this.setFocusOnNativeElement(this.tripSwitch.toggleElement);\n        break;\n    }\n  }\n\n  transitKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'ArrowRight':\n        if (document.activeElement === this.transitTypeTransit.nativeElement) {\n          this.transitTypeDirectOnly.nativeElement.focus();\n        }\n        break;\n      case 'ArrowLeft':\n        if (\n          document.activeElement === this.transitTypeDirectOnly.nativeElement\n        ) {\n          this.transitTypeTransit.nativeElement.focus();\n        }\n        break;\n      case 'Tab':\n      case 'Enter':\n        if (event.shiftKey) {\n          event.preventDefault();\n          this.onTripSwitchOpen(true);\n          this.focusAsync(<any>this.tripSwitch.toggleElement);\n        } else {\n          if (this.isMobileDisplay()) {\n            this.onPassengerSelectOpen();\n            this.focusAsync(this.passengerSelectDropdown.toggleElement);\n          } else {\n            this.onTransitSwitchOpen(!this.transitSwitch.open);\n\n            if (this.subsidyDiscounts && this.subsidyDiscounts.length > 0) {\n              this.subsidyDiscount.infoButton.button.nativeElement.focus();\n            } else {\n              this.focusOnNextChange.emit();\n            }\n          }\n\n          if (event.key === 'Tab') {\n            event.preventDefault();\n          }\n        }\n\n        break;\n      case 'Escape':\n        this.onTransitSwitchOpen(false);\n        event.preventDefault();\n        this.setFocusOnNativeElement(this.transitSwitch.toggleElement);\n        break;\n    }\n  }\n\n  onSubsidyDiscountInfoButtonKeydown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Tab':\n        if (event.shiftKey) {\n          if (this.isMobileDisplay()) {\n            this.focusAsync(this.passengerSelectDropdown.toggleElement);\n          } else {\n            this.focusAsync(this.transitSwitch.toggleElement);\n          }\n\n          event.preventDefault();\n        }\n        break;\n\n      default:\n        break;\n    }\n  }\n\n  onPassengersSelectFocusOnNext(): void {\n    if (this.isMobileDisplay()) {\n      this.passengerSelectDropdown.toggle();\n    } else {\n      this.onTripSwitchOpen(true);\n      this.focusAsync(<any>this.tripSwitch.toggleElement);\n    }\n  }\n\n  focusAsync(refElement: ElementRef): void {\n    clearTimeout(this.focusAsyncTimout);\n\n    this.focusAsyncTimout = setTimeout(() =>\n      this.setFocusOnNativeElement(refElement)\n    );\n  }\n\n  onDatepickerFocusOnPrevious(event: KeyboardEvent | MouseEvent): void {\n    event.preventDefault();\n\n    this.focusOnAirportSelectBackwards();\n  }\n\n  selectPreviousControl(): void {\n    if (this.datepickerCombo) {\n      if (this.datepickerCombo.outboundOnly) {\n        this.outboundOpen = true;\n      } else {\n        this.inboundOpen = true;\n      }\n    } else if (this.airportSelect) {\n      if (this.exists(this.airportSelect.combo)) {\n        this.airportSelect.onDestinationOpen(true);\n        if (<any>this.airportSelect.airportSelectDropdownDestination) {\n          this.focusAsync(\n            (<any>this.airportSelect.airportSelectDropdownDestination).input\n          );\n        }\n      } else {\n        this.airportSelect.onOriginOpen(true);\n        if (<any>this.airportSelect.airportSelectDropdownOrigin) {\n          this.focusAsync(\n            (<any>this.airportSelect.airportSelectDropdownOrigin).input\n          );\n        }\n      }\n    }\n  }\n\n  onFocusOnNextChange(event: KeyboardEvent | MouseEvent): void {\n    if (this.isMobileDisplay() && this.tripSwitch) {\n      this.onTripSwitchOpen(true);\n      this.focusAsync(this.tripSwitch.toggleElement);\n    } else if (this.isTabletDisplay()) {\n      if (this.passengerSelectDropdown) {\n        event.preventDefault();\n        setTimeout(() => {\n          this.onPassengerSelectOpen();\n          this.setFocusOnNativeElement(\n            this.passengerSelectDropdown.toggleElement\n          );\n        });\n      } else if (this.tripSwitch) {\n        this.onTripSwitchOpen(true);\n        this.focusAsync(this.tripSwitch.toggleElement);\n      }\n    }\n  }\n\n  isMobileDisplay(): boolean {\n    return this.deviceHelper.isWidthMobile(this.containerWidth.getValue());\n  }\n\n  isTabletDisplay(): boolean {\n    return this.deviceHelper.isWidthTablet(this.containerWidth.getValue());\n  }\n\n  onOriginOpen(open: boolean): void {\n    if (this.passengerSelectDropdown) {\n      this.passengerSelectDropdown.open = false;\n    }\n\n    if (this.tripSwitch) {\n      this.tripSwitch.open = false;\n    }\n\n    if (this.transitSwitch) {\n      this.transitSwitch.open = false;\n    }\n\n    if (this.datepickerCombo) {\n      this.datepickerCombo.inboundOpen = false;\n      this.datepickerCombo.outboundOpen = false;\n    }\n    if (this.airportSelect && !this.airportSelect.originOpen) {\n      this.updateMaximize();\n    }\n\n    this.originOpenChange.emit(open);\n\n    this.changeDetector.detectChanges();\n  }\n\n  validateAirportValues(): boolean {\n    if (!this.airportSelect) {\n      return false;\n    }\n    const originSnapshot = this.airportSelect.origin;\n    const destinationSnapshot = this.airportSelect.destination;\n    if (\n      originSnapshot &&\n      destinationSnapshot &&\n      originSnapshot.code &&\n      originSnapshot.code.length &&\n      destinationSnapshot.code &&\n      destinationSnapshot.code.length\n    ) {\n      return true;\n    }\n    return false;\n  }\n\n  updateMaximize(): void {\n    setTimeout(() => {\n      this.maximize = this.validateAirportValues();\n    });\n  }\n\n  onDestinationOpen(open: boolean): void {\n    if (this.passengerSelectDropdown) {\n      this.passengerSelectDropdown.open = false;\n    }\n\n    if (this.tripSwitch) {\n      this.tripSwitch.open = false;\n    }\n\n    if (this.transitSwitch) {\n      this.transitSwitch.open = false;\n    }\n\n    if (this.datepickerCombo) {\n      this.datepickerCombo.inboundOpen = false;\n      this.datepickerCombo.outboundOpen = false;\n    }\n    if (this.airportSelect && !this.airportSelect.destinationOpen) {\n      this.updateMaximize();\n    }\n    this.destinationOpenChange.emit(open);\n  }\n\n  onPassengerSelectOpen(): void {\n    this.openPassengerSelect = true;\n    if (this.airportSelect) {\n      this.airportSelect.originOpen = false;\n      this.airportSelect.destinationOpen = false;\n    }\n\n    if (this.tripSwitch) {\n      this.tripSwitch.open = false;\n    }\n\n    if (this.transitSwitch) {\n      this.transitSwitch.open = false;\n    }\n\n    if (this.datepickerCombo) {\n      if (this.datepickerCombo.inboundOpen) {\n        this.datepickerCombo.inboundOpen = false;\n      }\n      if (this.datepickerCombo.outboundOpen) {\n        this.datepickerCombo.outboundOpen = false;\n      }\n    }\n\n    this.passengerSelectOpenChange.emit(this.openPassengerSelect);\n\n    if (this.openPassengerSelect) {\n      setTimeout(() => {\n        if (this.passengerSelect?.numberFields.first) {\n          this.passengerSelect.numberFields.first.input.nativeElement.focus();\n        }\n      }, 300);\n    }\n  }\n\n  onTripSwitchOpen(open: boolean): void {\n    clearTimeout(this.tripSwitchFocusTimeout);\n\n    if (this.passengerSelectDropdown) {\n      setTimeout(() => {\n        this.passengerSelectDropdown.open = false;\n      });\n    }\n\n    if (this.transitSwitch) {\n      this.transitSwitch.open = false;\n    }\n\n    if (this.airportSelect) {\n      this.airportSelect.originOpen = false;\n      this.airportSelect.destinationOpen = false;\n    }\n\n    if (this.datepickerCombo) {\n      this.datepickerCombo.inboundOpen = false;\n      this.datepickerCombo.outboundOpen = false;\n    }\n\n    this.tripSwitch.open = open;\n\n    if (open) {\n      this.tripSwitchFocusTimeout = setTimeout(() => {\n        this.tripTypeRoundTrip.nativeElement.focus();\n      }, 200);\n    }\n  }\n\n  onTransitSwitchOpen(open: boolean): void {\n    this.openTransitTypeSelect = !this.openTransitTypeSelect;\n    clearTimeout(this.transitSwitchFocusTimeout);\n\n    if (this.passengerSelectDropdown) {\n      this.passengerSelectDropdown.open = false;\n    }\n\n    if (this.tripSwitch) {\n      this.tripSwitch.open = false;\n    }\n\n    if (this.airportSelect) {\n      this.airportSelect.originOpen = false;\n      this.airportSelect.destinationOpen = false;\n    }\n\n    if (this.datepickerCombo) {\n      this.datepickerCombo.inboundOpen = false;\n      this.datepickerCombo.outboundOpen = false;\n    }\n\n    if (this.transitSwitch) {\n      this.transitSwitch.open = open;\n    }\n\n    if (open) {\n      this.transitSwitchFocusTimeout = setTimeout(() => {\n        this.transitTypeTransit.nativeElement.focus();\n      }, 200);\n    }\n  }\n\n  onOriginChange(airport: AirportModel): void {\n    this.originChange.emit(airport);\n  }\n\n  setSelectedOriginAirport(airport: AirportModel): void {\n    if (!airport) {\n      return;\n    }\n\n    this.onOriginChange(airport);\n\n    if (this.originAirportCode === airport.code) {\n      return;\n    }\n\n    this.originAirportCode = airport.code;\n    this.changeDetector.detectChanges();\n  }\n\n  onDestinationChange(airport: AirportModel): void {\n    this.destinationChange.emit(airport);\n  }\n\n  setFocusOnPassengerSelect(event: KeyboardEvent): void {\n    this.minimize = false;\n\n    if (this.isMobileDisplay()) {\n      if (this.datepickerCombo) {\n        event.preventDefault();\n        this.outboundOpen = true;\n        this.focusAsync((<any>this.datepickerCombo.datepickerOutbound).input);\n      } else if (this.tripSwitch) {\n        event.preventDefault();\n        this.onTripSwitchOpen(true);\n        this.focusAsync(this.tripSwitch.toggleElement);\n      }\n    } else if (this.isTabletDisplay() && this.datepickerCombo) {\n      setTimeout(() => {\n        this.outboundOpen = true;\n      });\n    } else {\n      if (this.passengerSelectDropdown) {\n        this.onPassengerSelectOpen();\n        const currentElementRef = this.passengerSelectDropdown.toggleElement;\n        setTimeout(() => this.setFocusOnNativeElement(currentElementRef));\n      } else if (this.tripSwitch) {\n        this.onTripSwitchOpen(true);\n        this.tripSwitch.toggleElement.nativeElement.focus();\n      }\n    }\n  }\n\n  setFocusOnNativeElement(element: ElementRef): void {\n    element.nativeElement.focus();\n  }\n\n  onTripTypeChange(tripType: TripType): void {\n    setTimeout(() => {\n      if (this.tripSwitch) {\n        this.tripSwitch.open = false;\n      }\n    });\n\n    this.tripType = tripType;\n\n    if (this.nasFormGroup && this.nasFormControlNameTripType) {\n      const tripSwitchControl = this.nasFormGroup.get(\n        this.nasFormControlNameTripType\n      );\n      tripSwitchControl.patchValue(tripType);\n    }\n  }\n\n  onTransitChange(directOnly: boolean): void {\n    setTimeout(() => {\n      if (this.transitSwitch) {\n        this.transitSwitch.open = false;\n      }\n    });\n\n    this.directOnly = directOnly;\n\n    if (this.nasFormGroup && this.nasFormControlNameDirectOnly) {\n      const tripTypeControl = this.nasFormGroup.get(\n        this.nasFormControlNameDirectOnly\n      );\n      tripTypeControl.patchValue(directOnly);\n    }\n    this.openTransitTypeSelect = !this.openTransitTypeSelect;\n  }\n\n  getTravelDetailsTripSwitchIconClass(modifiers?: any): Array<ClassModel> {\n    const iconMediumBase = new NasComponentBase('icon-medium');\n\n    return [\n      iconMediumBase.getClass('', modifiers),\n      this.getTravelDetailsClass('icon'),\n    ];\n  }\n\n  getTripSwitchLabel(): string {\n    return this.tripType === TripType.twoWayReturn\n      ? this.tripSwitchRoundTripLabel\n      : this.tripSwitchOneWayLabel;\n  }\n\n  getTransitLabel(): string {\n    return this.directOnly ? this.directOnlyLabel : this.directTransitLabel;\n  }\n\n  onAccordionToggleChange(expanded: boolean): void {\n    this.displaySummary = !expanded;\n  }\n\n  getSummary(): string {\n    return (\n      `${this.passengerSelectLabel}${this.defaultSummarySeparator}` +\n      `${this.getTripSwitchLabel().toLowerCase()}${\n        this.lastSummarySeparator\n      }${this.getTransitLabel().toLowerCase()}`\n    );\n  }\n\n  shouldMaximize(): boolean {\n    if (!this.exists(this.minimize)) {\n      return true;\n    } else if (\n      this.airportSelect &&\n      this.enableDestinationSelect &&\n      this.airportSelect.origin &&\n      this.airportSelect.origin.code &&\n      this.airportSelect.destination &&\n      this.airportSelect.destination.code\n    ) {\n      return true;\n    } else if (\n      this.airportSelect &&\n      !this.enableDestinationSelect &&\n      this.airportSelect.origin &&\n      this.airportSelect.origin.code\n    ) {\n      return true;\n    } else if (\n      this.airportSelect &&\n      (this.airportSelect.originOpen || this.airportSelect.destinationOpen)\n    ) {\n      return this.maximize;\n    } else if (this.exists(this.minimize)) {\n      if (this.maximize) {\n        if (this.nasFormGroup) {\n          return this.isNasGroupValid;\n        }\n        return true;\n      } else {\n        return false;\n      }\n    }\n  }\n\n  private focusOnAirportSelectBackwards(): void {\n    if (this.exists(this.airportSelect.combo)) {\n      this.airportSelect.onDestinationOpen(true);\n      setTimeout(() => {\n        this.airportSelect.airportSelectDropdownDestination.input.nativeElement.focus();\n      }, 100);\n    } else {\n      this.airportSelect.onOriginOpen(true);\n      this.focusAsync(\n        (<any>this.airportSelect.airportSelectDropdownOrigin).input\n      );\n    }\n  }\n\n  private setLatestSearches(\n    abandonedBasket: Array<AbandonedBasketItemModel>,\n    airports: Array<AirportModel>\n  ): void {\n    if (!abandonedBasket || !airports) {\n      return;\n    }\n\n    const unique = new Array<AbandonedBasketItemModel>();\n\n    for (const item of abandonedBasket) {\n      if (!unique.some((x) => x.destinationCode === item.destinationCode)) {\n        unique.push(item);\n      }\n    }\n\n    const originCodes = unique.map((x) => x.originCode);\n    const destinationCodes = unique.map((x) => x.destinationCode);\n\n    const latestSearchesOrigin = airports.filter((airport) =>\n      unique.some(\n        (x) => x.originCode.toLowerCase() === airport.code.toLowerCase()\n      )\n    );\n\n    const latestSearchesDestination = airports.filter((airport) =>\n      unique.some(\n        (x) => x.destinationCode.toLowerCase() === airport.code.toLowerCase()\n      )\n    );\n\n    const code = 'code';\n    this.latestSearchesOrigin = this.sortService\n      .sortByObject(latestSearchesOrigin, originCodes, code)\n      .slice(0, 3);\n\n    if (\n      this.latestSearchesOrigin &&\n      this.latestSearchesOrigin.length > 0 &&\n      this.exists(this.overrideOrigin)\n    ) {\n      this.originAirportCode = this.latestSearchesOrigin[0].code;\n    }\n\n    this.latestSearchesDestination = this.sortService\n      .sortByObject(latestSearchesDestination, destinationCodes, code)\n      .slice(0, 3);\n  }\n\n  private closeDropdowns(): void {\n    if (this.passengerSelectDropdown) {\n      this.passengerSelectDropdown.open = false;\n    }\n\n    if (this.tripSwitch) {\n      this.tripSwitch.open = false;\n    }\n\n    if (this.transitSwitch) {\n      this.transitSwitch.open = false;\n    }\n  }\n\n  private setInlineFlexWidth() {\n    this.inlineFlex = this.container.nativeElement.offsetWidth > 290 ? this.container.nativeElement.offsetWidth : 0;\n  }\n}\n","<nas-accordion *ngIf=\"deviceHelper?.isMobile() && exists(minimizeOnMobile); else filterTemplate\"\n  simple\n  containerOnToggle\n  transparent\n  [expanded]=\"expandedAccordionMobile\"\n  [title]=\"editSearchTitle\"\n  (toggleChange)=\"onAccordionToggleChange($event)\">\n  <ng-container *ngTemplateOutlet=\"filterTemplate\"></ng-container>\n</nas-accordion>\n<div class=\"container\"\n  *ngIf=\"deviceHelper?.isMobile() && exists(minimizeOnMobile) && displaySummary\">{{getSummary()}}</div>\n\n<ng-template #filterTemplate>\n  <div #container\n    [nasClass]=\"getContainerClass()\">\n    <div [nasClass]=\"getFilterClass('filters', [exists(minimize) && 'minimized', maximize && 'maximize'])\">\n      <ng-container *ngIf=\"airports?.length > 0\">\n        <nas-airport-select-new *ngIf=\"airports && airportRelations && (enableDestinationSelect)\"\n          #airportSelect\n          combo\n          [ariaLabelClear]=\"ariaLabelClear\" \n          [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n          [nasFormGroup]=\"nasFormGroup\"\n          [nasFormControlNameOrigin]=\"nasFormControlNameOrigin\"\n          [nasFormControlNameDestination]=\"nasFormControlNameDestination\"\n          [useSwitch]=\"useSwitch\"\n          [nasClass]=\"getAirportSelectClass()\"\n          [airports]=\"airports\"\n          [allowedOriginAiports]=\"allowedOriginAirports\"\n          [allowedDestinationAirports]=\"allowedDestinationAirports\"\n          [airportRelations]=\"airportRelations\"\n          [latestSearchesOrigin]=\"latestSearchesOrigin\"\n          [latestSearchesDestination]=\"latestSearchesDestination\"\n          [displayLatestSearches]=\"displayLatestSearches\"\n          [displayClosestAirports]=\"displayClosestAirports\"\n          [originAirportCode]=\"originAirportCode\"\n          [destinationAirportCode]=\"destinationAirportCode\"\n          [allAirportsLabel]=\"allAirportsLabel\"\n          [latestSearchesLabel]=\"latestSearchesLabel\"\n          [closestAirportsLabel]=\"closestAirportsLabel\"\n          [closestAirports]=\"closestAirports\"\n          [selectOriginFirstLabel]=\"selectOriginFirstLabel\"\n          [labelOrigin]=\"labelOrigin\"\n          [placeholderOrigin]=\"placeholderOrigin\"\n          [labelDestination]=\"labelDestination\"\n          [geolocationLabel]=\"geolocationLabel\"\n          [geolocationBlockedLabel]=\"geolocationBlockedLabel\"\n          [placeholderDestination]=\"placeholderDestination\"\n          [keepSelection]=\"keepSelection\"\n          [invalidDestinationText]=\"invalidDestinationText\"\n          (originChange)=\"setSelectedOriginAirport($event)\"\n          (destinationChange)=\"onDestinationChange($event)\"\n          (focusOnNext)=\"setFocusOnPassengerSelect($event)\"\n          (originOpenChange)=\"onOriginOpen($event)\"\n          (destinationOpenChange)=\"onDestinationOpen($event)\"\n          (positionChange)=\"getClosestAirports($event)\"></nas-airport-select-new>\n        <nas-airport-select-new *ngIf=\"airports && (!enableDestinationSelect)\"\n          #airportSelect\n          [ariaLabelClear]=\"ariaLabelClear\"\n          [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n          [nasFormGroup]=\"nasFormGroup\"\n          [nasFormControlNameOrigin]=\"nasFormControlNameOrigin\"\n          [useSwitch]=\"useSwitch\"\n          [nasClass]=\"getClass('airport-origin-select')\"\n          [airports]=\"airports\"\n          [allowedOriginAiports]=\"allowedOriginAirports\"\n          [airportRelations]=\"airportRelations\"\n          [latestSearchesOrigin]=\"latestSearchesOrigin\"\n          [displayLatestSearches]=\"displayLatestSearches\"\n          [displayClosestAirports]=\"displayClosestAirports\"\n          [originAirportCode]=\"originAirportCode\"\n          [allAirportsLabel]=\"allAirportsLabel\"\n          [latestSearchesLabel]=\"latestSearchesLabel\"\n          [closestAirportsLabel]=\"closestAirportsLabel\"\n          [closestAirports]=\"closestAirports\"\n          [selectOriginFirstLabel]=\"selectOriginFirstLabel\"\n          [labelOrigin]=\"labelOrigin\"\n          [placeholderOrigin]=\"placeholderOrigin\"\n          [geolocationLabel]=\"geolocationLabel\"\n          [geolocationBlockedLabel]=\"geolocationBlockedLabel\"\n          [keepSelection]=\"keepSelection\"\n          (originChange)=\"setSelectedOriginAirport($event)\"\n          (focusOnNext)=\"setFocusOnPassengerSelect($event)\"\n          (originOpenChange)=\"onOriginOpen($event)\"\n          (positionChange)=\"getClosestAirports($event)\"></nas-airport-select-new>\n        <nas-suggestions *ngIf=\"(closestAirports || latestSearchesOrigin) && exists(enableSuggestions)\"\n          [nasClass]=\"getFilterClass('suggestions')\"\n          [suggestions]=\"getSuggestions()\"\n          [orLabel]=\"orLabel\"\n          (airportSelect)=\"setSelectedOriginAirport($event)\"></nas-suggestions>\n      </ng-container>\n      <ng-container *ngIf=\"shouldMaximize()\">\n        <div [nasClass]=\"!enableDestinationSelect ? getClass('origin-combined') :\n          getTravelDetailsClass('', ['combined', exists(enableDatepickers) && 'no-border', exists(minimize) && 'minimized'])\">\n          <ng-container *ngIf=\"enablePassengersSelect\">\n            <button (click)=\"onPassengerSelectOpen($event)\" [nasClass]=\"getClass('passengers-button', openPassengerSelect && 'active')\">\n              <div [nasClass]=\"getClass('label')\">\n                <p [nasClass]=\"getClass('button-title')\">{{passengersTitleLabel}}</p>\n                <p>{{passengerSelectLabel}}</p>\n              </div>\n              <div [nasClass]=\"getClass('traveler-icon')\"><nas-icon [icon]=\"'my-profile-compact'\" [type]=\"'small'\"></nas-icon></div>\n            </button>\n            <!-- <nas-dropdown #passengerSelectDropdown\n              *ngIf=\"passengers?.length > 0\"\n              [nasClass]=\"getTravelDetailsClass('dropdown', 'passengers')\"\n              [cssClass]=\"getTravelDetailsClass('dropdown')\"\n              [label]=\"passengerSelectLabel\"\n              [labelStyle]=\"{'width': '102px'}\"\n              [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n              (openChange)=\"onPassengerSelectOpen($event)\"\n              (keydown)=\"passengerKeyDown($event)\"> -->\n            <div *ngIf=\"openPassengerSelect\">\n              <nas-passenger-select-new\n                [ariaLabelAdd]=\"ariaLabelAdd\"\n                [ariaLabelSubtract]=\"ariaLabelSubtract\"\n                [adultsLabel]=\"passengerSelectAdultsLabel\"\n                [youthsLabel]=\"passengerSelectYouthsLabel\"\n                [youngAdultsLabel]=\"passengerSelectYoungAdultsLabel\"\n                [childrenLabel]=\"passengerSelectChildrenLabel\"\n                [infantsLabel]=\"passengerSelectInfantsLabel\"\n                [maxPaxCount]=\"maxPaxCount\"\n                [minAdultCount]=\"minAdultCount\"\n                [title]=\"passengerSelectTitle\"\n                [nasFormGroup]=\"nasFormGroup\"\n                [nasFormControlGroupBooking]=\"nasFormControlGroupBooking\"\n                [groupBookingLabel]=\"groupBookingLabel\"\n                [groupBookingLimit]=\"groupBookingLimit\"\n                (focusOnNext)=\"onPassengersSelectFocusOnNext()\"\n                (focusOnPrevious)=\"onPassengersSelectFocusOnPrevious()\"\n                [(passengers)]=\"passengers\"></nas-passenger-select-new>\n                <nas-button-new *ngIf=\"this.openPassengerSelect\" light block \n                  [disabled]=\"passengers[0].count === 0 && passengers[1].count === 0 && passengers[2].count === 0\" (click)=\"openPassengerSelect = false\">\n                  Done\n                </nas-button-new>\n              </div>\n          </ng-container>\n          <ng-container *ngIf=\"enableTripSwitch\">\n            <form [nasClass]=\"getClass('radio')\">\n              <nas-radio-new #tripTypeRoundTrip [name]=\"'tripType'\" [value]=\"2\" [checked]=\"true\" (checkedChange)=\"onTripTypeChange(2)\">\n                {{tripSwitchRoundTripLabel}}\n              </nas-radio-new>\n              <nas-radio-new #tripTypeOneway [name]=\"'tripType'\" [value]=\"1\" (checkedChange)=\"onTripTypeChange(1)\">\n                {{tripSwitchOneWayLabel}}\n              </nas-radio-new>\n            </form>\n          </ng-container>\n          <div *ngIf=\"exists(enableDatepickers)\"\n          [nasClass]=\"getDatePickersClass()\">\n          <nas-datepicker-combo-new #datepickerCombo\n            compact\n            [inlineFlex]=\"inlineFlex\"\n            [nasFormGroup]=\"nasFormGroup\"\n            [nasFormControlNameOutbound]=\"nasFormControlNameOutbound\"\n            [nasFormControlNameInbound]=\"nasFormControlNameInbound\"\n            [availability]=\"availability\"\n            [availableFlightsLabel]=\"availableFlightsLabel\"\n            [dateDisplayFormat]=\"dateDisplayFormat\"\n            [disablePastSelection]=\"disablePastSelection\"\n            [locale]=\"locale\"\n            [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n            [inboundAvailableDates]=\"inboundAvailableDates\"\n            [inboundLabel]=\"inboundLabel\"\n            [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n            [outboundAvailableDates]=\"outboundAvailableDates\"\n            [outboundLabel]=\"outboundLabel\"\n            [timeDisplayFormat]=\"timeDisplayFormat\"\n            [times]=\"times\"\n            [outboundDisabled]=\"outboundDisabled\"\n            [inboundDisabled]=\"inboundDisabled\"\n            [outboundOnly]=\"tripType === 1\"\n            [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n            [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n            [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n            (focusOnNextChange)=\"onFocusOnNextChange($event)\"\n            (focusOnPreviousChange)=\"onDatepickerFocusOnPrevious($event)\"\n            (inboundMonthChange)=\"onInboundMonthChange($event)\"\n            (outboundMonthChange)=\"onOutboundMonthChange($event)\"\n            [(outboundOpen)]=\"outboundOpen\"\n            [(inboundOpen)]=\"inboundOpen\"\n            [(inboundSelectedDate)]=\"inboundSelectedDate\"\n            [(outboundSelectedDate)]=\"outboundSelectedDate\">\n          </nas-datepicker-combo-new>\n        </div>\n        <ng-container *ngIf=\"enableTransitSwitch\">\n          <nas-button-new *ngIf=\"directOnlyLabel && directTransitLabel\"\n            #transitSwitch\n            block\n            light\n            [iconType]=\"'chevron-down'\"\n            [label]=\"getTransitLabel()\"\n            [nasClass]=\"getClass('transit', openTransitTypeSelect && 'active')\"\n            [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n            (click)=\"onTransitSwitchOpen($event)\"\n            (keydown)=\"transitKeyDown($event)\">{{ getTransitLabel() }}\n          </nas-button-new>\n          <div *ngIf=\"openTransitTypeSelect\" [nasClass]=\"getClass('transit-type')\">\n            <button [nasClass]=\"getTravelDetailsClass('action', directOnly && 'active')\"\n              type=\"button\"\n              #transitTypeDirectOnly\n              (click)=\"onTransitChange(true)\">{{ directOnlyLabel }}\n            </button>\n            <button type=\"button\"\n              #transitTypeTransit\n              [nasClass]=\"getTravelDetailsClass('action', !directOnly && 'active')\"\n              (click)=\"onTransitChange(false)\">{{ directTransitLabel }}\n            </button>\n          </div>\n        </ng-container>\n        </div>\n        <div *ngIf=\"subsidyDiscounts && subsidyDiscounts.length > 0\"\n          [nasClass]=\"getFilterClass('subsidy-discount')\">\n          <nas-subsidy-discount #subsidyDiscount\n            [discounts]=\"subsidyDiscounts\"\n            [selectedDiscount]=\"selectedSubsidyDiscount\"\n            [label]=\"subsidyDiscountLabel\"\n            (infoButtonClick)=\"onSubsidyDiscountInfoClick()\"\n            (discountSelectChange)=\"onSubsidyDiscountSelectChange($event)\"\n            (infoButtonKeydown)=\"onSubsidyDiscountInfoButtonKeydown($event)\"></nas-subsidy-discount>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n</ng-template>"]}