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