@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.
- package/assets/documentation/filter-new/filter-new.md +0 -0
- package/esm2022/lib/components/airport-select-new/airport-select-new.component.mjs +2 -2
- package/esm2022/lib/components/alert/alert.component.mjs +2 -2
- package/esm2022/lib/components/datepicker-combo-new/datepicker-combo-new.component.mjs +1 -1
- package/esm2022/lib/components/filter/index.mjs +1 -2
- package/esm2022/lib/components/filter-new/enums/trip-type.enum.mjs +8 -0
- package/esm2022/lib/components/filter-new/filter-new.component.mjs +1328 -0
- package/esm2022/lib/components/filter-new/filter-new.module.mjs +101 -0
- package/esm2022/lib/components/filter-new/index.mjs +4 -0
- package/esm2022/lib/components/index.mjs +3 -1
- package/esm2022/lib/components/number-field-new/number-field-new.component.mjs +3 -3
- package/esm2022/lib/components/passenger-select/index.mjs +1 -3
- package/esm2022/lib/components/passenger-select-new/enums/passenger-type.enum.mjs +9 -0
- package/esm2022/lib/components/passenger-select-new/index.mjs +5 -0
- package/esm2022/lib/components/passenger-select-new/models/passengers.model.mjs +2 -0
- package/esm2022/lib/components/passenger-select-new/passenger-select-new.component.mjs +417 -0
- package/esm2022/lib/components/passenger-select-new/passenger-select-new.module.mjs +28 -0
- package/fesm2022/norwegian-core-components.mjs +8664 -6835
- package/fesm2022/norwegian-core-components.mjs.map +1 -1
- package/lib/components/datepicker-combo-new/datepicker-combo-new.component.d.ts +2 -2
- package/lib/components/filter/index.d.ts +0 -1
- package/lib/components/filter-new/enums/trip-type.enum.d.ts +6 -0
- package/lib/components/filter-new/filter-new.component.d.ts +829 -0
- package/lib/components/filter-new/filter-new.module.d.ts +27 -0
- package/lib/components/filter-new/index.d.ts +3 -0
- package/lib/components/index.d.ts +2 -0
- package/lib/components/passenger-select/index.d.ts +0 -2
- package/lib/components/passenger-select-new/enums/passenger-type.enum.d.ts +7 -0
- package/lib/components/passenger-select-new/index.d.ts +4 -0
- package/lib/components/passenger-select-new/models/passengers.model.d.ts +10 -0
- package/lib/components/passenger-select-new/passenger-select-new.component.d.ts +141 -0
- package/lib/components/passenger-select-new/passenger-select-new.module.d.ts +10 -0
- 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>"]}
|