@roomstay/frontend 2.1.5 → 2.1.7

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 (874) hide show
  1. package/dist/14.bundle.js +1 -0
  2. package/dist/151.bundle.js +1 -0
  3. package/dist/201.bundle.js +1 -1
  4. package/dist/279.bundle.js +1 -1
  5. package/dist/370.bundle.js +1 -1
  6. package/dist/399.bundle.js +2 -0
  7. package/dist/399.bundle.js.LICENSE.txt +30 -0
  8. package/dist/449.bundle.js +1 -1
  9. package/dist/559.bundle.js +1 -0
  10. package/dist/760.bundle.js +1 -1
  11. package/dist/815.bundle.js +1 -0
  12. package/dist/855.bundle.js +1 -0
  13. package/dist/873.bundle.js +1 -1
  14. package/dist/882.bundle.js +1 -1
  15. package/dist/962.bundle.js +1 -0
  16. package/dist/972.bundle.js +1 -1
  17. package/dist/main.bundle.js +1 -1
  18. package/dist/src/animations/AutoAutoHeight.d.ts +1 -1
  19. package/dist/src/animations/AutoAutoHeight.js +11 -34
  20. package/dist/src/animations/AutoAutoHeight.js.map +1 -1
  21. package/dist/src/animations/Fade.d.ts +1 -1
  22. package/dist/src/animations/Fade.js +3 -4
  23. package/dist/src/animations/Fade.js.map +1 -1
  24. package/dist/src/api/AddonAPI.js +3 -2
  25. package/dist/src/api/AddonAPI.js.map +1 -1
  26. package/dist/src/api/AvailabilityAPI.d.ts +2 -2
  27. package/dist/src/api/AvailabilityAPI.js +6 -6
  28. package/dist/src/api/AvailabilityAPI.js.map +1 -1
  29. package/dist/src/api/BaseAPI.d.ts +4 -4
  30. package/dist/src/api/BaseAPI.js +30 -24
  31. package/dist/src/api/BaseAPI.js.map +1 -1
  32. package/dist/src/api/ExchangeRateAPI.d.ts +1 -1
  33. package/dist/src/api/ExchangeRateAPI.js.map +1 -1
  34. package/dist/src/api/HotelAPI.js +1 -1
  35. package/dist/src/api/HotelAPI.js.map +1 -1
  36. package/dist/src/api/ReservationAPI.d.ts +1 -1
  37. package/dist/src/api/ReservationAPI.js +2 -1
  38. package/dist/src/api/ReservationAPI.js.map +1 -1
  39. package/dist/src/api/SessionAPI.d.ts +1 -1
  40. package/dist/src/api/SessionAPI.js +2 -2
  41. package/dist/src/api/SessionAPI.js.map +1 -1
  42. package/dist/src/components/User/Forms/ForgotPasswordForm.js +19 -23
  43. package/dist/src/components/User/Forms/ForgotPasswordForm.js.map +1 -1
  44. package/dist/src/components/User/Forms/SignInForm.js +50 -52
  45. package/dist/src/components/User/Forms/SignInForm.js.map +1 -1
  46. package/dist/src/components/User/Forms/SignUpForm.js +61 -62
  47. package/dist/src/components/User/Forms/SignUpForm.js.map +1 -1
  48. package/dist/src/components/generic/Alert.js +3 -26
  49. package/dist/src/components/generic/Alert.js.map +1 -1
  50. package/dist/src/components/generic/BEButton.d.ts +1 -1
  51. package/dist/src/components/generic/BEButton.js +8 -7
  52. package/dist/src/components/generic/BEButton.js.map +1 -1
  53. package/dist/src/components/generic/BESelect.d.ts +0 -0
  54. package/dist/src/components/generic/BESelect.js +2 -0
  55. package/dist/src/components/generic/BESelect.js.map +1 -0
  56. package/dist/src/components/generic/BackButton.js +2 -26
  57. package/dist/src/components/generic/BackButton.js.map +1 -1
  58. package/dist/src/components/generic/BookNowPayLaterInfoBlock.d.ts +2 -1
  59. package/dist/src/components/generic/BookNowPayLaterInfoBlock.js +9 -9
  60. package/dist/src/components/generic/BookNowPayLaterInfoBlock.js.map +1 -1
  61. package/dist/src/components/generic/BookingWizard/BookingWizardBottomSheet/BookingWizardBottomSheet.d.ts +1 -3
  62. package/dist/src/components/generic/BookingWizard/BookingWizardBottomSheet/BookingWizardBottomSheet.js.map +1 -1
  63. package/dist/src/components/generic/BookingWizard/BookingWizardContent.js +1 -1
  64. package/dist/src/components/generic/BookingWizard/BookingWizardContent.js.map +1 -1
  65. package/dist/src/components/generic/BookingWizard/BookingWizardContext.d.ts +1 -1
  66. package/dist/src/components/generic/BookingWizard/BookingWizardContext.js +1 -1
  67. package/dist/src/components/generic/BookingWizard/BookingWizardContext.js.map +1 -1
  68. package/dist/src/components/generic/BookingWizard/BookingWizardDateSelector/BookingWizardDateSelector.js +6 -4
  69. package/dist/src/components/generic/BookingWizard/BookingWizardDateSelector/BookingWizardDateSelector.js.map +1 -1
  70. package/dist/src/components/generic/BookingWizard/BookingWizardGuestSelector/BookingWizardGuestSelector.js +1 -1
  71. package/dist/src/components/generic/BookingWizard/BookingWizardGuestSelector/BookingWizardGuestSelector.js.map +1 -1
  72. package/dist/src/components/generic/BookingWizard/BookingWizardHotelSelector/BookingWizardHotelSelector.js +5 -4
  73. package/dist/src/components/generic/BookingWizard/BookingWizardHotelSelector/BookingWizardHotelSelector.js.map +1 -1
  74. package/dist/src/components/generic/Card/Card/Card.js +4 -27
  75. package/dist/src/components/generic/Card/Card/Card.js.map +1 -1
  76. package/dist/src/components/generic/Card/IconNavCard/IconNavCard.d.ts +1 -1
  77. package/dist/src/components/generic/Card/IconNavCard/IconNavCard.js +8 -8
  78. package/dist/src/components/generic/Card/IconNavCard/IconNavCard.js.map +1 -1
  79. package/dist/src/components/generic/Checkbox/Checkbox.d.ts +1 -1
  80. package/dist/src/components/generic/Checkbox/Checkbox.js +8 -8
  81. package/dist/src/components/generic/Checkbox/Checkbox.js.map +1 -1
  82. package/dist/src/components/generic/Countdown.js +6 -29
  83. package/dist/src/components/generic/Countdown.js.map +1 -1
  84. package/dist/src/components/generic/Currency.js +10 -10
  85. package/dist/src/components/generic/Currency.js.map +1 -1
  86. package/dist/src/components/generic/DateRangePicker/DateRangePicker.d.ts +3 -3
  87. package/dist/src/components/generic/DateRangePicker/DateRangePicker.js +28 -28
  88. package/dist/src/components/generic/DateRangePicker/DateRangePicker.js.map +1 -1
  89. package/dist/src/components/generic/DateRangePicker/DateRangePickerContext.d.ts +13 -7
  90. package/dist/src/components/generic/DateRangePicker/DateRangePickerContext.js +4 -39
  91. package/dist/src/components/generic/DateRangePicker/DateRangePickerContext.js.map +1 -1
  92. package/dist/src/components/generic/DateRangePicker/DateRangePickerDay.js +18 -16
  93. package/dist/src/components/generic/DateRangePicker/DateRangePickerDay.js.map +1 -1
  94. package/dist/src/components/generic/DateRangePicker/DateRangePickerDays.js +4 -27
  95. package/dist/src/components/generic/DateRangePicker/DateRangePickerDays.js.map +1 -1
  96. package/dist/src/components/generic/DateRangePicker/DateRangePickerMonth.js +10 -10
  97. package/dist/src/components/generic/DateRangePicker/DateRangePickerMonth.js.map +1 -1
  98. package/dist/src/components/generic/DateRangePicker/FloatingDateRangePicker.d.ts +3 -3
  99. package/dist/src/components/generic/DateRangePicker/FloatingDateRangePicker.js +13 -36
  100. package/dist/src/components/generic/DateRangePicker/FloatingDateRangePicker.js.map +1 -1
  101. package/dist/src/components/generic/Distance.js +5 -28
  102. package/dist/src/components/generic/Distance.js.map +1 -1
  103. package/dist/src/components/generic/ForwardedSelect.d.ts +1 -1
  104. package/dist/src/components/generic/ForwardedSelect.js +9 -29
  105. package/dist/src/components/generic/ForwardedSelect.js.map +1 -1
  106. package/dist/src/components/generic/Headline.d.ts +1 -1
  107. package/dist/src/components/generic/Headline.js +5 -30
  108. package/dist/src/components/generic/Headline.js.map +1 -1
  109. package/dist/src/components/generic/Icon/Icon.js +5 -28
  110. package/dist/src/components/generic/Icon/Icon.js.map +1 -1
  111. package/dist/src/components/generic/IconText/IconText.js +5 -4
  112. package/dist/src/components/generic/IconText/IconText.js.map +1 -1
  113. package/dist/src/components/generic/InputGroup/InputGroup.js +6 -29
  114. package/dist/src/components/generic/InputGroup/InputGroup.js.map +1 -1
  115. package/dist/src/components/generic/LineBreak.js +2 -25
  116. package/dist/src/components/generic/LineBreak.js.map +1 -1
  117. package/dist/src/components/generic/Notification.d.ts +2 -3
  118. package/dist/src/components/generic/Notification.js +16 -13
  119. package/dist/src/components/generic/Notification.js.map +1 -1
  120. package/dist/src/components/generic/NumberIncrement.js +10 -10
  121. package/dist/src/components/generic/NumberIncrement.js.map +1 -1
  122. package/dist/src/components/generic/Overlay/Overlay.d.ts +3 -3
  123. package/dist/src/components/generic/Overlay/Overlay.js +16 -40
  124. package/dist/src/components/generic/Overlay/Overlay.js.map +1 -1
  125. package/dist/src/components/generic/PasswordBox/PasswordBox.d.ts +1 -1
  126. package/dist/src/components/generic/PasswordBox/PasswordBox.js +8 -8
  127. package/dist/src/components/generic/PasswordBox/PasswordBox.js.map +1 -1
  128. package/dist/src/components/generic/PaymentCard/CardTypeSelect.js +9 -28
  129. package/dist/src/components/generic/PaymentCard/CardTypeSelect.js.map +1 -1
  130. package/dist/src/components/generic/PaymentCard/PaymentCard.js +18 -41
  131. package/dist/src/components/generic/PaymentCard/PaymentCard.js.map +1 -1
  132. package/dist/src/components/generic/PaymentCard/PaymentCardInput.js +66 -51
  133. package/dist/src/components/generic/PaymentCard/PaymentCardInput.js.map +1 -1
  134. package/dist/src/components/generic/Pill.d.ts +1 -1
  135. package/dist/src/components/generic/Pill.js +4 -27
  136. package/dist/src/components/generic/Pill.js.map +1 -1
  137. package/dist/src/components/generic/Placeholder.js +4 -27
  138. package/dist/src/components/generic/Placeholder.js.map +1 -1
  139. package/dist/src/components/generic/PlanpayButton/PlanpayButton.js +2 -25
  140. package/dist/src/components/generic/PlanpayButton/PlanpayButton.js.map +1 -1
  141. package/dist/src/components/generic/Portal/Portal.d.ts +1 -1
  142. package/dist/src/components/generic/Portal/Portal.js +4 -24
  143. package/dist/src/components/generic/Portal/Portal.js.map +1 -1
  144. package/dist/src/components/generic/PromoCodeInput.js +27 -28
  145. package/dist/src/components/generic/PromoCodeInput.js.map +1 -1
  146. package/dist/src/components/generic/RadioButtonGroup/RadioButton.js +9 -32
  147. package/dist/src/components/generic/RadioButtonGroup/RadioButton.js.map +1 -1
  148. package/dist/src/components/generic/RadioButtonGroup/RadioButtonGroup.d.ts +6 -6
  149. package/dist/src/components/generic/RadioButtonGroup/RadioButtonGroup.js +6 -29
  150. package/dist/src/components/generic/RadioButtonGroup/RadioButtonGroup.js.map +1 -1
  151. package/dist/src/components/generic/RecentSearchesCard.js +19 -18
  152. package/dist/src/components/generic/RecentSearchesCard.js.map +1 -1
  153. package/dist/src/components/generic/RoomstayMark.d.ts +1 -0
  154. package/dist/src/components/generic/RoomstayMark.js +49 -0
  155. package/dist/src/components/generic/RoomstayMark.js.map +1 -0
  156. package/dist/src/components/generic/ScrollToTop.d.ts +2 -0
  157. package/dist/src/components/generic/ScrollToTop.js +3 -3
  158. package/dist/src/components/generic/ScrollToTop.js.map +1 -1
  159. package/dist/src/components/generic/Select/Select.d.ts +4 -4
  160. package/dist/src/components/generic/Select/Select.js +16 -6
  161. package/dist/src/components/generic/Select/Select.js.map +1 -1
  162. package/dist/src/components/generic/Select.d.ts +0 -0
  163. package/dist/src/components/generic/Select.js +2 -0
  164. package/dist/src/components/generic/Select.js.map +1 -0
  165. package/dist/src/components/generic/Slider/Slider.d.ts +3 -3
  166. package/dist/src/components/generic/Slider/Slider.js +23 -45
  167. package/dist/src/components/generic/Slider/Slider.js.map +1 -1
  168. package/dist/src/components/generic/Tabs/ElementChildren.d.ts +1 -1
  169. package/dist/src/components/generic/Tabs/ElementChildren.js +6 -26
  170. package/dist/src/components/generic/Tabs/ElementChildren.js.map +1 -1
  171. package/dist/src/components/generic/Tabs/Tab.d.ts +1 -1
  172. package/dist/src/components/generic/Tabs/Tab.js +4 -24
  173. package/dist/src/components/generic/Tabs/Tab.js.map +1 -1
  174. package/dist/src/components/generic/Tabs/TabContext.d.ts +5 -6
  175. package/dist/src/components/generic/Tabs/TabContext.js +11 -31
  176. package/dist/src/components/generic/Tabs/TabContext.js.map +1 -1
  177. package/dist/src/components/generic/Tabs/TabLink.d.ts +1 -1
  178. package/dist/src/components/generic/Tabs/TabLink.js +7 -30
  179. package/dist/src/components/generic/Tabs/TabLink.js.map +1 -1
  180. package/dist/src/components/generic/Tabs/TabRouteContainer.js +10 -33
  181. package/dist/src/components/generic/Tabs/TabRouteContainer.js.map +1 -1
  182. package/dist/src/components/generic/Tabs/Tabs.d.ts +2 -2
  183. package/dist/src/components/generic/Tabs/Tabs.js +9 -32
  184. package/dist/src/components/generic/Tabs/Tabs.js.map +1 -1
  185. package/dist/src/components/generic/Text.d.ts +1 -1
  186. package/dist/src/components/generic/Text.js +3 -26
  187. package/dist/src/components/generic/Text.js.map +1 -1
  188. package/dist/src/components/generic/TextArea.d.ts +1 -1
  189. package/dist/src/components/generic/TextArea.js +6 -26
  190. package/dist/src/components/generic/TextArea.js.map +1 -1
  191. package/dist/src/components/generic/TextBox.d.ts +2 -2
  192. package/dist/src/components/generic/TextBox.js +11 -34
  193. package/dist/src/components/generic/TextBox.js.map +1 -1
  194. package/dist/src/components/generic/Tooltip/Tooltip.d.ts +1 -1
  195. package/dist/src/components/generic/Tooltip/Tooltip.js +8 -31
  196. package/dist/src/components/generic/Tooltip/Tooltip.js.map +1 -1
  197. package/dist/src/components/generic/badging/SSLSecureBadge.js +3 -26
  198. package/dist/src/components/generic/badging/SSLSecureBadge.js.map +1 -1
  199. package/dist/src/components/generic/buttons/NextStepButton.js +5 -28
  200. package/dist/src/components/generic/buttons/NextStepButton.js.map +1 -1
  201. package/dist/src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.d.ts +3 -4
  202. package/dist/src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.js +23 -32
  203. package/dist/src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.js.map +1 -1
  204. package/dist/src/components/generic/date/DatePicker.js +42 -42
  205. package/dist/src/components/generic/date/DatePicker.js.map +1 -1
  206. package/dist/src/components/generic/date/DatePickerDay.js +27 -27
  207. package/dist/src/components/generic/date/DatePickerDay.js.map +1 -1
  208. package/dist/src/components/generic/date/DatePickerDays.js +4 -27
  209. package/dist/src/components/generic/date/DatePickerDays.js.map +1 -1
  210. package/dist/src/components/generic/date/DatePickerMonth.js +9 -9
  211. package/dist/src/components/generic/date/DatePickerMonth.js.map +1 -1
  212. package/dist/src/components/generic/date/DatePickerWeek.js +26 -26
  213. package/dist/src/components/generic/date/DatePickerWeek.js.map +1 -1
  214. package/dist/src/components/generic/date/FloatingDatePicker.d.ts +1 -1
  215. package/dist/src/components/generic/date/FloatingDatePicker.js +11 -11
  216. package/dist/src/components/generic/date/FloatingDatePicker.js.map +1 -1
  217. package/dist/src/components/generic/date/WeekViewSkeleton.js +23 -46
  218. package/dist/src/components/generic/date/WeekViewSkeleton.js.map +1 -1
  219. package/dist/src/components/generic/loader/ImageLoader.d.ts +1 -1
  220. package/dist/src/components/generic/loader/ImageLoader.js +8 -8
  221. package/dist/src/components/generic/loader/ImageLoader.js.map +1 -1
  222. package/dist/src/components/generic/loader/LargeLoader.js +15 -38
  223. package/dist/src/components/generic/loader/LargeLoader.js.map +1 -1
  224. package/dist/src/components/generic/loader/SmallSpinner.js +6 -3
  225. package/dist/src/components/generic/loader/SmallSpinner.js.map +1 -1
  226. package/dist/src/components/generic/map/HotelLocationMap.js +3 -26
  227. package/dist/src/components/generic/map/HotelLocationMap.js.map +1 -1
  228. package/dist/src/components/generic/modal/ConfirmationModal.js +8 -8
  229. package/dist/src/components/generic/modal/ConfirmationModal.js.map +1 -1
  230. package/dist/src/components/generic/modal/ErrorModal.d.ts +2 -2
  231. package/dist/src/components/generic/modal/ErrorModal.js +5 -5
  232. package/dist/src/components/generic/modal/ErrorModal.js.map +1 -1
  233. package/dist/src/components/generic/modal/SigninModal/AuthenticatedUserModal.d.ts +3 -2
  234. package/dist/src/components/generic/modal/SigninModal/AuthenticatedUserModal.js +16 -16
  235. package/dist/src/components/generic/modal/SigninModal/AuthenticatedUserModal.js.map +1 -1
  236. package/dist/src/components/generic/modal/SigninModal/UnauthenticatedUserModal.d.ts +1 -1
  237. package/dist/src/components/generic/modal/SigninModal/UnauthenticatedUserModal.js +26 -26
  238. package/dist/src/components/generic/modal/SigninModal/UnauthenticatedUserModal.js.map +1 -1
  239. package/dist/src/components/generic/modal/SimpleModal.d.ts +2 -2
  240. package/dist/src/components/generic/modal/SimpleModal.js +21 -22
  241. package/dist/src/components/generic/modal/SimpleModal.js.map +1 -1
  242. package/dist/src/components/generic/modal/TabbedModal.d.ts +1 -1
  243. package/dist/src/components/generic/modal/TabbedModal.js +12 -12
  244. package/dist/src/components/generic/modal/TabbedModal.js.map +1 -1
  245. package/dist/src/components/generic/radio/RadioFields.js +11 -11
  246. package/dist/src/components/generic/radio/RadioFields.js.map +1 -1
  247. package/dist/src/components/iconComponents/BookNowPayLaterIcon.js +16 -36
  248. package/dist/src/components/iconComponents/BookNowPayLaterIcon.js.map +1 -1
  249. package/dist/src/components/members/EditMyProfile.d.ts +1 -1
  250. package/dist/src/components/members/EditMyProfile.js +35 -59
  251. package/dist/src/components/members/EditMyProfile.js.map +1 -1
  252. package/dist/src/components/navigation/Header.js +69 -64
  253. package/dist/src/components/navigation/Header.js.map +1 -1
  254. package/dist/src/components/navigation/StepSelector.js +27 -27
  255. package/dist/src/components/navigation/StepSelector.js.map +1 -1
  256. package/dist/src/components/navigation/StepSelectorModal.js +14 -13
  257. package/dist/src/components/navigation/StepSelectorModal.js.map +1 -1
  258. package/dist/src/components/pages/Account/Card/CardList.js +10 -33
  259. package/dist/src/components/pages/Account/Card/CardList.js.map +1 -1
  260. package/dist/src/components/pages/Account/Card/MemberCardItem.js +10 -10
  261. package/dist/src/components/pages/Account/Card/MemberCardItem.js.map +1 -1
  262. package/dist/src/components/pages/PageColorComponent.js +4 -27
  263. package/dist/src/components/pages/PageColorComponent.js.map +1 -1
  264. package/dist/src/components/reservation/EmptyReservation.d.ts +6 -0
  265. package/dist/src/components/reservation/EmptyReservation.js +52 -0
  266. package/dist/src/components/reservation/EmptyReservation.js.map +1 -0
  267. package/dist/src/components/reservation/ReservationItem.js +56 -56
  268. package/dist/src/components/reservation/ReservationItem.js.map +1 -1
  269. package/dist/src/components/reservation/ReservationList.d.ts +3 -2
  270. package/dist/src/components/reservation/ReservationList.js +7 -26
  271. package/dist/src/components/reservation/ReservationList.js.map +1 -1
  272. package/dist/src/components/steps/DaysSelectedInformer.js +9 -6
  273. package/dist/src/components/steps/DaysSelectedInformer.js.map +1 -1
  274. package/dist/src/components/steps/MinimumNightStayPill.d.ts +1 -1
  275. package/dist/src/components/steps/MinimumNightStayPill.js +8 -8
  276. package/dist/src/components/steps/MinimumNightStayPill.js.map +1 -1
  277. package/dist/src/components/steps/addons/AddonCard.js +59 -58
  278. package/dist/src/components/steps/addons/AddonCard.js.map +1 -1
  279. package/dist/src/components/steps/addons/AddonList.js +16 -39
  280. package/dist/src/components/steps/addons/AddonList.js.map +1 -1
  281. package/dist/src/components/steps/addons/AddonsNotFound.js +38 -61
  282. package/dist/src/components/steps/addons/AddonsNotFound.js.map +1 -1
  283. package/dist/src/components/steps/common/CommonAddonSummary/CommonAddonSummary.d.ts +1 -1
  284. package/dist/src/components/steps/common/CommonAddonSummary/CommonAddonSummary.js +19 -19
  285. package/dist/src/components/steps/common/CommonAddonSummary/CommonAddonSummary.js.map +1 -1
  286. package/dist/src/components/steps/confirmation/AccountDetails.js +11 -34
  287. package/dist/src/components/steps/confirmation/AccountDetails.js.map +1 -1
  288. package/dist/src/components/steps/confirmation/PaymentDetails/AcceptablePaymentCard.js +5 -27
  289. package/dist/src/components/steps/confirmation/PaymentDetails/AcceptablePaymentCard.js.map +1 -1
  290. package/dist/src/components/steps/confirmation/PaymentDetails/CardPaymentDetails.js +1 -0
  291. package/dist/src/components/steps/confirmation/PaymentDetails/ExistingCardPicker.js +12 -32
  292. package/dist/src/components/steps/confirmation/PaymentDetails/ExistingCardPicker.js.map +1 -1
  293. package/dist/src/components/steps/confirmation/PaymentDetails/StepConfirmationPaymentDetails.d.ts +1 -1
  294. package/dist/src/components/steps/confirmation/PaymentDetails/StepConfirmationPaymentDetails.js +26 -25
  295. package/dist/src/components/steps/confirmation/PaymentDetails/StepConfirmationPaymentDetails.js.map +1 -1
  296. package/dist/src/components/steps/confirmation/PlanpayPaymentMethod.js +35 -58
  297. package/dist/src/components/steps/confirmation/PlanpayPaymentMethod.js.map +1 -1
  298. package/dist/src/components/steps/confirmation/RoomContactDetails.js +72 -68
  299. package/dist/src/components/steps/confirmation/RoomContactDetails.js.map +1 -1
  300. package/dist/src/components/steps/confirmation/StepConfirmationAcknowledgement.js +14 -14
  301. package/dist/src/components/steps/confirmation/StepConfirmationAcknowledgement.js.map +1 -1
  302. package/dist/src/components/steps/confirmation/StepConfirmationCheckoutDifferencesModal.js +36 -35
  303. package/dist/src/components/steps/confirmation/StepConfirmationCheckoutDifferencesModal.js.map +1 -1
  304. package/dist/src/components/steps/confirmation/StepConfirmationCommentsComponent.js +7 -30
  305. package/dist/src/components/steps/confirmation/StepConfirmationCommentsComponent.js.map +1 -1
  306. package/dist/src/components/steps/confirmation/StepConfirmationCountrySelector.d.ts +2 -2
  307. package/dist/src/components/steps/confirmation/StepConfirmationCountrySelector.js +29 -24
  308. package/dist/src/components/steps/confirmation/StepConfirmationCountrySelector.js.map +1 -1
  309. package/dist/src/components/steps/confirmation/StepConfirmationForm.js +94 -89
  310. package/dist/src/components/steps/confirmation/StepConfirmationForm.js.map +1 -1
  311. package/dist/src/components/steps/confirmation/StepConfirmationFormProvider.js +3 -26
  312. package/dist/src/components/steps/confirmation/StepConfirmationFormProvider.js.map +1 -1
  313. package/dist/src/components/steps/confirmation/StepConfirmationLimitedOffer.js +13 -13
  314. package/dist/src/components/steps/confirmation/StepConfirmationLimitedOffer.js.map +1 -1
  315. package/dist/src/components/steps/confirmation/StepConfirmationPoliciesSection.js +16 -16
  316. package/dist/src/components/steps/confirmation/StepConfirmationPoliciesSection.js.map +1 -1
  317. package/dist/src/components/steps/confirmation/StepConfirmationPolicyBlock.js +25 -20
  318. package/dist/src/components/steps/confirmation/StepConfirmationPolicyBlock.js.map +1 -1
  319. package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffers.js +26 -26
  320. package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffers.js.map +1 -1
  321. package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersColumn.js +13 -9
  322. package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersColumn.js.map +1 -1
  323. package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersModal.js +61 -61
  324. package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersModal.js.map +1 -1
  325. package/dist/src/components/steps/date/PeoplePicker.js +11 -7
  326. package/dist/src/components/steps/date/PeoplePicker.js.map +1 -1
  327. package/dist/src/components/steps/date/PeoplePickerRow.js +18 -18
  328. package/dist/src/components/steps/date/PeoplePickerRow.js.map +1 -1
  329. package/dist/src/components/steps/date/StepDatePricePerRoom.js +16 -16
  330. package/dist/src/components/steps/date/StepDatePricePerRoom.js.map +1 -1
  331. package/dist/src/components/steps/date/StepOneDateRange.js +10 -10
  332. package/dist/src/components/steps/date/StepOneDateRange.js.map +1 -1
  333. package/dist/src/components/steps/date/StepOneDateRangePicker.js +6 -6
  334. package/dist/src/components/steps/date/StepOneDateRangePicker.js.map +1 -1
  335. package/dist/src/components/steps/date/StepOneDateRangePickerLegend.js +6 -6
  336. package/dist/src/components/steps/date/StepOneDateRangePickerLegend.js.map +1 -1
  337. package/dist/src/components/steps/date/StepOneNextStepButton.js +5 -5
  338. package/dist/src/components/steps/date/StepOneNextStepButton.js.map +1 -1
  339. package/dist/src/components/steps/date/StepOneStatusPeople.js +4 -27
  340. package/dist/src/components/steps/date/StepOneStatusPeople.js.map +1 -1
  341. package/dist/src/components/steps/hotel/HotelCard.js +56 -56
  342. package/dist/src/components/steps/hotel/HotelCard.js.map +1 -1
  343. package/dist/src/components/steps/hotel/HotelCardList.js +5 -28
  344. package/dist/src/components/steps/hotel/HotelCardList.js.map +1 -1
  345. package/dist/src/components/steps/hotel/HotelCardModal.d.ts +1 -1
  346. package/dist/src/components/steps/hotel/HotelCardModal.js +45 -45
  347. package/dist/src/components/steps/hotel/HotelCardModal.js.map +1 -1
  348. package/dist/src/components/steps/hotel/HotelSearchParameters.js +40 -40
  349. package/dist/src/components/steps/hotel/HotelSearchParameters.js.map +1 -1
  350. package/dist/src/components/steps/hotel/NoHotelsAvailable.js +57 -80
  351. package/dist/src/components/steps/hotel/NoHotelsAvailable.js.map +1 -1
  352. package/dist/src/components/steps/room/AvailableUpgradesModal.d.ts +2 -1
  353. package/dist/src/components/steps/room/AvailableUpgradesModal.js +40 -42
  354. package/dist/src/components/steps/room/AvailableUpgradesModal.js.map +1 -1
  355. package/dist/src/components/steps/room/ImageGallerySlider.js +21 -21
  356. package/dist/src/components/steps/room/ImageGallerySlider.js.map +1 -1
  357. package/dist/src/components/steps/room/InactivityWindow.js +20 -20
  358. package/dist/src/components/steps/room/InactivityWindow.js.map +1 -1
  359. package/dist/src/components/steps/room/LargeRoomCard.js +36 -35
  360. package/dist/src/components/steps/room/LargeRoomCard.js.map +1 -1
  361. package/dist/src/components/steps/room/MemberSignInModal/MemberSignInModal.js +44 -48
  362. package/dist/src/components/steps/room/MemberSignInModal/MemberSignInModal.js.map +1 -1
  363. package/dist/src/components/steps/room/NoRoomsFoundBlock.js +52 -52
  364. package/dist/src/components/steps/room/NoRoomsFoundBlock.js.map +1 -1
  365. package/dist/src/components/steps/room/RatesNotFound.js +39 -62
  366. package/dist/src/components/steps/room/RatesNotFound.js.map +1 -1
  367. package/dist/src/components/steps/room/RoomList.js +13 -36
  368. package/dist/src/components/steps/room/RoomList.js.map +1 -1
  369. package/dist/src/components/steps/room/RoomListAlert.d.ts +1 -1
  370. package/dist/src/components/steps/room/RoomListAlert.js +11 -34
  371. package/dist/src/components/steps/room/RoomListAlert.js.map +1 -1
  372. package/dist/src/components/steps/room/RoomListCrossSellBlock.d.ts +2 -1
  373. package/dist/src/components/steps/room/RoomListCrossSellBlock.js +38 -38
  374. package/dist/src/components/steps/room/RoomListCrossSellBlock.js.map +1 -1
  375. package/dist/src/components/steps/room/RoomModal.js +32 -32
  376. package/dist/src/components/steps/room/RoomModal.js.map +1 -1
  377. package/dist/src/components/steps/room/StepRoomAlertBlocks.js +9 -9
  378. package/dist/src/components/steps/room/StepRoomAlertBlocks.js.map +1 -1
  379. package/dist/src/components/steps/room/StepRoomBestRateAlert.js +6 -6
  380. package/dist/src/components/steps/room/StepRoomBestRateAlert.js.map +1 -1
  381. package/dist/src/components/steps/room/StepRoomErrorForm.js +34 -34
  382. package/dist/src/components/steps/room/StepRoomErrorForm.js.map +1 -1
  383. package/dist/src/components/steps/room/StepRoomHotelDetails.js +18 -18
  384. package/dist/src/components/steps/room/StepRoomHotelDetails.js.map +1 -1
  385. package/dist/src/components/steps/room/StepRoomNextStepButton.js +4 -4
  386. package/dist/src/components/steps/room/StepRoomNextStepButton.js.map +1 -1
  387. package/dist/src/components/steps/room/StepRoomSortBy.js +6 -6
  388. package/dist/src/components/steps/room/StepRoomSortBy.js.map +1 -1
  389. package/dist/src/components/steps/room/StepRoomSummaryAndButton.js +15 -38
  390. package/dist/src/components/steps/room/StepRoomSummaryAndButton.js.map +1 -1
  391. package/dist/src/components/steps/room/roomBuilderProgress/NumberOfAdultsPicker.js +2 -25
  392. package/dist/src/components/steps/room/roomBuilderProgress/NumberOfAdultsPicker.js.map +1 -1
  393. package/dist/src/components/steps/room/roomBuilderProgress/NumberOfChildrenPicker.js +2 -25
  394. package/dist/src/components/steps/room/roomBuilderProgress/NumberOfChildrenPicker.js.map +1 -1
  395. package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgress.js +9 -9
  396. package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgress.js.map +1 -1
  397. package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgressRow.js +71 -69
  398. package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgressRow.js.map +1 -1
  399. package/dist/src/components/steps/room/roomDetails/RoomDetails.js +42 -39
  400. package/dist/src/components/steps/room/roomDetails/RoomDetails.js.map +1 -1
  401. package/dist/src/components/steps/room/roomDetails/RoomDetailsBedsBlock.js +18 -15
  402. package/dist/src/components/steps/room/roomDetails/RoomDetailsBedsBlock.js.map +1 -1
  403. package/dist/src/components/steps/room/roomDetails/RoomDetailsPerkBlock.js +6 -7
  404. package/dist/src/components/steps/room/roomDetails/RoomDetailsPerkBlock.js.map +1 -1
  405. package/dist/src/components/steps/room/roomDetails/RoomDetailsPriceBlock.js +16 -16
  406. package/dist/src/components/steps/room/roomDetails/RoomDetailsPriceBlock.js.map +1 -1
  407. package/dist/src/components/steps/room/roomDetails/RoomDetailsRetargeting.d.ts +1 -1
  408. package/dist/src/components/steps/room/roomDetails/RoomDetailsRetargeting.js +37 -36
  409. package/dist/src/components/steps/room/roomDetails/RoomDetailsRetargeting.js.map +1 -1
  410. package/dist/src/components/steps/room/roomDetails/roomRates/BookNowButton.js +8 -31
  411. package/dist/src/components/steps/room/roomDetails/roomRates/BookNowButton.js.map +1 -1
  412. package/dist/src/components/steps/room/roomDetails/roomRates/MembersOnlyRow.js +26 -26
  413. package/dist/src/components/steps/room/roomDetails/roomRates/MembersOnlyRow.js.map +1 -1
  414. package/dist/src/components/steps/room/roomDetails/roomRates/PriceBreakdownBlock.js +43 -43
  415. package/dist/src/components/steps/room/roomDetails/roomRates/PriceBreakdownBlock.js.map +1 -1
  416. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDescriptionTab.js +34 -34
  417. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDescriptionTab.js.map +1 -1
  418. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDetailsAndPriceBreakdownModal.js +8 -8
  419. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDetailsAndPriceBreakdownModal.js.map +1 -1
  420. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateListPromotion/RoomRateListPromotion.js +11 -11
  421. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateListPromotion/RoomRateListPromotion.js.map +1 -1
  422. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRatePills.js +8 -10
  423. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRatePills.js.map +1 -1
  424. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateRow.js +32 -32
  425. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateRow.js.map +1 -1
  426. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRates.js +16 -39
  427. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRates.js.map +1 -1
  428. package/dist/src/components/steps/room/roomFilter/AppliedFiltersBlock.js +10 -9
  429. package/dist/src/components/steps/room/roomFilter/AppliedFiltersBlock.js.map +1 -1
  430. package/dist/src/components/steps/room/roomFilter/RoomFilterOverlay.js +32 -31
  431. package/dist/src/components/steps/room/roomFilter/RoomFilterOverlay.js.map +1 -1
  432. package/dist/src/components/steps/room/roomFilter/RoomFilterPriceSlider.d.ts +1 -1
  433. package/dist/src/components/steps/room/roomFilter/RoomFilterPriceSlider.js +20 -21
  434. package/dist/src/components/steps/room/roomFilter/RoomFilterPriceSlider.js.map +1 -1
  435. package/dist/src/components/steps/room/roomFilter/RoomFilterRateType.d.ts +1 -1
  436. package/dist/src/components/steps/room/roomFilter/RoomFilterRateType.js +17 -17
  437. package/dist/src/components/steps/room/roomFilter/RoomFilterRateType.js.map +1 -1
  438. package/dist/src/components/steps/room/roomFilter/RoomFilterRoomType.d.ts +1 -1
  439. package/dist/src/components/steps/room/roomFilter/RoomFilterRoomType.js +20 -18
  440. package/dist/src/components/steps/room/roomFilter/RoomFilterRoomType.js.map +1 -1
  441. package/dist/src/components/summary/BEMapWidget.d.ts +1 -1
  442. package/dist/src/components/summary/BEMapWidget.js +29 -27
  443. package/dist/src/components/summary/BEMapWidget.js.map +1 -1
  444. package/dist/src/components/summary/BEMobileSummary.js +22 -22
  445. package/dist/src/components/summary/BEMobileSummary.js.map +1 -1
  446. package/dist/src/components/summary/BEMobileSummaryModal.js +62 -60
  447. package/dist/src/components/summary/BEMobileSummaryModal.js.map +1 -1
  448. package/dist/src/components/summary/BESummary.js +42 -41
  449. package/dist/src/components/summary/BESummary.js.map +1 -1
  450. package/dist/src/components/summary/BESummaryAddonRow.js +18 -18
  451. package/dist/src/components/summary/BESummaryAddonRow.js.map +1 -1
  452. package/dist/src/components/summary/BESummaryPerkBlock.js +11 -11
  453. package/dist/src/components/summary/BESummaryPerkBlock.js.map +1 -1
  454. package/dist/src/components/summary/BESummaryPrivacyPolicy.js +11 -8
  455. package/dist/src/components/summary/BESummaryPrivacyPolicy.js.map +1 -1
  456. package/dist/src/components/summary/BESummaryRoomRow.js +57 -57
  457. package/dist/src/components/summary/BESummaryRoomRow.js.map +1 -1
  458. package/dist/src/components/summary/TransportDistanceFromHotelBlock.js +12 -12
  459. package/dist/src/components/summary/TransportDistanceFromHotelBlock.js.map +1 -1
  460. package/dist/src/components/temp/Login.js +29 -29
  461. package/dist/src/components/temp/Login.js.map +1 -1
  462. package/dist/src/containers/PrivateRoute.js +6 -26
  463. package/dist/src/containers/PrivateRoute.js.map +1 -1
  464. package/dist/src/contexts/BasketContext/BasketContext.js +1 -1
  465. package/dist/src/contexts/BasketContext/BasketContext.js.map +1 -1
  466. package/dist/src/contexts/BasketContext/BasketContextType.d.ts +3 -3
  467. package/dist/src/contexts/BasketContext/BasketContextType.js.map +1 -1
  468. package/dist/src/contexts/BasketContext/BasketContextWrapper.d.ts +1 -1
  469. package/dist/src/contexts/BasketContext/BasketContextWrapper.js +35 -59
  470. package/dist/src/contexts/BasketContext/BasketContextWrapper.js.map +1 -1
  471. package/dist/src/contexts/BookingEngineContext/BookingEngineContext.js +1 -1
  472. package/dist/src/contexts/BookingEngineContext/BookingEngineContext.js.map +1 -1
  473. package/dist/src/contexts/BookingEngineContext/BookingEngineContextType.types.d.ts +1 -1
  474. package/dist/src/contexts/BookingEngineContext/BookingEngineContextType.types.js.map +1 -1
  475. package/dist/src/contexts/BookingEngineContext/BookingEngineContextWrapper.d.ts +1 -1
  476. package/dist/src/contexts/BookingEngineContext/BookingEngineContextWrapper.js +3 -4
  477. package/dist/src/contexts/BookingEngineContext/BookingEngineContextWrapper.js.map +1 -1
  478. package/dist/src/contexts/CompanyContext/CompanyContext.js +1 -1
  479. package/dist/src/contexts/CompanyContext/CompanyContext.js.map +1 -1
  480. package/dist/src/contexts/CompanyContext/CompanyContextWrapper.js +24 -47
  481. package/dist/src/contexts/CompanyContext/CompanyContextWrapper.js.map +1 -1
  482. package/dist/src/contexts/ConfirmationFormContext.d.ts +2 -2
  483. package/dist/src/contexts/ConfirmationFormContext.js +8 -28
  484. package/dist/src/contexts/ConfirmationFormContext.js.map +1 -1
  485. package/dist/src/contexts/ConfirmationStepContext/ConfirmationStepContextWrapper.js +10 -10
  486. package/dist/src/contexts/ConfirmationStepContext/ConfirmationStepContextWrapper.js.map +1 -1
  487. package/dist/src/contexts/DatePickerContext.d.ts +12 -11
  488. package/dist/src/contexts/DatePickerContext.js +4 -41
  489. package/dist/src/contexts/DatePickerContext.js.map +1 -1
  490. package/dist/src/contexts/ErrorContext.d.ts +2 -2
  491. package/dist/src/contexts/ErrorContext.js +10 -10
  492. package/dist/src/contexts/ErrorContext.js.map +1 -1
  493. package/dist/src/contexts/FullPageEngineContext/FullPageEngineContext.js +1 -1
  494. package/dist/src/contexts/FullPageEngineContext/FullPageEngineContext.js.map +1 -1
  495. package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextWrapper.d.ts +1 -1
  496. package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextWrapper.js +43 -49
  497. package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextWrapper.js.map +1 -1
  498. package/dist/src/contexts/HotelOverridesContext.d.ts +1 -1
  499. package/dist/src/contexts/HotelOverridesContext.js +14 -37
  500. package/dist/src/contexts/HotelOverridesContext.js.map +1 -1
  501. package/dist/src/contexts/Members/AuthenticationContext/AuthenticationContext.d.ts +7 -7
  502. package/dist/src/contexts/Members/AuthenticationContext/AuthenticationContext.js +18 -6
  503. package/dist/src/contexts/Members/AuthenticationContext/AuthenticationContext.js.map +1 -1
  504. package/dist/src/contexts/Members/AuthenticationContext/AuthenticationContextProvider.d.ts +1 -1
  505. package/dist/src/contexts/Members/AuthenticationContext/AuthenticationContextProvider.js +38 -53
  506. package/dist/src/contexts/Members/AuthenticationContext/AuthenticationContextProvider.js.map +1 -1
  507. package/dist/src/contexts/Members/RoomstayMemberContext/RoomstayMemberContextProvider.d.ts +1 -1
  508. package/dist/src/contexts/Members/RoomstayMemberContext/RoomstayMemberContextProvider.js +29 -49
  509. package/dist/src/contexts/Members/RoomstayMemberContext/RoomstayMemberContextProvider.js.map +1 -1
  510. package/dist/src/contexts/ModalContext.d.ts +1 -1
  511. package/dist/src/contexts/ModalContext.js +4 -5
  512. package/dist/src/contexts/ModalContext.js.map +1 -1
  513. package/dist/src/contexts/NotificationContext.d.ts +1 -1
  514. package/dist/src/contexts/NotificationContext.js +8 -31
  515. package/dist/src/contexts/NotificationContext.js.map +1 -1
  516. package/dist/src/engines/BaseEngine.js.map +1 -1
  517. package/dist/src/engines/BookingWizardEngine/BookingWizardEngine.js +2 -0
  518. package/dist/src/engines/BookingWizardEngine/BookingWizardEngine.js.map +1 -1
  519. package/dist/src/engines/BookingWizardEngine/BookingWizardEngineElement.js +4 -27
  520. package/dist/src/engines/BookingWizardEngine/BookingWizardEngineElement.js.map +1 -1
  521. package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngineElement.js +15 -35
  522. package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngineElement.js.map +1 -1
  523. package/dist/src/engines/InlineRoomMiniEngine/InlineRoomMiniEngineElement.js +67 -66
  524. package/dist/src/engines/InlineRoomMiniEngine/InlineRoomMiniEngineElement.js.map +1 -1
  525. package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngine.js.map +1 -1
  526. package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngineElement.js +20 -20
  527. package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngineElement.js.map +1 -1
  528. package/dist/src/events/RoomstayEvent.d.ts +0 -1
  529. package/dist/src/events/RoomstayEvent.js +0 -1
  530. package/dist/src/events/RoomstayEvent.js.map +1 -1
  531. package/dist/src/events/RoomstayEventManager.d.ts +2 -2
  532. package/dist/src/events/RoomstayEventManager.js +1 -1
  533. package/dist/src/events/RoomstayEventManager.js.map +1 -1
  534. package/dist/src/hooks/AutoFocusOnSelect.d.ts +1 -1
  535. package/dist/src/hooks/AutoFocusOnSelect.js.map +1 -1
  536. package/dist/src/hooks/BodyClickHook.d.ts +2 -4
  537. package/dist/src/hooks/BodyClickHook.js +3 -3
  538. package/dist/src/hooks/BodyClickHook.js.map +1 -1
  539. package/dist/src/hooks/CombineState.d.ts +1 -1
  540. package/dist/src/hooks/CombineState.js.map +1 -1
  541. package/dist/src/hooks/ConfirmationQuery.d.ts +3 -3
  542. package/dist/src/hooks/CurrentHotelHook.d.ts +1 -1
  543. package/dist/src/hooks/ElementSortHook.d.ts +1 -1
  544. package/dist/src/hooks/ElementSortHook.js +7 -27
  545. package/dist/src/hooks/ElementSortHook.js.map +1 -1
  546. package/dist/src/hooks/EventHook.d.ts +1 -1
  547. package/dist/src/hooks/EventHook.js.map +1 -1
  548. package/dist/src/hooks/KeyboardControlOnSelect.d.ts +3 -3
  549. package/dist/src/hooks/LoggedInUserHook.d.ts +6 -6
  550. package/dist/src/hooks/LoggedInUserHook.js.map +1 -1
  551. package/dist/src/hooks/Query.js +5 -25
  552. package/dist/src/hooks/Query.js.map +1 -1
  553. package/dist/src/hooks/VGSHooks.d.ts +4 -4
  554. package/dist/src/hooks/VGSHooks.js +16 -11
  555. package/dist/src/hooks/VGSHooks.js.map +1 -1
  556. package/dist/src/icons/Check.js +7 -27
  557. package/dist/src/icons/Check.js.map +1 -1
  558. package/dist/src/index.d.ts +3 -3
  559. package/dist/src/index.js +2 -17
  560. package/dist/src/index.js.map +1 -1
  561. package/dist/src/mockApi/AddonAPI.js +2 -1
  562. package/dist/src/mockApi/AddonAPI.js.map +1 -1
  563. package/dist/src/mockApi/MockAPI.d.ts +1 -1
  564. package/dist/src/mockApi/ReservationAPI.d.ts +1 -1
  565. package/dist/src/mockApi/ReservationAPI.js +2 -1
  566. package/dist/src/mockApi/ReservationAPI.js.map +1 -1
  567. package/dist/src/models/Addon/Addon.js +1 -1
  568. package/dist/src/models/Addon/Addon.js.map +1 -1
  569. package/dist/src/models/BasketAddonRow.d.ts +2 -2
  570. package/dist/src/models/BasketAddonRow.js +1 -1
  571. package/dist/src/models/BasketAddonRow.js.map +1 -1
  572. package/dist/src/models/BasketRow.d.ts +6 -6
  573. package/dist/src/models/BasketRow.js +3 -2
  574. package/dist/src/models/BasketRow.js.map +1 -1
  575. package/dist/src/models/BookingWizard/BookingWizardProperty.d.ts +1 -1
  576. package/dist/src/models/BookingWizard/BookingWizardProperty.js.map +1 -1
  577. package/dist/src/models/Client/Client.js.map +1 -1
  578. package/dist/src/models/Currency.d.ts +1 -1
  579. package/dist/src/models/Currency.js.map +1 -1
  580. package/dist/src/models/Room/Filters/BudgetFilter.d.ts +1 -1
  581. package/dist/src/models/Room/Filters/RoomTypeFilter.d.ts +1 -1
  582. package/dist/src/models/Room/Filters/RoomTypeFilter.js.map +1 -1
  583. package/dist/src/models/Room/Room.d.ts +10 -10
  584. package/dist/src/models/Room/Room.js +10 -8
  585. package/dist/src/models/Room/Room.js.map +1 -1
  586. package/dist/src/models/Room/RoomRate.d.ts +1 -1
  587. package/dist/src/models/Room/RoomRate.js +1 -1
  588. package/dist/src/models/Room/RoomRate.js.map +1 -1
  589. package/dist/src/models/Room/RoomRateNight.js.map +1 -1
  590. package/dist/src/models/RoomstaySession.d.ts +2 -2
  591. package/dist/src/models/RoomstaySession.js.map +1 -1
  592. package/dist/src/pages/account/AccountHome/AccountHomePage.js +31 -31
  593. package/dist/src/pages/account/AccountHome/AccountHomePage.js.map +1 -1
  594. package/dist/src/pages/account/AccountOutlet.d.ts +1 -1
  595. package/dist/src/pages/account/AccountOutlet.js +5 -25
  596. package/dist/src/pages/account/AccountOutlet.js.map +1 -1
  597. package/dist/src/pages/account/AccountRouter.js +12 -37
  598. package/dist/src/pages/account/AccountRouter.js.map +1 -1
  599. package/dist/src/pages/account/Details/AccountDetailsCardsPage.js +24 -28
  600. package/dist/src/pages/account/Details/AccountDetailsCardsPage.js.map +1 -1
  601. package/dist/src/pages/account/Details/AccountDetailsNoCardsPage.js +8 -8
  602. package/dist/src/pages/account/Details/AccountDetailsNoCardsPage.js.map +1 -1
  603. package/dist/src/pages/account/Details/AccountDetailsProfilePage.js +41 -42
  604. package/dist/src/pages/account/Details/AccountDetailsProfilePage.js.map +1 -1
  605. package/dist/src/pages/account/Help/AccountHelpPage.js +42 -44
  606. package/dist/src/pages/account/Help/AccountHelpPage.js.map +1 -1
  607. package/dist/src/pages/account/Reservations/AccountReservationSinglePage.js +78 -82
  608. package/dist/src/pages/account/Reservations/AccountReservationSinglePage.js.map +1 -1
  609. package/dist/src/pages/account/Reservations/AccountReservationsPage.js +17 -40
  610. package/dist/src/pages/account/Reservations/AccountReservationsPage.js.map +1 -1
  611. package/dist/src/pages/findReservation/FindReservation.js +81 -76
  612. package/dist/src/pages/findReservation/FindReservation.js.map +1 -1
  613. package/dist/src/pages/findReservation/FindReservationResults.js +33 -33
  614. package/dist/src/pages/findReservation/FindReservationResults.js.map +1 -1
  615. package/dist/src/pages/findReservation/ReservationRow.js +66 -65
  616. package/dist/src/pages/findReservation/ReservationRow.js.map +1 -1
  617. package/dist/src/pages/findReservation/ReservationRowModal.js +52 -52
  618. package/dist/src/pages/findReservation/ReservationRowModal.js.map +1 -1
  619. package/dist/src/pages/hotel/HotelInfo.js +88 -88
  620. package/dist/src/pages/hotel/HotelInfo.js.map +1 -1
  621. package/dist/src/pages/hotel/HotelInfoPlaceholder.js +4 -27
  622. package/dist/src/pages/hotel/HotelInfoPlaceholder.js.map +1 -1
  623. package/dist/src/pages/steps/Step.d.ts +2 -2
  624. package/dist/src/pages/steps/Step.js.map +1 -1
  625. package/dist/src/pages/steps/StepAddon/StepAddon.d.ts +1 -1
  626. package/dist/src/pages/steps/StepAddon/StepAddon.js.map +1 -1
  627. package/dist/src/pages/steps/StepAddon/StepAddonComponent.js +18 -41
  628. package/dist/src/pages/steps/StepAddon/StepAddonComponent.js.map +1 -1
  629. package/dist/src/pages/steps/StepAddon/StepAddonLoader.js +51 -51
  630. package/dist/src/pages/steps/StepAddon/StepAddonLoader.js.map +1 -1
  631. package/dist/src/pages/steps/StepConfirmation/StepConfirmation.d.ts +1 -1
  632. package/dist/src/pages/steps/StepConfirmation/StepConfirmation.js.map +1 -1
  633. package/dist/src/pages/steps/StepConfirmation/StepConfirmationComponent.js +28 -51
  634. package/dist/src/pages/steps/StepConfirmation/StepConfirmationComponent.js.map +1 -1
  635. package/dist/src/pages/steps/StepConfirmation/StepConfirmationLoader.js +72 -72
  636. package/dist/src/pages/steps/StepConfirmation/StepConfirmationLoader.js.map +1 -1
  637. package/dist/src/pages/steps/StepDate/StepDate.d.ts +14 -0
  638. package/dist/src/pages/steps/StepDate/StepDate.js.map +1 -1
  639. package/dist/src/pages/steps/StepDate/StepDateComponent.d.ts +2 -0
  640. package/dist/src/pages/steps/StepDate/StepDateComponent.js +46 -48
  641. package/dist/src/pages/steps/StepDate/StepDateComponent.js.map +1 -1
  642. package/dist/src/pages/steps/StepGuide.d.ts +1 -1
  643. package/dist/src/pages/steps/StepGuide.js +3 -26
  644. package/dist/src/pages/steps/StepGuide.js.map +1 -1
  645. package/dist/src/pages/steps/StepHotel/StepHotelComponent.js +21 -21
  646. package/dist/src/pages/steps/StepHotel/StepHotelComponent.js.map +1 -1
  647. package/dist/src/pages/steps/StepHotel/StepHotelLoader.js +43 -43
  648. package/dist/src/pages/steps/StepHotel/StepHotelLoader.js.map +1 -1
  649. package/dist/src/pages/steps/StepRoom/StepRoom.d.ts +1 -1
  650. package/dist/src/pages/steps/StepRoom/StepRoom.js.map +1 -1
  651. package/dist/src/pages/steps/StepRoom/StepRoomComponent.js +33 -33
  652. package/dist/src/pages/steps/StepRoom/StepRoomComponent.js.map +1 -1
  653. package/dist/src/pages/steps/StepRoom/StepRoomLoader.js +74 -74
  654. package/dist/src/pages/steps/StepRoom/StepRoomLoader.js.map +1 -1
  655. package/dist/src/pages/steps/StepThanks/StepThanks.d.ts +1 -1
  656. package/dist/src/pages/steps/StepThanks/StepThanks.js.map +1 -1
  657. package/dist/src/pages/steps/StepThanks/StepThanksComponent.js +28 -29
  658. package/dist/src/pages/steps/StepThanks/StepThanksComponent.js.map +1 -1
  659. package/dist/src/providers/CurrencyProvider.d.ts +1 -1
  660. package/dist/src/providers/DIProvider.js +5 -25
  661. package/dist/src/providers/DIProvider.js.map +1 -1
  662. package/dist/src/providers/FilterProvider.d.ts +1 -1
  663. package/dist/src/providers/FilterProvider.js +3 -2
  664. package/dist/src/providers/FilterProvider.js.map +1 -1
  665. package/dist/src/providers/LanguageProvider.d.ts +1 -1
  666. package/dist/src/providers/LanguageProvider.js.map +1 -1
  667. package/dist/src/providers/PromotionProvider.d.ts +1 -1
  668. package/dist/src/providers/PromotionProvider.js +1 -1
  669. package/dist/src/providers/PromotionProvider.js.map +1 -1
  670. package/dist/src/providers/RoomstayThemeEngine.d.ts +2 -2
  671. package/dist/src/providers/RoomstayThemeEngine.js +5 -7
  672. package/dist/src/providers/RoomstayThemeEngine.js.map +1 -1
  673. package/dist/src/providers/SessionProvider.js +4 -4
  674. package/dist/src/providers/SessionProvider.js.map +1 -1
  675. package/dist/src/providers/feature/Feature.d.ts +1 -1
  676. package/dist/src/providers/feature/Feature.js +3 -0
  677. package/dist/src/providers/feature/Feature.js.map +1 -1
  678. package/dist/src/providers/feature/InlineAddonStepFeature.js.map +1 -1
  679. package/dist/src/providers/feature/MemberPortalFeature.d.ts +0 -1
  680. package/dist/src/providers/feature/MemberPortalFeature.js +0 -1
  681. package/dist/src/providers/feature/MemberPortalFeature.js.map +1 -1
  682. package/dist/src/providers/feature/NumberOfPeopleBookedPillFeature.d.ts +0 -1
  683. package/dist/src/providers/feature/NumberOfPeopleBookedPillFeature.js +0 -1
  684. package/dist/src/providers/feature/NumberOfPeopleBookedPillFeature.js.map +1 -1
  685. package/dist/src/providers/storage/LocalStorageProvider.d.ts +2 -2
  686. package/dist/src/providers/storage/LocalStorageProvider.js.map +1 -1
  687. package/dist/src/reducers/BasketReducer.js +3 -2
  688. package/dist/src/reducers/BasketReducer.js.map +1 -1
  689. package/dist/src/routes/NaturallyProgressedStepRoute.js +6 -29
  690. package/dist/src/routes/NaturallyProgressedStepRoute.js.map +1 -1
  691. package/dist/src/stories/Alert.stories.d.ts +2 -2
  692. package/dist/src/stories/Alert.stories.js +2 -25
  693. package/dist/src/stories/Alert.stories.js.map +1 -1
  694. package/dist/src/stories/BEButton.stories.d.ts +2 -2
  695. package/dist/src/stories/BEButton.stories.js +2 -25
  696. package/dist/src/stories/BEButton.stories.js.map +1 -1
  697. package/dist/src/stories/BackButton.stories.d.ts +2 -2
  698. package/dist/src/stories/BackButton.stories.js +2 -25
  699. package/dist/src/stories/BackButton.stories.js.map +1 -1
  700. package/dist/src/stories/BookNowPayLaterInfoBlock.stories.d.ts +2 -2
  701. package/dist/src/stories/BookNowPayLaterInfoBlock.stories.js +4 -24
  702. package/dist/src/stories/BookNowPayLaterInfoBlock.stories.js.map +1 -1
  703. package/dist/src/stories/BookingWizard.stories.d.ts +5 -5
  704. package/dist/src/stories/BookingWizard.stories.js +25 -9
  705. package/dist/src/stories/BookingWizard.stories.js.map +1 -1
  706. package/dist/src/stories/Card.stories.d.ts +6 -3
  707. package/dist/src/stories/CardTypeSelect.stories.d.ts +3 -3
  708. package/dist/src/stories/CardTypeSelect.stories.js +4 -24
  709. package/dist/src/stories/CardTypeSelect.stories.js.map +1 -1
  710. package/dist/src/stories/Checkbox.stories.d.ts +3 -3
  711. package/dist/src/stories/Checkbox.stories.js +2 -25
  712. package/dist/src/stories/Checkbox.stories.js.map +1 -1
  713. package/dist/src/stories/ConfirmationModal.stories.js +6 -29
  714. package/dist/src/stories/ConfirmationModal.stories.js.map +1 -1
  715. package/dist/src/stories/Countdown.stories.d.ts +2 -2
  716. package/dist/src/stories/Countdown.stories.js +4 -27
  717. package/dist/src/stories/Countdown.stories.js.map +1 -1
  718. package/dist/src/stories/Currency.stories.d.ts +2 -2
  719. package/dist/src/stories/Currency.stories.js +2 -25
  720. package/dist/src/stories/Currency.stories.js.map +1 -1
  721. package/dist/src/stories/DateRangePicker.stories.js +25 -15
  722. package/dist/src/stories/DateRangePicker.stories.js.map +1 -1
  723. package/dist/src/stories/Distance.stories.d.ts +2 -2
  724. package/dist/src/stories/Distance.stories.js +2 -25
  725. package/dist/src/stories/Distance.stories.js.map +1 -1
  726. package/dist/src/stories/EnhancedPhoneNumberField.stories.d.ts +5 -0
  727. package/dist/src/stories/EnhancedPhoneNumberField.stories.js +2 -25
  728. package/dist/src/stories/EnhancedPhoneNumberField.stories.js.map +1 -1
  729. package/dist/src/stories/ErrorModal.stories.js +7 -30
  730. package/dist/src/stories/ErrorModal.stories.js.map +1 -1
  731. package/dist/src/stories/FloatingDateRangePicker.stories.d.ts +1 -1
  732. package/dist/src/stories/FloatingDateRangePicker.stories.js +15 -38
  733. package/dist/src/stories/FloatingDateRangePicker.stories.js.map +1 -1
  734. package/dist/src/stories/ForwardedSelect.stories.d.ts +3 -3
  735. package/dist/src/stories/ForwardedSelect.stories.js +4 -27
  736. package/dist/src/stories/ForwardedSelect.stories.js.map +1 -1
  737. package/dist/src/stories/Headline.stories.d.ts +2 -2
  738. package/dist/src/stories/Headline.stories.js +2 -25
  739. package/dist/src/stories/Headline.stories.js.map +1 -1
  740. package/dist/src/stories/Icon.stories.d.ts +2 -2
  741. package/dist/src/stories/Icon.stories.js +5 -2
  742. package/dist/src/stories/Icon.stories.js.map +1 -1
  743. package/dist/src/stories/IconNavCard.stories.d.ts +18 -8
  744. package/dist/src/stories/IconNavCard.stories.js +5 -25
  745. package/dist/src/stories/IconNavCard.stories.js.map +1 -1
  746. package/dist/src/stories/IconText.stories.d.ts +5 -0
  747. package/dist/src/stories/IconText.stories.js +4 -6
  748. package/dist/src/stories/IconText.stories.js.map +1 -1
  749. package/dist/src/stories/ImageLoader.stories.d.ts +2 -2
  750. package/dist/src/stories/ImageLoader.stories.js +2 -25
  751. package/dist/src/stories/ImageLoader.stories.js.map +1 -1
  752. package/dist/src/stories/InputGroup.stories.d.ts +2 -2
  753. package/dist/src/stories/InputGroup.stories.js +3 -26
  754. package/dist/src/stories/InputGroup.stories.js.map +1 -1
  755. package/dist/src/stories/LargeLoader.stories.d.ts +2 -2
  756. package/dist/src/stories/LargeLoader.stories.js +2 -25
  757. package/dist/src/stories/LargeLoader.stories.js.map +1 -1
  758. package/dist/src/stories/LineBreak.stories.d.ts +2 -2
  759. package/dist/src/stories/LineBreak.stories.js +2 -25
  760. package/dist/src/stories/LineBreak.stories.js.map +1 -1
  761. package/dist/src/stories/Notification.stories.d.ts +2 -2
  762. package/dist/src/stories/Notification.stories.js +2 -25
  763. package/dist/src/stories/Notification.stories.js.map +1 -1
  764. package/dist/src/stories/NumberIncrement.stories.js +6 -28
  765. package/dist/src/stories/NumberIncrement.stories.js.map +1 -1
  766. package/dist/src/stories/PasswordBox.stories.d.ts +3 -3
  767. package/dist/src/stories/PasswordBox.stories.js +4 -24
  768. package/dist/src/stories/PasswordBox.stories.js.map +1 -1
  769. package/dist/src/stories/PaymentCard.stories.d.ts +2 -2
  770. package/dist/src/stories/PaymentCard.stories.js +4 -24
  771. package/dist/src/stories/PaymentCard.stories.js.map +1 -1
  772. package/dist/src/stories/PaymentCardInput.stories.d.ts +4 -4
  773. package/dist/src/stories/PaymentCardInput.stories.js +13 -25
  774. package/dist/src/stories/PaymentCardInput.stories.js.map +1 -1
  775. package/dist/src/stories/Pill.stories.d.ts +2 -2
  776. package/dist/src/stories/Pill.stories.js +2 -25
  777. package/dist/src/stories/Pill.stories.js.map +1 -1
  778. package/dist/src/stories/Placeholder.stories.d.ts +2 -2
  779. package/dist/src/stories/Placeholder.stories.js +2 -25
  780. package/dist/src/stories/Placeholder.stories.js.map +1 -1
  781. package/dist/src/stories/PlanpayButton.stories.d.ts +3 -3
  782. package/dist/src/stories/PlanpayButton.stories.js +4 -24
  783. package/dist/src/stories/PlanpayButton.stories.js.map +1 -1
  784. package/dist/src/stories/PromoCodeInput.stories.d.ts +2 -2
  785. package/dist/src/stories/PromoCodeInput.stories.js +2 -25
  786. package/dist/src/stories/PromoCodeInput.stories.js.map +1 -1
  787. package/dist/src/stories/RadioButton.stories.d.ts +4 -4
  788. package/dist/src/stories/RadioButton.stories.js +4 -24
  789. package/dist/src/stories/RadioButton.stories.js.map +1 -1
  790. package/dist/src/stories/RadioButtonGroup.stories.d.ts +2 -2
  791. package/dist/src/stories/RadioButtonGroup.stories.js +4 -27
  792. package/dist/src/stories/RadioButtonGroup.stories.js.map +1 -1
  793. package/dist/src/stories/RadioFields.stories.d.ts +2 -2
  794. package/dist/src/stories/RadioFields.stories.js +2 -25
  795. package/dist/src/stories/RadioFields.stories.js.map +1 -1
  796. package/dist/src/stories/SSLSecureBadge.stories.d.ts +2 -2
  797. package/dist/src/stories/SSLSecureBadge.stories.js +1 -1
  798. package/dist/src/stories/SSLSecureBadge.stories.js.map +1 -1
  799. package/dist/src/stories/Select.stories.d.ts +14 -14
  800. package/dist/src/stories/Select.stories.js +18 -38
  801. package/dist/src/stories/Select.stories.js.map +1 -1
  802. package/dist/src/stories/SimpleModal.stories.js +11 -33
  803. package/dist/src/stories/SimpleModal.stories.js.map +1 -1
  804. package/dist/src/stories/Slider.stories.d.ts +4 -4
  805. package/dist/src/stories/Slider.stories.js +6 -26
  806. package/dist/src/stories/Slider.stories.js.map +1 -1
  807. package/dist/src/stories/SmallSpinner.stories.d.ts +2 -2
  808. package/dist/src/stories/SmallSpinner.stories.js +2 -25
  809. package/dist/src/stories/SmallSpinner.stories.js.map +1 -1
  810. package/dist/src/stories/TabbedModal.stories.js +6 -29
  811. package/dist/src/stories/TabbedModal.stories.js.map +1 -1
  812. package/dist/src/stories/Tabs.stories.d.ts +1 -1
  813. package/dist/src/stories/Tabs.stories.js +7 -30
  814. package/dist/src/stories/Tabs.stories.js.map +1 -1
  815. package/dist/src/stories/Text.stories.d.ts +2 -2
  816. package/dist/src/stories/Text.stories.js +2 -25
  817. package/dist/src/stories/Text.stories.js.map +1 -1
  818. package/dist/src/stories/TextArea.stories.d.ts +3 -3
  819. package/dist/src/stories/TextArea.stories.js +2 -25
  820. package/dist/src/stories/TextArea.stories.js.map +1 -1
  821. package/dist/src/stories/TextBox.stories.d.ts +3 -3
  822. package/dist/src/stories/TextBox.stories.js +2 -25
  823. package/dist/src/stories/TextBox.stories.js.map +1 -1
  824. package/dist/src/stories/Tooltip.stories.d.ts +2 -2
  825. package/dist/src/stories/Tooltip.stories.js +2 -25
  826. package/dist/src/stories/Tooltip.stories.js.map +1 -1
  827. package/dist/src/translations/Translation.d.ts +4 -0
  828. package/dist/src/translations/Translation.js +4 -0
  829. package/dist/src/translations/Translation.js.map +1 -1
  830. package/dist/src/translations/languages/en-gb.js +4 -0
  831. package/dist/src/translations/languages/en-gb.js.map +1 -1
  832. package/dist/src/util/AsyncAuth.d.ts +5 -0
  833. package/dist/src/util/AsyncAuth.js +44 -0
  834. package/dist/src/util/AsyncAuth.js.map +1 -0
  835. package/dist/src/util/DataLayer.js +3 -3
  836. package/dist/src/util/DataLayer.js.map +1 -1
  837. package/dist/src/util/EnumHelper.d.ts +1 -1
  838. package/dist/src/util/EnumHelper.js +1 -1
  839. package/dist/src/util/EnumHelper.js.map +1 -1
  840. package/dist/src/util/ObjectHelper.d.ts +1 -1
  841. package/dist/src/util/PaymentCardHelper.js +2 -1
  842. package/dist/src/util/PaymentCardHelper.js.map +1 -1
  843. package/dist/src/util/StepManager.d.ts +1 -1
  844. package/dist/src/util/Validation.d.ts +0 -1
  845. package/dist/src/util/Validation.js +3 -4
  846. package/dist/src/util/Validation.js.map +1 -1
  847. package/dist/test.bundle.js +1 -1
  848. package/dist/tests/jest/engines/RoomstayThemeEngine.test.js +5 -3
  849. package/dist/tests/jest/engines/RoomstayThemeEngine.test.js.map +1 -1
  850. package/dist/tests/jest/providers/LanguageProvider.test.js +6 -4
  851. package/dist/tests/jest/providers/LanguageProvider.test.js.map +1 -1
  852. package/dist/tests/jest/providers/SessionProvider.test.js +12 -10
  853. package/dist/tests/jest/providers/SessionProvider.test.js.map +1 -1
  854. package/dist/tests/jest/reducers/BasketReducer.test.js +2 -1
  855. package/dist/tests/jest/reducers/BasketReducer.test.js.map +1 -1
  856. package/dist/tests/offline/RoomstayBestRateAlert.js +6 -6
  857. package/dist/tests/offline/RoomstayBestRateAlert.js.map +1 -1
  858. package/dist/tests/offline/entry/ReactWrapper.js +26 -49
  859. package/dist/tests/offline/entry/ReactWrapper.js.map +1 -1
  860. package/dist/tests/offline/entry/allEngines.js +2 -2
  861. package/dist/tests/offline/entry/allEngines.js.map +1 -1
  862. package/dist/tests/offline/entry/components/TestPicker.js +42 -52
  863. package/dist/tests/offline/entry/components/TestPicker.js.map +1 -1
  864. package/dist/tests/setupTests.js +1 -0
  865. package/dist/tests/setupTests.js.map +1 -1
  866. package/dist/vendors.bundle.js +1 -1
  867. package/dist/vendors.bundle.js.LICENSE.txt +0 -31
  868. package/package.json +11 -5
  869. package/dist/src/pages/account/Reservations/AccountReservationCancelledPage.d.ts +0 -1
  870. package/dist/src/pages/account/Reservations/AccountReservationCancelledPage.js +0 -133
  871. package/dist/src/pages/account/Reservations/AccountReservationCancelledPage.js.map +0 -1
  872. package/dist/src/pages/account/Reservations/AccountReservationMultiplePage.d.ts +0 -2
  873. package/dist/src/pages/account/Reservations/AccountReservationMultiplePage.js +0 -158
  874. package/dist/src/pages/account/Reservations/AccountReservationMultiplePage.js.map +0 -1
@@ -1,37 +1,14 @@
1
1
  "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
2
  var __importDefault = (this && this.__importDefault) || function (mod) {
26
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
4
  };
28
5
  Object.defineProperty(exports, "__esModule", { value: true });
29
- const React = __importStar(require("react"));
6
+ const react_1 = __importDefault(require("react"));
30
7
  const RoomstayThemeEngine_1 = __importDefault(require("../../../providers/RoomstayThemeEngine"));
31
8
  const Tooltip_1 = __importDefault(require("../Tooltip/Tooltip"));
32
9
  function SSLSecureBadge() {
33
- return (React.createElement(Tooltip_1.default, { title: "Shop without worries! This site is protected by high level encryption, to ensure every purchase is always safe & secure" },
34
- React.createElement("img", { src: RoomstayThemeEngine_1.default.getAssetUrl() + 'assets/img/ssl-secure-connection.png' })));
10
+ return (react_1.default.createElement(Tooltip_1.default, { title: "Shop without worries! This site is protected by high level encryption, to ensure every purchase is always safe & secure" },
11
+ react_1.default.createElement("img", { src: RoomstayThemeEngine_1.default.getAssetUrl() + 'assets/img/ssl-secure-connection.png' })));
35
12
  }
36
13
  exports.default = SSLSecureBadge;
37
14
  //# sourceMappingURL=SSLSecureBadge.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SSLSecureBadge.js","sourceRoot":"/","sources":["src/components/generic/badging/SSLSecureBadge.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6CAA+B;AAC/B,0FAAkE;AAClE,mFAA2D;AAE3D,SAAwB,cAAc;IAClC,OAAO,CACH,oBAAC,iBAAO,IAAC,KAAK,EAAC,yHAAyH;QACpI,6BAAK,GAAG,EAAE,6BAAmB,CAAC,WAAW,EAAE,GAAG,sCAAsC,GAAI,CAClF,CACb,CAAC;AACN,CAAC;AAND,iCAMC","sourcesContent":["import * as React from 'react';\nimport RoomstayThemeEngine from '@/providers/RoomstayThemeEngine';\nimport Tooltip from '@/components/generic/Tooltip/Tooltip';\n\nexport default function SSLSecureBadge() {\n return (\n <Tooltip title=\"Shop without worries! This site is protected by high level encryption, to ensure every purchase is always safe & secure\">\n <img src={RoomstayThemeEngine.getAssetUrl() + 'assets/img/ssl-secure-connection.png'} />\n </Tooltip>\n );\n}\n"]}
1
+ {"version":3,"file":"SSLSecureBadge.js","sourceRoot":"/","sources":["src/components/generic/badging/SSLSecureBadge.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAC1B,0FAAkE;AAClE,mFAA2D;AAE3D,SAAwB,cAAc;IAClC,OAAO,CACH,8BAAC,iBAAO,IAAC,KAAK,EAAC,yHAAyH;QACpI,uCAAK,GAAG,EAAE,6BAAmB,CAAC,WAAW,EAAE,GAAG,sCAAsC,GAAI,CAClF,CACb,CAAC;AACN,CAAC;AAND,iCAMC","sourcesContent":["import React from 'react';\nimport RoomstayThemeEngine from '@/providers/RoomstayThemeEngine';\nimport Tooltip from '@/components/generic/Tooltip/Tooltip';\n\nexport default function SSLSecureBadge() {\n return (\n <Tooltip title=\"Shop without worries! This site is protected by high level encryption, to ensure every purchase is always safe & secure\">\n <img src={RoomstayThemeEngine.getAssetUrl() + 'assets/img/ssl-secure-connection.png'} />\n </Tooltip>\n );\n}\n"]}
@@ -1,27 +1,4 @@
1
1
  "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
2
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
3
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
4
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -35,22 +12,22 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
35
12
  return (mod && mod.__esModule) ? mod : { "default": mod };
36
13
  };
37
14
  Object.defineProperty(exports, "__esModule", { value: true });
38
- const React = __importStar(require("react"));
39
- const react_1 = require("react");
15
+ const react_1 = __importDefault(require("react"));
16
+ const react_2 = require("react");
40
17
  const BEButton_1 = __importDefault(require("../BEButton"));
41
18
  const Icon_1 = require("../Icon/Icon");
42
19
  const ScreenSize_1 = __importDefault(require("../../../util/ScreenSize"));
43
20
  const StepManager_1 = __importDefault(require("../../../util/StepManager"));
44
21
  const contexts_1 = require("../../../contexts/index.js");
45
22
  function NextStepButton(props) {
46
- const context = (0, react_1.useContext)(contexts_1.BookingEngineContext);
23
+ const context = (0, react_2.useContext)(contexts_1.BookingEngineContext);
47
24
  const buttonClickHandler = () => __awaiter(this, void 0, void 0, function* () {
48
25
  if (!props.onClick || (props.onClick && (yield props.onClick()))) {
49
26
  props.history.push(StepManager_1.default.getNextStepUrl(props.currentStep));
50
27
  }
51
28
  });
52
- return (React.createElement("div", { className: "next-step-button" },
53
- React.createElement(BEButton_1.default, { size: 'large', icon: props.hideIcon ? null : Icon_1.IconType.ArrowRight, iconPosition: "right", filled: true, primary: true, isLoading: props.isLoading, disabled: props.disabled, wide: props.wideByDefault || context.screenSize <= ScreenSize_1.default.Medium, onClick: buttonClickHandler }, props.text)));
29
+ return (react_1.default.createElement("div", { className: "next-step-button" },
30
+ react_1.default.createElement(BEButton_1.default, { size: "large", icon: props.hideIcon ? undefined : Icon_1.IconType.ArrowRight, iconPosition: "right", filled: true, primary: true, isLoading: props.isLoading, disabled: props.disabled, wide: props.wideByDefault || context.screenSize <= ScreenSize_1.default.Medium, onClick: buttonClickHandler }, props.text)));
54
31
  }
55
32
  exports.default = NextStepButton;
56
33
  //# sourceMappingURL=NextStepButton.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NextStepButton.js","sourceRoot":"/","sources":["src/components/generic/buttons/NextStepButton.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6CAA+B;AAC/B,iCAAmC;AACnC,6EAAqD;AACrD,yDAA0D;AAE1D,mEAA2C;AAE3C,qEAA6C;AAC7C,iDAA0D;AAe1D,SAAwB,cAAc,CAAC,KAA0B;IAC7D,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,+BAAoB,CAAC,CAAC;IACjD,MAAM,kBAAkB,GAAG,GAAS,EAAE;QAClC,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,MAAM,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE;YAC9D,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;SACrE;IACL,CAAC,CAAA,CAAC;IACF,OAAO,CACH,6BAAK,SAAS,EAAC,kBAAkB;QAC7B,oBAAC,kBAAQ,IACL,IAAI,EAAE,OAAO,EACb,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,eAAQ,CAAC,UAAU,EACjD,YAAY,EAAC,OAAO,EACpB,MAAM,EAAE,IAAI,EACZ,OAAO,EAAE,IAAI,EACb,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,QAAQ,EAAE,KAAK,CAAC,QAAQ,EACxB,IAAI,EAAE,KAAK,CAAC,aAAa,IAAI,OAAO,CAAC,UAAU,IAAI,oBAAU,CAAC,MAAM,EACpE,OAAO,EAAE,kBAAkB,IAE1B,KAAK,CAAC,IAAI,CACJ,CACT,CACT,CAAC;AACN,CAAC;AAxBD,iCAwBC","sourcesContent":["import * as React from 'react';\nimport { useContext } from 'react';\nimport BEButton from '@/components/generic/BEButton';\nimport { IconType } from '@/components/generic/Icon/Icon';\n\nimport ScreenSize from '@/util/ScreenSize';\nimport Step from '@/pages/steps/Step';\nimport StepManager from '@/util/StepManager';\nimport { BookingEngineContext } from '@frontend/contexts';\n\nexport interface NextStepButtonProps {\n text: string;\n history: any;\n currentStep: Step;\n\n disabled?: boolean;\n isLoading?: boolean;\n onClick?: () => Promise<unknown>;\n wideByDefault?: boolean;\n\n hideIcon?: boolean;\n}\n\nexport default function NextStepButton(props: NextStepButtonProps) {\n const context = useContext(BookingEngineContext);\n const buttonClickHandler = async () => {\n if (!props.onClick || (props.onClick && (await props.onClick()))) {\n props.history.push(StepManager.getNextStepUrl(props.currentStep));\n }\n };\n return (\n <div className=\"next-step-button\">\n <BEButton\n size={'large'}\n icon={props.hideIcon ? null : IconType.ArrowRight}\n iconPosition=\"right\"\n filled={true}\n primary={true}\n isLoading={props.isLoading}\n disabled={props.disabled}\n wide={props.wideByDefault || context.screenSize <= ScreenSize.Medium}\n onClick={buttonClickHandler}\n >\n {props.text}\n </BEButton>\n </div>\n );\n}\n"]}
1
+ {"version":3,"file":"NextStepButton.js","sourceRoot":"/","sources":["src/components/generic/buttons/NextStepButton.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,kDAA0B;AAC1B,iCAAmC;AACnC,6EAAqD;AACrD,yDAA0D;AAE1D,mEAA2C;AAE3C,qEAA6C;AAC7C,iDAA0D;AAe1D,SAAwB,cAAc,CAAC,KAA0B;IAC7D,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,+BAAoB,CAAC,CAAC;IACjD,MAAM,kBAAkB,GAAG,GAAS,EAAE;QAClC,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,MAAM,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE;YAC9D,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;SACrE;IACL,CAAC,CAAA,CAAC;IACF,OAAO,CACH,uCAAK,SAAS,EAAC,kBAAkB;QAC7B,8BAAC,kBAAQ,IACL,IAAI,EAAC,OAAO,EACZ,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,eAAQ,CAAC,UAAU,EACtD,YAAY,EAAC,OAAO,EACpB,MAAM,QACN,OAAO,QACP,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,QAAQ,EAAE,KAAK,CAAC,QAAQ,EACxB,IAAI,EAAE,KAAK,CAAC,aAAa,IAAI,OAAO,CAAC,UAAU,IAAI,oBAAU,CAAC,MAAM,EACpE,OAAO,EAAE,kBAAkB,IAE1B,KAAK,CAAC,IAAI,CACJ,CACT,CACT,CAAC;AACN,CAAC;AAxBD,iCAwBC","sourcesContent":["import React from 'react';\nimport { useContext } from 'react';\nimport BEButton from '@/components/generic/BEButton';\nimport { IconType } from '@/components/generic/Icon/Icon';\n\nimport ScreenSize from '@/util/ScreenSize';\nimport Step from '@/pages/steps/Step';\nimport StepManager from '@/util/StepManager';\nimport { BookingEngineContext } from '@frontend/contexts';\n\nexport interface NextStepButtonProps {\n text: string;\n history: any;\n currentStep: Step;\n\n disabled?: boolean;\n isLoading?: boolean;\n onClick?: () => Promise<unknown>;\n wideByDefault?: boolean;\n\n hideIcon?: boolean;\n}\n\nexport default function NextStepButton(props: NextStepButtonProps) {\n const context = useContext(BookingEngineContext);\n const buttonClickHandler = async () => {\n if (!props.onClick || (props.onClick && (await props.onClick()))) {\n props.history.push(StepManager.getNextStepUrl(props.currentStep));\n }\n };\n return (\n <div className=\"next-step-button\">\n <BEButton\n size=\"large\"\n icon={props.hideIcon ? undefined : IconType.ArrowRight}\n iconPosition=\"right\"\n filled\n primary\n isLoading={props.isLoading}\n disabled={props.disabled}\n wide={props.wideByDefault || context.screenSize <= ScreenSize.Medium}\n onClick={buttonClickHandler}\n >\n {props.text}\n </BEButton>\n </div>\n );\n}\n"]}
@@ -1,13 +1,12 @@
1
- import * as React from 'react';
2
- import { ChangeEvent, ForwardRefRenderFunction, PropsWithChildren } from 'react';
1
+ import React from 'react';
2
+ import { ChangeEvent, PropsWithChildren } from 'react';
3
3
  import './EnhancedPhoneNumberField.global.scss';
4
- interface EnhancedPhoneNumberField extends PropsWithChildren<any> {
4
+ export interface EnhancedPhoneNumberField extends PropsWithChildren<any> {
5
5
  validationStatus?: 'success' | 'error';
6
6
  name?: string;
7
7
  value?: string;
8
8
  onChange?: (e: ChangeEvent<HTMLInputElement>) => void;
9
9
  disabled?: boolean;
10
10
  }
11
- declare const EnhancedPhoneNumberField: ForwardRefRenderFunction<HTMLInputElement, EnhancedPhoneNumberField>;
12
11
  declare const _default: React.ForwardRefExoticComponent<Pick<React.PropsWithChildren<EnhancedPhoneNumberField>, keyof EnhancedPhoneNumberField> & React.RefAttributes<HTMLInputElement>>;
13
12
  export default _default;
@@ -27,8 +27,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
27
27
  };
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
29
  const classnames_1 = __importDefault(require("classnames"));
30
- const React = __importStar(require("react"));
31
- const react_1 = require("react");
30
+ const react_1 = __importDefault(require("react"));
31
+ const react_2 = require("react");
32
32
  const react_i18next_1 = require("react-i18next");
33
33
  const CountryCodesAndNumbers_1 = require("../../../../models/CountryCodesAndNumbers");
34
34
  const Translation_1 = require("translations/Translation");
@@ -38,34 +38,25 @@ const AutoFocusOnSelect_1 = require("../../../../hooks/AutoFocusOnSelect");
38
38
  const Select_1 = require("../../Select/Select");
39
39
  const PHONE_AND_PREFIX_SPLIT = ' ';
40
40
  const EnhancedPhoneNumberField = (props, ref) => {
41
- const innerRef = (0, react_1.useRef)(null);
42
- (0, react_1.useImperativeHandle)(ref, () => innerRef.current);
41
+ const innerRef = (0, react_2.useRef)(null);
42
+ (0, react_2.useImperativeHandle)(ref, () => innerRef.current);
43
43
  const { onDropdownClosed, onItemSelected, onTriggerClicked, isDropdownOpen, isFocused } = (0, AutoFocusOnSelect_1.useAutoFocusOnSelect)({
44
44
  ref: innerRef.current,
45
45
  onlyAutoOpenWhenInputEmpty: true,
46
46
  });
47
47
  const { t } = (0, react_i18next_1.useTranslation)();
48
- const organizedCountries = (0, react_1.useMemo)(() => {
48
+ const organizedCountries = (0, react_2.useMemo)(() => {
49
49
  return CountryCodesAndNumbers_1.ListOfCountriesAndCodes.sort((a, b) => {
50
50
  return `${(a.suggested ? '000' : '') + a.label}`.localeCompare(`${(b.suggested ? '000' : '') + b.label}`);
51
51
  });
52
52
  }, [CountryCodesAndNumbers_1.ListOfCountriesAndCodes]);
53
- const [container, setContainer] = (0, react_1.useState)(null);
53
+ const [container, setContainer] = (0, react_2.useState)(null);
54
54
  const { validationStatus, name, onChange, value } = props;
55
- const [selectedCountry, subscriberCode] = (0, react_1.useMemo)(() => {
55
+ const [selectedCountry, subscriberCode] = (0, react_2.useMemo)(() => {
56
56
  var _a;
57
57
  const [prefix, number] = (_a = value === null || value === void 0 ? void 0 : value.split(PHONE_AND_PREFIX_SPLIT)) !== null && _a !== void 0 ? _a : [];
58
- let selectedCountry;
59
58
  if (prefix) {
60
- for (const country of organizedCountries) {
61
- if (prefix === `${country.phone}`) {
62
- selectedCountry = country;
63
- break;
64
- }
65
- }
66
- if (!selectedCountry) {
67
- selectedCountry = organizedCountries[0];
68
- }
59
+ const selectedCountry = organizedCountries.find(({ phone }) => prefix === phone) || organizedCountries[0];
69
60
  return [selectedCountry, number];
70
61
  }
71
62
  return [organizedCountries[0], ''];
@@ -101,25 +92,25 @@ const EnhancedPhoneNumberField = (props, ref) => {
101
92
  onPrefixChanged(country);
102
93
  return;
103
94
  };
104
- return (React.createElement("div", { className: fieldClasses },
105
- React.createElement("div", { className: "rs-enhanced-phone-field--country", onClick: onTriggerClicked },
106
- React.createElement("div", { className: "rs-enhanced-phone-field--country-icon" }, (0, CountryCodesAndNumbers_1.convertCountryCodeToFlag)(selectedCountry.code)),
107
- React.createElement(Icon_1.default, { icon: Icon_1.IconType.Dropdown })),
108
- React.createElement("div", { className: "rs-enhanced-phone-field--number" },
109
- React.createElement("span", { className: "rs-enhanced-phone-field--number-prefix" },
95
+ return (react_1.default.createElement("div", { className: fieldClasses },
96
+ react_1.default.createElement("div", { className: "rs-enhanced-phone-field--country", onClick: onTriggerClicked },
97
+ react_1.default.createElement("div", { className: "rs-enhanced-phone-field--country-icon" }, (0, CountryCodesAndNumbers_1.convertCountryCodeToFlag)(selectedCountry.code)),
98
+ react_1.default.createElement(Icon_1.default, { icon: Icon_1.IconType.Dropdown })),
99
+ react_1.default.createElement("div", { className: "rs-enhanced-phone-field--number" },
100
+ react_1.default.createElement("span", { className: "rs-enhanced-phone-field--number-prefix" },
110
101
  "+",
111
102
  selectedCountry.phone),
112
- React.createElement("input", { disabled: props.disabled, ref: innerRef, placeholder: t(Translation_1.Translation.Step.Confirmation.Inputs.Phone) + ' *', type: "number", style: { paddingLeft: selectedCountry.phone.length * 8 + 20 + 'px' }, onChange: onInputChanged, value: subscriberCode }),
113
- React.createElement("div", { className: "rs-enhanced-phone-field--number-status" })),
114
- React.createElement("div", { className: "rs-enhanced-phone-field--anchor", ref: setContainer }),
115
- React.createElement(Select_1.Select, { open: isDropdownOpen, onClose: onDropdownClosed, target: container, options: organizedCountries, value: selectedCountry.code, onChange: (value) => onCountryClick(getOption(value)), labelName: "code", keyName: "code", renderOption: (country) => (React.createElement("div", { className: "rs-enhanced-phone-field--suggest-list-country" },
116
- React.createElement("div", { className: "rs-enhanced-phone-field--suggest-list-country-icon" }, (0, CountryCodesAndNumbers_1.convertCountryCodeToFlag)(country.code)),
117
- React.createElement("div", { className: "rs-enhanced-phone-field--suggest-list-country-name" },
103
+ react_1.default.createElement("input", { disabled: props.disabled, ref: innerRef, placeholder: t(Translation_1.Translation.Step.Confirmation.Inputs.Phone) + ' *', type: "number", style: { paddingLeft: selectedCountry.phone.length * 8 + 20 + 'px' }, onChange: onInputChanged, value: subscriberCode }),
104
+ react_1.default.createElement("div", { className: "rs-enhanced-phone-field--number-status" })),
105
+ react_1.default.createElement("div", { className: "rs-enhanced-phone-field--anchor", ref: setContainer }),
106
+ react_1.default.createElement(Select_1.Select, { open: isDropdownOpen, onClose: onDropdownClosed, target: container, options: organizedCountries, value: selectedCountry.code, onChange: (value) => onCountryClick(getOption(value)), labelName: "code", keyName: "code", renderOption: (country) => (react_1.default.createElement("div", { className: "rs-enhanced-phone-field--suggest-list-country" },
107
+ react_1.default.createElement("div", { className: "rs-enhanced-phone-field--suggest-list-country-icon" }, (0, CountryCodesAndNumbers_1.convertCountryCodeToFlag)(country === null || country === void 0 ? void 0 : country.code)),
108
+ react_1.default.createElement("div", { className: "rs-enhanced-phone-field--suggest-list-country-name" }, country === null || country === void 0 ? void 0 :
118
109
  country.label,
119
110
  " ",
120
- React.createElement("span", null,
121
- "+",
111
+ react_1.default.createElement("span", null,
112
+ "+", country === null || country === void 0 ? void 0 :
122
113
  country.phone)))) })));
123
114
  };
124
- exports.default = React.forwardRef(EnhancedPhoneNumberField);
115
+ exports.default = react_1.default.forwardRef(EnhancedPhoneNumberField);
125
116
  //# sourceMappingURL=EnhancedPhoneNumberField.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"EnhancedPhoneNumberField.js","sourceRoot":"/","sources":["src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.tsx"],"names":[],"mappings":"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","sourcesContent":["import classNames from 'classnames';\nimport * as React from 'react';\nimport { ChangeEvent, ForwardRefRenderFunction, PropsWithChildren, useImperativeHandle, useMemo, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { convertCountryCodeToFlag, CountryType, ListOfCountriesAndCodes } from '@/models/CountryCodesAndNumbers';\nimport { Translation } from 'translations/Translation';\nimport Icon, { IconType } from '@/components/generic/Icon/Icon';\n\nimport './EnhancedPhoneNumberField.global.scss';\nimport { useAutoFocusOnSelect } from '@/hooks/AutoFocusOnSelect';\nimport { Select } from '../../Select/Select';\n\ninterface EnhancedPhoneNumberField extends PropsWithChildren<any> {\n validationStatus?: 'success' | 'error';\n name?: string;\n value?: string;\n onChange?: (e: ChangeEvent<HTMLInputElement>) => void;\n disabled?: boolean;\n}\n\nconst PHONE_AND_PREFIX_SPLIT = ' ';\n\nconst EnhancedPhoneNumberField: ForwardRefRenderFunction<HTMLInputElement, EnhancedPhoneNumberField> = (props, ref) => {\n const innerRef = useRef<HTMLInputElement>(null);\n useImperativeHandle(ref, () => innerRef.current);\n const { onDropdownClosed, onItemSelected, onTriggerClicked, isDropdownOpen, isFocused } = useAutoFocusOnSelect({\n ref: innerRef.current,\n onlyAutoOpenWhenInputEmpty: true,\n });\n\n const { t } = useTranslation();\n\n const organizedCountries: CountryType[] = useMemo(() => {\n return ListOfCountriesAndCodes.sort((a, b) => {\n return `${(a.suggested ? '000' : '') + a.label}`.localeCompare(`${(b.suggested ? '000' : '') + b.label}`);\n });\n }, [ListOfCountriesAndCodes]);\n\n const [container, setContainer] = useState<HTMLDivElement>(null);\n\n const { validationStatus, name, onChange, value } = props;\n\n const [selectedCountry, subscriberCode] = useMemo(() => {\n const [prefix, number] = value?.split(PHONE_AND_PREFIX_SPLIT) ?? [];\n let selectedCountry: CountryType;\n\n if (prefix) {\n for (const country of organizedCountries) {\n if (prefix === `${country.phone}`) {\n selectedCountry = country;\n break;\n }\n }\n\n if (!selectedCountry) {\n selectedCountry = organizedCountries[0];\n }\n\n return [selectedCountry, number];\n }\n\n return [organizedCountries[0], ''];\n }, [value]);\n\n const getOption = (key: CountryType['code']): CountryType => {\n return organizedCountries.find(({ code }) => code === key);\n };\n\n const raiseOnChangeEvent = (prefix?: CountryType, suffix?: string) => {\n let newSuffix = suffix ?? subscriberCode;\n\n if (newSuffix.startsWith('0')) {\n newSuffix = newSuffix.substring(1);\n }\n\n const newValue = `${prefix?.phone ?? selectedCountry.phone}${PHONE_AND_PREFIX_SPLIT}${newSuffix}`;\n\n if (value != newValue) {\n onChange?.({ target: { name, value: newValue } } as any);\n }\n };\n\n const onInputChanged = (e: ChangeEvent<HTMLInputElement>) => {\n const value = e.target.value;\n raiseOnChangeEvent(undefined, value);\n };\n\n const onPrefixChanged = (selectedCountry: CountryType) => {\n onItemSelected();\n raiseOnChangeEvent(selectedCountry, undefined);\n };\n\n const fieldClasses = classNames('rs-enhanced-phone-field', {\n [`--${validationStatus}`]: !!validationStatus,\n '--focused': isFocused,\n '--disabled': props.disabled,\n });\n const onCountryClick = (country: CountryType) => {\n onPrefixChanged(country);\n return;\n };\n\n return (\n <div className={fieldClasses}>\n <div className=\"rs-enhanced-phone-field--country\" onClick={onTriggerClicked}>\n <div className=\"rs-enhanced-phone-field--country-icon\">{convertCountryCodeToFlag(selectedCountry.code)}</div>\n <Icon icon={IconType.Dropdown} />\n </div>\n <div className=\"rs-enhanced-phone-field--number\">\n <span className=\"rs-enhanced-phone-field--number-prefix\">+{selectedCountry.phone}</span>\n <input\n disabled={props.disabled}\n ref={innerRef}\n placeholder={t(Translation.Step.Confirmation.Inputs.Phone) + ' *'}\n type=\"number\"\n style={{ paddingLeft: selectedCountry.phone.length * 8 + 20 + 'px' }}\n onChange={onInputChanged}\n value={subscriberCode}\n />\n\n <div className=\"rs-enhanced-phone-field--number-status\"></div>\n </div>\n <div className=\"rs-enhanced-phone-field--anchor\" ref={setContainer}></div>\n <Select<CountryType, 'code'>\n open={isDropdownOpen}\n onClose={onDropdownClosed}\n target={container}\n options={organizedCountries}\n value={selectedCountry.code}\n onChange={(value) => onCountryClick(getOption(value))}\n labelName=\"code\"\n keyName=\"code\"\n renderOption={(country) => (\n <div className=\"rs-enhanced-phone-field--suggest-list-country\">\n <div className=\"rs-enhanced-phone-field--suggest-list-country-icon\">{convertCountryCodeToFlag(country.code)}</div>\n <div className=\"rs-enhanced-phone-field--suggest-list-country-name\">\n {country.label} <span>+{country.phone}</span>\n </div>\n </div>\n )}\n />\n </div>\n );\n};\n\nexport default React.forwardRef<HTMLInputElement, React.PropsWithChildren<EnhancedPhoneNumberField>>(EnhancedPhoneNumberField);\n"]}
1
+ {"version":3,"file":"EnhancedPhoneNumberField.js","sourceRoot":"/","sources":["src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.tsx"],"names":[],"mappings":"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","sourcesContent":["import classNames from 'classnames';\nimport React from 'react';\nimport { ChangeEvent, ForwardRefRenderFunction, PropsWithChildren, useImperativeHandle, useMemo, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { convertCountryCodeToFlag, CountryType, ListOfCountriesAndCodes } from '@/models/CountryCodesAndNumbers';\nimport { Translation } from 'translations/Translation';\nimport Icon, { IconType } from '@/components/generic/Icon/Icon';\n\nimport './EnhancedPhoneNumberField.global.scss';\nimport { useAutoFocusOnSelect } from '@/hooks/AutoFocusOnSelect';\nimport { Select } from '../../Select/Select';\n\nexport interface EnhancedPhoneNumberField extends PropsWithChildren<any> {\n validationStatus?: 'success' | 'error';\n name?: string;\n value?: string;\n onChange?: (e: ChangeEvent<HTMLInputElement>) => void;\n disabled?: boolean;\n}\n\nconst PHONE_AND_PREFIX_SPLIT = ' ';\n\nconst EnhancedPhoneNumberField: ForwardRefRenderFunction<HTMLInputElement, EnhancedPhoneNumberField> = (props, ref) => {\n const innerRef = useRef<HTMLInputElement>(null);\n useImperativeHandle<HTMLInputElement | null, HTMLInputElement | null>(ref, () => innerRef.current);\n const { onDropdownClosed, onItemSelected, onTriggerClicked, isDropdownOpen, isFocused } = useAutoFocusOnSelect({\n ref: innerRef.current,\n onlyAutoOpenWhenInputEmpty: true,\n });\n\n const { t } = useTranslation();\n\n const organizedCountries: CountryType[] = useMemo(() => {\n return ListOfCountriesAndCodes.sort((a, b) => {\n return `${(a.suggested ? '000' : '') + a.label}`.localeCompare(`${(b.suggested ? '000' : '') + b.label}`);\n });\n }, [ListOfCountriesAndCodes]);\n\n const [container, setContainer] = useState<HTMLDivElement | null>(null);\n\n const { validationStatus, name, onChange, value } = props;\n\n const [selectedCountry, subscriberCode] = useMemo(() => {\n const [prefix, number] = value?.split(PHONE_AND_PREFIX_SPLIT) ?? [];\n\n if (prefix) {\n const selectedCountry = organizedCountries.find(({ phone }) => prefix === phone) || organizedCountries[0];\n return [selectedCountry, number];\n }\n\n return [organizedCountries[0], ''];\n }, [value]);\n\n const getOption = (key: CountryType['code']): CountryType => {\n return organizedCountries.find(({ code }) => code === key) as CountryType;\n };\n\n const raiseOnChangeEvent = (prefix?: CountryType, suffix?: string) => {\n let newSuffix = suffix ?? subscriberCode;\n\n if (newSuffix.startsWith('0')) {\n newSuffix = newSuffix.substring(1);\n }\n\n const newValue = `${prefix?.phone ?? selectedCountry.phone}${PHONE_AND_PREFIX_SPLIT}${newSuffix}`;\n\n if (value != newValue) {\n onChange?.({ target: { name, value: newValue } } as any);\n }\n };\n\n const onInputChanged = (e: ChangeEvent<HTMLInputElement>) => {\n const value = e.target.value;\n raiseOnChangeEvent(undefined, value);\n };\n\n const onPrefixChanged = (selectedCountry: CountryType) => {\n onItemSelected();\n raiseOnChangeEvent(selectedCountry, undefined);\n };\n\n const fieldClasses = classNames('rs-enhanced-phone-field', {\n [`--${validationStatus}`]: !!validationStatus,\n '--focused': isFocused,\n '--disabled': props.disabled,\n });\n const onCountryClick = (country: CountryType) => {\n onPrefixChanged(country);\n return;\n };\n\n return (\n <div className={fieldClasses}>\n <div className=\"rs-enhanced-phone-field--country\" onClick={onTriggerClicked}>\n <div className=\"rs-enhanced-phone-field--country-icon\">{convertCountryCodeToFlag(selectedCountry.code)}</div>\n <Icon icon={IconType.Dropdown} />\n </div>\n <div className=\"rs-enhanced-phone-field--number\">\n <span className=\"rs-enhanced-phone-field--number-prefix\">+{selectedCountry.phone}</span>\n <input\n disabled={props.disabled}\n ref={innerRef}\n placeholder={t(Translation.Step.Confirmation.Inputs.Phone) + ' *'}\n type=\"number\"\n style={{ paddingLeft: selectedCountry.phone.length * 8 + 20 + 'px' }}\n onChange={onInputChanged}\n value={subscriberCode}\n />\n\n <div className=\"rs-enhanced-phone-field--number-status\"></div>\n </div>\n <div className=\"rs-enhanced-phone-field--anchor\" ref={setContainer}></div>\n <Select<CountryType, 'code'>\n open={isDropdownOpen}\n onClose={onDropdownClosed}\n target={container}\n options={organizedCountries}\n value={selectedCountry.code}\n onChange={(value) => onCountryClick(getOption(value))}\n labelName=\"code\"\n keyName=\"code\"\n renderOption={(country) => (\n <div className=\"rs-enhanced-phone-field--suggest-list-country\">\n <div className=\"rs-enhanced-phone-field--suggest-list-country-icon\">{convertCountryCodeToFlag(country?.code as string)}</div>\n <div className=\"rs-enhanced-phone-field--suggest-list-country-name\">\n {country?.label} <span>+{country?.phone}</span>\n </div>\n </div>\n )}\n />\n </div>\n );\n};\n\nexport default React.forwardRef<HTMLInputElement, React.PropsWithChildren<EnhancedPhoneNumberField>>(EnhancedPhoneNumberField);\n"]}
@@ -35,10 +35,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
35
35
  return (mod && mod.__esModule) ? mod : { "default": mod };
36
36
  };
37
37
  Object.defineProperty(exports, "__esModule", { value: true });
38
- const React = __importStar(require("react"));
38
+ const react_1 = __importDefault(require("react"));
39
39
  const Color_1 = require("../../../util/Color");
40
40
  const Icon_1 = __importStar(require("../Icon/Icon"));
41
- const react_1 = require("react");
41
+ const react_2 = require("react");
42
42
  const classnames_1 = __importDefault(require("classnames"));
43
43
  const dayjs_1 = __importDefault(require("dayjs"));
44
44
  const contexts_1 = require("../../../contexts/index.js");
@@ -51,7 +51,7 @@ const DaysSelectedInformer_1 = __importDefault(require("../../steps/DaysSelected
51
51
  const hooks_1 = require("../../../hooks/index.js");
52
52
  const DatePickerTypeFeature_1 = __importDefault(require("../../../providers/feature/DatePickerTypeFeature"));
53
53
  const WeekViewSkeleton_1 = __importDefault(require("./WeekViewSkeleton"));
54
- const DatePickerWeek = (0, react_1.lazy)(() => Promise.resolve().then(() => __importStar(require('./DatePickerWeek'))));
54
+ const DatePickerWeek = (0, react_2.lazy)(() => Promise.resolve().then(() => __importStar(require('./DatePickerWeek'))));
55
55
  var DateRangePickingState;
56
56
  (function (DateRangePickingState) {
57
57
  DateRangePickingState[DateRangePickingState["StartDate"] = 1] = "StartDate";
@@ -60,18 +60,18 @@ var DateRangePickingState;
60
60
  function DatePicker(props) {
61
61
  var _a, _b;
62
62
  const { hotel } = (0, hooks_1.useCurrentHotel)();
63
- const [currentMonth, setCurrentMonth] = (0, react_1.useState)(props.showMonthOnLoad ? props.showMonthOnLoad : props.selectedStartDate ? props.selectedStartDate : (0, dayjs_1.default)());
64
- const [selectedStartDate, setSelectedStartDate] = (0, react_1.useState)((_a = props.selectedStartDate) !== null && _a !== void 0 ? _a : null);
65
- const [selectedEndDate, setSelectedEndDate] = (0, react_1.useState)((_b = props.selectedEndDate) !== null && _b !== void 0 ? _b : null);
66
- const [hoveringOverDate, setHoveringOverDate] = (0, react_1.useState)(null);
67
- const [pickingState, setPickingState] = (0, react_1.useState)(DateRangePickingState.StartDate);
68
- const [calendarStyle, setCalendarStyle] = (0, react_1.useState)((hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType) ? hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType : 'Month');
69
- (0, react_1.useEffect)(() => {
63
+ const [currentMonth, setCurrentMonth] = (0, react_2.useState)(props.showMonthOnLoad ? props.showMonthOnLoad : props.selectedStartDate ? props.selectedStartDate : (0, dayjs_1.default)());
64
+ const [selectedStartDate, setSelectedStartDate] = (0, react_2.useState)((_a = props.selectedStartDate) !== null && _a !== void 0 ? _a : null);
65
+ const [selectedEndDate, setSelectedEndDate] = (0, react_2.useState)((_b = props.selectedEndDate) !== null && _b !== void 0 ? _b : null);
66
+ const [hoveringOverDate, setHoveringOverDate] = (0, react_2.useState)(null);
67
+ const [pickingState, setPickingState] = (0, react_2.useState)(DateRangePickingState.StartDate);
68
+ const [calendarStyle, setCalendarStyle] = (0, react_2.useState)((hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType) ? hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType : 'Month');
69
+ (0, react_2.useEffect)(() => {
70
70
  setCalendarStyle((hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType) ? hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType : 'Month');
71
71
  }, [hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType]);
72
- const [months, setMonths] = (0, react_1.useState)(props.showMultipleMonths ? [currentMonth, currentMonth.add(1, 'month')] : [currentMonth]);
73
- const [maxPrice, setMaxPrice] = (0, react_1.useState)(0);
74
- const basketContext = (0, react_1.useContext)(contexts_2.BasketContext);
72
+ const [months, setMonths] = (0, react_2.useState)(props.showMultipleMonths ? [currentMonth, currentMonth.add(1, 'month')] : [currentMonth]);
73
+ const [maxPrice, setMaxPrice] = (0, react_2.useState)(0);
74
+ const basketContext = (0, react_2.useContext)(contexts_2.BasketContext);
75
75
  const onClickDate = (newDate) => __awaiter(this, void 0, void 0, function* () {
76
76
  let newPickingState = null;
77
77
  const selectedBasketRow = basketContext.selectedBasketRow;
@@ -138,35 +138,35 @@ function DatePicker(props) {
138
138
  });
139
139
  }
140
140
  };
141
- const firstUpdate = (0, react_1.useRef)();
141
+ const firstUpdate = (0, react_2.useRef)(null);
142
142
  // TODO: Perhaps refactor this later to not depend on non-state items
143
- (0, react_1.useEffect)(() => {
143
+ (0, react_2.useEffect)(() => {
144
144
  if ((DatePickerTypeFeature_1.default === null || DatePickerTypeFeature_1.default === void 0 ? void 0 : DatePickerTypeFeature_1.default.isActive()) && props.supportsWeek) {
145
145
  setCalendarStyle('Week');
146
146
  }
147
147
  }, [DatePickerTypeFeature_1.default === null || DatePickerTypeFeature_1.default === void 0 ? void 0 : DatePickerTypeFeature_1.default.isActive()]);
148
- (0, react_1.useEffect)(() => {
148
+ (0, react_2.useEffect)(() => {
149
149
  if (props.showMonthOnLoad) {
150
150
  setCurrentMonth(props.showMonthOnLoad);
151
151
  }
152
152
  }, [props.showMonthOnLoad]);
153
- (0, react_1.useEffect)(() => {
153
+ (0, react_2.useEffect)(() => {
154
154
  if (props.showMultipleMonths) {
155
155
  setMonths([currentMonth, currentMonth.add(1, 'month')]);
156
156
  }
157
157
  }, [currentMonth, props.showMultipleMonths]);
158
- (0, react_1.useEffect)(() => {
158
+ (0, react_2.useEffect)(() => {
159
159
  if (firstUpdate.current) {
160
- firstUpdate.current = undefined;
160
+ firstUpdate.current = null;
161
161
  return;
162
162
  }
163
163
  if (props.onStartDateChanged) {
164
164
  props.onStartDateChanged(selectedStartDate);
165
165
  }
166
166
  }, [selectedStartDate]);
167
- (0, react_1.useLayoutEffect)(() => {
167
+ (0, react_2.useLayoutEffect)(() => {
168
168
  if (firstUpdate.current) {
169
- firstUpdate.current = undefined;
169
+ firstUpdate.current = null;
170
170
  return;
171
171
  }
172
172
  if (props.onEndDateChanged) {
@@ -187,11 +187,11 @@ function DatePicker(props) {
187
187
  },
188
188
  setMaxPrice,
189
189
  };
190
- const printMonths = (0, react_1.useMemo)(() => (React.createElement(React.Fragment, null, calendarStyle === 'Month' ? (React.createElement(React.Fragment, null,
191
- React.createElement(DatePickerMonth_1.default, { small: props.small, showingMonth: currentMonth }),
192
- props.showMultipleMonths && React.createElement(DatePickerMonth_1.default, { showingMonth: currentMonth.add(1, 'month') }))) : (React.createElement(React.Fragment, null,
193
- React.createElement(React.Suspense, { fallback: React.createElement(WeekViewSkeleton_1.default, null) },
194
- React.createElement(DatePickerWeek, null)))))), [currentMonth, props.showMultipleMonths, calendarStyle]);
190
+ const printMonths = (0, react_2.useMemo)(() => (react_1.default.createElement(react_1.default.Fragment, null, calendarStyle === 'Month' ? (react_1.default.createElement(react_1.default.Fragment, null,
191
+ react_1.default.createElement(DatePickerMonth_1.default, { small: props.small, showingMonth: currentMonth }),
192
+ props.showMultipleMonths && react_1.default.createElement(DatePickerMonth_1.default, { showingMonth: currentMonth.add(1, 'month') }))) : (react_1.default.createElement(react_1.default.Fragment, null,
193
+ react_1.default.createElement(react_1.default.Suspense, { fallback: react_1.default.createElement(WeekViewSkeleton_1.default, null) },
194
+ react_1.default.createElement(DatePickerWeek, null)))))), [currentMonth, props.showMultipleMonths, calendarStyle]);
195
195
  const calendarClassNames = (0, classnames_1.default)('diji-calendar', {
196
196
  '--single': !props.showMultipleMonths,
197
197
  '--small': props.small,
@@ -213,23 +213,23 @@ function DatePicker(props) {
213
213
  DataLayer_1.default.instance.sendInteraction('Set Calendar Style - Week', DataLayer_1.InteractionType.CALENDAR, DataLayer_1.InteractionStep.DATES);
214
214
  setCalendarStyle('Week');
215
215
  };
216
- return (React.createElement(contexts_1.DatePickerContext.Provider, { value: context },
217
- React.createElement("div", { ref: firstUpdate, className: calendarClassNames },
218
- calendarStyle === 'Month' && (React.createElement("div", { className: "diji-calendar-navigation" },
219
- React.createElement(Icon_1.default, { icon: Icon_1.IconType.ArrowLeft2, onClick: previousMonthOnClick, color: Color_1.Color.White, backgroundColor: Color_1.Color.Navy, borderRadius: "round", size: "24px" }),
220
- React.createElement(Icon_1.default, { icon: Icon_1.IconType.ArrowRight2, onClick: nextMonthOnClick, color: Color_1.Color.White, backgroundColor: Color_1.Color.Navy, borderRadius: "round", size: "24px" }))),
221
- props.supportsWeek && (React.createElement("div", { className: "diji-calendar-picker-type" },
222
- React.createElement(Icon_1.default, { icon: Icon_1.IconType.ViewMonth, size: "32px", color: calendarStyle === 'Month' ? Color_1.Color.Navy : Color_1.Color.Grey, onClick: setCalendarStyleAsMonth }),
223
- React.createElement(Icon_1.default, { icon: Icon_1.IconType.ViewWeek, size: "32px", color: calendarStyle === 'Week' ? Color_1.Color.Navy : Color_1.Color.Grey, onClick: setCalendarStyleAsWeek }))),
216
+ return (react_1.default.createElement(contexts_1.DatePickerContext.Provider, { value: context },
217
+ react_1.default.createElement("div", { ref: firstUpdate, className: calendarClassNames },
218
+ calendarStyle === 'Month' && (react_1.default.createElement("div", { className: "diji-calendar-navigation" },
219
+ react_1.default.createElement(Icon_1.default, { icon: Icon_1.IconType.ArrowLeft2, onClick: previousMonthOnClick, color: Color_1.Color.White, backgroundColor: Color_1.Color.Navy, borderRadius: "round", size: "24px" }),
220
+ react_1.default.createElement(Icon_1.default, { icon: Icon_1.IconType.ArrowRight2, onClick: nextMonthOnClick, color: Color_1.Color.White, backgroundColor: Color_1.Color.Navy, borderRadius: "round", size: "24px" }))),
221
+ props.supportsWeek && (react_1.default.createElement("div", { className: "diji-calendar-picker-type" },
222
+ react_1.default.createElement(Icon_1.default, { icon: Icon_1.IconType.ViewMonth, size: "32px", color: calendarStyle === 'Month' ? Color_1.Color.Navy : Color_1.Color.Grey, onClick: setCalendarStyleAsMonth }),
223
+ react_1.default.createElement(Icon_1.default, { icon: Icon_1.IconType.ViewWeek, size: "32px", color: calendarStyle === 'Week' ? Color_1.Color.Navy : Color_1.Color.Grey, onClick: setCalendarStyleAsWeek }))),
224
224
  printMonths,
225
- props.showMinNightStay && props.showMultipleMonths && (React.createElement("div", { className: "diji-calendar--min-night-stay u-flex u-flex-direction-column u-flex-align-center" },
226
- React.createElement(DaysSelectedInformer_1.default, null),
227
- React.createElement("div", { className: "u-marg-top--light" },
228
- React.createElement(MinimumNightStayPill_1.default, null))))),
229
- props.showMinNightStay && !props.showMultipleMonths && (React.createElement("div", { className: "diji-calendar--min-night-stay --small u-flex u-flex-direction-column u-flex-align-center u-marg-top" },
230
- React.createElement(DaysSelectedInformer_1.default, null),
231
- React.createElement("div", { className: "u-marg-top--light" },
232
- React.createElement(MinimumNightStayPill_1.default, null))))));
225
+ props.showMinNightStay && props.showMultipleMonths && (react_1.default.createElement("div", { className: "diji-calendar--min-night-stay u-flex u-flex-direction-column u-flex-align-center" },
226
+ react_1.default.createElement(DaysSelectedInformer_1.default, null),
227
+ react_1.default.createElement("div", { className: "u-marg-top--light" },
228
+ react_1.default.createElement(MinimumNightStayPill_1.default, null))))),
229
+ props.showMinNightStay && !props.showMultipleMonths && (react_1.default.createElement("div", { className: "diji-calendar--min-night-stay --small u-flex u-flex-direction-column u-flex-align-center u-marg-top" },
230
+ react_1.default.createElement(DaysSelectedInformer_1.default, null),
231
+ react_1.default.createElement("div", { className: "u-marg-top--light" },
232
+ react_1.default.createElement(MinimumNightStayPill_1.default, null))))));
233
233
  }
234
234
  exports.default = DatePicker;
235
235
  //# sourceMappingURL=DatePicker.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DatePicker.js","sourceRoot":"/","sources":["src/components/generic/date/DatePicker.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6CAA+B;AAE/B,wCAAqC;AACrC,uEAAgE;AAChE,iCAAgG;AAEhG,4DAAoC;AAEpC,kDAA0B;AAC1B,iDAAuD;AACvD,gGAAwE;AACxE,kEAAmC;AACnC,iDAAmD;AACnD,8DAA+E;AAC/E,mGAA2E;AAC3E,mGAA2E;AAC3E,2CAAkD;AAClD,sGAA8E;AAC9E,0EAAkD;AAElD,MAAM,cAAc,GAAG,IAAA,YAAI,EAAC,GAAG,EAAE,mDAAQ,0CAA0C,GAAC,CAAC,CAAC;AAqCtF,IAAK,qBAGJ;AAHD,WAAK,qBAAqB;IACtB,2EAAa,CAAA;IACb,uEAAW,CAAA;AACf,CAAC,EAHI,qBAAqB,KAArB,qBAAqB,QAGzB;AAED,SAAwB,UAAU,CAAC,KAAsB;;IACrD,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,uBAAe,GAAE,CAAC;IAEpC,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAA,eAAK,GAAE,CAAC,CAAC;IAE9J,MAAM,CAAC,iBAAiB,EAAE,oBAAoB,CAAC,GAAG,IAAA,gBAAQ,EAAC,MAAA,KAAK,CAAC,iBAAiB,mCAAI,IAAI,CAAC,CAAC;IAC5F,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,IAAA,gBAAQ,EAAC,MAAA,KAAK,CAAC,eAAe,mCAAI,IAAI,CAAC,CAAC;IAEtF,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,IAAA,gBAAQ,EAAC,IAAI,CAAC,CAAC;IAE/D,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,IAAA,gBAAQ,EAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC;IAClF,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,IAAA,gBAAQ,EAAmB,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,qBAAqB,EAAC,CAAC,CAAC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,qBAAqB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IAC5I,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,gBAAgB,CAAC,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,qBAAqB,EAAC,CAAC,CAAC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,qBAAqB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IAC5F,CAAC,EAAE,CAAC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,qBAAqB,CAAC,CAAC,CAAC;IAEnC,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;IAC/H,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,CAAC,CAAC,CAAC;IAE5C,MAAM,aAAa,GAAG,IAAA,kBAAU,EAAC,wBAAa,CAAC,CAAC;IAEhD,MAAM,WAAW,GAAG,CAAO,OAAoB,EAAE,EAAE;QAC/C,IAAI,eAAe,GAA0B,IAAI,CAAC;QAElD,MAAM,iBAAiB,GAAG,aAAa,CAAC,iBAAiB,CAAC;QAC1D,MAAM,MAAM,GAAG,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,MAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACzE,MAAM,SAAS,GAAG,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAE5E,MAAM,YAAY,GAAG,MAAM,oBAAG,CAAC,YAAY,CAAC,sBAAsB,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QAEhI,QAAQ,YAAY,EAAE;YAClB,QAAQ;YACR,KAAK,qBAAqB,CAAC,SAAS;gBAChC,IAAI,YAAY,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE;oBAC9B,eAAe,GAAG,qBAAqB,CAAC,OAAO,CAAC;oBAEhD,oBAAoB,CAAC,OAAO,CAAC,CAAC;oBAC9B,kBAAkB,CAAC,IAAI,CAAC,CAAC;iBAC5B;gBAED,MAAM;YACV,KAAK,qBAAqB,CAAC,OAAO;gBAC9B,IAAI,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAC,EAAE;oBACrC,oBAAoB,CAAC,OAAO,CAAC,CAAC;oBAC9B,eAAe,GAAG,qBAAqB,CAAC,OAAO,CAAC;iBACnD;qBAAM;oBACH,eAAe,GAAG,qBAAqB,CAAC,SAAS,CAAC;oBAElD,mBAAmB,CAAC,IAAI,CAAC,CAAC;oBAE1B,MAAM,gBAAgB,GAAG,MAAM,eAAe,CAAC,iBAAiB,EAAE,OAAO,CAAC,CAAC;oBAE3E,IAAI,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE;wBACnC,kBAAkB,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;qBACtD;yBAAM;wBACH,kBAAkB,CAAC,gBAAgB,CAAC,CAAC;qBACxC;iBACJ;gBAED,MAAM;SACb;QAED,IAAI,KAAK,CAAC,sBAAsB,EAAE;YAC9B,eAAe,CAAC,eAAe,CAAC,CAAC;SACpC;IACL,CAAC,CAAA,CAAC;IAEF,MAAM,eAAe,GAAG,CAAC,QAAqB,EAAE,MAAmB,EAAwB,EAAE,CACzF,IAAI,OAAO,CAAC,CAAO,OAAO,EAAE,EAAE;;QAC1B,MAAM,iBAAiB,GAAG,aAAa,CAAC,iBAAiB,CAAC;QAC1D,MAAM,MAAM,GAAG,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,MAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACzE,MAAM,SAAS,GAAG,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAE5E,MAAM,IAAI,GAAG,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,uDAAG,QAAQ,EAAE,KAAK,CAAC,CAAC;QAE7C,IAAI,aAAa,GAAG,KAAK,CAAC;QAC1B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,EAAE,EAAE;YAC5B,MAAM,UAAU,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;YAE1C,MAAM,KAAK,GAAG,MAAM,oBAAG,CAAC,YAAY,CAAC,sBAAsB,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,EAAE,KAAK,CAAC,CAAC;YAE5H,IAAI,aAAa,EAAE;gBACf,OAAO,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;aACjD;YAED,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,EAAE;gBACvB,aAAa,GAAG,IAAI,CAAC;gBACrB,SAAS;aACZ;SACJ;QAED,OAAO,CAAC,MAAM,CAAC,CAAC;IACpB,CAAC,CAAA,CAAC,CAAC;IAEP,MAAM,gBAAgB,GAAG,CAAC,GAAgB,EAAE,EAAE;QAC1C,IAAI,iBAAiB,IAAI,CAAC,eAAe,EAAE;YACvC,eAAe,CAAC,iBAAiB,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,YAAY,EAAE,EAAE;gBAC1D,mBAAmB,CAAC,YAAY,CAAC,CAAC;YACtC,CAAC,CAAC,CAAC;SACN;IACL,CAAC,CAAC;IAEF,MAAM,WAAW,GAAG,IAAA,cAAM,GAAE,CAAC;IAE7B,qEAAqE;IACrE,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,IAAI,CAAA,+BAAqB,aAArB,+BAAqB,uBAArB,+BAAqB,CAAE,QAAQ,EAAE,KAAI,KAAK,CAAC,YAAY,EAAE;YACzD,gBAAgB,CAAC,MAAM,CAAC,CAAC;SAC5B;IACL,CAAC,EAAE,CAAC,+BAAqB,aAArB,+BAAqB,uBAArB,+BAAqB,CAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IAExC,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,IAAI,KAAK,CAAC,eAAe,EAAE;YACvB,eAAe,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;SAC1C;IACL,CAAC,EAAE,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC;IAE5B,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,IAAI,KAAK,CAAC,kBAAkB,EAAE;YAC1B,SAAS,CAAC,CAAC,YAAY,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;SAC3D;IACL,CAAC,EAAE,CAAC,YAAY,EAAE,KAAK,CAAC,kBAAkB,CAAC,CAAC,CAAC;IAE7C,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,IAAI,WAAW,CAAC,OAAO,EAAE;YACrB,WAAW,CAAC,OAAO,GAAG,SAAS,CAAC;YAChC,OAAO;SACV;QAED,IAAI,KAAK,CAAC,kBAAkB,EAAE;YAC1B,KAAK,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;SAC/C;IACL,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAExB,IAAA,uBAAe,EAAC,GAAG,EAAE;QACjB,IAAI,WAAW,CAAC,OAAO,EAAE;YACrB,WAAW,CAAC,OAAO,GAAG,SAAS,CAAC;YAChC,OAAO;SACV;QAED,IAAI,KAAK,CAAC,gBAAgB,EAAE;YACxB,KAAK,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;SAC3C;IACL,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC;IAEtB,MAAM,OAAO,GAAG;QACZ,KAAK,EAAE,IAAA,eAAK,GAAE;QACd,WAAW,EAAE,IAAA,eAAK,GAAE,CAAC,IAAI,EAAE;QAC3B,SAAS,EAAE,iBAAiB;QAC5B,OAAO,EAAE,eAAe;QAExB,YAAY,EAAE,gBAAgB;QAC9B,QAAQ;QAER,WAAW,EAAE,gBAAgB;QAC7B,YAAY;QAEZ,YAAY,EAAE,CAAC,IAAiB,EAAE,EAAE;YAChC,WAAW,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC;QACD,WAAW;KACd,CAAC;IAEF,MAAM,WAAW,GAAG,IAAA,eAAO,EACvB,GAAG,EAAE,CAAC,CACF,0CACK,aAAa,KAAK,OAAO,CAAC,CAAC,CAAC,CACzB;QACI,oBAAC,yBAAe,IAAC,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,YAAY,EAAE,YAAY,GAAI;QAClE,KAAK,CAAC,kBAAkB,IAAI,oBAAC,yBAAe,IAAC,YAAY,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,GAAI,CAC7F,CACN,CAAC,CAAC,CAAC,CACA;QACI,oBAAC,KAAK,CAAC,QAAQ,IAAC,QAAQ,EAAE,oBAAC,0BAAgB,OAAG;YAC1C,oBAAC,cAAc,OAAG,CACL,CAClB,CACN,CACF,CACN,EACD,CAAC,YAAY,EAAE,KAAK,CAAC,kBAAkB,EAAE,aAAa,CAAC,CAC1D,CAAC;IAEF,MAAM,kBAAkB,GAAG,IAAA,oBAAU,EAAC,eAAe,EAAE;QACnD,UAAU,EAAE,CAAC,KAAK,CAAC,kBAAkB;QACrC,SAAS,EAAE,KAAK,CAAC,KAAK;QACtB,QAAQ,EAAE,aAAa,KAAK,MAAM;KACrC,CAAC,CAAC;IACH,MAAM,oBAAoB,GAAG,GAAG,EAAE;QAC9B,mBAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,qBAAqB,EAAE,2BAAe,CAAC,QAAQ,EAAE,2BAAe,CAAC,KAAK,CAAC,CAAC;QAC3G,eAAe,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;IACvD,CAAC,CAAC;IACF,MAAM,gBAAgB,GAAG,GAAG,EAAE;QAC1B,mBAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,iBAAiB,EAAE,2BAAe,CAAC,QAAQ,EAAE,2BAAe,CAAC,KAAK,CAAC,CAAC;QACvG,eAAe,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;IAClD,CAAC,CAAC;IACF,MAAM,uBAAuB,GAAG,GAAG,EAAE;QACjC,mBAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,4BAA4B,EAAE,2BAAe,CAAC,QAAQ,EAAE,2BAAe,CAAC,KAAK,CAAC,CAAC;QAClH,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC,CAAC;IACF,MAAM,sBAAsB,GAAG,GAAG,EAAE;QAChC,mBAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,2BAA2B,EAAE,2BAAe,CAAC,QAAQ,EAAE,2BAAe,CAAC,KAAK,CAAC,CAAC;QACjH,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC,CAAC;IAEF,OAAO,CACH,oBAAC,4BAAiB,CAAC,QAAQ,IAAC,KAAK,EAAE,OAAO;QACtC,6BAAK,GAAG,EAAE,WAAW,EAAE,SAAS,EAAE,kBAAkB;YAC/C,aAAa,KAAK,OAAO,IAAI,CAC1B,6BAAK,SAAS,EAAC,0BAA0B;gBACrC,oBAAC,cAAI,IAAC,IAAI,EAAE,eAAQ,CAAC,UAAU,EAAE,OAAO,EAAE,oBAAoB,EAAE,KAAK,EAAE,aAAK,CAAC,KAAK,EAAE,eAAe,EAAE,aAAK,CAAC,IAAI,EAAE,YAAY,EAAC,OAAO,EAAC,IAAI,EAAC,MAAM,GAAG;gBACpJ,oBAAC,cAAI,IAAC,IAAI,EAAE,eAAQ,CAAC,WAAW,EAAE,OAAO,EAAE,gBAAgB,EAAE,KAAK,EAAE,aAAK,CAAC,KAAK,EAAE,eAAe,EAAE,aAAK,CAAC,IAAI,EAAE,YAAY,EAAC,OAAO,EAAC,IAAI,EAAC,MAAM,GAAG,CAC/I,CACT;YACA,KAAK,CAAC,YAAY,IAAI,CACnB,6BAAK,SAAS,EAAC,2BAA2B;gBACtC,oBAAC,cAAI,IAAC,IAAI,EAAE,eAAQ,CAAC,SAAS,EAAE,IAAI,EAAC,MAAM,EAAC,KAAK,EAAE,aAAa,KAAK,OAAO,CAAC,CAAC,CAAC,aAAK,CAAC,IAAI,CAAC,CAAC,CAAC,aAAK,CAAC,IAAI,EAAE,OAAO,EAAE,uBAAuB,GAAI;gBAC5I,oBAAC,cAAI,IAAC,IAAI,EAAE,eAAQ,CAAC,QAAQ,EAAE,IAAI,EAAC,MAAM,EAAC,KAAK,EAAE,aAAa,KAAK,MAAM,CAAC,CAAC,CAAC,aAAK,CAAC,IAAI,CAAC,CAAC,CAAC,aAAK,CAAC,IAAI,EAAE,OAAO,EAAE,sBAAsB,GAAI,CACvI,CACT;YACA,WAAW;YACX,KAAK,CAAC,gBAAgB,IAAI,KAAK,CAAC,kBAAkB,IAAI,CACnD,6BAAK,SAAS,EAAC,kFAAkF;gBAC7F,oBAAC,8BAAoB,OAAG;gBACxB,6BAAK,SAAS,EAAC,mBAAmB;oBAC9B,oBAAC,8BAAoB,OAAG,CACtB,CACJ,CACT,CACC;QAEL,KAAK,CAAC,gBAAgB,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,CACpD,6BAAK,SAAS,EAAC,qGAAqG;YAChH,oBAAC,8BAAoB,OAAG;YACxB,6BAAK,SAAS,EAAC,mBAAmB;gBAC9B,oBAAC,8BAAoB,OAAG,CACtB,CACJ,CACT,CACwB,CAChC,CAAC;AACN,CAAC;AAnPD,6BAmPC","sourcesContent":["import * as React from 'react';\n\nimport { Color } from '@/util/Color';\nimport Icon, { IconType } from '@/components/generic/Icon/Icon';\nimport { useEffect, useState, useRef, useLayoutEffect, useMemo, useContext, lazy } from 'react';\n\nimport classNames from 'classnames';\n\nimport dayjs from 'dayjs';\nimport { DatePickerContext } from '@frontend/contexts';\nimport DatePickerMonth from '@/components/generic/date/DatePickerMonth';\nimport API from '@/api/BookingAPI';\nimport { BasketContext } from '@frontend/contexts';\nimport DataLayer, { InteractionStep, InteractionType } from '@/util/DataLayer';\nimport MinimumNightStayPill from '@/components/steps/MinimumNightStayPill';\nimport DaysSelectedInformer from '@/components/steps/DaysSelectedInformer';\nimport { useCurrentHotel } from '@frontend/hooks';\nimport DatePickerTypeFeature from '@/providers/feature/DatePickerTypeFeature';\nimport WeekViewSkeleton from './WeekViewSkeleton';\n\nconst DatePickerWeek = lazy(() => import('@/components/generic/date/DatePickerWeek'));\n\nexport interface DatePickerProps {\n showMonthOnLoad?: dayjs.Dayjs;\n\n selectedStartDate?: dayjs.Dayjs;\n selectedEndDate?: dayjs.Dayjs;\n\n canSelect?: boolean;\n // Includes default navigation arrows\n showArrows?: boolean;\n // Displays two side by side\n showMultipleMonths?: boolean;\n\n // Used for tight spaces\n small?: boolean;\n\n // is there support for start / end dates\n supportsMultiSelecting?: boolean;\n\n // Do or don't show mininmum night stay block\n showMinNightStay?: boolean;\n\n supportsWeek?: boolean;\n\n onDateClicked?: (date: dayjs.Dayjs) => void;\n onStartDateChanged?: (date: dayjs.Dayjs) => void;\n onEndDateChanged?: (date: dayjs.Dayjs) => void;\n}\n\ninterface DatePickerDayObject {\n value: string;\n dateObj: dayjs.Dayjs | null;\n price?: string;\n hovered: boolean;\n}\n\nenum DateRangePickingState {\n StartDate = 1,\n EndDate = 2,\n}\n\nexport default function DatePicker(props: DatePickerProps) {\n const { hotel } = useCurrentHotel();\n\n const [currentMonth, setCurrentMonth] = useState(props.showMonthOnLoad ? props.showMonthOnLoad : props.selectedStartDate ? props.selectedStartDate : dayjs());\n\n const [selectedStartDate, setSelectedStartDate] = useState(props.selectedStartDate ?? null);\n const [selectedEndDate, setSelectedEndDate] = useState(props.selectedEndDate ?? null);\n\n const [hoveringOverDate, setHoveringOverDate] = useState(null);\n\n const [pickingState, setPickingState] = useState(DateRangePickingState.StartDate);\n const [calendarStyle, setCalendarStyle] = useState<'Month' | 'Week'>(hotel?.defaultDatepickerType ? hotel?.defaultDatepickerType : 'Month');\n useEffect(() => {\n setCalendarStyle(hotel?.defaultDatepickerType ? hotel?.defaultDatepickerType : 'Month');\n }, [hotel?.defaultDatepickerType]);\n\n const [months, setMonths] = useState(props.showMultipleMonths ? [currentMonth, currentMonth.add(1, 'month')] : [currentMonth]);\n const [maxPrice, setMaxPrice] = useState(0);\n\n const basketContext = useContext(BasketContext);\n\n const onClickDate = async (newDate: dayjs.Dayjs) => {\n let newPickingState: DateRangePickingState = null;\n\n const selectedBasketRow = basketContext.selectedBasketRow;\n const adults = selectedBasketRow ? selectedBasketRow.getAdults() : 0;\n const children = selectedBasketRow ? selectedBasketRow.getChildren() : 0;\n const promoCode = selectedBasketRow ? selectedBasketRow.getPromoCode() : '';\n\n const newDatePrice = await API.Availability.getCheapestPriceForDay(newDate, adults, children, promoCode, hotel?.hotelID, false);\n\n switch (pickingState) {\n default:\n case DateRangePickingState.StartDate:\n if (newDatePrice.price || !hotel) {\n newPickingState = DateRangePickingState.EndDate;\n\n setSelectedStartDate(newDate);\n setSelectedEndDate(null);\n }\n\n break;\n case DateRangePickingState.EndDate:\n if (newDate.isBefore(selectedStartDate)) {\n setSelectedStartDate(newDate);\n newPickingState = DateRangePickingState.EndDate;\n } else {\n newPickingState = DateRangePickingState.StartDate;\n\n setHoveringOverDate(null);\n\n const nextAvailableDay = await getLastValidDay(selectedStartDate, newDate);\n\n if (newDate.isSame(selectedStartDate)) {\n setSelectedEndDate(nextAvailableDay.add(1, 'day'));\n } else {\n setSelectedEndDate(nextAvailableDay);\n }\n }\n\n break;\n }\n\n if (props.supportsMultiSelecting) {\n setPickingState(newPickingState);\n }\n };\n\n const getLastValidDay = (fromDate: dayjs.Dayjs, toDate: dayjs.Dayjs): Promise<dayjs.Dayjs> =>\n new Promise(async (resolve) => {\n const selectedBasketRow = basketContext.selectedBasketRow;\n const adults = selectedBasketRow ? selectedBasketRow.getAdults() : 0;\n const children = selectedBasketRow ? selectedBasketRow.getChildren() : 0;\n const promoCode = selectedBasketRow ? selectedBasketRow.getPromoCode() : '';\n\n const diff = toDate?.diff?.(fromDate, 'day');\n\n let nextMustBreak = false;\n for (let i = 0; i <= diff; i++) {\n const dayToCheck = fromDate.add(i, 'day');\n\n const price = await API.Availability.getCheapestPriceForDay(dayToCheck, adults, children, promoCode, hotel?.hotelID, false);\n\n if (nextMustBreak) {\n return resolve(dayToCheck.subtract(1, 'day'));\n }\n\n if (!price.price && hotel) {\n nextMustBreak = true;\n continue;\n }\n }\n\n resolve(toDate);\n });\n\n const onHoveredOverDay = (day: dayjs.Dayjs) => {\n if (selectedStartDate && !selectedEndDate) {\n getLastValidDay(selectedStartDate, day).then((lastValidDay) => {\n setHoveringOverDate(lastValidDay);\n });\n }\n };\n\n const firstUpdate = useRef();\n\n // TODO: Perhaps refactor this later to not depend on non-state items\n useEffect(() => {\n if (DatePickerTypeFeature?.isActive() && props.supportsWeek) {\n setCalendarStyle('Week');\n }\n }, [DatePickerTypeFeature?.isActive()]);\n\n useEffect(() => {\n if (props.showMonthOnLoad) {\n setCurrentMonth(props.showMonthOnLoad);\n }\n }, [props.showMonthOnLoad]);\n\n useEffect(() => {\n if (props.showMultipleMonths) {\n setMonths([currentMonth, currentMonth.add(1, 'month')]);\n }\n }, [currentMonth, props.showMultipleMonths]);\n\n useEffect(() => {\n if (firstUpdate.current) {\n firstUpdate.current = undefined;\n return;\n }\n\n if (props.onStartDateChanged) {\n props.onStartDateChanged(selectedStartDate);\n }\n }, [selectedStartDate]);\n\n useLayoutEffect(() => {\n if (firstUpdate.current) {\n firstUpdate.current = undefined;\n return;\n }\n\n if (props.onEndDateChanged) {\n props.onEndDateChanged(selectedEndDate);\n }\n }, [selectedEndDate]);\n\n const context = {\n today: dayjs(),\n todayInUnix: dayjs().unix(),\n startDate: selectedStartDate,\n endDate: selectedEndDate,\n\n hoveredMonth: hoveringOverDate,\n maxPrice,\n\n onHoverOver: onHoveredOverDay,\n currentMonth,\n\n onDayClicked: (date: dayjs.Dayjs) => {\n onClickDate(date);\n },\n setMaxPrice,\n };\n\n const printMonths = useMemo(\n () => (\n <>\n {calendarStyle === 'Month' ? (\n <>\n <DatePickerMonth small={props.small} showingMonth={currentMonth} />\n {props.showMultipleMonths && <DatePickerMonth showingMonth={currentMonth.add(1, 'month')} />}\n </>\n ) : (\n <>\n <React.Suspense fallback={<WeekViewSkeleton />}>\n <DatePickerWeek />\n </React.Suspense>\n </>\n )}\n </>\n ),\n [currentMonth, props.showMultipleMonths, calendarStyle]\n );\n\n const calendarClassNames = classNames('diji-calendar', {\n '--single': !props.showMultipleMonths,\n '--small': props.small,\n '--week': calendarStyle === 'Week',\n });\n const previousMonthOnClick = () => {\n DataLayer.instance.sendInteraction('Show Previous Month', InteractionType.CALENDAR, InteractionStep.DATES);\n setCurrentMonth(currentMonth.subtract(1, 'month'));\n };\n const nextMonthOnClick = () => {\n DataLayer.instance.sendInteraction('Show Next Month', InteractionType.CALENDAR, InteractionStep.DATES);\n setCurrentMonth(currentMonth.add(1, 'month'));\n };\n const setCalendarStyleAsMonth = () => {\n DataLayer.instance.sendInteraction('Set Calendar Style - Month', InteractionType.CALENDAR, InteractionStep.DATES);\n setCalendarStyle('Month');\n };\n const setCalendarStyleAsWeek = () => {\n DataLayer.instance.sendInteraction('Set Calendar Style - Week', InteractionType.CALENDAR, InteractionStep.DATES);\n setCalendarStyle('Week');\n };\n\n return (\n <DatePickerContext.Provider value={context}>\n <div ref={firstUpdate} className={calendarClassNames}>\n {calendarStyle === 'Month' && (\n <div className=\"diji-calendar-navigation\">\n <Icon icon={IconType.ArrowLeft2} onClick={previousMonthOnClick} color={Color.White} backgroundColor={Color.Navy} borderRadius=\"round\" size=\"24px\" />\n <Icon icon={IconType.ArrowRight2} onClick={nextMonthOnClick} color={Color.White} backgroundColor={Color.Navy} borderRadius=\"round\" size=\"24px\" />\n </div>\n )}\n {props.supportsWeek && (\n <div className=\"diji-calendar-picker-type\">\n <Icon icon={IconType.ViewMonth} size=\"32px\" color={calendarStyle === 'Month' ? Color.Navy : Color.Grey} onClick={setCalendarStyleAsMonth} />\n <Icon icon={IconType.ViewWeek} size=\"32px\" color={calendarStyle === 'Week' ? Color.Navy : Color.Grey} onClick={setCalendarStyleAsWeek} />\n </div>\n )}\n {printMonths}\n {props.showMinNightStay && props.showMultipleMonths && (\n <div className=\"diji-calendar--min-night-stay u-flex u-flex-direction-column u-flex-align-center\">\n <DaysSelectedInformer />\n <div className=\"u-marg-top--light\">\n <MinimumNightStayPill />\n </div>\n </div>\n )}\n </div>\n\n {props.showMinNightStay && !props.showMultipleMonths && (\n <div className=\"diji-calendar--min-night-stay --small u-flex u-flex-direction-column u-flex-align-center u-marg-top\">\n <DaysSelectedInformer />\n <div className=\"u-marg-top--light\">\n <MinimumNightStayPill />\n </div>\n </div>\n )}\n </DatePickerContext.Provider>\n );\n}\n"]}
1
+ {"version":3,"file":"DatePicker.js","sourceRoot":"/","sources":["src/components/generic/date/DatePicker.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react';\n\nimport { Color } from '@/util/Color';\nimport Icon, { IconType } from '@/components/generic/Icon/Icon';\nimport { useEffect, useState, useRef, useLayoutEffect, useMemo, useContext, lazy } from 'react';\n\nimport classNames from 'classnames';\n\nimport dayjs, { Dayjs } from 'dayjs';\nimport { DatePickerContext, IDatePickerContext } from '@frontend/contexts';\nimport DatePickerMonth from '@/components/generic/date/DatePickerMonth';\nimport API from '@/api/BookingAPI';\nimport { BasketContext } from '@frontend/contexts';\nimport DataLayer, { InteractionStep, InteractionType } from '@/util/DataLayer';\nimport MinimumNightStayPill from '@/components/steps/MinimumNightStayPill';\nimport DaysSelectedInformer from '@/components/steps/DaysSelectedInformer';\nimport { useCurrentHotel } from '@frontend/hooks';\nimport DatePickerTypeFeature from '@/providers/feature/DatePickerTypeFeature';\nimport WeekViewSkeleton from './WeekViewSkeleton';\n\nconst DatePickerWeek = lazy(() => import('@/components/generic/date/DatePickerWeek'));\n\nexport interface DatePickerProps {\n showMonthOnLoad?: dayjs.Dayjs;\n\n selectedStartDate?: dayjs.Dayjs;\n selectedEndDate?: dayjs.Dayjs;\n\n canSelect?: boolean;\n // Includes default navigation arrows\n showArrows?: boolean;\n // Displays two side by side\n showMultipleMonths?: boolean;\n\n // Used for tight spaces\n small?: boolean;\n\n // is there support for start / end dates\n supportsMultiSelecting?: boolean;\n\n // Do or don't show mininmum night stay block\n showMinNightStay?: boolean;\n\n supportsWeek?: boolean;\n\n onDateClicked?: (date: dayjs.Dayjs) => void;\n onStartDateChanged?: (date: dayjs.Dayjs) => void;\n onEndDateChanged?: (date: dayjs.Dayjs) => void;\n}\n\ninterface DatePickerDayObject {\n value: string;\n dateObj: dayjs.Dayjs | null;\n price?: string;\n hovered: boolean;\n}\n\nenum DateRangePickingState {\n StartDate = 1,\n EndDate = 2,\n}\n\nexport default function DatePicker(props: DatePickerProps) {\n const { hotel } = useCurrentHotel();\n\n const [currentMonth, setCurrentMonth] = useState(props.showMonthOnLoad ? props.showMonthOnLoad : props.selectedStartDate ? props.selectedStartDate : dayjs());\n\n const [selectedStartDate, setSelectedStartDate] = useState(props.selectedStartDate ?? null);\n const [selectedEndDate, setSelectedEndDate] = useState(props.selectedEndDate ?? null);\n\n const [hoveringOverDate, setHoveringOverDate] = useState<Dayjs | null>(null);\n\n const [pickingState, setPickingState] = useState(DateRangePickingState.StartDate);\n const [calendarStyle, setCalendarStyle] = useState<'Month' | 'Week'>(hotel?.defaultDatepickerType ? hotel?.defaultDatepickerType : 'Month');\n useEffect(() => {\n setCalendarStyle(hotel?.defaultDatepickerType ? hotel?.defaultDatepickerType : 'Month');\n }, [hotel?.defaultDatepickerType]);\n\n const [months, setMonths] = useState(props.showMultipleMonths ? [currentMonth, currentMonth.add(1, 'month')] : [currentMonth]);\n const [maxPrice, setMaxPrice] = useState(0);\n\n const basketContext = useContext(BasketContext);\n\n const onClickDate = async (newDate: dayjs.Dayjs) => {\n let newPickingState: DateRangePickingState | null = null;\n\n const selectedBasketRow = basketContext.selectedBasketRow;\n const adults = selectedBasketRow ? selectedBasketRow.getAdults() : 0;\n const children = selectedBasketRow ? selectedBasketRow.getChildren() : 0;\n const promoCode = selectedBasketRow ? selectedBasketRow.getPromoCode() : '';\n\n const newDatePrice = await API.Availability.getCheapestPriceForDay(newDate, adults, children, promoCode, hotel?.hotelID as string, false);\n\n switch (pickingState) {\n default:\n case DateRangePickingState.StartDate:\n if (newDatePrice.price || !hotel) {\n newPickingState = DateRangePickingState.EndDate;\n\n setSelectedStartDate(newDate);\n setSelectedEndDate(null);\n }\n\n break;\n case DateRangePickingState.EndDate:\n if (newDate.isBefore(selectedStartDate)) {\n setSelectedStartDate(newDate);\n newPickingState = DateRangePickingState.EndDate;\n } else {\n newPickingState = DateRangePickingState.StartDate;\n\n setHoveringOverDate(null);\n\n const nextAvailableDay = await getLastValidDay(selectedStartDate as Dayjs, newDate);\n\n if (newDate.isSame(selectedStartDate)) {\n setSelectedEndDate(nextAvailableDay.add(1, 'day'));\n } else {\n setSelectedEndDate(nextAvailableDay);\n }\n }\n\n break;\n }\n\n if (props.supportsMultiSelecting) {\n setPickingState(newPickingState as DateRangePickingState);\n }\n };\n\n const getLastValidDay = (fromDate: dayjs.Dayjs, toDate: dayjs.Dayjs): Promise<dayjs.Dayjs> =>\n new Promise(async (resolve) => {\n const selectedBasketRow = basketContext.selectedBasketRow;\n const adults = selectedBasketRow ? selectedBasketRow.getAdults() : 0;\n const children = selectedBasketRow ? selectedBasketRow.getChildren() : 0;\n const promoCode = selectedBasketRow ? selectedBasketRow.getPromoCode() : '';\n\n const diff = toDate?.diff?.(fromDate, 'day');\n\n let nextMustBreak = false;\n for (let i = 0; i <= diff; i++) {\n const dayToCheck = fromDate.add(i, 'day');\n\n const price = await API.Availability.getCheapestPriceForDay(dayToCheck, adults, children, promoCode, hotel?.hotelID as string, false);\n\n if (nextMustBreak) {\n return resolve(dayToCheck.subtract(1, 'day'));\n }\n\n if (!price.price && hotel) {\n nextMustBreak = true;\n continue;\n }\n }\n\n resolve(toDate);\n });\n\n const onHoveredOverDay = (day: dayjs.Dayjs) => {\n if (selectedStartDate && !selectedEndDate) {\n getLastValidDay(selectedStartDate, day).then((lastValidDay) => {\n setHoveringOverDate(lastValidDay);\n });\n }\n };\n\n const firstUpdate = useRef<HTMLDivElement | null>(null);\n\n // TODO: Perhaps refactor this later to not depend on non-state items\n useEffect(() => {\n if (DatePickerTypeFeature?.isActive() && props.supportsWeek) {\n setCalendarStyle('Week');\n }\n }, [DatePickerTypeFeature?.isActive()]);\n\n useEffect(() => {\n if (props.showMonthOnLoad) {\n setCurrentMonth(props.showMonthOnLoad);\n }\n }, [props.showMonthOnLoad]);\n\n useEffect(() => {\n if (props.showMultipleMonths) {\n setMonths([currentMonth, currentMonth.add(1, 'month')]);\n }\n }, [currentMonth, props.showMultipleMonths]);\n\n useEffect(() => {\n if (firstUpdate.current) {\n firstUpdate.current = null;\n return;\n }\n\n if (props.onStartDateChanged) {\n props.onStartDateChanged(selectedStartDate as Dayjs);\n }\n }, [selectedStartDate]);\n\n useLayoutEffect(() => {\n if (firstUpdate.current) {\n firstUpdate.current = null;\n return;\n }\n\n if (props.onEndDateChanged) {\n props.onEndDateChanged(selectedEndDate as Dayjs);\n }\n }, [selectedEndDate]);\n\n const context: IDatePickerContext = {\n today: dayjs(),\n todayInUnix: dayjs().unix(),\n startDate: selectedStartDate,\n endDate: selectedEndDate,\n\n hoveredMonth: hoveringOverDate,\n maxPrice,\n\n onHoverOver: onHoveredOverDay,\n currentMonth,\n\n onDayClicked: (date: dayjs.Dayjs) => {\n onClickDate(date);\n },\n setMaxPrice,\n };\n\n const printMonths = useMemo(\n () => (\n <>\n {calendarStyle === 'Month' ? (\n <>\n <DatePickerMonth small={props.small} showingMonth={currentMonth} />\n {props.showMultipleMonths && <DatePickerMonth showingMonth={currentMonth.add(1, 'month')} />}\n </>\n ) : (\n <>\n <React.Suspense fallback={<WeekViewSkeleton />}>\n <DatePickerWeek />\n </React.Suspense>\n </>\n )}\n </>\n ),\n [currentMonth, props.showMultipleMonths, calendarStyle]\n );\n\n const calendarClassNames = classNames('diji-calendar', {\n '--single': !props.showMultipleMonths,\n '--small': props.small,\n '--week': calendarStyle === 'Week',\n });\n const previousMonthOnClick = () => {\n DataLayer.instance.sendInteraction('Show Previous Month', InteractionType.CALENDAR, InteractionStep.DATES);\n setCurrentMonth(currentMonth.subtract(1, 'month'));\n };\n const nextMonthOnClick = () => {\n DataLayer.instance.sendInteraction('Show Next Month', InteractionType.CALENDAR, InteractionStep.DATES);\n setCurrentMonth(currentMonth.add(1, 'month'));\n };\n const setCalendarStyleAsMonth = () => {\n DataLayer.instance.sendInteraction('Set Calendar Style - Month', InteractionType.CALENDAR, InteractionStep.DATES);\n setCalendarStyle('Month');\n };\n const setCalendarStyleAsWeek = () => {\n DataLayer.instance.sendInteraction('Set Calendar Style - Week', InteractionType.CALENDAR, InteractionStep.DATES);\n setCalendarStyle('Week');\n };\n\n return (\n <DatePickerContext.Provider value={context}>\n <div ref={firstUpdate} className={calendarClassNames}>\n {calendarStyle === 'Month' && (\n <div className=\"diji-calendar-navigation\">\n <Icon icon={IconType.ArrowLeft2} onClick={previousMonthOnClick} color={Color.White} backgroundColor={Color.Navy} borderRadius=\"round\" size=\"24px\" />\n <Icon icon={IconType.ArrowRight2} onClick={nextMonthOnClick} color={Color.White} backgroundColor={Color.Navy} borderRadius=\"round\" size=\"24px\" />\n </div>\n )}\n {props.supportsWeek && (\n <div className=\"diji-calendar-picker-type\">\n <Icon icon={IconType.ViewMonth} size=\"32px\" color={calendarStyle === 'Month' ? Color.Navy : Color.Grey} onClick={setCalendarStyleAsMonth} />\n <Icon icon={IconType.ViewWeek} size=\"32px\" color={calendarStyle === 'Week' ? Color.Navy : Color.Grey} onClick={setCalendarStyleAsWeek} />\n </div>\n )}\n {printMonths}\n {props.showMinNightStay && props.showMultipleMonths && (\n <div className=\"diji-calendar--min-night-stay u-flex u-flex-direction-column u-flex-align-center\">\n <DaysSelectedInformer />\n <div className=\"u-marg-top--light\">\n <MinimumNightStayPill />\n </div>\n </div>\n )}\n </div>\n\n {props.showMinNightStay && !props.showMultipleMonths && (\n <div className=\"diji-calendar--min-night-stay --small u-flex u-flex-direction-column u-flex-align-center u-marg-top\">\n <DaysSelectedInformer />\n <div className=\"u-marg-top--light\">\n <MinimumNightStayPill />\n </div>\n </div>\n )}\n </DatePickerContext.Provider>\n );\n}\n"]}