@qite/tide-booking-component 1.3.2 → 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 +16332 -7414
  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 +15926 -7396
  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 -389
  212. package/src/booking-wizard/features/booking/booking-slice.ts +665 -663
  213. package/src/booking-wizard/features/booking/booking.tsx +361 -361
  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 -279
  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,317 +1,317 @@
1
- import {
2
- BookingPackageLine,
3
- PerPackageOption,
4
- } from "@qite/tide-client/build/types";
5
- import { compact, first, isEmpty, sortBy, uniqBy } from "lodash";
6
- import React from "react";
7
- import { buildClassName } from "../../../shared/utils/class-util";
8
- import { getPriceDifferenceText } from "../../../shared/utils/localization-util";
9
- import { getDateText } from "../sidebar/sidebar-util";
10
-
11
- interface OptionItemProps {
12
- option: PerPackageOption;
13
- parentId: string;
14
- index: number;
15
- selectedPrice: number;
16
- onOptionChange?: (option: PerPackageOption, index: number) => void;
17
- }
18
-
19
- const OptionItem: React.FC<OptionItemProps> = ({
20
- option,
21
- parentId,
22
- index,
23
- selectedPrice,
24
- onOptionChange,
25
- }) => {
26
- const priceDifference =
27
- option.requirementType === 1
28
- ? option.isSelected
29
- ? -option.line.price
30
- : option.line.price
31
- : option.requirementType === 2 || option.requirementType === 3
32
- ? option.line.price - selectedPrice
33
- : 0;
34
-
35
- const accommodations = uniqBy(
36
- compact(
37
- [option.line, ...option.alternatives].map((option) => {
38
- if (!option.accommodationCode) {
39
- return undefined;
40
- }
41
-
42
- return {
43
- accommodationCode: option.accommodationCode,
44
- accommodationName: option.accommodationName,
45
- };
46
- })
47
- ),
48
- "accommodationCode"
49
- );
50
-
51
- const regimes = uniqBy(
52
- compact(
53
- [option.line, ...option.alternatives]
54
- .filter((x) => x.accommodationCode === option.line.accommodationCode)
55
- .map((option) => {
56
- return {
57
- regimeCode: option.regimeCode,
58
- regimeName: option.regimeName,
59
- };
60
- })
61
- ),
62
- "regimeCode"
63
- );
64
-
65
- const handleAccommodationChange: React.FormEventHandler<HTMLSelectElement> = (
66
- e
67
- ) => {
68
- const accommodationCode = e.currentTarget.value;
69
-
70
- var accommodationAlternatives = option.alternatives.filter(
71
- (x) => x.accommodationCode == accommodationCode
72
- );
73
-
74
- if (accommodationAlternatives) {
75
- const alternative =
76
- accommodationAlternatives.find(
77
- (x) => x.regimeCode == option.line.regimeCode
78
- ) ?? accommodationAlternatives[0];
79
-
80
- updateOption(alternative);
81
- }
82
-
83
- e.preventDefault();
84
- };
85
-
86
- const handleRegimeChange: React.FormEventHandler<HTMLSelectElement> = (e) => {
87
- const regimeCode = e.currentTarget.value;
88
- const alternative = option.alternatives.find(
89
- (x) =>
90
- x.accommodationCode === option.line.accommodationCode &&
91
- x.regimeCode == regimeCode
92
- );
93
-
94
- updateOption(alternative);
95
-
96
- e.preventDefault();
97
- };
98
-
99
- const handleSelectionChange: React.FormEventHandler<HTMLInputElement> = (
100
- e
101
- ) => {
102
- const updatedOption = {
103
- ...option,
104
- isSelected: e.currentTarget.checked,
105
- };
106
-
107
- // Bubble up option changes
108
- if (onOptionChange) onOptionChange(updatedOption, index);
109
- };
110
-
111
- const updateOption = (alternative?: BookingPackageLine) => {
112
- if (alternative) {
113
- const updatedAlternatives = [option.line, ...option.alternatives]
114
- .filter((x) => x != alternative)
115
- .sort((x, y) => x.price - y.price);
116
-
117
- const updatedOption = {
118
- ...option,
119
- line: alternative,
120
- alternatives: updatedAlternatives,
121
- };
122
-
123
- // Bubble up option changes
124
- if (onOptionChange) onOptionChange(updatedOption, index);
125
- }
126
- };
127
-
128
- const getAccommodationPriceDifference = (accommodation: {
129
- accommodationCode: string;
130
- accommodationName: string;
131
- }) => {
132
- if (option.line.accommodationCode === accommodation.accommodationCode)
133
- return "";
134
-
135
- var currentPrice = option.line.price;
136
- var accommodationPrice = first(
137
- sortBy(
138
- option.alternatives.filter(
139
- (x) => x.accommodationCode === accommodation.accommodationCode
140
- ),
141
- (x) => x.price
142
- )
143
- )?.price;
144
-
145
- const priceDifference = (accommodationPrice ?? 0) - currentPrice;
146
- if (priceDifference !== 0) {
147
- return `(${getPriceDifferenceText(priceDifference)})`;
148
- } else {
149
- return "";
150
- }
151
- };
152
-
153
- const getRegimePriceDifference = (regime: {
154
- regimeCode: string;
155
- regimeName: string;
156
- }) => {
157
- if (option.line.regimeCode === regime.regimeCode) return "";
158
-
159
- var currentPrice = option.line.price;
160
- var regimePrice = option.alternatives.find(
161
- (x) =>
162
- x.accommodationCode === option.line.accommodationCode &&
163
- x.regimeCode === regime.regimeCode
164
- )?.price;
165
-
166
- const priceDifference = (regimePrice ?? 0) - currentPrice;
167
- if (priceDifference !== 0) {
168
- return `(${getPriceDifferenceText(priceDifference)})`;
169
- } else {
170
- return "";
171
- }
172
- };
173
-
174
- return (
175
- <>
176
- {option.requirementType === 0 && (
177
- <input
178
- type="checkbox"
179
- id={`${parentId}_${index}`}
180
- className={buildClassName([
181
- "checkbox__input",
182
- "checkbox__input--parent",
183
- ])}
184
- defaultChecked={true}
185
- disabled={true}
186
- ></input>
187
- )}
188
- {option.requirementType === 1 && (
189
- <input
190
- type="checkbox"
191
- id={`${parentId}_${index}`}
192
- className={buildClassName([
193
- "checkbox__input",
194
- "checkbox__input--parent",
195
- ])}
196
- defaultChecked={option.isSelected}
197
- onChange={handleSelectionChange}
198
- ></input>
199
- )}
200
- {(option.requirementType === 2 || option.requirementType === 3) && (
201
- <input
202
- type="radio"
203
- value={index}
204
- id={`${parentId}_${index}`}
205
- name={parentId}
206
- className={buildClassName([
207
- "radiobutton__input",
208
- "radiobutton__input--parent",
209
- ])}
210
- defaultChecked={option.isSelected}
211
- onChange={handleSelectionChange}
212
- ></input>
213
- )}
214
- <span className="radiobutton__label-text">
215
- <div className="date-list">
216
- <span className="date-list__item">
217
- {getDateText(option.line.startDate, true)}
218
- </span>
219
- <span className="date-list__item">
220
- {getDateText(option.line.endDate, true)}
221
- </span>
222
- </div>
223
- </span>
224
- <div className="tree__columns-actions">
225
- <div className="tree__columns">
226
- <div className="tree__column">
227
- <div className="tree__product-name">{option.line.productName}</div>
228
- </div>
229
- {isEmpty(option.alternatives) && (
230
- <>
231
- <div className="tree__column">
232
- <span className="tree__product-name">
233
- {option.line.accommodationName}
234
- </span>
235
- </div>
236
- <div className="tree__column">
237
- <span className="tree__product-name">
238
- {option.line.regimeName}
239
- </span>
240
- </div>
241
- </>
242
- )}
243
- {!isEmpty(option.alternatives) && (
244
- <>
245
- <div className="tree__column">
246
- <div className="select-wrapper">
247
- <div className="select-wrapper__select">
248
- <select onChange={handleAccommodationChange}>
249
- {accommodations.map((accommodation) => (
250
- <option
251
- defaultValue={option.line.accommodationCode}
252
- key={accommodation.accommodationCode}
253
- value={accommodation.accommodationCode}
254
- >
255
- {accommodation.accommodationName}{" "}
256
- {getAccommodationPriceDifference(accommodation)}
257
- </option>
258
- ))}
259
- </select>
260
- </div>
261
- </div>
262
- </div>
263
- <div className="tree__column">
264
- <div className="select-wrapper">
265
- {regimes?.length > 1 && (
266
- <div className="select-wrapper__select">
267
- <select
268
- defaultValue={option.line.regimeCode}
269
- onChange={handleRegimeChange}
270
- >
271
- {regimes.map((regime) => (
272
- <option
273
- key={regime.regimeCode}
274
- value={regime.regimeCode}
275
- >
276
- {regime.regimeName}{" "}
277
- {getRegimePriceDifference(regime)}
278
- </option>
279
- ))}
280
- </select>
281
- </div>
282
- )}
283
- {regimes.length === 1 && (
284
- <>
285
- {
286
- regimes.find(
287
- (x) => x.regimeCode == option.line.regimeCode
288
- )?.regimeName
289
- }
290
- </>
291
- )}
292
- </div>
293
- </div>
294
- </>
295
- )}
296
- <div
297
- className={buildClassName(["tree__column", "tree__column--price"])}
298
- >
299
- {!option.isSelected && (
300
- <span
301
- className={buildClassName([
302
- "price",
303
- priceDifference > 0 && "price--increase",
304
- priceDifference < 0 && "price--decrease",
305
- ])}
306
- >
307
- {getPriceDifferenceText(priceDifference)}
308
- </span>
309
- )}
310
- </div>
311
- </div>
312
- </div>
313
- </>
314
- );
315
- };
316
-
317
- export default OptionItem;
1
+ import {
2
+ BookingPackageLine,
3
+ PerPackageOption,
4
+ } from "@qite/tide-client/build/types";
5
+ import { compact, first, isEmpty, sortBy, uniqBy } from "lodash";
6
+ import React from "react";
7
+ import { buildClassName } from "../../../shared/utils/class-util";
8
+ import { getPriceDifferenceText } from "../../../shared/utils/localization-util";
9
+ import { getDateText } from "../sidebar/sidebar-util";
10
+
11
+ interface OptionItemProps {
12
+ option: PerPackageOption;
13
+ parentId: string;
14
+ index: number;
15
+ selectedPrice: number;
16
+ onOptionChange?: (option: PerPackageOption, index: number) => void;
17
+ }
18
+
19
+ const OptionItem: React.FC<OptionItemProps> = ({
20
+ option,
21
+ parentId,
22
+ index,
23
+ selectedPrice,
24
+ onOptionChange,
25
+ }) => {
26
+ const priceDifference =
27
+ option.requirementType === 1
28
+ ? option.isSelected
29
+ ? -option.line.price
30
+ : option.line.price
31
+ : option.requirementType === 2 || option.requirementType === 3
32
+ ? option.line.price - selectedPrice
33
+ : 0;
34
+
35
+ const accommodations = uniqBy(
36
+ compact(
37
+ [option.line, ...option.alternatives].map((option) => {
38
+ if (!option.accommodationCode) {
39
+ return undefined;
40
+ }
41
+
42
+ return {
43
+ accommodationCode: option.accommodationCode,
44
+ accommodationName: option.accommodationName,
45
+ };
46
+ })
47
+ ),
48
+ "accommodationCode"
49
+ );
50
+
51
+ const regimes = uniqBy(
52
+ compact(
53
+ [option.line, ...option.alternatives]
54
+ .filter((x) => x.accommodationCode === option.line.accommodationCode)
55
+ .map((option) => {
56
+ return {
57
+ regimeCode: option.regimeCode,
58
+ regimeName: option.regimeName,
59
+ };
60
+ })
61
+ ),
62
+ "regimeCode"
63
+ );
64
+
65
+ const handleAccommodationChange: React.FormEventHandler<HTMLSelectElement> = (
66
+ e
67
+ ) => {
68
+ const accommodationCode = e.currentTarget.value;
69
+
70
+ var accommodationAlternatives = option.alternatives.filter(
71
+ (x) => x.accommodationCode == accommodationCode
72
+ );
73
+
74
+ if (accommodationAlternatives) {
75
+ const alternative =
76
+ accommodationAlternatives.find(
77
+ (x) => x.regimeCode == option.line.regimeCode
78
+ ) ?? accommodationAlternatives[0];
79
+
80
+ updateOption(alternative);
81
+ }
82
+
83
+ e.preventDefault();
84
+ };
85
+
86
+ const handleRegimeChange: React.FormEventHandler<HTMLSelectElement> = (e) => {
87
+ const regimeCode = e.currentTarget.value;
88
+ const alternative = option.alternatives.find(
89
+ (x) =>
90
+ x.accommodationCode === option.line.accommodationCode &&
91
+ x.regimeCode == regimeCode
92
+ );
93
+
94
+ updateOption(alternative);
95
+
96
+ e.preventDefault();
97
+ };
98
+
99
+ const handleSelectionChange: React.FormEventHandler<HTMLInputElement> = (
100
+ e
101
+ ) => {
102
+ const updatedOption = {
103
+ ...option,
104
+ isSelected: e.currentTarget.checked,
105
+ };
106
+
107
+ // Bubble up option changes
108
+ if (onOptionChange) onOptionChange(updatedOption, index);
109
+ };
110
+
111
+ const updateOption = (alternative?: BookingPackageLine) => {
112
+ if (alternative) {
113
+ const updatedAlternatives = [option.line, ...option.alternatives]
114
+ .filter((x) => x != alternative)
115
+ .sort((x, y) => x.price - y.price);
116
+
117
+ const updatedOption = {
118
+ ...option,
119
+ line: alternative,
120
+ alternatives: updatedAlternatives,
121
+ };
122
+
123
+ // Bubble up option changes
124
+ if (onOptionChange) onOptionChange(updatedOption, index);
125
+ }
126
+ };
127
+
128
+ const getAccommodationPriceDifference = (accommodation: {
129
+ accommodationCode: string;
130
+ accommodationName: string;
131
+ }) => {
132
+ if (option.line.accommodationCode === accommodation.accommodationCode)
133
+ return "";
134
+
135
+ var currentPrice = option.line.price;
136
+ var accommodationPrice = first(
137
+ sortBy(
138
+ option.alternatives.filter(
139
+ (x) => x.accommodationCode === accommodation.accommodationCode
140
+ ),
141
+ (x) => x.price
142
+ )
143
+ )?.price;
144
+
145
+ const priceDifference = (accommodationPrice ?? 0) - currentPrice;
146
+ if (priceDifference !== 0) {
147
+ return `(${getPriceDifferenceText(priceDifference)})`;
148
+ } else {
149
+ return "";
150
+ }
151
+ };
152
+
153
+ const getRegimePriceDifference = (regime: {
154
+ regimeCode: string;
155
+ regimeName: string;
156
+ }) => {
157
+ if (option.line.regimeCode === regime.regimeCode) return "";
158
+
159
+ var currentPrice = option.line.price;
160
+ var regimePrice = option.alternatives.find(
161
+ (x) =>
162
+ x.accommodationCode === option.line.accommodationCode &&
163
+ x.regimeCode === regime.regimeCode
164
+ )?.price;
165
+
166
+ const priceDifference = (regimePrice ?? 0) - currentPrice;
167
+ if (priceDifference !== 0) {
168
+ return `(${getPriceDifferenceText(priceDifference)})`;
169
+ } else {
170
+ return "";
171
+ }
172
+ };
173
+
174
+ return (
175
+ <>
176
+ {option.requirementType === 0 && (
177
+ <input
178
+ type="checkbox"
179
+ id={`${parentId}_${index}`}
180
+ className={buildClassName([
181
+ "checkbox__input",
182
+ "checkbox__input--parent",
183
+ ])}
184
+ defaultChecked={true}
185
+ disabled={true}
186
+ ></input>
187
+ )}
188
+ {option.requirementType === 1 && (
189
+ <input
190
+ type="checkbox"
191
+ id={`${parentId}_${index}`}
192
+ className={buildClassName([
193
+ "checkbox__input",
194
+ "checkbox__input--parent",
195
+ ])}
196
+ defaultChecked={option.isSelected}
197
+ onChange={handleSelectionChange}
198
+ ></input>
199
+ )}
200
+ {(option.requirementType === 2 || option.requirementType === 3) && (
201
+ <input
202
+ type="radio"
203
+ value={index}
204
+ id={`${parentId}_${index}`}
205
+ name={parentId}
206
+ className={buildClassName([
207
+ "radiobutton__input",
208
+ "radiobutton__input--parent",
209
+ ])}
210
+ defaultChecked={option.isSelected}
211
+ onChange={handleSelectionChange}
212
+ ></input>
213
+ )}
214
+ <span className="radiobutton__label-text">
215
+ <div className="date-list">
216
+ <span className="date-list__item">
217
+ {getDateText(option.line.startDate, true)}
218
+ </span>
219
+ <span className="date-list__item">
220
+ {getDateText(option.line.endDate, true)}
221
+ </span>
222
+ </div>
223
+ </span>
224
+ <div className="tree__columns-actions">
225
+ <div className="tree__columns">
226
+ <div className="tree__column">
227
+ <div className="tree__product-name">{option.line.productName}</div>
228
+ </div>
229
+ {isEmpty(option.alternatives) && (
230
+ <>
231
+ <div className="tree__column">
232
+ <span className="tree__product-name">
233
+ {option.line.accommodationName}
234
+ </span>
235
+ </div>
236
+ <div className="tree__column">
237
+ <span className="tree__product-name">
238
+ {option.line.regimeName}
239
+ </span>
240
+ </div>
241
+ </>
242
+ )}
243
+ {!isEmpty(option.alternatives) && (
244
+ <>
245
+ <div className="tree__column">
246
+ <div className="select-wrapper">
247
+ <div className="select-wrapper__select">
248
+ <select onChange={handleAccommodationChange}>
249
+ {accommodations.map((accommodation) => (
250
+ <option
251
+ defaultValue={option.line.accommodationCode}
252
+ key={accommodation.accommodationCode}
253
+ value={accommodation.accommodationCode}
254
+ >
255
+ {accommodation.accommodationName}{" "}
256
+ {getAccommodationPriceDifference(accommodation)}
257
+ </option>
258
+ ))}
259
+ </select>
260
+ </div>
261
+ </div>
262
+ </div>
263
+ <div className="tree__column">
264
+ <div className="select-wrapper">
265
+ {regimes?.length > 1 && (
266
+ <div className="select-wrapper__select">
267
+ <select
268
+ defaultValue={option.line.regimeCode}
269
+ onChange={handleRegimeChange}
270
+ >
271
+ {regimes.map((regime) => (
272
+ <option
273
+ key={regime.regimeCode}
274
+ value={regime.regimeCode}
275
+ >
276
+ {regime.regimeName}{" "}
277
+ {getRegimePriceDifference(regime)}
278
+ </option>
279
+ ))}
280
+ </select>
281
+ </div>
282
+ )}
283
+ {regimes.length === 1 && (
284
+ <>
285
+ {
286
+ regimes.find(
287
+ (x) => x.regimeCode == option.line.regimeCode
288
+ )?.regimeName
289
+ }
290
+ </>
291
+ )}
292
+ </div>
293
+ </div>
294
+ </>
295
+ )}
296
+ <div
297
+ className={buildClassName(["tree__column", "tree__column--price"])}
298
+ >
299
+ {!option.isSelected && (
300
+ <span
301
+ className={buildClassName([
302
+ "price",
303
+ priceDifference > 0 && "price--increase",
304
+ priceDifference < 0 && "price--decrease",
305
+ ])}
306
+ >
307
+ {getPriceDifferenceText(priceDifference)}
308
+ </span>
309
+ )}
310
+ </div>
311
+ </div>
312
+ </div>
313
+ </>
314
+ );
315
+ };
316
+
317
+ export default OptionItem;