@qite/tide-booking-component 1.3.1 → 1.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (305) hide show
  1. package/.vs/ProjectSettings.json +3 -3
  2. package/.vs/VSWorkspaceState.json +5 -5
  3. package/README.md +8 -8
  4. package/build/build-cjs/booking-product/components/age-select.d.ts +8 -8
  5. package/build/build-cjs/booking-product/components/amount-input.d.ts +10 -10
  6. package/build/build-cjs/booking-product/components/date-range-picker/calendar-day.d.ts +12 -12
  7. package/build/build-cjs/booking-product/components/date-range-picker/calendar.d.ts +19 -19
  8. package/build/build-cjs/booking-product/components/date-range-picker/index.d.ts +20 -23
  9. package/build/build-cjs/booking-product/components/dates.d.ts +9 -9
  10. package/build/build-cjs/booking-product/components/footer.d.ts +10 -10
  11. package/build/build-cjs/booking-product/components/header.d.ts +11 -11
  12. package/build/build-cjs/booking-product/components/icon.d.ts +10 -10
  13. package/build/build-cjs/booking-product/components/product.d.ts +9 -9
  14. package/build/build-cjs/booking-product/components/rating.d.ts +6 -6
  15. package/build/build-cjs/booking-product/components/rooms.d.ts +10 -10
  16. package/build/build-cjs/booking-product/index.d.ts +10 -10
  17. package/build/build-cjs/booking-product/settings-context.d.ts +5 -6
  18. package/build/build-cjs/booking-product/types.d.ts +25 -25
  19. package/build/build-cjs/booking-product/utils/api.d.ts +16 -6
  20. package/build/build-cjs/booking-product/utils/price.d.ts +9 -1
  21. package/build/build-cjs/booking-wizard/api-settings-slice.d.ts +14 -4
  22. package/build/build-cjs/booking-wizard/components/icon.d.ts +10 -10
  23. package/build/build-cjs/booking-wizard/components/labeled-input.d.ts +18 -18
  24. package/build/build-cjs/booking-wizard/components/labeled-select.d.ts +21 -21
  25. package/build/build-cjs/booking-wizard/components/message.d.ts +9 -9
  26. package/build/build-cjs/booking-wizard/components/multi-range-filter.d.ts +11 -11
  27. package/build/build-cjs/booking-wizard/components/print-offer-button.d.ts +17 -17
  28. package/build/build-cjs/booking-wizard/components/product-card.d.ts +8 -8
  29. package/build/build-cjs/booking-wizard/components/step-indicator.d.ts +6 -6
  30. package/build/build-cjs/booking-wizard/components/step-route.d.ts +9 -9
  31. package/build/build-cjs/booking-wizard/features/booking/api.d.ts +29 -10
  32. package/build/build-cjs/booking-wizard/features/booking/booking-self-contained.d.ts +8 -8
  33. package/build/build-cjs/booking-wizard/features/booking/booking-slice.d.ts +177 -46
  34. package/build/build-cjs/booking-wizard/features/booking/booking.d.ts +8 -8
  35. package/build/build-cjs/booking-wizard/features/booking/constants.d.ts +15 -8
  36. package/build/build-cjs/booking-wizard/features/booking/selectors.d.ts +308 -136
  37. package/build/build-cjs/booking-wizard/features/confirmation/confirmation.d.ts +4 -5
  38. package/build/build-cjs/booking-wizard/features/error/error.d.ts +4 -5
  39. package/build/build-cjs/booking-wizard/features/flight-options/flight-filter.d.ts +9 -9
  40. package/build/build-cjs/booking-wizard/features/flight-options/flight-option-flight.d.ts +8 -8
  41. package/build/build-cjs/booking-wizard/features/flight-options/flight-option-modal.d.ts +3 -3
  42. package/build/build-cjs/booking-wizard/features/flight-options/flight-option.d.ts +10 -10
  43. package/build/build-cjs/booking-wizard/features/flight-options/flight-utils.d.ts +16 -6
  44. package/build/build-cjs/booking-wizard/features/flight-options/index.d.ts +4 -5
  45. package/build/build-cjs/booking-wizard/features/price-details/price-details-api.d.ts +15 -6
  46. package/build/build-cjs/booking-wizard/features/price-details/price-details-slice.d.ts +121 -80
  47. package/build/build-cjs/booking-wizard/features/price-details/util.d.ts +5 -2
  48. package/build/build-cjs/booking-wizard/features/product-options/no-options.d.ts +3 -3
  49. package/build/build-cjs/booking-wizard/features/product-options/none-option.d.ts +17 -9
  50. package/build/build-cjs/booking-wizard/features/product-options/option-booking-airline-group.d.ts +17 -8
  51. package/build/build-cjs/booking-wizard/features/product-options/option-booking-group.d.ts +18 -12
  52. package/build/build-cjs/booking-wizard/features/product-options/option-item.d.ts +11 -11
  53. package/build/build-cjs/booking-wizard/features/product-options/option-pax-card.d.ts +13 -10
  54. package/build/build-cjs/booking-wizard/features/product-options/option-pax-group.d.ts +20 -13
  55. package/build/build-cjs/booking-wizard/features/product-options/option-room.d.ts +18 -10
  56. package/build/build-cjs/booking-wizard/features/product-options/option-unit-group.d.ts +20 -13
  57. package/build/build-cjs/booking-wizard/features/product-options/option-units-card.d.ts +9 -9
  58. package/build/build-cjs/booking-wizard/features/product-options/options-form.d.ts +4 -5
  59. package/build/build-cjs/booking-wizard/features/room-options/index.d.ts +4 -5
  60. package/build/build-cjs/booking-wizard/features/room-options/room-utils.d.ts +29 -9
  61. package/build/build-cjs/booking-wizard/features/room-options/room.d.ts +15 -12
  62. package/build/build-cjs/booking-wizard/features/room-options/traveler-rooms.d.ts +13 -9
  63. package/build/build-cjs/booking-wizard/features/sidebar/index.d.ts +7 -7
  64. package/build/build-cjs/booking-wizard/features/sidebar/sidebar-flight.d.ts +8 -8
  65. package/build/build-cjs/booking-wizard/features/sidebar/sidebar-util.d.ts +31 -12
  66. package/build/build-cjs/booking-wizard/features/sidebar/sidebar.d.ts +29 -25
  67. package/build/build-cjs/booking-wizard/features/summary/summary-booking-option-pax.d.ts +7 -7
  68. package/build/build-cjs/booking-wizard/features/summary/summary-booking-option-unit.d.ts +7 -7
  69. package/build/build-cjs/booking-wizard/features/summary/summary-flight.d.ts +8 -8
  70. package/build/build-cjs/booking-wizard/features/summary/summary-per-booking-option-group.d.ts +10 -7
  71. package/build/build-cjs/booking-wizard/features/summary/summary-per-pax-option-group.d.ts +10 -7
  72. package/build/build-cjs/booking-wizard/features/summary/summary-per-unit-option-group.d.ts +10 -7
  73. package/build/build-cjs/booking-wizard/features/summary/summary-slice.d.ts +14 -8
  74. package/build/build-cjs/booking-wizard/features/summary/summary.d.ts +4 -5
  75. package/build/build-cjs/booking-wizard/features/travelers-form/travelers-form-slice.d.ts +75 -49
  76. package/build/build-cjs/booking-wizard/features/travelers-form/travelers-form.d.ts +4 -5
  77. package/build/build-cjs/booking-wizard/features/travelers-form/type-ahead-input.d.ts +16 -16
  78. package/build/build-cjs/booking-wizard/features/travelers-form/validate-form.d.ts +9 -4
  79. package/build/build-cjs/booking-wizard/index.d.ts +12 -12
  80. package/build/build-cjs/booking-wizard/settings-context.d.ts +5 -6
  81. package/build/build-cjs/booking-wizard/store.d.ts +44 -24
  82. package/build/build-cjs/booking-wizard/types.d.ts +253 -257
  83. package/build/build-cjs/booking-wizard/use-offer-printer.d.ts +19 -13
  84. package/build/build-cjs/index.d.ts +3 -3
  85. package/build/build-cjs/index.js +16348 -7394
  86. package/build/build-cjs/shared/components/loader.d.ts +6 -6
  87. package/build/build-cjs/shared/types.d.ts +4 -4
  88. package/build/build-cjs/shared/utils/class-util.d.ts +1 -1
  89. package/build/build-cjs/shared/utils/localization-util.d.ts +248 -248
  90. package/build/build-cjs/shared/utils/query-string-util.d.ts +29 -8
  91. package/build/build-cjs/shared/utils/tide-api-utils.d.ts +6 -4
  92. package/build/build-esm/booking-product/components/age-select.d.ts +8 -8
  93. package/build/build-esm/booking-product/components/amount-input.d.ts +10 -10
  94. package/build/build-esm/booking-product/components/date-range-picker/calendar-day.d.ts +12 -12
  95. package/build/build-esm/booking-product/components/date-range-picker/calendar.d.ts +19 -19
  96. package/build/build-esm/booking-product/components/date-range-picker/index.d.ts +20 -23
  97. package/build/build-esm/booking-product/components/dates.d.ts +9 -9
  98. package/build/build-esm/booking-product/components/footer.d.ts +10 -10
  99. package/build/build-esm/booking-product/components/header.d.ts +11 -11
  100. package/build/build-esm/booking-product/components/icon.d.ts +10 -10
  101. package/build/build-esm/booking-product/components/product.d.ts +9 -9
  102. package/build/build-esm/booking-product/components/rating.d.ts +6 -6
  103. package/build/build-esm/booking-product/components/rooms.d.ts +10 -10
  104. package/build/build-esm/booking-product/index.d.ts +10 -10
  105. package/build/build-esm/booking-product/settings-context.d.ts +5 -6
  106. package/build/build-esm/booking-product/types.d.ts +25 -25
  107. package/build/build-esm/booking-product/utils/api.d.ts +16 -6
  108. package/build/build-esm/booking-product/utils/price.d.ts +9 -1
  109. package/build/build-esm/booking-wizard/api-settings-slice.d.ts +14 -4
  110. package/build/build-esm/booking-wizard/components/icon.d.ts +10 -10
  111. package/build/build-esm/booking-wizard/components/labeled-input.d.ts +18 -18
  112. package/build/build-esm/booking-wizard/components/labeled-select.d.ts +21 -21
  113. package/build/build-esm/booking-wizard/components/message.d.ts +9 -9
  114. package/build/build-esm/booking-wizard/components/multi-range-filter.d.ts +11 -11
  115. package/build/build-esm/booking-wizard/components/print-offer-button.d.ts +17 -17
  116. package/build/build-esm/booking-wizard/components/product-card.d.ts +8 -8
  117. package/build/build-esm/booking-wizard/components/step-indicator.d.ts +6 -6
  118. package/build/build-esm/booking-wizard/components/step-route.d.ts +9 -9
  119. package/build/build-esm/booking-wizard/features/booking/api.d.ts +29 -10
  120. package/build/build-esm/booking-wizard/features/booking/booking-self-contained.d.ts +8 -8
  121. package/build/build-esm/booking-wizard/features/booking/booking-slice.d.ts +177 -46
  122. package/build/build-esm/booking-wizard/features/booking/booking.d.ts +8 -8
  123. package/build/build-esm/booking-wizard/features/booking/constants.d.ts +15 -8
  124. package/build/build-esm/booking-wizard/features/booking/selectors.d.ts +308 -136
  125. package/build/build-esm/booking-wizard/features/confirmation/confirmation.d.ts +4 -5
  126. package/build/build-esm/booking-wizard/features/error/error.d.ts +4 -5
  127. package/build/build-esm/booking-wizard/features/flight-options/flight-filter.d.ts +9 -9
  128. package/build/build-esm/booking-wizard/features/flight-options/flight-option-flight.d.ts +8 -8
  129. package/build/build-esm/booking-wizard/features/flight-options/flight-option-modal.d.ts +3 -3
  130. package/build/build-esm/booking-wizard/features/flight-options/flight-option.d.ts +10 -10
  131. package/build/build-esm/booking-wizard/features/flight-options/flight-utils.d.ts +16 -6
  132. package/build/build-esm/booking-wizard/features/flight-options/index.d.ts +4 -5
  133. package/build/build-esm/booking-wizard/features/price-details/price-details-api.d.ts +15 -6
  134. package/build/build-esm/booking-wizard/features/price-details/price-details-slice.d.ts +121 -80
  135. package/build/build-esm/booking-wizard/features/price-details/util.d.ts +5 -2
  136. package/build/build-esm/booking-wizard/features/product-options/no-options.d.ts +3 -3
  137. package/build/build-esm/booking-wizard/features/product-options/none-option.d.ts +17 -9
  138. package/build/build-esm/booking-wizard/features/product-options/option-booking-airline-group.d.ts +17 -8
  139. package/build/build-esm/booking-wizard/features/product-options/option-booking-group.d.ts +18 -12
  140. package/build/build-esm/booking-wizard/features/product-options/option-item.d.ts +11 -11
  141. package/build/build-esm/booking-wizard/features/product-options/option-pax-card.d.ts +13 -10
  142. package/build/build-esm/booking-wizard/features/product-options/option-pax-group.d.ts +20 -13
  143. package/build/build-esm/booking-wizard/features/product-options/option-room.d.ts +18 -10
  144. package/build/build-esm/booking-wizard/features/product-options/option-unit-group.d.ts +20 -13
  145. package/build/build-esm/booking-wizard/features/product-options/option-units-card.d.ts +9 -9
  146. package/build/build-esm/booking-wizard/features/product-options/options-form.d.ts +4 -5
  147. package/build/build-esm/booking-wizard/features/room-options/index.d.ts +4 -5
  148. package/build/build-esm/booking-wizard/features/room-options/room-utils.d.ts +29 -9
  149. package/build/build-esm/booking-wizard/features/room-options/room.d.ts +15 -12
  150. package/build/build-esm/booking-wizard/features/room-options/traveler-rooms.d.ts +13 -9
  151. package/build/build-esm/booking-wizard/features/sidebar/index.d.ts +7 -7
  152. package/build/build-esm/booking-wizard/features/sidebar/sidebar-flight.d.ts +8 -8
  153. package/build/build-esm/booking-wizard/features/sidebar/sidebar-util.d.ts +31 -12
  154. package/build/build-esm/booking-wizard/features/sidebar/sidebar.d.ts +29 -25
  155. package/build/build-esm/booking-wizard/features/summary/summary-booking-option-pax.d.ts +7 -7
  156. package/build/build-esm/booking-wizard/features/summary/summary-booking-option-unit.d.ts +7 -7
  157. package/build/build-esm/booking-wizard/features/summary/summary-flight.d.ts +8 -8
  158. package/build/build-esm/booking-wizard/features/summary/summary-per-booking-option-group.d.ts +10 -7
  159. package/build/build-esm/booking-wizard/features/summary/summary-per-pax-option-group.d.ts +10 -7
  160. package/build/build-esm/booking-wizard/features/summary/summary-per-unit-option-group.d.ts +10 -7
  161. package/build/build-esm/booking-wizard/features/summary/summary-slice.d.ts +14 -8
  162. package/build/build-esm/booking-wizard/features/summary/summary.d.ts +4 -5
  163. package/build/build-esm/booking-wizard/features/travelers-form/travelers-form-slice.d.ts +75 -49
  164. package/build/build-esm/booking-wizard/features/travelers-form/travelers-form.d.ts +4 -5
  165. package/build/build-esm/booking-wizard/features/travelers-form/type-ahead-input.d.ts +16 -16
  166. package/build/build-esm/booking-wizard/features/travelers-form/validate-form.d.ts +9 -4
  167. package/build/build-esm/booking-wizard/index.d.ts +12 -12
  168. package/build/build-esm/booking-wizard/settings-context.d.ts +5 -6
  169. package/build/build-esm/booking-wizard/store.d.ts +44 -24
  170. package/build/build-esm/booking-wizard/types.d.ts +253 -257
  171. package/build/build-esm/booking-wizard/use-offer-printer.d.ts +19 -13
  172. package/build/build-esm/index.d.ts +3 -3
  173. package/build/build-esm/index.js +15949 -7383
  174. package/build/build-esm/shared/components/loader.d.ts +6 -6
  175. package/build/build-esm/shared/types.d.ts +4 -4
  176. package/build/build-esm/shared/utils/class-util.d.ts +1 -1
  177. package/build/build-esm/shared/utils/localization-util.d.ts +248 -248
  178. package/build/build-esm/shared/utils/query-string-util.d.ts +29 -8
  179. package/build/build-esm/shared/utils/tide-api-utils.d.ts +6 -4
  180. package/package.json +75 -75
  181. package/rollup.config.js +23 -23
  182. package/src/booking-product/components/age-select.tsx +35 -35
  183. package/src/booking-product/components/amount-input.tsx +78 -78
  184. package/src/booking-product/components/date-range-picker/calendar-day.tsx +58 -58
  185. package/src/booking-product/components/date-range-picker/calendar.tsx +178 -178
  186. package/src/booking-product/components/date-range-picker/index.tsx +196 -196
  187. package/src/booking-product/components/dates.tsx +136 -136
  188. package/src/booking-product/components/footer.tsx +69 -69
  189. package/src/booking-product/components/header.tsx +79 -79
  190. package/src/booking-product/components/icon.tsx +251 -251
  191. package/src/booking-product/components/product.tsx +314 -314
  192. package/src/booking-product/components/rating.tsx +21 -21
  193. package/src/booking-product/components/rooms.tsx +195 -195
  194. package/src/booking-product/index.tsx +30 -30
  195. package/src/booking-product/settings-context.ts +14 -14
  196. package/src/booking-product/types.ts +28 -28
  197. package/src/booking-product/utils/api.ts +25 -25
  198. package/src/booking-product/utils/price.ts +29 -29
  199. package/src/booking-wizard/api-settings-slice.ts +24 -24
  200. package/src/booking-wizard/components/icon.tsx +508 -508
  201. package/src/booking-wizard/components/labeled-input.tsx +64 -64
  202. package/src/booking-wizard/components/labeled-select.tsx +69 -69
  203. package/src/booking-wizard/components/message.tsx +34 -34
  204. package/src/booking-wizard/components/multi-range-filter.tsx +113 -113
  205. package/src/booking-wizard/components/print-offer-button.tsx +63 -66
  206. package/src/booking-wizard/components/product-card.tsx +37 -37
  207. package/src/booking-wizard/components/step-indicator.tsx +51 -51
  208. package/src/booking-wizard/components/step-route.tsx +27 -27
  209. package/src/booking-wizard/declarations.d.ts +4 -4
  210. package/src/booking-wizard/features/booking/api.ts +49 -49
  211. package/src/booking-wizard/features/booking/booking-self-contained.tsx +389 -384
  212. package/src/booking-wizard/features/booking/booking-slice.ts +665 -662
  213. package/src/booking-wizard/features/booking/booking.tsx +361 -356
  214. package/src/booking-wizard/features/booking/constants.ts +16 -16
  215. package/src/booking-wizard/features/booking/selectors.ts +441 -441
  216. package/src/booking-wizard/features/confirmation/confirmation.tsx +97 -97
  217. package/src/booking-wizard/features/error/error.tsx +78 -78
  218. package/src/booking-wizard/features/flight-options/flight-filter.tsx +432 -432
  219. package/src/booking-wizard/features/flight-options/flight-option-flight.tsx +385 -385
  220. package/src/booking-wizard/features/flight-options/flight-option-modal.tsx +229 -229
  221. package/src/booking-wizard/features/flight-options/flight-option.tsx +81 -81
  222. package/src/booking-wizard/features/flight-options/flight-utils.ts +516 -516
  223. package/src/booking-wizard/features/flight-options/index.tsx +196 -196
  224. package/src/booking-wizard/features/price-details/price-details-api.ts +24 -24
  225. package/src/booking-wizard/features/price-details/price-details-slice.ts +178 -178
  226. package/src/booking-wizard/features/price-details/util.ts +155 -155
  227. package/src/booking-wizard/features/product-options/no-options.tsx +21 -21
  228. package/src/booking-wizard/features/product-options/none-option.tsx +120 -120
  229. package/src/booking-wizard/features/product-options/option-booking-airline-group.tsx +64 -64
  230. package/src/booking-wizard/features/product-options/option-booking-group.tsx +216 -216
  231. package/src/booking-wizard/features/product-options/option-item.tsx +317 -317
  232. package/src/booking-wizard/features/product-options/option-pax-card.tsx +201 -201
  233. package/src/booking-wizard/features/product-options/option-pax-group.tsx +175 -175
  234. package/src/booking-wizard/features/product-options/option-room.tsx +321 -321
  235. package/src/booking-wizard/features/product-options/option-unit-group.tsx +198 -198
  236. package/src/booking-wizard/features/product-options/option-units-card.tsx +185 -185
  237. package/src/booking-wizard/features/product-options/options-form.tsx +481 -563
  238. package/src/booking-wizard/features/room-options/index.tsx +187 -187
  239. package/src/booking-wizard/features/room-options/room-utils.ts +190 -190
  240. package/src/booking-wizard/features/room-options/room.tsx +160 -160
  241. package/src/booking-wizard/features/room-options/traveler-rooms.tsx +75 -75
  242. package/src/booking-wizard/features/sidebar/index.tsx +76 -76
  243. package/src/booking-wizard/features/sidebar/sidebar-flight.tsx +68 -68
  244. package/src/booking-wizard/features/sidebar/sidebar-util.ts +177 -177
  245. package/src/booking-wizard/features/sidebar/sidebar.tsx +364 -364
  246. package/src/booking-wizard/features/summary/summary-booking-option-pax.tsx +25 -25
  247. package/src/booking-wizard/features/summary/summary-booking-option-unit.tsx +25 -25
  248. package/src/booking-wizard/features/summary/summary-flight.tsx +39 -39
  249. package/src/booking-wizard/features/summary/summary-per-booking-option-group.tsx +69 -69
  250. package/src/booking-wizard/features/summary/summary-per-pax-option-group.tsx +63 -63
  251. package/src/booking-wizard/features/summary/summary-per-unit-option-group.tsx +66 -66
  252. package/src/booking-wizard/features/summary/summary-slice.ts +28 -28
  253. package/src/booking-wizard/features/summary/summary.tsx +674 -674
  254. package/src/booking-wizard/features/travelers-form/travelers-form-slice.ts +164 -164
  255. package/src/booking-wizard/features/travelers-form/travelers-form.tsx +754 -754
  256. package/src/booking-wizard/features/travelers-form/type-ahead-input.tsx +101 -101
  257. package/src/booking-wizard/features/travelers-form/validate-form.ts +245 -245
  258. package/src/booking-wizard/index.tsx +36 -36
  259. package/src/booking-wizard/settings-context.ts +62 -62
  260. package/src/booking-wizard/store.ts +31 -31
  261. package/src/booking-wizard/types.ts +279 -278
  262. package/src/booking-wizard/use-offer-printer.ts +117 -136
  263. package/src/index.ts +4 -4
  264. package/src/shared/components/loader.tsx +16 -16
  265. package/src/shared/translations/en-GB.json +237 -237
  266. package/src/shared/translations/fr-BE.json +238 -238
  267. package/src/shared/translations/nl-BE.json +237 -237
  268. package/src/shared/types.ts +4 -4
  269. package/src/shared/utils/class-util.ts +9 -9
  270. package/src/shared/utils/localization-util.ts +62 -62
  271. package/src/shared/utils/query-string-util.ts +119 -119
  272. package/src/shared/utils/tide-api-utils.ts +36 -36
  273. package/styles/booking-product-variables.scss +394 -394
  274. package/styles/booking-product.scss +446 -446
  275. package/styles/booking-wizard-variables.scss +873 -873
  276. package/styles/booking-wizard.scss +59 -59
  277. package/styles/components/_animations.scss +39 -39
  278. package/styles/components/_base.scss +107 -107
  279. package/styles/components/_booking.scss +879 -879
  280. package/styles/components/_button.scss +238 -238
  281. package/styles/components/_checkbox.scss +219 -219
  282. package/styles/components/_cta.scss +208 -208
  283. package/styles/components/_date-list.scss +41 -41
  284. package/styles/components/_date-range-picker.scss +225 -225
  285. package/styles/components/_decrement-increment.scss +35 -35
  286. package/styles/components/_dropdown.scss +72 -72
  287. package/styles/components/_flight-option.scss +1429 -1429
  288. package/styles/components/_form.scss +1583 -1583
  289. package/styles/components/_info-message.scss +71 -71
  290. package/styles/components/_input.scss +25 -25
  291. package/styles/components/_list.scss +187 -187
  292. package/styles/components/_loader.scss +72 -72
  293. package/styles/components/_mixins.scss +550 -550
  294. package/styles/components/_placeholders.scss +166 -166
  295. package/styles/components/_pricing-summary.scss +155 -155
  296. package/styles/components/_qsm.scss +17 -17
  297. package/styles/components/_radiobutton.scss +170 -170
  298. package/styles/components/_select-wrapper.scss +80 -80
  299. package/styles/components/_spinner.scss +29 -29
  300. package/styles/components/_step-indicators.scss +168 -168
  301. package/styles/components/_table.scss +81 -81
  302. package/styles/components/_tree.scss +530 -530
  303. package/styles/components/_typeahead.scss +281 -281
  304. package/styles/components/_variables.scss +89 -89
  305. package/tsconfig.json +24 -24
@@ -1,432 +1,432 @@
1
- import React, { useState, useEffect, useRef } from "react";
2
- import { useSelector } from "react-redux";
3
- import { buildClassName } from "../../../shared/utils/class-util";
4
- import Icon from "../../components/icon";
5
- import MultiRangeFilter from "../../components/multi-range-filter";
6
- import { FlightFilterOptions } from "../../types";
7
- import { selectTranslations } from "../booking/selectors";
8
- import { formatMinutes } from "./flight-utils";
9
-
10
- interface FlightFilterProps {
11
- filterOptions: FlightFilterOptions;
12
- resultCount: number;
13
-
14
- applyFilter: (options: FlightFilterOptions) => void;
15
- }
16
-
17
- const FlightFilter: React.FC<FlightFilterProps> = ({
18
- filterOptions,
19
- resultCount,
20
- applyFilter,
21
- }) => {
22
- const translations = useSelector(selectTranslations);
23
-
24
- const [filtersVisible, setFiltersVisible] = useState<boolean>(false);
25
- const filterRef = useRef<HTMLDivElement>(null);
26
-
27
- useEffect(() => {
28
- function handleClickOutside(event: MouseEvent) {
29
- if (
30
- filterRef.current &&
31
- !filterRef.current.contains(event.target as Node)
32
- ) {
33
- setFiltersVisible(false);
34
- }
35
- }
36
- document.addEventListener("mousedown", handleClickOutside);
37
- return () => {
38
- document.removeEventListener("mousedown", handleClickOutside);
39
- };
40
- }, []);
41
-
42
- const updateAirportFilter = (code: string) => {
43
- const updatedFilterOptions = {
44
- ...filterOptions,
45
- airports: filterOptions.airports.map((x) => {
46
- if (x.value !== code) return x;
47
-
48
- return {
49
- ...x,
50
- isSelected: !x.isSelected,
51
- };
52
- }),
53
- };
54
-
55
- applyFilter(updatedFilterOptions);
56
- };
57
-
58
- const updateAirlineFilter = (code: string) => {
59
- const updatedFilterOptions = {
60
- ...filterOptions,
61
- airlines: filterOptions.airlines.map((x) => {
62
- if (x.value !== code) return x;
63
-
64
- return {
65
- ...x,
66
- isSelected: !x.isSelected,
67
- };
68
- }),
69
- };
70
-
71
- applyFilter(updatedFilterOptions);
72
- };
73
-
74
- const updateStopsFilter = (count: string) => {
75
- const updatedFilterOptions = {
76
- ...filterOptions,
77
- numberOfStops: filterOptions.numberOfStops.map((x) => {
78
- if (x.value !== count) return x;
79
-
80
- return {
81
- ...x,
82
- isSelected: !x.isSelected,
83
- };
84
- }),
85
- };
86
-
87
- applyFilter(updatedFilterOptions);
88
- };
89
-
90
- const updateOutwardDeparture = (period: string) => {
91
- const updatedFilterOptions = {
92
- ...filterOptions,
93
- outward: {
94
- ...filterOptions.outward,
95
- departurePeriod: filterOptions.outward.departurePeriod.map((x) => {
96
- if (x.value !== period) return x;
97
-
98
- return {
99
- ...x,
100
- isSelected: !x.isSelected,
101
- };
102
- }),
103
- },
104
- };
105
-
106
- applyFilter(updatedFilterOptions);
107
- };
108
-
109
- const updateOutwardTravelDuration = (min: number, max: number) => {
110
- const updatedFilterOptions = {
111
- ...filterOptions,
112
- outward: {
113
- ...filterOptions.outward,
114
- travelDuration: {
115
- ...filterOptions.outward.travelDuration,
116
- selectedMin: min,
117
- selectedMax: max,
118
- },
119
- },
120
- };
121
-
122
- applyFilter(updatedFilterOptions);
123
- };
124
-
125
- const updateOutwardChangeDuration = (min: number, max: number) => {
126
- const updatedFilterOptions = {
127
- ...filterOptions,
128
- outward: {
129
- ...filterOptions.outward,
130
- changeDuration: {
131
- ...filterOptions.outward.changeDuration,
132
- selectedMin: min,
133
- selectedMax: max,
134
- },
135
- },
136
- };
137
-
138
- applyFilter(updatedFilterOptions);
139
- };
140
-
141
- const updateReturnDeparture = (period: string) => {
142
- const updatedFilterOptions = {
143
- ...filterOptions,
144
- return: {
145
- ...filterOptions.return,
146
- departurePeriod: filterOptions.return.departurePeriod.map((x) => {
147
- if (x.value !== period) return x;
148
-
149
- return {
150
- ...x,
151
- isSelected: !x.isSelected,
152
- };
153
- }),
154
- },
155
- };
156
-
157
- applyFilter(updatedFilterOptions);
158
- };
159
-
160
- const updateReturnTravelDuration = (min: number, max: number) => {
161
- const updatedFilterOptions = {
162
- ...filterOptions,
163
- return: {
164
- ...filterOptions.return,
165
- travelDuration: {
166
- ...filterOptions.return.travelDuration,
167
- selectedMin: min,
168
- selectedMax: max,
169
- },
170
- },
171
- };
172
-
173
- applyFilter(updatedFilterOptions);
174
- };
175
-
176
- const updateReturnChangeDuration = (min: number, max: number) => {
177
- const updatedFilterOptions = {
178
- ...filterOptions,
179
- return: {
180
- ...filterOptions.return,
181
- changeDuration: {
182
- ...filterOptions.return.changeDuration,
183
- selectedMin: min,
184
- selectedMax: max,
185
- },
186
- },
187
- };
188
-
189
- applyFilter(updatedFilterOptions);
190
- };
191
-
192
- return (
193
- <>
194
- <button
195
- type="button"
196
- className="cta cta--filter"
197
- onClick={() => setFiltersVisible(!filtersVisible)}
198
- >
199
- <Icon name="ui-filter" width={11} height={10} />
200
- <span>{translations.FLIGHTS_FORM.FILTER_OPTIONS}</span>
201
- </button>
202
-
203
- <div
204
- ref={filterRef}
205
- className={buildClassName([
206
- "flight__filter",
207
- filtersVisible && "flight__filter--active",
208
- ])}
209
- >
210
- <div className="flight__filter__header">
211
- <div className="flight__filter__header__title">
212
- <h3>{translations.FLIGHTS_FORM.FILTER_OPTIONS}</h3>
213
- <p>
214
- {translations.FLIGHTS_FORM.FLIGHTS_FOUND_1}{" "}
215
- <strong>
216
- {resultCount} {translations.FLIGHTS_FORM.FLIGHTS_FOUND_2}
217
- </strong>{" "}
218
- {translations.FLIGHTS_FORM.FLIGHTS_FOUND_3}
219
- </p>
220
- </div>
221
- <button
222
- type="button"
223
- className="cta cta--close"
224
- onClick={() => setFiltersVisible(false)}
225
- >
226
- <Icon name="ui-close" width={25} height={25} />
227
- </button>
228
- </div>
229
- <div className="flight__filter__body">
230
- <div className="flight__filter__group">
231
- <div className="flight__filter__group__title">
232
- {translations.FLIGHTS_FORM.AIRLINES}
233
- </div>
234
- <div className="flight__filter__group__wrapper">
235
- {filterOptions.airlines.map((option, k) => (
236
- <div className="tree" key={k}>
237
- <div className="checkbox flight__filter__checkbox">
238
- <label
239
- htmlFor={"airline_" + option.value}
240
- className="checkbox__label"
241
- >
242
- <input
243
- type="checkbox"
244
- id={"airline_" + option.value}
245
- className="checkbox__input checkbox__input--parent"
246
- onClick={() => updateAirlineFilter(option.value)}
247
- />
248
- <span className="radiobutton__label-text">
249
- {option.label}{" "}
250
- {option.count > 0 && (
251
- <span className="amount">({option.count})</span>
252
- )}
253
- </span>
254
- </label>
255
- </div>
256
- </div>
257
- ))}
258
- </div>
259
- </div>
260
- <div className="flight__filter__group">
261
- <div className="flight__filter__group__title">
262
- {translations.FLIGHTS_FORM.AIRPORTS}
263
- </div>
264
- <div className="flight__filter__group__wrapper">
265
- {filterOptions.airports.map((option, k) => (
266
- <div className="tree" key={k}>
267
- <div className="checkbox flight__filter__checkbox">
268
- <label
269
- htmlFor={"airport_" + option.value}
270
- className="checkbox__label"
271
- >
272
- <input
273
- type="checkbox"
274
- id={"airport_" + option.value}
275
- className="checkbox__input checkbox__input--parent"
276
- onClick={() => updateAirportFilter(option.value)}
277
- />
278
- <span className="radiobutton__label-text">
279
- {option.label}{" "}
280
- {option.count > 0 && (
281
- <span className="amount">({option.count})</span>
282
- )}
283
- </span>
284
- </label>
285
- </div>
286
- </div>
287
- ))}
288
- </div>
289
- </div>
290
- <div className="flight__filter__group">
291
- <div className="flight__filter__group__title">
292
- {translations.FLIGHTS_FORM.NUMBER_OF_STOPS}
293
- </div>
294
- <div className="flight__filter__group__wrapper">
295
- {filterOptions.numberOfStops.map((option, k) => (
296
- <div className="tree" key={k}>
297
- <div className="checkbox flight__filter__checkbox">
298
- <label
299
- htmlFor={"stops_" + option.value}
300
- className="checkbox__label"
301
- >
302
- <input
303
- type="checkbox"
304
- id={"stops_" + option.value}
305
- className="checkbox__input checkbox__input--parent"
306
- onClick={() => updateStopsFilter(option.value)}
307
- />
308
- <span className="radiobutton__label-text">
309
- {option.label}{" "}
310
- {option.count > 0 && (
311
- <span className="amount">({option.count})</span>
312
- )}
313
- </span>
314
- </label>
315
- </div>
316
- </div>
317
- ))}
318
- </div>
319
- </div>
320
- <div className="flight__filter__group">
321
- <div className="flight__filter__group__title">
322
- {translations.FLIGHTS_FORM.FLIGHT_OUTWARD}
323
- </div>
324
- <div className="flight__filter__group__wrapper">
325
- <p>{translations.FLIGHTS_FORM.DEPARTURE_TIME}</p>
326
- {filterOptions.outward.departurePeriod.map((option, k) => (
327
- <div className="tree" key={k}>
328
- <div className="checkbox flight__filter__checkbox">
329
- <label
330
- htmlFor={"outward_time_" + option.value}
331
- className="checkbox__label"
332
- >
333
- <input
334
- type="checkbox"
335
- id={"outward_time_" + option.value}
336
- className="checkbox__input checkbox__input--parent"
337
- onClick={() => updateOutwardDeparture(option.value)}
338
- />
339
- <span className="radiobutton__label-text">
340
- {option.label}{" "}
341
- {option.count > 0 && (
342
- <span className="amount">({option.count})</span>
343
- )}
344
- </span>
345
- </label>
346
- </div>
347
- </div>
348
- ))}
349
- </div>
350
- <div className="flight__filter__group__wrapper">
351
- <p>{translations.FLIGHTS_FORM.TRAVEL_DURATION}</p>
352
- <MultiRangeFilter
353
- min={filterOptions.outward.travelDuration.min}
354
- max={filterOptions.outward.travelDuration.max}
355
- selectedMin={filterOptions.outward.travelDuration.selectedMin}
356
- selectedMax={filterOptions.outward.travelDuration.selectedMax}
357
- valueFormatter={formatMinutes}
358
- onChange={updateOutwardTravelDuration}
359
- />
360
- </div>
361
- <div className="flight__filter__group__wrapper">
362
- <p>{translations.FLIGHTS_FORM.CHANGE_TIME}</p>
363
- <MultiRangeFilter
364
- min={filterOptions.outward.changeDuration.min}
365
- max={filterOptions.outward.changeDuration.max}
366
- selectedMin={filterOptions.outward.changeDuration.selectedMin}
367
- selectedMax={filterOptions.outward.changeDuration.selectedMax}
368
- valueFormatter={formatMinutes}
369
- onChange={updateOutwardChangeDuration}
370
- />
371
- </div>
372
- </div>
373
- <div className="flight__filter__group">
374
- <div className="flight__filter__group__title">
375
- {translations.FLIGHTS_FORM.FLIGHT_RETURN}
376
- </div>
377
- <div className="flight__filter__group__wrapper">
378
- <p>{translations.FLIGHTS_FORM.DEPARTURE_TIME}</p>
379
- {filterOptions.return.departurePeriod.map((option, k) => (
380
- <div className="tree" key={k}>
381
- <div className="checkbox flight__filter__checkbox">
382
- <label
383
- htmlFor={"return_time_" + option.value}
384
- className="checkbox__label"
385
- >
386
- <input
387
- type="checkbox"
388
- id={"return_time_" + option.value}
389
- className="checkbox__input checkbox__input--parent"
390
- onClick={() => updateReturnDeparture(option.value)}
391
- />
392
- <span className="radiobutton__label-text">
393
- {option.label}{" "}
394
- {option.count > 0 && (
395
- <span className="amount">({option.count})</span>
396
- )}
397
- </span>
398
- </label>
399
- </div>
400
- </div>
401
- ))}
402
- </div>
403
- <div className="flight__filter__group__wrapper">
404
- <p>{translations.FLIGHTS_FORM.TRAVEL_DURATION}</p>
405
- <MultiRangeFilter
406
- min={filterOptions.return.travelDuration.min}
407
- max={filterOptions.return.travelDuration.max}
408
- selectedMin={filterOptions.return.travelDuration.selectedMin}
409
- selectedMax={filterOptions.return.travelDuration.selectedMax}
410
- valueFormatter={formatMinutes}
411
- onChange={updateReturnTravelDuration}
412
- />
413
- </div>
414
- <div className="flight__filter__group__wrapper">
415
- <p>{translations.FLIGHTS_FORM.CHANGE_TIME}</p>
416
- <MultiRangeFilter
417
- min={filterOptions.return.changeDuration.min}
418
- max={filterOptions.return.changeDuration.max}
419
- selectedMin={filterOptions.return.changeDuration.selectedMin}
420
- selectedMax={filterOptions.return.changeDuration.selectedMax}
421
- valueFormatter={formatMinutes}
422
- onChange={updateReturnChangeDuration}
423
- />
424
- </div>
425
- </div>
426
- </div>
427
- </div>
428
- </>
429
- );
430
- };
431
-
432
- export default FlightFilter;
1
+ import React, { useState, useEffect, useRef } from "react";
2
+ import { useSelector } from "react-redux";
3
+ import { buildClassName } from "../../../shared/utils/class-util";
4
+ import Icon from "../../components/icon";
5
+ import MultiRangeFilter from "../../components/multi-range-filter";
6
+ import { FlightFilterOptions } from "../../types";
7
+ import { selectTranslations } from "../booking/selectors";
8
+ import { formatMinutes } from "./flight-utils";
9
+
10
+ interface FlightFilterProps {
11
+ filterOptions: FlightFilterOptions;
12
+ resultCount: number;
13
+
14
+ applyFilter: (options: FlightFilterOptions) => void;
15
+ }
16
+
17
+ const FlightFilter: React.FC<FlightFilterProps> = ({
18
+ filterOptions,
19
+ resultCount,
20
+ applyFilter,
21
+ }) => {
22
+ const translations = useSelector(selectTranslations);
23
+
24
+ const [filtersVisible, setFiltersVisible] = useState<boolean>(false);
25
+ const filterRef = useRef<HTMLDivElement>(null);
26
+
27
+ useEffect(() => {
28
+ function handleClickOutside(event: MouseEvent) {
29
+ if (
30
+ filterRef.current &&
31
+ !filterRef.current.contains(event.target as Node)
32
+ ) {
33
+ setFiltersVisible(false);
34
+ }
35
+ }
36
+ document.addEventListener("mousedown", handleClickOutside);
37
+ return () => {
38
+ document.removeEventListener("mousedown", handleClickOutside);
39
+ };
40
+ }, []);
41
+
42
+ const updateAirportFilter = (code: string) => {
43
+ const updatedFilterOptions = {
44
+ ...filterOptions,
45
+ airports: filterOptions.airports.map((x) => {
46
+ if (x.value !== code) return x;
47
+
48
+ return {
49
+ ...x,
50
+ isSelected: !x.isSelected,
51
+ };
52
+ }),
53
+ };
54
+
55
+ applyFilter(updatedFilterOptions);
56
+ };
57
+
58
+ const updateAirlineFilter = (code: string) => {
59
+ const updatedFilterOptions = {
60
+ ...filterOptions,
61
+ airlines: filterOptions.airlines.map((x) => {
62
+ if (x.value !== code) return x;
63
+
64
+ return {
65
+ ...x,
66
+ isSelected: !x.isSelected,
67
+ };
68
+ }),
69
+ };
70
+
71
+ applyFilter(updatedFilterOptions);
72
+ };
73
+
74
+ const updateStopsFilter = (count: string) => {
75
+ const updatedFilterOptions = {
76
+ ...filterOptions,
77
+ numberOfStops: filterOptions.numberOfStops.map((x) => {
78
+ if (x.value !== count) return x;
79
+
80
+ return {
81
+ ...x,
82
+ isSelected: !x.isSelected,
83
+ };
84
+ }),
85
+ };
86
+
87
+ applyFilter(updatedFilterOptions);
88
+ };
89
+
90
+ const updateOutwardDeparture = (period: string) => {
91
+ const updatedFilterOptions = {
92
+ ...filterOptions,
93
+ outward: {
94
+ ...filterOptions.outward,
95
+ departurePeriod: filterOptions.outward.departurePeriod.map((x) => {
96
+ if (x.value !== period) return x;
97
+
98
+ return {
99
+ ...x,
100
+ isSelected: !x.isSelected,
101
+ };
102
+ }),
103
+ },
104
+ };
105
+
106
+ applyFilter(updatedFilterOptions);
107
+ };
108
+
109
+ const updateOutwardTravelDuration = (min: number, max: number) => {
110
+ const updatedFilterOptions = {
111
+ ...filterOptions,
112
+ outward: {
113
+ ...filterOptions.outward,
114
+ travelDuration: {
115
+ ...filterOptions.outward.travelDuration,
116
+ selectedMin: min,
117
+ selectedMax: max,
118
+ },
119
+ },
120
+ };
121
+
122
+ applyFilter(updatedFilterOptions);
123
+ };
124
+
125
+ const updateOutwardChangeDuration = (min: number, max: number) => {
126
+ const updatedFilterOptions = {
127
+ ...filterOptions,
128
+ outward: {
129
+ ...filterOptions.outward,
130
+ changeDuration: {
131
+ ...filterOptions.outward.changeDuration,
132
+ selectedMin: min,
133
+ selectedMax: max,
134
+ },
135
+ },
136
+ };
137
+
138
+ applyFilter(updatedFilterOptions);
139
+ };
140
+
141
+ const updateReturnDeparture = (period: string) => {
142
+ const updatedFilterOptions = {
143
+ ...filterOptions,
144
+ return: {
145
+ ...filterOptions.return,
146
+ departurePeriod: filterOptions.return.departurePeriod.map((x) => {
147
+ if (x.value !== period) return x;
148
+
149
+ return {
150
+ ...x,
151
+ isSelected: !x.isSelected,
152
+ };
153
+ }),
154
+ },
155
+ };
156
+
157
+ applyFilter(updatedFilterOptions);
158
+ };
159
+
160
+ const updateReturnTravelDuration = (min: number, max: number) => {
161
+ const updatedFilterOptions = {
162
+ ...filterOptions,
163
+ return: {
164
+ ...filterOptions.return,
165
+ travelDuration: {
166
+ ...filterOptions.return.travelDuration,
167
+ selectedMin: min,
168
+ selectedMax: max,
169
+ },
170
+ },
171
+ };
172
+
173
+ applyFilter(updatedFilterOptions);
174
+ };
175
+
176
+ const updateReturnChangeDuration = (min: number, max: number) => {
177
+ const updatedFilterOptions = {
178
+ ...filterOptions,
179
+ return: {
180
+ ...filterOptions.return,
181
+ changeDuration: {
182
+ ...filterOptions.return.changeDuration,
183
+ selectedMin: min,
184
+ selectedMax: max,
185
+ },
186
+ },
187
+ };
188
+
189
+ applyFilter(updatedFilterOptions);
190
+ };
191
+
192
+ return (
193
+ <>
194
+ <button
195
+ type="button"
196
+ className="cta cta--filter"
197
+ onClick={() => setFiltersVisible(!filtersVisible)}
198
+ >
199
+ <Icon name="ui-filter" width={11} height={10} />
200
+ <span>{translations.FLIGHTS_FORM.FILTER_OPTIONS}</span>
201
+ </button>
202
+
203
+ <div
204
+ ref={filterRef}
205
+ className={buildClassName([
206
+ "flight__filter",
207
+ filtersVisible && "flight__filter--active",
208
+ ])}
209
+ >
210
+ <div className="flight__filter__header">
211
+ <div className="flight__filter__header__title">
212
+ <h3>{translations.FLIGHTS_FORM.FILTER_OPTIONS}</h3>
213
+ <p>
214
+ {translations.FLIGHTS_FORM.FLIGHTS_FOUND_1}{" "}
215
+ <strong>
216
+ {resultCount} {translations.FLIGHTS_FORM.FLIGHTS_FOUND_2}
217
+ </strong>{" "}
218
+ {translations.FLIGHTS_FORM.FLIGHTS_FOUND_3}
219
+ </p>
220
+ </div>
221
+ <button
222
+ type="button"
223
+ className="cta cta--close"
224
+ onClick={() => setFiltersVisible(false)}
225
+ >
226
+ <Icon name="ui-close" width={25} height={25} />
227
+ </button>
228
+ </div>
229
+ <div className="flight__filter__body">
230
+ <div className="flight__filter__group">
231
+ <div className="flight__filter__group__title">
232
+ {translations.FLIGHTS_FORM.AIRLINES}
233
+ </div>
234
+ <div className="flight__filter__group__wrapper">
235
+ {filterOptions.airlines.map((option, k) => (
236
+ <div className="tree" key={k}>
237
+ <div className="checkbox flight__filter__checkbox">
238
+ <label
239
+ htmlFor={"airline_" + option.value}
240
+ className="checkbox__label"
241
+ >
242
+ <input
243
+ type="checkbox"
244
+ id={"airline_" + option.value}
245
+ className="checkbox__input checkbox__input--parent"
246
+ onClick={() => updateAirlineFilter(option.value)}
247
+ />
248
+ <span className="radiobutton__label-text">
249
+ {option.label}{" "}
250
+ {option.count > 0 && (
251
+ <span className="amount">({option.count})</span>
252
+ )}
253
+ </span>
254
+ </label>
255
+ </div>
256
+ </div>
257
+ ))}
258
+ </div>
259
+ </div>
260
+ <div className="flight__filter__group">
261
+ <div className="flight__filter__group__title">
262
+ {translations.FLIGHTS_FORM.AIRPORTS}
263
+ </div>
264
+ <div className="flight__filter__group__wrapper">
265
+ {filterOptions.airports.map((option, k) => (
266
+ <div className="tree" key={k}>
267
+ <div className="checkbox flight__filter__checkbox">
268
+ <label
269
+ htmlFor={"airport_" + option.value}
270
+ className="checkbox__label"
271
+ >
272
+ <input
273
+ type="checkbox"
274
+ id={"airport_" + option.value}
275
+ className="checkbox__input checkbox__input--parent"
276
+ onClick={() => updateAirportFilter(option.value)}
277
+ />
278
+ <span className="radiobutton__label-text">
279
+ {option.label}{" "}
280
+ {option.count > 0 && (
281
+ <span className="amount">({option.count})</span>
282
+ )}
283
+ </span>
284
+ </label>
285
+ </div>
286
+ </div>
287
+ ))}
288
+ </div>
289
+ </div>
290
+ <div className="flight__filter__group">
291
+ <div className="flight__filter__group__title">
292
+ {translations.FLIGHTS_FORM.NUMBER_OF_STOPS}
293
+ </div>
294
+ <div className="flight__filter__group__wrapper">
295
+ {filterOptions.numberOfStops.map((option, k) => (
296
+ <div className="tree" key={k}>
297
+ <div className="checkbox flight__filter__checkbox">
298
+ <label
299
+ htmlFor={"stops_" + option.value}
300
+ className="checkbox__label"
301
+ >
302
+ <input
303
+ type="checkbox"
304
+ id={"stops_" + option.value}
305
+ className="checkbox__input checkbox__input--parent"
306
+ onClick={() => updateStopsFilter(option.value)}
307
+ />
308
+ <span className="radiobutton__label-text">
309
+ {option.label}{" "}
310
+ {option.count > 0 && (
311
+ <span className="amount">({option.count})</span>
312
+ )}
313
+ </span>
314
+ </label>
315
+ </div>
316
+ </div>
317
+ ))}
318
+ </div>
319
+ </div>
320
+ <div className="flight__filter__group">
321
+ <div className="flight__filter__group__title">
322
+ {translations.FLIGHTS_FORM.FLIGHT_OUTWARD}
323
+ </div>
324
+ <div className="flight__filter__group__wrapper">
325
+ <p>{translations.FLIGHTS_FORM.DEPARTURE_TIME}</p>
326
+ {filterOptions.outward.departurePeriod.map((option, k) => (
327
+ <div className="tree" key={k}>
328
+ <div className="checkbox flight__filter__checkbox">
329
+ <label
330
+ htmlFor={"outward_time_" + option.value}
331
+ className="checkbox__label"
332
+ >
333
+ <input
334
+ type="checkbox"
335
+ id={"outward_time_" + option.value}
336
+ className="checkbox__input checkbox__input--parent"
337
+ onClick={() => updateOutwardDeparture(option.value)}
338
+ />
339
+ <span className="radiobutton__label-text">
340
+ {option.label}{" "}
341
+ {option.count > 0 && (
342
+ <span className="amount">({option.count})</span>
343
+ )}
344
+ </span>
345
+ </label>
346
+ </div>
347
+ </div>
348
+ ))}
349
+ </div>
350
+ <div className="flight__filter__group__wrapper">
351
+ <p>{translations.FLIGHTS_FORM.TRAVEL_DURATION}</p>
352
+ <MultiRangeFilter
353
+ min={filterOptions.outward.travelDuration.min}
354
+ max={filterOptions.outward.travelDuration.max}
355
+ selectedMin={filterOptions.outward.travelDuration.selectedMin}
356
+ selectedMax={filterOptions.outward.travelDuration.selectedMax}
357
+ valueFormatter={formatMinutes}
358
+ onChange={updateOutwardTravelDuration}
359
+ />
360
+ </div>
361
+ <div className="flight__filter__group__wrapper">
362
+ <p>{translations.FLIGHTS_FORM.CHANGE_TIME}</p>
363
+ <MultiRangeFilter
364
+ min={filterOptions.outward.changeDuration.min}
365
+ max={filterOptions.outward.changeDuration.max}
366
+ selectedMin={filterOptions.outward.changeDuration.selectedMin}
367
+ selectedMax={filterOptions.outward.changeDuration.selectedMax}
368
+ valueFormatter={formatMinutes}
369
+ onChange={updateOutwardChangeDuration}
370
+ />
371
+ </div>
372
+ </div>
373
+ <div className="flight__filter__group">
374
+ <div className="flight__filter__group__title">
375
+ {translations.FLIGHTS_FORM.FLIGHT_RETURN}
376
+ </div>
377
+ <div className="flight__filter__group__wrapper">
378
+ <p>{translations.FLIGHTS_FORM.DEPARTURE_TIME}</p>
379
+ {filterOptions.return.departurePeriod.map((option, k) => (
380
+ <div className="tree" key={k}>
381
+ <div className="checkbox flight__filter__checkbox">
382
+ <label
383
+ htmlFor={"return_time_" + option.value}
384
+ className="checkbox__label"
385
+ >
386
+ <input
387
+ type="checkbox"
388
+ id={"return_time_" + option.value}
389
+ className="checkbox__input checkbox__input--parent"
390
+ onClick={() => updateReturnDeparture(option.value)}
391
+ />
392
+ <span className="radiobutton__label-text">
393
+ {option.label}{" "}
394
+ {option.count > 0 && (
395
+ <span className="amount">({option.count})</span>
396
+ )}
397
+ </span>
398
+ </label>
399
+ </div>
400
+ </div>
401
+ ))}
402
+ </div>
403
+ <div className="flight__filter__group__wrapper">
404
+ <p>{translations.FLIGHTS_FORM.TRAVEL_DURATION}</p>
405
+ <MultiRangeFilter
406
+ min={filterOptions.return.travelDuration.min}
407
+ max={filterOptions.return.travelDuration.max}
408
+ selectedMin={filterOptions.return.travelDuration.selectedMin}
409
+ selectedMax={filterOptions.return.travelDuration.selectedMax}
410
+ valueFormatter={formatMinutes}
411
+ onChange={updateReturnTravelDuration}
412
+ />
413
+ </div>
414
+ <div className="flight__filter__group__wrapper">
415
+ <p>{translations.FLIGHTS_FORM.CHANGE_TIME}</p>
416
+ <MultiRangeFilter
417
+ min={filterOptions.return.changeDuration.min}
418
+ max={filterOptions.return.changeDuration.max}
419
+ selectedMin={filterOptions.return.changeDuration.selectedMin}
420
+ selectedMax={filterOptions.return.changeDuration.selectedMax}
421
+ valueFormatter={formatMinutes}
422
+ onChange={updateReturnChangeDuration}
423
+ />
424
+ </div>
425
+ </div>
426
+ </div>
427
+ </div>
428
+ </>
429
+ );
430
+ };
431
+
432
+ export default FlightFilter;