@qite/tide-booking-component 1.2.3 → 1.2.5
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/.vs/ProjectSettings.json +3 -3
- package/.vs/VSWorkspaceState.json +5 -5
- package/README.md +8 -8
- package/build/build-cjs/booking-product/components/footer.d.ts +1 -0
- package/build/build-cjs/booking-product/components/rooms.d.ts +2 -0
- package/build/build-cjs/booking-wizard/features/booking/selectors.d.ts +1 -1
- package/build/build-cjs/booking-wizard/features/flight-options/flight-option-flight.d.ts +1 -1
- package/build/build-cjs/booking-wizard/features/flight-options/flight-option.d.ts +1 -1
- package/build/build-cjs/booking-wizard/types.d.ts +5 -0
- package/build/build-cjs/index.js +1453 -735
- package/build/build-cjs/shared/utils/localization-util.d.ts +4 -0
- package/build/build-esm/booking-product/components/footer.d.ts +1 -0
- package/build/build-esm/booking-product/components/rooms.d.ts +2 -0
- package/build/build-esm/booking-wizard/features/booking/selectors.d.ts +1 -1
- package/build/build-esm/booking-wizard/features/flight-options/flight-option-flight.d.ts +1 -1
- package/build/build-esm/booking-wizard/features/flight-options/flight-option.d.ts +1 -1
- package/build/build-esm/booking-wizard/types.d.ts +5 -0
- package/build/build-esm/index.js +1455 -737
- package/build/build-esm/shared/utils/localization-util.d.ts +4 -0
- package/package.json +75 -77
- package/src/booking-product/components/age-select.tsx +35 -41
- package/src/booking-product/components/amount-input.tsx +78 -64
- package/src/booking-product/components/date-range-picker/calendar-day.tsx +58 -54
- package/src/booking-product/components/date-range-picker/calendar.tsx +178 -176
- package/src/booking-product/components/date-range-picker/index.tsx +196 -181
- package/src/booking-product/components/dates.tsx +136 -132
- package/src/booking-product/components/footer.tsx +69 -64
- package/src/booking-product/components/header.tsx +79 -68
- package/src/booking-product/components/icon.tsx +251 -208
- package/src/booking-product/components/product.tsx +314 -277
- package/src/booking-product/components/rooms.tsx +195 -177
- package/src/booking-product/index.tsx +30 -30
- package/src/booking-product/settings-context.ts +14 -14
- package/src/booking-product/types.ts +28 -28
- package/src/booking-product/utils/api.ts +25 -25
- package/src/booking-product/utils/price.ts +29 -27
- package/src/booking-wizard/api-settings-slice.ts +24 -24
- package/src/booking-wizard/components/icon.tsx +508 -60
- package/src/booking-wizard/components/message.tsx +34 -34
- package/src/booking-wizard/components/multi-range-filter.tsx +113 -113
- package/src/booking-wizard/components/product-card.tsx +37 -37
- package/src/booking-wizard/components/step-indicator.tsx +51 -51
- package/src/booking-wizard/components/step-route.tsx +27 -27
- package/src/booking-wizard/declarations.d.ts +4 -4
- package/src/booking-wizard/features/booking/api.ts +49 -45
- package/src/booking-wizard/features/booking/booking-self-contained.tsx +384 -357
- package/src/booking-wizard/features/booking/booking-slice.ts +662 -603
- package/src/booking-wizard/features/booking/booking.tsx +356 -349
- package/src/booking-wizard/features/booking/constants.ts +16 -16
- package/src/booking-wizard/features/booking/selectors.ts +441 -408
- package/src/booking-wizard/features/confirmation/confirmation.tsx +97 -94
- package/src/booking-wizard/features/error/error.tsx +78 -75
- package/src/booking-wizard/features/flight-options/flight-filter.tsx +432 -344
- package/src/booking-wizard/features/flight-options/flight-option-flight.tsx +385 -351
- package/src/booking-wizard/features/flight-options/flight-option-modal.tsx +229 -214
- package/src/booking-wizard/features/flight-options/flight-option.tsx +81 -66
- package/src/booking-wizard/features/flight-options/flight-utils.ts +516 -401
- package/src/booking-wizard/features/flight-options/index.tsx +196 -177
- package/src/booking-wizard/features/price-details/price-details-api.ts +24 -24
- package/src/booking-wizard/features/price-details/price-details-slice.ts +178 -171
- package/src/booking-wizard/features/price-details/util.ts +155 -155
- package/src/booking-wizard/features/product-options/no-options.tsx +21 -21
- package/src/booking-wizard/features/product-options/none-option.tsx +120 -120
- package/src/booking-wizard/features/product-options/option-booking-airline-group.tsx +64 -66
- package/src/booking-wizard/features/product-options/option-booking-group.tsx +216 -210
- package/src/booking-wizard/features/product-options/option-item.tsx +317 -318
- package/src/booking-wizard/features/product-options/option-pax-card.tsx +201 -117
- package/src/booking-wizard/features/product-options/option-pax-group.tsx +175 -169
- package/src/booking-wizard/features/product-options/option-room.tsx +321 -314
- package/src/booking-wizard/features/product-options/option-unit-group.tsx +198 -192
- package/src/booking-wizard/features/product-options/option-units-card.tsx +185 -102
- package/src/booking-wizard/features/product-options/options-form.tsx +459 -437
- package/src/booking-wizard/features/room-options/index.tsx +187 -172
- package/src/booking-wizard/features/room-options/room-utils.ts +190 -143
- package/src/booking-wizard/features/room-options/room.tsx +160 -124
- package/src/booking-wizard/features/room-options/traveler-rooms.tsx +75 -63
- package/src/booking-wizard/features/sidebar/index.tsx +76 -76
- package/src/booking-wizard/features/sidebar/sidebar-flight.tsx +68 -68
- package/src/booking-wizard/features/sidebar/sidebar-util.ts +177 -177
- package/src/booking-wizard/features/sidebar/sidebar.tsx +364 -346
- package/src/booking-wizard/features/summary/summary-booking-option-pax.tsx +25 -25
- package/src/booking-wizard/features/summary/summary-booking-option-unit.tsx +25 -25
- package/src/booking-wizard/features/summary/summary-flight.tsx +39 -39
- package/src/booking-wizard/features/summary/summary-per-booking-option-group.tsx +69 -57
- package/src/booking-wizard/features/summary/summary-per-pax-option-group.tsx +63 -51
- package/src/booking-wizard/features/summary/summary-per-unit-option-group.tsx +66 -54
- package/src/booking-wizard/features/summary/summary-slice.ts +28 -28
- package/src/booking-wizard/features/summary/summary.tsx +674 -641
- package/src/booking-wizard/features/travelers-form/travelers-form-slice.ts +164 -164
- package/src/booking-wizard/features/travelers-form/travelers-form.tsx +754 -755
- package/src/booking-wizard/features/travelers-form/type-ahead-input.tsx +101 -101
- package/src/booking-wizard/features/travelers-form/validate-form.ts +245 -245
- package/src/booking-wizard/index.tsx +36 -36
- package/src/booking-wizard/settings-context.ts +60 -60
- package/src/booking-wizard/store.ts +31 -31
- package/src/booking-wizard/types.ts +276 -271
- package/src/index.ts +4 -5
- package/src/shared/components/loader.tsx +16 -16
- package/src/shared/translations/en-GB.json +232 -0
- package/src/shared/translations/fr-BE.json +233 -233
- package/src/shared/translations/nl-BE.json +232 -232
- package/src/shared/types.ts +4 -4
- package/src/shared/utils/localization-util.ts +62 -56
- package/src/shared/utils/query-string-util.ts +119 -116
- package/src/shared/utils/tide-api-utils.ts +36 -36
- package/styles/booking-product-variables.scss +394 -288
- package/styles/booking-product.scss +446 -440
- package/styles/booking-wizard-variables.scss +871 -0
- package/styles/booking-wizard.scss +59 -4
- package/styles/components/_animations.scss +39 -39
- package/styles/components/_base.scss +107 -106
- package/styles/components/_booking.scss +879 -0
- package/styles/components/_button.scss +238 -185
- package/styles/components/_checkbox.scss +219 -0
- package/styles/components/_cta.scss +208 -67
- package/styles/components/_date-list.scss +41 -0
- package/styles/components/_date-range-picker.scss +225 -224
- package/styles/components/_decrement-increment.scss +35 -37
- package/styles/components/_dropdown.scss +72 -74
- package/styles/components/_flight-option.scss +1429 -0
- package/styles/components/_form.scss +1583 -136
- package/styles/components/_info-message.scss +71 -0
- package/styles/components/_input.scss +25 -0
- package/styles/components/_list.scss +187 -0
- package/styles/components/_loader.scss +72 -71
- package/styles/components/_mixins.scss +550 -518
- package/styles/components/_placeholders.scss +166 -166
- package/styles/components/_pricing-summary.scss +155 -0
- package/styles/components/_qsm.scss +17 -20
- package/styles/components/_radiobutton.scss +170 -0
- package/styles/components/_select-wrapper.scss +80 -0
- package/styles/components/_spinner.scss +29 -0
- package/styles/components/_step-indicators.scss +168 -0
- package/styles/components/_table.scss +81 -0
- package/styles/components/_tree.scss +530 -0
- package/styles/components/_typeahead.scss +281 -0
- package/styles/components/_variables.scss +89 -89
|
@@ -1,351 +1,385 @@
|
|
|
1
|
-
import React, { useState } from
|
|
2
|
-
import { useSelector } from "react-redux";
|
|
3
|
-
import { buildClassName } from
|
|
4
|
-
import { GroupedFlightDetails } from "../../types";
|
|
5
|
-
import { selectTranslations } from "../booking/selectors";
|
|
6
|
-
import { getDateText } from
|
|
7
|
-
import Icon from
|
|
8
|
-
|
|
9
|
-
interface FlightOptionFlightProps {
|
|
10
|
-
details: GroupedFlightDetails
|
|
11
|
-
isOptionsVisible: boolean;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const FlightOptionFlight: React.FC<FlightOptionFlightProps> = ({
|
|
15
|
-
details,
|
|
16
|
-
isOptionsVisible
|
|
17
|
-
}) => {
|
|
18
|
-
const translations = useSelector(selectTranslations);
|
|
19
|
-
|
|
20
|
-
const [isDetailVisible, setIsDetailVisible] = useState<boolean>(false);
|
|
21
|
-
|
|
22
|
-
return (
|
|
23
|
-
<div className="flight__flight">
|
|
24
|
-
<div className="flight__flight__container">
|
|
25
|
-
<div className="flight__flight__wrapper">
|
|
26
|
-
<div className="flight__logo__wrapper">
|
|
27
|
-
<img
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
<div className="
|
|
36
|
-
<
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
</
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
</
|
|
96
|
-
<
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
</div>
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
</
|
|
146
|
-
<
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
<div className="
|
|
151
|
-
<
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
<div className="
|
|
155
|
-
<span
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
<
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
</
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
<
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
<
|
|
223
|
-
|
|
224
|
-
<
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
<
|
|
230
|
-
|
|
231
|
-
<
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
<
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
<
|
|
274
|
-
|
|
275
|
-
<
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
<
|
|
281
|
-
|
|
282
|
-
<
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
<
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
<
|
|
325
|
-
|
|
326
|
-
<
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
<
|
|
332
|
-
|
|
333
|
-
<
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
1
|
+
import React, { useState } from "react";
|
|
2
|
+
import { useSelector } from "react-redux";
|
|
3
|
+
import { buildClassName } from "../../../shared/utils/class-util";
|
|
4
|
+
import { GroupedFlightDetails } from "../../types";
|
|
5
|
+
import { selectTranslations } from "../booking/selectors";
|
|
6
|
+
import { getDateText } from "../sidebar/sidebar-util";
|
|
7
|
+
import Icon from "../../components/icon";
|
|
8
|
+
|
|
9
|
+
interface FlightOptionFlightProps {
|
|
10
|
+
details: GroupedFlightDetails;
|
|
11
|
+
isOptionsVisible: boolean;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
const FlightOptionFlight: React.FC<FlightOptionFlightProps> = ({
|
|
15
|
+
details,
|
|
16
|
+
isOptionsVisible,
|
|
17
|
+
}) => {
|
|
18
|
+
const translations = useSelector(selectTranslations);
|
|
19
|
+
|
|
20
|
+
const [isDetailVisible, setIsDetailVisible] = useState<boolean>(false);
|
|
21
|
+
|
|
22
|
+
return (
|
|
23
|
+
<div className="flight__flight">
|
|
24
|
+
<div className="flight__flight__container">
|
|
25
|
+
<div className="flight__flight__wrapper">
|
|
26
|
+
<div className="flight__logo__wrapper">
|
|
27
|
+
<img
|
|
28
|
+
src={`https://media.tidesoftware.be/media/shared/Airlines/${details.airlineCode}.png?height=256`}
|
|
29
|
+
alt=""
|
|
30
|
+
className="flight__logo"
|
|
31
|
+
/>
|
|
32
|
+
<span>{details.airline}</span>
|
|
33
|
+
</div>
|
|
34
|
+
<div className="flight__info">
|
|
35
|
+
<div className="flight__info__times">
|
|
36
|
+
<strong>
|
|
37
|
+
{details.departureTime} {details.departureAirport}
|
|
38
|
+
</strong>
|
|
39
|
+
<p>{getDateText(details.departureDate)}</p>
|
|
40
|
+
</div>
|
|
41
|
+
<div className="flight__info__duration">
|
|
42
|
+
<p>{details.travelDuration}</p>
|
|
43
|
+
<div className="flight__info__duration__stops">
|
|
44
|
+
<div className="flight__info__duration__stop"></div>
|
|
45
|
+
</div>
|
|
46
|
+
{details.numberOfStops > 0 && (
|
|
47
|
+
<span>
|
|
48
|
+
{details.numberOfStops}{" "}
|
|
49
|
+
{translations.FLIGHTS_FORM.FLIGHT_STOPS}
|
|
50
|
+
</span>
|
|
51
|
+
)}
|
|
52
|
+
</div>
|
|
53
|
+
<div className="flight__info__times flight__info__times--arrival">
|
|
54
|
+
<strong>
|
|
55
|
+
{details.arrivalTime} {details.arrivalAirport}
|
|
56
|
+
</strong>
|
|
57
|
+
<p>{getDateText(details.arrivalDate)}</p>
|
|
58
|
+
{details.isNextDay && (
|
|
59
|
+
<span className="flight__info__times__days">
|
|
60
|
+
{translations.FLIGHTS_FORM.PLUS_ONE_DAY}
|
|
61
|
+
</span>
|
|
62
|
+
)}
|
|
63
|
+
</div>
|
|
64
|
+
</div>
|
|
65
|
+
</div>
|
|
66
|
+
<div className="flight__detail__btn__wrapper">
|
|
67
|
+
<div
|
|
68
|
+
className={buildClassName([
|
|
69
|
+
"flight__detail__btn",
|
|
70
|
+
isDetailVisible && "flight__detail__btn--active",
|
|
71
|
+
])}
|
|
72
|
+
onClick={() => setIsDetailVisible(!isDetailVisible)}
|
|
73
|
+
>
|
|
74
|
+
<Icon
|
|
75
|
+
name="ui-chevron"
|
|
76
|
+
className="flight__detail__btn__arrow"
|
|
77
|
+
width={16}
|
|
78
|
+
height={16}
|
|
79
|
+
/>
|
|
80
|
+
</div>
|
|
81
|
+
</div>
|
|
82
|
+
</div>
|
|
83
|
+
<div
|
|
84
|
+
className={buildClassName([
|
|
85
|
+
"flight__detail",
|
|
86
|
+
isDetailVisible && "flight__detail--active",
|
|
87
|
+
])}
|
|
88
|
+
>
|
|
89
|
+
{details.flightLines.map((flightLine, flightLineIndex) => (
|
|
90
|
+
<React.Fragment key={flightLineIndex}>
|
|
91
|
+
<div className="flight__info">
|
|
92
|
+
<div className="flight__info__times__wrapper">
|
|
93
|
+
<div className="flight__info__times">
|
|
94
|
+
<p>{flightLine.departureTime}</p>
|
|
95
|
+
<strong>{flightLine.departureAirport}</strong>
|
|
96
|
+
<p>{getDateText(flightLine.departureDate)}</p>
|
|
97
|
+
</div>
|
|
98
|
+
<div>
|
|
99
|
+
<Icon name="ui-plane-depart" width={30} height={20} />
|
|
100
|
+
</div>
|
|
101
|
+
</div>
|
|
102
|
+
<div className="flight__info__duration">
|
|
103
|
+
<p>{flightLine.travelDuration}</p>
|
|
104
|
+
<div className="flight__info__duration__stops"></div>
|
|
105
|
+
<span>{flightLine.airline}</span>
|
|
106
|
+
<strong>{flightLine.number}</strong>
|
|
107
|
+
</div>
|
|
108
|
+
<div className="flight__info__times__wrapper flight__info__times__wrapper--arrival">
|
|
109
|
+
<div>
|
|
110
|
+
<Icon name="ui-plane-arrive" width={30} height={20} />
|
|
111
|
+
</div>
|
|
112
|
+
<div className="flight__info__times flight__info__times--arrival">
|
|
113
|
+
<p>{flightLine.arrivalTime}</p>
|
|
114
|
+
<strong>{flightLine.arrivalAirport}</strong>
|
|
115
|
+
<p>{getDateText(flightLine.arrivalDate)}</p>
|
|
116
|
+
</div>
|
|
117
|
+
</div>
|
|
118
|
+
</div>
|
|
119
|
+
{flightLine.waitDuration && (
|
|
120
|
+
<div className="flight__info">
|
|
121
|
+
<div className="flight__info__times"></div>
|
|
122
|
+
<div className="flight__info__duration flight__info__duration--waittime">
|
|
123
|
+
<div className="flight__info__duration__stops flight__info__duration__stops--stoptime">
|
|
124
|
+
<Icon name="ui-clock" width={24} height={24} />
|
|
125
|
+
</div>
|
|
126
|
+
<div className="flight__info__duration__stoptime">
|
|
127
|
+
<span>{translations.FLIGHTS_FORM.STOP_TIME}</span>
|
|
128
|
+
<strong>{flightLine.waitDuration}</strong>
|
|
129
|
+
</div>
|
|
130
|
+
</div>
|
|
131
|
+
<div className="flight__info__times flight__info__times--arrival"></div>
|
|
132
|
+
</div>
|
|
133
|
+
)}
|
|
134
|
+
</React.Fragment>
|
|
135
|
+
))}
|
|
136
|
+
</div>
|
|
137
|
+
<div
|
|
138
|
+
className={buildClassName([
|
|
139
|
+
"flight__rate",
|
|
140
|
+
isOptionsVisible && "flight__rate--active",
|
|
141
|
+
])}
|
|
142
|
+
>
|
|
143
|
+
{/*<div className="flight__rate__container">
|
|
144
|
+
<div className="flight__rate__title">
|
|
145
|
+
<h2><strong>{translations.FLIGHTS_FORM.OUTWARD_FLIGHT}</strong></h2>
|
|
146
|
+
<h2>{translations.FLIGHTS_FORM.CHOOSE_YOUR_CLASS}</h2>
|
|
147
|
+
</div>
|
|
148
|
+
<div className="flight__rate__wrapper">
|
|
149
|
+
<div className={`flight__rate__card ${isCardActive ? 'flight__rate__card--active' : ''}`} onClick={handleCardButtonClick}>
|
|
150
|
+
<div className="flight__rate__card__header">
|
|
151
|
+
<h3 className="flight__rate__card__header__title">Economy</h3>
|
|
152
|
+
</div>
|
|
153
|
+
<div className="flight__rate__card__content">
|
|
154
|
+
<div className="flight__rate__card__chairs">
|
|
155
|
+
<span>nog 2 stoelen vrij</span>
|
|
156
|
+
</div>
|
|
157
|
+
<div className="flight__rate__card__lowest">
|
|
158
|
+
<span>Laagste prijs</span>
|
|
159
|
+
</div>
|
|
160
|
+
<div className="flight__rate__card__item">
|
|
161
|
+
<span>€ 275 p.p</span>
|
|
162
|
+
<Icon name="chevron" width={20} height={20} />
|
|
163
|
+
</div>
|
|
164
|
+
</div>
|
|
165
|
+
</div>
|
|
166
|
+
<div className={`flight__rate__card flight__rate__card--premium ${isCard2Active ? 'flight__rate__card--premium--active' : ''}`} onClick={handleCard2ButtonClick}>
|
|
167
|
+
<div className="flight__rate__card__header">
|
|
168
|
+
<h3 className="flight__rate__card__header__title">Economy premium</h3>
|
|
169
|
+
</div>
|
|
170
|
+
<div className="flight__rate__card__content">
|
|
171
|
+
<div className="flight__rate__card__chairs">
|
|
172
|
+
<span>nog 2 stoelen vrij</span>
|
|
173
|
+
</div>
|
|
174
|
+
<div className="flight__rate__card__item">
|
|
175
|
+
<span>€ 960 p.p</span>
|
|
176
|
+
<Icon name="chevron" width={20} height={20} />
|
|
177
|
+
</div>
|
|
178
|
+
</div>
|
|
179
|
+
</div>
|
|
180
|
+
<div className={`flight__rate__card flight__rate__card--business ${isCard3Active ? 'flight__rate__card--business--active' : ''}`} onClick={handleCard3ButtonClick}>
|
|
181
|
+
<div className="flight__rate__card__header">
|
|
182
|
+
<h3 className="flight__rate__card__header__title">Business</h3>
|
|
183
|
+
</div>
|
|
184
|
+
<div className="flight__rate__card__content">
|
|
185
|
+
<div className="flight__rate__card__chairs">
|
|
186
|
+
<span>nog 2 stoelen vrij</span>
|
|
187
|
+
</div>
|
|
188
|
+
<div className="flight__rate__card__item">
|
|
189
|
+
<span>€ 3.060 p.p</span>
|
|
190
|
+
<Icon name="chevron" width={20} height={20} />
|
|
191
|
+
</div>
|
|
192
|
+
</div>
|
|
193
|
+
</div>
|
|
194
|
+
</div>
|
|
195
|
+
</div>
|
|
196
|
+
<div className={`flight__rate__detail ${isCardActive ? 'flight__rate__detail--active' : ''}`}>
|
|
197
|
+
<div className="flight__rate__modal__card">
|
|
198
|
+
<div className="flight__rate__modal__card__wrapper">
|
|
199
|
+
<div className="flight__rate__modal__card__header">
|
|
200
|
+
<h3 className="flight__rate__modal__card__header__title">Economy Basic</h3>
|
|
201
|
+
<p className="flight__rate__modal__card__header__class">Klasse: Economy</p>
|
|
202
|
+
</div>
|
|
203
|
+
<div className="flight__rate__modal__card__items flight__rate__modal__card__items--top">
|
|
204
|
+
<div className="flight__rate__modal__card__item flight__rate__modal__card__item--disabled">
|
|
205
|
+
<Icon name="ticket" width={20} height={20} />
|
|
206
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
207
|
+
<strong>Wijzigingen in het ticket</strong>
|
|
208
|
+
<p>Wijzigingen toestaan</p>
|
|
209
|
+
</div>
|
|
210
|
+
</div>
|
|
211
|
+
<div className="flight__rate__modal__card__item flight__rate__modal__card__item--disabled">
|
|
212
|
+
<Icon name="payback" width={20} height={20} />
|
|
213
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
214
|
+
<strong>Terugbetaling van ticket</strong>
|
|
215
|
+
<p>Ticket retourneerbaar</p>
|
|
216
|
+
</div>
|
|
217
|
+
</div>
|
|
218
|
+
</div>
|
|
219
|
+
<div className="flight__rate__modal__card__items">
|
|
220
|
+
<div className="flight__rate__modal__card__item">
|
|
221
|
+
<Icon name="shopping-bag" width={20} height={20} />
|
|
222
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
223
|
+
<strong>persoonlijke items</strong>
|
|
224
|
+
<p>Gratis</p>
|
|
225
|
+
</div>
|
|
226
|
+
</div>
|
|
227
|
+
<div className="flight__rate__modal__card__item">
|
|
228
|
+
<Icon name="backpack" width={20} height={20} />
|
|
229
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
230
|
+
<strong>Handbagage</strong>
|
|
231
|
+
<p>Gratis: 2 x 8kg</p>
|
|
232
|
+
</div>
|
|
233
|
+
</div>
|
|
234
|
+
<div className="flight__rate__modal__card__item">
|
|
235
|
+
<Icon name="suitcase" width={20} height={20} />
|
|
236
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
237
|
+
<strong>Ingecheckte bagage</strong>
|
|
238
|
+
<p>Gratis: 2 x 32kg</p>
|
|
239
|
+
</div>
|
|
240
|
+
</div>
|
|
241
|
+
</div>
|
|
242
|
+
</div>
|
|
243
|
+
<div className="flight__rate__modal__card__footer">
|
|
244
|
+
<button className="cta cta--secondary">Selecteer</button>
|
|
245
|
+
<span className="price price--increase">€2.460</span>
|
|
246
|
+
</div>
|
|
247
|
+
</div>
|
|
248
|
+
<div className="flight__rate__modal__card flight__rate__modal__card--premium">
|
|
249
|
+
<div className="flight__rate__modal__card__wrapper">
|
|
250
|
+
<div className="flight__rate__modal__card__header">
|
|
251
|
+
<h3 className="flight__rate__modal__card__header__title">Premium Economy Basic Plus</h3>
|
|
252
|
+
<p className="flight__rate__modal__card__header__class">Klasse: Economy</p>
|
|
253
|
+
</div>
|
|
254
|
+
<div className="flight__rate__modal__card__items flight__rate__modal__card__items--top">
|
|
255
|
+
<div className="flight__rate__modal__card__item">
|
|
256
|
+
<Icon name="ticket" width={20} height={20} />
|
|
257
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
258
|
+
<strong>Wijzigingen in het ticket</strong>
|
|
259
|
+
<p>Wijzigingen toestaan</p>
|
|
260
|
+
</div>
|
|
261
|
+
</div>
|
|
262
|
+
<div className="flight__rate__modal__card__item">
|
|
263
|
+
<Icon name="payback" width={20} height={20} />
|
|
264
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
265
|
+
<strong>Terugbetaling van ticket</strong>
|
|
266
|
+
<p>Ticket retourneerbaar</p>
|
|
267
|
+
</div>
|
|
268
|
+
</div>
|
|
269
|
+
</div>
|
|
270
|
+
<div className="flight__rate__modal__card__items">
|
|
271
|
+
<div className="flight__rate__modal__card__item">
|
|
272
|
+
<Icon name="shopping-bag width={20} height={20}" />
|
|
273
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
274
|
+
<strong>persoonlijke items</strong>
|
|
275
|
+
<p>Gratis</p>
|
|
276
|
+
</div>
|
|
277
|
+
</div>
|
|
278
|
+
<div className="flight__rate__modal__card__item">
|
|
279
|
+
<Icon name="backpack" width={20} height={20} />
|
|
280
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
281
|
+
<strong>Handbagage</strong>
|
|
282
|
+
<p>Gratis: 2 x 8kg</p>
|
|
283
|
+
</div>
|
|
284
|
+
</div>
|
|
285
|
+
<div className="flight__rate__modal__card__item">
|
|
286
|
+
<Icon name="suitcase" width={20} height={20} />
|
|
287
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
288
|
+
<strong>Ingecheckte bagage</strong>
|
|
289
|
+
<p>Gratis: 2 x 32kg</p>
|
|
290
|
+
</div>
|
|
291
|
+
</div>
|
|
292
|
+
</div>
|
|
293
|
+
</div>
|
|
294
|
+
<div className="flight__rate__modal__card__footer">
|
|
295
|
+
<button className="cta cta--secondary">Selecteer</button>
|
|
296
|
+
<span className="price price--increase">€.2460</span>
|
|
297
|
+
</div>
|
|
298
|
+
</div>
|
|
299
|
+
<div className="flight__rate__modal__card flight__rate__modal__card--business">
|
|
300
|
+
<div className="flight__rate__modal__card__wrapper">
|
|
301
|
+
<div className="flight__rate__modal__card__header">
|
|
302
|
+
<h3 className="flight__rate__modal__card__header__title">Business Basic Plus</h3>
|
|
303
|
+
<p className="flight__rate__modal__card__header__class">Klasse: Economy</p>
|
|
304
|
+
</div>
|
|
305
|
+
<div className="flight__rate__modal__card__items flight__rate__modal__card__items--top">
|
|
306
|
+
<div className="flight__rate__modal__card__item">
|
|
307
|
+
<Icon name="ticket" width={20} height={20} />
|
|
308
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
309
|
+
<strong>Wijzigingen in het ticket</strong>
|
|
310
|
+
<p>Wijzigingen toestaan</p>
|
|
311
|
+
</div>
|
|
312
|
+
</div>
|
|
313
|
+
<div className="flight__rate__modal__card__item flight__rate__modal__card__item--disabled">
|
|
314
|
+
<Icon name="payback" width={20} height={20} />
|
|
315
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
316
|
+
<strong>Terugbetaling van ticket</strong>
|
|
317
|
+
<p>Ticket retourneerbaar</p>
|
|
318
|
+
</div>
|
|
319
|
+
</div>
|
|
320
|
+
</div>
|
|
321
|
+
<div className="flight__rate__modal__card__items">
|
|
322
|
+
<div className="flight__rate__modal__card__item">
|
|
323
|
+
<Icon name="shopping-bag" width={20} height={20} />
|
|
324
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
325
|
+
<strong>persoonlijke items</strong>
|
|
326
|
+
<p>Gratis</p>
|
|
327
|
+
</div>
|
|
328
|
+
</div>
|
|
329
|
+
<div className="flight__rate__modal__card__item">
|
|
330
|
+
<Icon name="backpack" width={20} height={20} />
|
|
331
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
332
|
+
<strong>Handbagage</strong>
|
|
333
|
+
<p>Gratis: 2 x 8kg</p>
|
|
334
|
+
</div>
|
|
335
|
+
</div>
|
|
336
|
+
<div className="flight__rate__modal__card__item">
|
|
337
|
+
<Icon name="suitcase" width={20} height={20} />
|
|
338
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
339
|
+
<strong>Ingecheckte bagage</strong>
|
|
340
|
+
<p>Gratis: 2 x 32kg</p>
|
|
341
|
+
</div>
|
|
342
|
+
</div>
|
|
343
|
+
<div className="flight__rate__modal__card__item">
|
|
344
|
+
<Icon name="seat-selection" width={20} height={20} />
|
|
345
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
346
|
+
<strong>Stoelselectie</strong>
|
|
347
|
+
<p>kies uw stoel in het vliegtijg</p>
|
|
348
|
+
</div>
|
|
349
|
+
</div>
|
|
350
|
+
<div className="flight__rate__modal__card__item">
|
|
351
|
+
<Icon name="check-in" width={20} height={20} />
|
|
352
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
353
|
+
<strong>Sneller inchecken</strong>
|
|
354
|
+
<p>Sla de wachtrijen voor de veiligheidscontrole over</p>
|
|
355
|
+
</div>
|
|
356
|
+
</div>
|
|
357
|
+
<div className="flight__rate__modal__card__item">
|
|
358
|
+
<Icon name="business-lounge" width={20} height={20} />
|
|
359
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
360
|
+
<strong>Zakenlunge</strong>
|
|
361
|
+
<p>Ontspan voor uw vlucht</p>
|
|
362
|
+
</div>
|
|
363
|
+
</div>
|
|
364
|
+
<div className="flight__rate__modal__card__item">
|
|
365
|
+
<Icon name="priority" width={20} height={20} />
|
|
366
|
+
<div className="flight__rate__modal__card__item__wrapper">
|
|
367
|
+
<strong>Prioriteit</strong>
|
|
368
|
+
<p>Stap voor anderen aan boord</p>
|
|
369
|
+
</div>
|
|
370
|
+
</div>
|
|
371
|
+
</div>
|
|
372
|
+
</div>
|
|
373
|
+
<div className="flight__rate__modal__card__footer">
|
|
374
|
+
<button className="cta cta--secondary">Selecteer</button>
|
|
375
|
+
<span className="price price--increase">+ €2.460</span>
|
|
376
|
+
</div>
|
|
377
|
+
</div>
|
|
378
|
+
</div>
|
|
379
|
+
*/}
|
|
380
|
+
</div>
|
|
381
|
+
</div>
|
|
382
|
+
);
|
|
383
|
+
};
|
|
384
|
+
|
|
385
|
+
export default FlightOptionFlight;
|