@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,195 +1,195 @@
1
- import { range } from "lodash";
2
- import React, { useContext, useState } from "react";
3
- import { buildClassName } from "../../shared/utils/class-util";
4
- import { getTranslations } from "../../shared/utils/localization-util";
5
- import SettingsContext from "../settings-context";
6
- import { ProductRoom } from "../types";
7
- import AgeSelect from "./age-select";
8
- import AmountInput from "./amount-input";
9
- import Icon from "./icon";
10
-
11
- interface RoomsProps {
12
- rooms: ProductRoom[];
13
- isDisabled: boolean;
14
- setIsDisabled: (isOpen: boolean) => void;
15
- onChange: (rooms: ProductRoom[]) => void;
16
- }
17
-
18
- const Rooms: React.FC<RoomsProps> = ({
19
- rooms,
20
- isDisabled,
21
- setIsDisabled,
22
- onChange,
23
- }) => {
24
- const [isTouched, setIsTouched] = useState<boolean>(false);
25
- const [currentRooms, setRoomState] = useState<ProductRoom[]>(rooms);
26
-
27
- const { language } = useContext(SettingsContext);
28
- const translations = getTranslations(language);
29
-
30
- const handleCloseClick = () => {
31
- setIsDisabled(true);
32
- if (isTouched) onChange(currentRooms);
33
- };
34
-
35
- return (
36
- <div className="booking-product__rooms">
37
- <div className="booking-product__rooms-title">
38
- <Icon name="ui-user" width={25} height={25} />
39
- {translations.PRODUCT.WHO_YOU_TRAVELING_WITH}
40
- </div>
41
- <div className="booking-product__rooms__container">
42
- <div className="booking-product__rooms__wrapper">
43
- <div className="booking-product__rooms__header">
44
- <div className="booking-product__rooms__heading">
45
- {translations.SHARED.ROOMS}
46
- </div>
47
- <div className="booking-product__rooms__actions">
48
- <AmountInput
49
- label={translations.PRODUCT.NUMBER_OF_ROOMS}
50
- value={currentRooms.length}
51
- disabled={isDisabled}
52
- min={1}
53
- onChange={(value) => {
54
- setRoomState(
55
- range(0, value).map(
56
- (roomIndex) =>
57
- currentRooms[roomIndex] ?? {
58
- adults: 2,
59
- children: 0,
60
- childAges: [],
61
- }
62
- )
63
- );
64
-
65
- setIsTouched(true);
66
- }}
67
- />
68
- </div>
69
- </div>
70
- <div className="booking-product__rooms-body">
71
- {currentRooms.map((room, roomIndex) => (
72
- <div className="booking-product__room" key={roomIndex}>
73
- <div className="booking-product__room__header">
74
- <h3 className="booking-product__room__heading">
75
- {translations.SHARED.ROOM + " " + (roomIndex + 1)}
76
- </h3>
77
- <div className="booking-product__room__actions">
78
- <AmountInput
79
- label={translations.SHARED.ADULTS}
80
- value={room.adults}
81
- disabled={isDisabled}
82
- min={1}
83
- onChange={(value) => {
84
- setRoomState(
85
- currentRooms.map((room, i) =>
86
- i === roomIndex ? { ...room, adults: value } : room
87
- )
88
- );
89
-
90
- setIsTouched(true);
91
- }}
92
- />
93
- <AmountInput
94
- label={translations.SHARED.CHILDREN}
95
- value={room.children}
96
- disabled={isDisabled}
97
- onChange={(value) => {
98
- setRoomState(
99
- currentRooms.map((room, i) =>
100
- i === roomIndex
101
- ? {
102
- ...room,
103
- children: value,
104
- childAges: range(0, value).map(
105
- (childIndex) =>
106
- room.childAges[childIndex] ?? 0
107
- ),
108
- }
109
- : room
110
- )
111
- );
112
-
113
- setIsTouched(true);
114
- }}
115
- />
116
- </div>
117
- </div>
118
- {room.children > 0 && (
119
- <div className="booking-product__room-children">
120
- <label className="booking-product__room-children-label">
121
- {translations.PRODUCT.AGE_BY_DEPARTURE_DATE}
122
- </label>
123
- <div className="booking-product__room-children-ages">
124
- {range(0, room.children).map((childIndex) => (
125
- <AgeSelect
126
- key={childIndex}
127
- value={room.childAges[childIndex]}
128
- disabled={isDisabled}
129
- onChange={(value) => {
130
- setRoomState(
131
- currentRooms.map((room, selectorRoomIndex) =>
132
- roomIndex === selectorRoomIndex
133
- ? {
134
- ...room,
135
- childAges: room.childAges
136
- .map((age, i) =>
137
- childIndex === i ? value : age
138
- )
139
- .sort((a, b) => b - a),
140
- }
141
- : room
142
- )
143
- );
144
-
145
- setIsTouched(true);
146
- }}
147
- />
148
- ))}
149
- </div>
150
- </div>
151
- )}
152
- </div>
153
- ))}
154
- </div>
155
- </div>
156
- <div className="booking-product__rooms-footer">
157
- {isDisabled ? (
158
- <button
159
- type="button"
160
- className={buildClassName(["cta--secondary", "cta--add"])}
161
- title={translations.PRODUCT.EDIT}
162
- onClick={() => {
163
- setIsDisabled(false);
164
- setIsTouched(false);
165
- }}
166
- >
167
- <span>
168
- <Icon name="ui-pencil" width={25} height={25} />
169
- {translations.PRODUCT.EDIT}
170
- </span>
171
- </button>
172
- ) : (
173
- <button
174
- type="button"
175
- className={buildClassName([
176
- "cta",
177
- isTouched ? "cta--secondary" : "cta--secondary",
178
- "cta--add",
179
- ])}
180
- title={translations.PRODUCT.APPLY}
181
- onClick={handleCloseClick}
182
- >
183
- <span>
184
- <Icon name="ui-check" />
185
- {translations.PRODUCT.APPLY}
186
- </span>
187
- </button>
188
- )}
189
- </div>
190
- </div>
191
- </div>
192
- );
193
- };
194
-
195
- export default Rooms;
1
+ import { range } from "lodash";
2
+ import React, { useContext, useState } from "react";
3
+ import { buildClassName } from "../../shared/utils/class-util";
4
+ import { getTranslations } from "../../shared/utils/localization-util";
5
+ import SettingsContext from "../settings-context";
6
+ import { ProductRoom } from "../types";
7
+ import AgeSelect from "./age-select";
8
+ import AmountInput from "./amount-input";
9
+ import Icon from "./icon";
10
+
11
+ interface RoomsProps {
12
+ rooms: ProductRoom[];
13
+ isDisabled: boolean;
14
+ setIsDisabled: (isOpen: boolean) => void;
15
+ onChange: (rooms: ProductRoom[]) => void;
16
+ }
17
+
18
+ const Rooms: React.FC<RoomsProps> = ({
19
+ rooms,
20
+ isDisabled,
21
+ setIsDisabled,
22
+ onChange,
23
+ }) => {
24
+ const [isTouched, setIsTouched] = useState<boolean>(false);
25
+ const [currentRooms, setRoomState] = useState<ProductRoom[]>(rooms);
26
+
27
+ const { language } = useContext(SettingsContext);
28
+ const translations = getTranslations(language);
29
+
30
+ const handleCloseClick = () => {
31
+ setIsDisabled(true);
32
+ if (isTouched) onChange(currentRooms);
33
+ };
34
+
35
+ return (
36
+ <div className="booking-product__rooms">
37
+ <div className="booking-product__rooms-title">
38
+ <Icon name="ui-user" width={25} height={25} />
39
+ {translations.PRODUCT.WHO_YOU_TRAVELING_WITH}
40
+ </div>
41
+ <div className="booking-product__rooms__container">
42
+ <div className="booking-product__rooms__wrapper">
43
+ <div className="booking-product__rooms__header">
44
+ <div className="booking-product__rooms__heading">
45
+ {translations.SHARED.ROOMS}
46
+ </div>
47
+ <div className="booking-product__rooms__actions">
48
+ <AmountInput
49
+ label={translations.PRODUCT.NUMBER_OF_ROOMS}
50
+ value={currentRooms.length}
51
+ disabled={isDisabled}
52
+ min={1}
53
+ onChange={(value) => {
54
+ setRoomState(
55
+ range(0, value).map(
56
+ (roomIndex) =>
57
+ currentRooms[roomIndex] ?? {
58
+ adults: 2,
59
+ children: 0,
60
+ childAges: [],
61
+ }
62
+ )
63
+ );
64
+
65
+ setIsTouched(true);
66
+ }}
67
+ />
68
+ </div>
69
+ </div>
70
+ <div className="booking-product__rooms-body">
71
+ {currentRooms.map((room, roomIndex) => (
72
+ <div className="booking-product__room" key={roomIndex}>
73
+ <div className="booking-product__room__header">
74
+ <h3 className="booking-product__room__heading">
75
+ {translations.SHARED.ROOM + " " + (roomIndex + 1)}
76
+ </h3>
77
+ <div className="booking-product__room__actions">
78
+ <AmountInput
79
+ label={translations.SHARED.ADULTS}
80
+ value={room.adults}
81
+ disabled={isDisabled}
82
+ min={1}
83
+ onChange={(value) => {
84
+ setRoomState(
85
+ currentRooms.map((room, i) =>
86
+ i === roomIndex ? { ...room, adults: value } : room
87
+ )
88
+ );
89
+
90
+ setIsTouched(true);
91
+ }}
92
+ />
93
+ <AmountInput
94
+ label={translations.SHARED.CHILDREN}
95
+ value={room.children}
96
+ disabled={isDisabled}
97
+ onChange={(value) => {
98
+ setRoomState(
99
+ currentRooms.map((room, i) =>
100
+ i === roomIndex
101
+ ? {
102
+ ...room,
103
+ children: value,
104
+ childAges: range(0, value).map(
105
+ (childIndex) =>
106
+ room.childAges[childIndex] ?? 0
107
+ ),
108
+ }
109
+ : room
110
+ )
111
+ );
112
+
113
+ setIsTouched(true);
114
+ }}
115
+ />
116
+ </div>
117
+ </div>
118
+ {room.children > 0 && (
119
+ <div className="booking-product__room-children">
120
+ <label className="booking-product__room-children-label">
121
+ {translations.PRODUCT.AGE_BY_DEPARTURE_DATE}
122
+ </label>
123
+ <div className="booking-product__room-children-ages">
124
+ {range(0, room.children).map((childIndex) => (
125
+ <AgeSelect
126
+ key={childIndex}
127
+ value={room.childAges[childIndex]}
128
+ disabled={isDisabled}
129
+ onChange={(value) => {
130
+ setRoomState(
131
+ currentRooms.map((room, selectorRoomIndex) =>
132
+ roomIndex === selectorRoomIndex
133
+ ? {
134
+ ...room,
135
+ childAges: room.childAges
136
+ .map((age, i) =>
137
+ childIndex === i ? value : age
138
+ )
139
+ .sort((a, b) => b - a),
140
+ }
141
+ : room
142
+ )
143
+ );
144
+
145
+ setIsTouched(true);
146
+ }}
147
+ />
148
+ ))}
149
+ </div>
150
+ </div>
151
+ )}
152
+ </div>
153
+ ))}
154
+ </div>
155
+ </div>
156
+ <div className="booking-product__rooms-footer">
157
+ {isDisabled ? (
158
+ <button
159
+ type="button"
160
+ className={buildClassName(["cta--secondary", "cta--add"])}
161
+ title={translations.PRODUCT.EDIT}
162
+ onClick={() => {
163
+ setIsDisabled(false);
164
+ setIsTouched(false);
165
+ }}
166
+ >
167
+ <span>
168
+ <Icon name="ui-pencil" width={25} height={25} />
169
+ {translations.PRODUCT.EDIT}
170
+ </span>
171
+ </button>
172
+ ) : (
173
+ <button
174
+ type="button"
175
+ className={buildClassName([
176
+ "cta",
177
+ isTouched ? "cta--secondary" : "cta--secondary",
178
+ "cta--add",
179
+ ])}
180
+ title={translations.PRODUCT.APPLY}
181
+ onClick={handleCloseClick}
182
+ >
183
+ <span>
184
+ <Icon name="ui-check" />
185
+ {translations.PRODUCT.APPLY}
186
+ </span>
187
+ </button>
188
+ )}
189
+ </div>
190
+ </div>
191
+ </div>
192
+ );
193
+ };
194
+
195
+ export default Rooms;
@@ -1,30 +1,30 @@
1
- import React from "react";
2
- import Product from "./components/product";
3
- import SettingsContext from "./settings-context";
4
- import { Settings } from "./types";
5
-
6
- interface BookingProductProps {
7
- productCode: string;
8
- productName: string;
9
- rating?: number;
10
- settings: Settings;
11
- }
12
-
13
- const BookingProduct: React.FC<BookingProductProps> = ({
14
- productCode,
15
- productName,
16
- rating,
17
- settings,
18
- }) => {
19
- return (
20
- <SettingsContext.Provider value={settings}>
21
- <Product
22
- productCode={productCode}
23
- productName={productName}
24
- rating={rating}
25
- ></Product>
26
- </SettingsContext.Provider>
27
- );
28
- };
29
-
30
- export default BookingProduct;
1
+ import React from "react";
2
+ import Product from "./components/product";
3
+ import SettingsContext from "./settings-context";
4
+ import { Settings } from "./types";
5
+
6
+ interface BookingProductProps {
7
+ productCode: string;
8
+ productName: string;
9
+ rating?: number;
10
+ settings: Settings;
11
+ }
12
+
13
+ const BookingProduct: React.FC<BookingProductProps> = ({
14
+ productCode,
15
+ productName,
16
+ rating,
17
+ settings,
18
+ }) => {
19
+ return (
20
+ <SettingsContext.Provider value={settings}>
21
+ <Product
22
+ productCode={productCode}
23
+ productName={productName}
24
+ rating={rating}
25
+ ></Product>
26
+ </SettingsContext.Provider>
27
+ );
28
+ };
29
+
30
+ export default BookingProduct;
@@ -1,14 +1,14 @@
1
- import React from "react";
2
- import { Settings } from "./types";
3
-
4
- interface ProductSettingsContextProps extends Settings {}
5
-
6
- const SettingsContext = React.createContext<ProductSettingsContextProps>({
7
- officeId: 1,
8
- catalogueId: 1,
9
- language: "nl-BE",
10
- basePath: "boeken",
11
- priceMode: 0,
12
- });
13
-
14
- export default SettingsContext;
1
+ import React from "react";
2
+ import { Settings } from "./types";
3
+
4
+ interface ProductSettingsContextProps extends Settings {}
5
+
6
+ const SettingsContext = React.createContext<ProductSettingsContextProps>({
7
+ officeId: 1,
8
+ catalogueId: 1,
9
+ language: "nl-BE",
10
+ basePath: "boeken",
11
+ priceMode: 0,
12
+ });
13
+
14
+ export default SettingsContext;
@@ -1,28 +1,28 @@
1
- export interface Settings {
2
- officeId: number;
3
- catalogueId: number;
4
- agentId?: number;
5
- basePath: string;
6
- language: string;
7
- includeFlights?: boolean;
8
- priceMode: number;
9
- icons?: string;
10
- apiUrl?: string;
11
- apiKey?: string;
12
- addProductToQuery?: boolean;
13
- isOffer?: boolean;
14
-
15
- alternativeActionText?: string;
16
- alternativeAction?: () => void;
17
- }
18
-
19
- export interface ProductRoom {
20
- adults: number;
21
- children: number;
22
- childAges: number[];
23
- }
24
-
25
- export interface DateRange {
26
- fromDate?: Date;
27
- toDate?: Date;
28
- }
1
+ export interface Settings {
2
+ officeId: number;
3
+ catalogueId: number;
4
+ agentId?: number;
5
+ basePath: string;
6
+ language: string;
7
+ includeFlights?: boolean;
8
+ priceMode: number;
9
+ icons?: string;
10
+ apiUrl?: string;
11
+ apiKey?: string;
12
+ addProductToQuery?: boolean;
13
+ isOffer?: boolean;
14
+
15
+ alternativeActionText?: string;
16
+ alternativeAction?: () => void;
17
+ }
18
+
19
+ export interface ProductRoom {
20
+ adults: number;
21
+ children: number;
22
+ childAges: number[];
23
+ }
24
+
25
+ export interface DateRange {
26
+ fromDate?: Date;
27
+ toDate?: Date;
28
+ }
@@ -1,25 +1,25 @@
1
- import { details } from "@qite/tide-client";
2
- import {
3
- BookingPackage,
4
- BookingPackageDetailsRequest,
5
- BookingPackageRequest,
6
- TideResponse,
7
- } from "@qite/tide-client/build/types";
8
- import { ApiSettingsState } from "../../shared/types";
9
- import { buildTideClientConfig } from "../../shared/utils/tide-api-utils";
10
-
11
- const fetchDetails = async (
12
- request: BookingPackageRequest<BookingPackageDetailsRequest>,
13
- signal: AbortSignal,
14
- languageCode?: string,
15
- apiSettings?: ApiSettingsState
16
- ): Promise<TideResponse<BookingPackage>> => {
17
- const tideClientConfig = buildTideClientConfig(apiSettings);
18
- return await details(tideClientConfig, request, signal, languageCode);
19
- };
20
-
21
- const packageApi = {
22
- fetchDetails,
23
- };
24
-
25
- export default packageApi;
1
+ import { details } from "@qite/tide-client";
2
+ import {
3
+ BookingPackage,
4
+ BookingPackageDetailsRequest,
5
+ BookingPackageRequest,
6
+ TideResponse,
7
+ } from "@qite/tide-client/build/types";
8
+ import { ApiSettingsState } from "../../shared/types";
9
+ import { buildTideClientConfig } from "../../shared/utils/tide-api-utils";
10
+
11
+ const fetchDetails = async (
12
+ request: BookingPackageRequest<BookingPackageDetailsRequest>,
13
+ signal: AbortSignal,
14
+ languageCode?: string,
15
+ apiSettings?: ApiSettingsState
16
+ ): Promise<TideResponse<BookingPackage>> => {
17
+ const tideClientConfig = buildTideClientConfig(apiSettings);
18
+ return await details(tideClientConfig, request, signal, languageCode);
19
+ };
20
+
21
+ const packageApi = {
22
+ fetchDetails,
23
+ };
24
+
25
+ export default packageApi;
@@ -1,29 +1,29 @@
1
- import { formatPrice } from "../../shared/utils/localization-util";
2
-
3
- export const formatPriceByMode = (
4
- price: number | undefined,
5
- priceMode: number,
6
- personCount: number,
7
- duration: number,
8
- perPersonLabel: string,
9
- perNightLabel: string,
10
- perPersonPerNightLabel: string
11
- ) => {
12
- if (!price) return "";
13
-
14
- switch (priceMode) {
15
- case 0:
16
- return `${formatPrice(price)}`;
17
- case 1:
18
- const perPersonPrice = price / personCount;
19
- return `${formatPrice(perPersonPrice)} / ${perPersonLabel}`;
20
- case 2:
21
- const perNightPrice = price / duration;
22
- return `${formatPrice(perNightPrice)} / ${perNightLabel}`;
23
- case 3:
24
- const perPersonPerNightPrice = price / duration;
25
- return `${formatPrice(
26
- perPersonPerNightPrice
27
- )} / ${perPersonPerNightLabel}`;
28
- }
29
- };
1
+ import { formatPrice } from "../../shared/utils/localization-util";
2
+
3
+ export const formatPriceByMode = (
4
+ price: number | undefined,
5
+ priceMode: number,
6
+ personCount: number,
7
+ duration: number,
8
+ perPersonLabel: string,
9
+ perNightLabel: string,
10
+ perPersonPerNightLabel: string
11
+ ) => {
12
+ if (!price) return "";
13
+
14
+ switch (priceMode) {
15
+ case 0:
16
+ return `${formatPrice(price)}`;
17
+ case 1:
18
+ const perPersonPrice = price / personCount;
19
+ return `${formatPrice(perPersonPrice)} / ${perPersonLabel}`;
20
+ case 2:
21
+ const perNightPrice = price / duration;
22
+ return `${formatPrice(perNightPrice)} / ${perNightLabel}`;
23
+ case 3:
24
+ const perPersonPerNightPrice = price / duration;
25
+ return `${formatPrice(
26
+ perPersonPerNightPrice
27
+ )} / ${perPersonPerNightLabel}`;
28
+ }
29
+ };