@roomstay/frontend 1.3.0
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.
- package/README.md +0 -0
- package/dist/src/animations/AutoAutoHeight.d.ts +8 -0
- package/dist/src/animations/AutoAutoHeight.js +48 -0
- package/dist/src/animations/AutoAutoHeight.js.map +1 -0
- package/dist/src/animations/Fade.d.ts +9 -0
- package/dist/src/animations/Fade.js +35 -0
- package/dist/src/animations/Fade.js.map +1 -0
- package/dist/src/api/AddonAPI.d.ts +7 -0
- package/dist/src/api/AddonAPI.js +68 -0
- package/dist/src/api/AddonAPI.js.map +1 -0
- package/dist/src/api/AvailabilityAPI.d.ts +40 -0
- package/dist/src/api/AvailabilityAPI.js +362 -0
- package/dist/src/api/AvailabilityAPI.js.map +1 -0
- package/dist/src/api/BaseAPI.d.ts +32 -0
- package/dist/src/api/BaseAPI.js +111 -0
- package/dist/src/api/BaseAPI.js.map +1 -0
- package/dist/src/api/BookingAPI.d.ts +17 -0
- package/dist/src/api/BookingAPI.js +22 -0
- package/dist/src/api/BookingAPI.js.map +1 -0
- package/dist/src/api/ExchangeRateAPI.d.ts +5 -0
- package/dist/src/api/ExchangeRateAPI.js +23 -0
- package/dist/src/api/ExchangeRateAPI.js.map +1 -0
- package/dist/src/api/HotelAPI.d.ts +12 -0
- package/dist/src/api/HotelAPI.js +47 -0
- package/dist/src/api/HotelAPI.js.map +1 -0
- package/dist/src/api/MemberAPI.d.ts +4 -0
- package/dist/src/api/MemberAPI.js +28 -0
- package/dist/src/api/MemberAPI.js.map +1 -0
- package/dist/src/api/ReservationAPI.d.ts +14 -0
- package/dist/src/api/ReservationAPI.js +113 -0
- package/dist/src/api/ReservationAPI.js.map +1 -0
- package/dist/src/components/generic/Alert.d.ts +21 -0
- package/dist/src/components/generic/Alert.js +31 -0
- package/dist/src/components/generic/Alert.js.map +1 -0
- package/dist/src/components/generic/BEButton.d.ts +24 -0
- package/dist/src/components/generic/BEButton.js +60 -0
- package/dist/src/components/generic/BEButton.js.map +1 -0
- package/dist/src/components/generic/BESelect.d.ts +13 -0
- package/dist/src/components/generic/BESelect.js +47 -0
- package/dist/src/components/generic/BESelect.js.map +1 -0
- package/dist/src/components/generic/BETooltip.d.ts +7 -0
- package/dist/src/components/generic/BETooltip.js +44 -0
- package/dist/src/components/generic/BETooltip.js.map +1 -0
- package/dist/src/components/generic/BackButton.d.ts +6 -0
- package/dist/src/components/generic/BackButton.js +14 -0
- package/dist/src/components/generic/BackButton.js.map +1 -0
- package/dist/src/components/generic/BookNowPayLaterInfoBlock.d.ts +2 -0
- package/dist/src/components/generic/BookNowPayLaterInfoBlock.js +32 -0
- package/dist/src/components/generic/BookNowPayLaterInfoBlock.js.map +1 -0
- package/dist/src/components/generic/Checkbox.d.ts +8 -0
- package/dist/src/components/generic/Checkbox.js +22 -0
- package/dist/src/components/generic/Checkbox.js.map +1 -0
- package/dist/src/components/generic/Countdown.d.ts +8 -0
- package/dist/src/components/generic/Countdown.js +35 -0
- package/dist/src/components/generic/Countdown.js.map +1 -0
- package/dist/src/components/generic/Currency.d.ts +12 -0
- package/dist/src/components/generic/Currency.js +71 -0
- package/dist/src/components/generic/Currency.js.map +1 -0
- package/dist/src/components/generic/Distance.d.ts +6 -0
- package/dist/src/components/generic/Distance.js +22 -0
- package/dist/src/components/generic/Distance.js.map +1 -0
- package/dist/src/components/generic/Headline.d.ts +13 -0
- package/dist/src/components/generic/Headline.js +28 -0
- package/dist/src/components/generic/Headline.js.map +1 -0
- package/dist/src/components/generic/Icon.d.ts +79 -0
- package/dist/src/components/generic/Icon.js +105 -0
- package/dist/src/components/generic/Icon.js.map +1 -0
- package/dist/src/components/generic/InputGroup/InputGroup.d.ts +7 -0
- package/dist/src/components/generic/InputGroup/InputGroup.js +26 -0
- package/dist/src/components/generic/InputGroup/InputGroup.js.map +1 -0
- package/dist/src/components/generic/InputGroup/InputGroup.types.d.ts +1 -0
- package/dist/src/components/generic/InputGroup/InputGroup.types.js +3 -0
- package/dist/src/components/generic/InputGroup/InputGroup.types.js.map +1 -0
- package/dist/src/components/generic/LineBreak.d.ts +7 -0
- package/dist/src/components/generic/LineBreak.js +14 -0
- package/dist/src/components/generic/LineBreak.js.map +1 -0
- package/dist/src/components/generic/Notification.d.ts +14 -0
- package/dist/src/components/generic/Notification.js +44 -0
- package/dist/src/components/generic/Notification.js.map +1 -0
- package/dist/src/components/generic/NumberIncrement.d.ts +8 -0
- package/dist/src/components/generic/NumberIncrement.js +45 -0
- package/dist/src/components/generic/NumberIncrement.js.map +1 -0
- package/dist/src/components/generic/Pill.d.ts +18 -0
- package/dist/src/components/generic/Pill.js +29 -0
- package/dist/src/components/generic/Pill.js.map +1 -0
- package/dist/src/components/generic/Placeholder.d.ts +13 -0
- package/dist/src/components/generic/Placeholder.js +23 -0
- package/dist/src/components/generic/Placeholder.js.map +1 -0
- package/dist/src/components/generic/PromoCodeInput.d.ts +9 -0
- package/dist/src/components/generic/PromoCodeInput.js +113 -0
- package/dist/src/components/generic/PromoCodeInput.js.map +1 -0
- package/dist/src/components/generic/RecentSearchesCard.d.ts +9 -0
- package/dist/src/components/generic/RecentSearchesCard.js +47 -0
- package/dist/src/components/generic/RecentSearchesCard.js.map +1 -0
- package/dist/src/components/generic/ScrollToTop.d.ts +4 -0
- package/dist/src/components/generic/ScrollToTop.js +18 -0
- package/dist/src/components/generic/ScrollToTop.js.map +1 -0
- package/dist/src/components/generic/Select.d.ts +12 -0
- package/dist/src/components/generic/Select.js +18 -0
- package/dist/src/components/generic/Select.js.map +1 -0
- package/dist/src/components/generic/Text.d.ts +25 -0
- package/dist/src/components/generic/Text.js +37 -0
- package/dist/src/components/generic/Text.js.map +1 -0
- package/dist/src/components/generic/TextArea.d.ts +3 -0
- package/dist/src/components/generic/TextArea.js +9 -0
- package/dist/src/components/generic/TextArea.js.map +1 -0
- package/dist/src/components/generic/TextBox.d.ts +16 -0
- package/dist/src/components/generic/TextBox.js +50 -0
- package/dist/src/components/generic/TextBox.js.map +1 -0
- package/dist/src/components/generic/badging/SSLSecureBadge.d.ts +2 -0
- package/dist/src/components/generic/badging/SSLSecureBadge.js +11 -0
- package/dist/src/components/generic/badging/SSLSecureBadge.js.map +1 -0
- package/dist/src/components/generic/buttons/NextStepButton.d.ts +13 -0
- package/dist/src/components/generic/buttons/NextStepButton.js +30 -0
- package/dist/src/components/generic/buttons/NextStepButton.js.map +1 -0
- package/dist/src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.d.ts +10 -0
- package/dist/src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.js +120 -0
- package/dist/src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.js.map +1 -0
- package/dist/src/components/generic/date/DatePicker.d.ts +18 -0
- package/dist/src/components/generic/date/DatePicker.js +200 -0
- package/dist/src/components/generic/date/DatePicker.js.map +1 -0
- package/dist/src/components/generic/date/DatePickerDay.d.ts +21 -0
- package/dist/src/components/generic/date/DatePickerDay.js +188 -0
- package/dist/src/components/generic/date/DatePickerDay.js.map +1 -0
- package/dist/src/components/generic/date/DatePickerDays.d.ts +7 -0
- package/dist/src/components/generic/date/DatePickerDays.js +21 -0
- package/dist/src/components/generic/date/DatePickerDays.js.map +1 -0
- package/dist/src/components/generic/date/DatePickerMonth.d.ts +8 -0
- package/dist/src/components/generic/date/DatePickerMonth.js +28 -0
- package/dist/src/components/generic/date/DatePickerMonth.js.map +1 -0
- package/dist/src/components/generic/date/DatePickerWeek.d.ts +2 -0
- package/dist/src/components/generic/date/DatePickerWeek.js +161 -0
- package/dist/src/components/generic/date/DatePickerWeek.js.map +1 -0
- package/dist/src/components/generic/date/FloatingDatePicker.d.ts +10 -0
- package/dist/src/components/generic/date/FloatingDatePicker.js +68 -0
- package/dist/src/components/generic/date/FloatingDatePicker.js.map +1 -0
- package/dist/src/components/generic/loader/ImageLoader.d.ts +11 -0
- package/dist/src/components/generic/loader/ImageLoader.js +37 -0
- package/dist/src/components/generic/loader/ImageLoader.js.map +1 -0
- package/dist/src/components/generic/loader/LargeLoader.d.ts +2 -0
- package/dist/src/components/generic/loader/LargeLoader.js +50 -0
- package/dist/src/components/generic/loader/LargeLoader.js.map +1 -0
- package/dist/src/components/generic/loader/SmallSpinner.d.ts +3 -0
- package/dist/src/components/generic/loader/SmallSpinner.js +11 -0
- package/dist/src/components/generic/loader/SmallSpinner.js.map +1 -0
- package/dist/src/components/generic/map/HotelLocationMap.d.ts +2 -0
- package/dist/src/components/generic/map/HotelLocationMap.js +11 -0
- package/dist/src/components/generic/map/HotelLocationMap.js.map +1 -0
- package/dist/src/components/generic/modal/ConfirmationModal.d.ts +9 -0
- package/dist/src/components/generic/modal/ConfirmationModal.js +27 -0
- package/dist/src/components/generic/modal/ConfirmationModal.js.map +1 -0
- package/dist/src/components/generic/modal/ErrorModal.d.ts +10 -0
- package/dist/src/components/generic/modal/ErrorModal.js +15 -0
- package/dist/src/components/generic/modal/ErrorModal.js.map +1 -0
- package/dist/src/components/generic/modal/SimpleModal.d.ts +21 -0
- package/dist/src/components/generic/modal/SimpleModal.js +82 -0
- package/dist/src/components/generic/modal/SimpleModal.js.map +1 -0
- package/dist/src/components/generic/modal/TabbedModal.d.ts +16 -0
- package/dist/src/components/generic/modal/TabbedModal.js +33 -0
- package/dist/src/components/generic/modal/TabbedModal.js.map +1 -0
- package/dist/src/components/generic/radio/RadioFields.d.ts +14 -0
- package/dist/src/components/generic/radio/RadioFields.js +34 -0
- package/dist/src/components/generic/radio/RadioFields.js.map +1 -0
- package/dist/src/components/iconComponents/BookNowPayLaterIcon.d.ts +7 -0
- package/dist/src/components/iconComponents/BookNowPayLaterIcon.js +20 -0
- package/dist/src/components/iconComponents/BookNowPayLaterIcon.js.map +1 -0
- package/dist/src/components/navigation/Header.d.ts +2 -0
- package/dist/src/components/navigation/Header.js +124 -0
- package/dist/src/components/navigation/Header.js.map +1 -0
- package/dist/src/components/navigation/StepSelector.d.ts +2 -0
- package/dist/src/components/navigation/StepSelector.js +75 -0
- package/dist/src/components/navigation/StepSelector.js.map +1 -0
- package/dist/src/components/navigation/StepSelectorModal.d.ts +6 -0
- package/dist/src/components/navigation/StepSelectorModal.js +63 -0
- package/dist/src/components/navigation/StepSelectorModal.js.map +1 -0
- package/dist/src/components/steps/DaysSelectedInformer.d.ts +2 -0
- package/dist/src/components/steps/DaysSelectedInformer.js +25 -0
- package/dist/src/components/steps/DaysSelectedInformer.js.map +1 -0
- package/dist/src/components/steps/MinimumNightStayPill.d.ts +2 -0
- package/dist/src/components/steps/MinimumNightStayPill.js +62 -0
- package/dist/src/components/steps/MinimumNightStayPill.js.map +1 -0
- package/dist/src/components/steps/addons/AddonCard.d.ts +8 -0
- package/dist/src/components/steps/addons/AddonCard.js +194 -0
- package/dist/src/components/steps/addons/AddonCard.js.map +1 -0
- package/dist/src/components/steps/addons/AddonList.d.ts +3 -0
- package/dist/src/components/steps/addons/AddonList.js +38 -0
- package/dist/src/components/steps/addons/AddonList.js.map +1 -0
- package/dist/src/components/steps/addons/AddonsNotFound.d.ts +2 -0
- package/dist/src/components/steps/addons/AddonsNotFound.js +50 -0
- package/dist/src/components/steps/addons/AddonsNotFound.js.map +1 -0
- package/dist/src/components/steps/common/CommonAddonSummary/CommonAddonSummary.d.ts +7 -0
- package/dist/src/components/steps/common/CommonAddonSummary/CommonAddonSummary.js +42 -0
- package/dist/src/components/steps/common/CommonAddonSummary/CommonAddonSummary.js.map +1 -0
- package/dist/src/components/steps/confirmation/AccountDetails.d.ts +2 -0
- package/dist/src/components/steps/confirmation/AccountDetails.js +31 -0
- package/dist/src/components/steps/confirmation/AccountDetails.js.map +1 -0
- package/dist/src/components/steps/confirmation/RoomContactDetails.d.ts +9 -0
- package/dist/src/components/steps/confirmation/RoomContactDetails.js +224 -0
- package/dist/src/components/steps/confirmation/RoomContactDetails.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationAcknowledgement.d.ts +6 -0
- package/dist/src/components/steps/confirmation/StepConfirmationAcknowledgement.js +33 -0
- package/dist/src/components/steps/confirmation/StepConfirmationAcknowledgement.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCheckoutDifferencesModal.d.ts +11 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCheckoutDifferencesModal.js +76 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCheckoutDifferencesModal.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCommentsComponent.d.ts +6 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCommentsComponent.js +25 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCommentsComponent.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCountrySelector.d.ts +10 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCountrySelector.js +65 -0
- package/dist/src/components/steps/confirmation/StepConfirmationCountrySelector.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationForm.d.ts +2 -0
- package/dist/src/components/steps/confirmation/StepConfirmationForm.js +343 -0
- package/dist/src/components/steps/confirmation/StepConfirmationForm.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationLimitedOffer.d.ts +7 -0
- package/dist/src/components/steps/confirmation/StepConfirmationLimitedOffer.js +29 -0
- package/dist/src/components/steps/confirmation/StepConfirmationLimitedOffer.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPaymentDetails.d.ts +8 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPaymentDetails.js +244 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPaymentDetails.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPoliciesSection.d.ts +2 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPoliciesSection.js +33 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPoliciesSection.js.map +1 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPolicyBlock.d.ts +2 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPolicyBlock.js +56 -0
- package/dist/src/components/steps/confirmation/StepConfirmationPolicyBlock.js.map +1 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffers.d.ts +2 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffers.js +117 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffers.js.map +1 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersColumn.d.ts +8 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersColumn.js +21 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersColumn.js.map +1 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersModal.d.ts +10 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersModal.js +145 -0
- package/dist/src/components/steps/confirmation/additionalOffers/AdditionalOffersModal.js.map +1 -0
- package/dist/src/components/steps/date/PeoplePicker.d.ts +2 -0
- package/dist/src/components/steps/date/PeoplePicker.js +69 -0
- package/dist/src/components/steps/date/PeoplePicker.js.map +1 -0
- package/dist/src/components/steps/date/PeoplePickerRow.d.ts +13 -0
- package/dist/src/components/steps/date/PeoplePickerRow.js +69 -0
- package/dist/src/components/steps/date/PeoplePickerRow.js.map +1 -0
- package/dist/src/components/steps/date/StepDatePricePerRoom.d.ts +6 -0
- package/dist/src/components/steps/date/StepDatePricePerRoom.js +68 -0
- package/dist/src/components/steps/date/StepDatePricePerRoom.js.map +1 -0
- package/dist/src/components/steps/date/StepOneDateRange.d.ts +2 -0
- package/dist/src/components/steps/date/StepOneDateRange.js +24 -0
- package/dist/src/components/steps/date/StepOneDateRange.js.map +1 -0
- package/dist/src/components/steps/date/StepOneDateRangePicker.d.ts +2 -0
- package/dist/src/components/steps/date/StepOneDateRangePicker.js +25 -0
- package/dist/src/components/steps/date/StepOneDateRangePicker.js.map +1 -0
- package/dist/src/components/steps/date/StepOneDateRangePickerLegend.d.ts +2 -0
- package/dist/src/components/steps/date/StepOneDateRangePickerLegend.js +37 -0
- package/dist/src/components/steps/date/StepOneDateRangePickerLegend.js.map +1 -0
- package/dist/src/components/steps/date/StepOneNextStepButton.d.ts +2 -0
- package/dist/src/components/steps/date/StepOneNextStepButton.js +51 -0
- package/dist/src/components/steps/date/StepOneNextStepButton.js.map +1 -0
- package/dist/src/components/steps/date/StepOneStatusPeople.d.ts +2 -0
- package/dist/src/components/steps/date/StepOneStatusPeople.js +17 -0
- package/dist/src/components/steps/date/StepOneStatusPeople.js.map +1 -0
- package/dist/src/components/steps/hotel/HotelCard.d.ts +7 -0
- package/dist/src/components/steps/hotel/HotelCard.js +145 -0
- package/dist/src/components/steps/hotel/HotelCard.js.map +1 -0
- package/dist/src/components/steps/hotel/HotelCardList.d.ts +6 -0
- package/dist/src/components/steps/hotel/HotelCardList.js +13 -0
- package/dist/src/components/steps/hotel/HotelCardList.js.map +1 -0
- package/dist/src/components/steps/hotel/HotelCardModal.d.ts +10 -0
- package/dist/src/components/steps/hotel/HotelCardModal.js +90 -0
- package/dist/src/components/steps/hotel/HotelCardModal.js.map +1 -0
- package/dist/src/components/steps/hotel/HotelSearchParameters.d.ts +3 -0
- package/dist/src/components/steps/hotel/HotelSearchParameters.js +149 -0
- package/dist/src/components/steps/hotel/HotelSearchParameters.js.map +1 -0
- package/dist/src/components/steps/hotel/NoHotelsAvailable.d.ts +2 -0
- package/dist/src/components/steps/hotel/NoHotelsAvailable.js +68 -0
- package/dist/src/components/steps/hotel/NoHotelsAvailable.js.map +1 -0
- package/dist/src/components/steps/room/AvailableUpgradesModal.d.ts +3 -0
- package/dist/src/components/steps/room/AvailableUpgradesModal.js +148 -0
- package/dist/src/components/steps/room/AvailableUpgradesModal.js.map +1 -0
- package/dist/src/components/steps/room/ImageGallerySlider.d.ts +9 -0
- package/dist/src/components/steps/room/ImageGallerySlider.js +126 -0
- package/dist/src/components/steps/room/ImageGallerySlider.js.map +1 -0
- package/dist/src/components/steps/room/InactivityWindow.d.ts +3 -0
- package/dist/src/components/steps/room/InactivityWindow.js +80 -0
- package/dist/src/components/steps/room/InactivityWindow.js.map +1 -0
- package/dist/src/components/steps/room/LargeRoomCard.d.ts +9 -0
- package/dist/src/components/steps/room/LargeRoomCard.js +82 -0
- package/dist/src/components/steps/room/LargeRoomCard.js.map +1 -0
- package/dist/src/components/steps/room/MemberSignInModal/MemberSignInModal.d.ts +7 -0
- package/dist/src/components/steps/room/MemberSignInModal/MemberSignInModal.js +260 -0
- package/dist/src/components/steps/room/MemberSignInModal/MemberSignInModal.js.map +1 -0
- package/dist/src/components/steps/room/MemberSignInModal/MemberSignInModal.types.d.ts +13 -0
- package/dist/src/components/steps/room/MemberSignInModal/MemberSignInModal.types.js +3 -0
- package/dist/src/components/steps/room/MemberSignInModal/MemberSignInModal.types.js.map +1 -0
- package/dist/src/components/steps/room/RatesNotFound.d.ts +2 -0
- package/dist/src/components/steps/room/RatesNotFound.js +48 -0
- package/dist/src/components/steps/room/RatesNotFound.js.map +1 -0
- package/dist/src/components/steps/room/RoomList.d.ts +2 -0
- package/dist/src/components/steps/room/RoomList.js +84 -0
- package/dist/src/components/steps/room/RoomList.js.map +1 -0
- package/dist/src/components/steps/room/RoomListCrossSellBlock.d.ts +5 -0
- package/dist/src/components/steps/room/RoomListCrossSellBlock.js +124 -0
- package/dist/src/components/steps/room/RoomListCrossSellBlock.js.map +1 -0
- package/dist/src/components/steps/room/RoomModal.d.ts +12 -0
- package/dist/src/components/steps/room/RoomModal.js +63 -0
- package/dist/src/components/steps/room/RoomModal.js.map +1 -0
- package/dist/src/components/steps/room/RoomNotFound.d.ts +3 -0
- package/dist/src/components/steps/room/RoomNotFound.js +108 -0
- package/dist/src/components/steps/room/RoomNotFound.js.map +1 -0
- package/dist/src/components/steps/room/StepRoomAlertBlocks.d.ts +2 -0
- package/dist/src/components/steps/room/StepRoomAlertBlocks.js +27 -0
- package/dist/src/components/steps/room/StepRoomAlertBlocks.js.map +1 -0
- package/dist/src/components/steps/room/StepRoomBestRateAlert.d.ts +3 -0
- package/dist/src/components/steps/room/StepRoomBestRateAlert.js +29 -0
- package/dist/src/components/steps/room/StepRoomBestRateAlert.js.map +1 -0
- package/dist/src/components/steps/room/StepRoomHotelDetails.d.ts +2 -0
- package/dist/src/components/steps/room/StepRoomHotelDetails.js +43 -0
- package/dist/src/components/steps/room/StepRoomHotelDetails.js.map +1 -0
- package/dist/src/components/steps/room/StepRoomNextStepButton.d.ts +2 -0
- package/dist/src/components/steps/room/StepRoomNextStepButton.js +21 -0
- package/dist/src/components/steps/room/StepRoomNextStepButton.js.map +1 -0
- package/dist/src/components/steps/room/StepRoomSortBy.d.ts +2 -0
- package/dist/src/components/steps/room/StepRoomSortBy.js +26 -0
- package/dist/src/components/steps/room/StepRoomSortBy.js.map +1 -0
- package/dist/src/components/steps/room/StepRoomSummaryAndButton.d.ts +2 -0
- package/dist/src/components/steps/room/StepRoomSummaryAndButton.js +40 -0
- package/dist/src/components/steps/room/StepRoomSummaryAndButton.js.map +1 -0
- package/dist/src/components/steps/room/roomBuilderProgress/NumberOfAdultsPicker.d.ts +8 -0
- package/dist/src/components/steps/room/roomBuilderProgress/NumberOfAdultsPicker.js +29 -0
- package/dist/src/components/steps/room/roomBuilderProgress/NumberOfAdultsPicker.js.map +1 -0
- package/dist/src/components/steps/room/roomBuilderProgress/NumberOfChildrenPicker.d.ts +8 -0
- package/dist/src/components/steps/room/roomBuilderProgress/NumberOfChildrenPicker.js +28 -0
- package/dist/src/components/steps/room/roomBuilderProgress/NumberOfChildrenPicker.js.map +1 -0
- package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgress.d.ts +2 -0
- package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgress.js +39 -0
- package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgress.js.map +1 -0
- package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgressRow.d.ts +7 -0
- package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgressRow.js +211 -0
- package/dist/src/components/steps/room/roomBuilderProgress/RoomBuilderProgressRow.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetails.d.ts +7 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetails.js +151 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetails.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsBedsBlock.d.ts +7 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsBedsBlock.js +34 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsBedsBlock.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsPerkBlock.d.ts +7 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsPerkBlock.js +33 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsPerkBlock.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsPriceBlock.d.ts +10 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsPriceBlock.js +44 -0
- package/dist/src/components/steps/room/roomDetails/RoomDetailsPriceBlock.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/BookNowButton.d.ts +10 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/BookNowButton.js +28 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/BookNowButton.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/MembersOnlyRow.d.ts +2 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/MembersOnlyRow.js +57 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/MembersOnlyRow.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/PriceBreakdownBlock.d.ts +15 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/PriceBreakdownBlock.js +120 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/PriceBreakdownBlock.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDescriptionTab.d.ts +14 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDescriptionTab.js +76 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDescriptionTab.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDetailsAndPriceBreakdownModal.d.ts +16 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDetailsAndPriceBreakdownModal.js +34 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDetailsAndPriceBreakdownModal.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRatePills.d.ts +11 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRatePills.js +86 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRatePills.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateRow.d.ts +9 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateRow.js +119 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateRow.js.map +1 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRates.d.ts +12 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRates.js +103 -0
- package/dist/src/components/steps/room/roomDetails/roomRates/RoomRates.js.map +1 -0
- package/dist/src/components/steps/room/roomFilter/AppliedFiltersBlock.d.ts +2 -0
- package/dist/src/components/steps/room/roomFilter/AppliedFiltersBlock.js +42 -0
- package/dist/src/components/steps/room/roomFilter/AppliedFiltersBlock.js.map +1 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterOverlay.d.ts +9 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterOverlay.js +106 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterOverlay.js.map +1 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterPriceSlider.d.ts +10 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterPriceSlider.js +99 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterPriceSlider.js.map +1 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterRateType.d.ts +10 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterRateType.js +65 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterRateType.js.map +1 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterRoomType.d.ts +10 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterRoomType.js +63 -0
- package/dist/src/components/steps/room/roomFilter/RoomFilterRoomType.js.map +1 -0
- package/dist/src/components/summary/BEMapWidget.d.ts +12 -0
- package/dist/src/components/summary/BEMapWidget.js +50 -0
- package/dist/src/components/summary/BEMapWidget.js.map +1 -0
- package/dist/src/components/summary/BEMobileSummary.d.ts +2 -0
- package/dist/src/components/summary/BEMobileSummary.js +55 -0
- package/dist/src/components/summary/BEMobileSummary.js.map +1 -0
- package/dist/src/components/summary/BEMobileSummaryModal.d.ts +7 -0
- package/dist/src/components/summary/BEMobileSummaryModal.js +142 -0
- package/dist/src/components/summary/BEMobileSummaryModal.js.map +1 -0
- package/dist/src/components/summary/BESummary.d.ts +7 -0
- package/dist/src/components/summary/BESummary.js +106 -0
- package/dist/src/components/summary/BESummary.js.map +1 -0
- package/dist/src/components/summary/BESummaryAddonRow.d.ts +8 -0
- package/dist/src/components/summary/BESummaryAddonRow.js +88 -0
- package/dist/src/components/summary/BESummaryAddonRow.js.map +1 -0
- package/dist/src/components/summary/BESummaryPerkBlock.d.ts +6 -0
- package/dist/src/components/summary/BESummaryPerkBlock.js +34 -0
- package/dist/src/components/summary/BESummaryPerkBlock.js.map +1 -0
- package/dist/src/components/summary/BESummaryPrivacyPolicy.d.ts +2 -0
- package/dist/src/components/summary/BESummaryPrivacyPolicy.js +24 -0
- package/dist/src/components/summary/BESummaryPrivacyPolicy.js.map +1 -0
- package/dist/src/components/summary/BESummaryRoomRow.d.ts +10 -0
- package/dist/src/components/summary/BESummaryRoomRow.js +113 -0
- package/dist/src/components/summary/BESummaryRoomRow.js.map +1 -0
- package/dist/src/components/summary/TransportDistanceFromHotelBlock.d.ts +10 -0
- package/dist/src/components/summary/TransportDistanceFromHotelBlock.js +48 -0
- package/dist/src/components/summary/TransportDistanceFromHotelBlock.js.map +1 -0
- package/dist/src/contexts/BasketContext/BasketContext.d.ts +3 -0
- package/dist/src/contexts/BasketContext/BasketContext.js +6 -0
- package/dist/src/contexts/BasketContext/BasketContext.js.map +1 -0
- package/dist/src/contexts/BasketContext/BasketContextType.d.ts +39 -0
- package/dist/src/contexts/BasketContext/BasketContextType.js +3 -0
- package/dist/src/contexts/BasketContext/BasketContextType.js.map +1 -0
- package/dist/src/contexts/BasketContext/BasketContextWrapper.d.ts +5 -0
- package/dist/src/contexts/BasketContext/BasketContextWrapper.js +383 -0
- package/dist/src/contexts/BasketContext/BasketContextWrapper.js.map +1 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContext.d.ts +3 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContext.js +6 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContext.js.map +1 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContextType.types.d.ts +17 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContextType.types.js +3 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContextType.types.js.map +1 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContextWrapper.d.ts +7 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContextWrapper.js +46 -0
- package/dist/src/contexts/BookingEngineContext/BookingEngineContextWrapper.js.map +1 -0
- package/dist/src/contexts/CompanyContext/CompanyContext.d.ts +3 -0
- package/dist/src/contexts/CompanyContext/CompanyContext.js +6 -0
- package/dist/src/contexts/CompanyContext/CompanyContext.js.map +1 -0
- package/dist/src/contexts/CompanyContext/CompanyContextType.type.d.ts +19 -0
- package/dist/src/contexts/CompanyContext/CompanyContextType.type.js +3 -0
- package/dist/src/contexts/CompanyContext/CompanyContextType.type.js.map +1 -0
- package/dist/src/contexts/CompanyContext/CompanyContextWrapper.d.ts +8 -0
- package/dist/src/contexts/CompanyContext/CompanyContextWrapper.js +270 -0
- package/dist/src/contexts/CompanyContext/CompanyContextWrapper.js.map +1 -0
- package/dist/src/contexts/ConfirmationFormContext.d.ts +16 -0
- package/dist/src/contexts/ConfirmationFormContext.js +33 -0
- package/dist/src/contexts/ConfirmationFormContext.js.map +1 -0
- package/dist/src/contexts/DatePickerContext.d.ts +14 -0
- package/dist/src/contexts/DatePickerContext.js +23 -0
- package/dist/src/contexts/DatePickerContext.js.map +1 -0
- package/dist/src/contexts/ErrorContext.d.ts +19 -0
- package/dist/src/contexts/ErrorContext.js +43 -0
- package/dist/src/contexts/ErrorContext.js.map +1 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContext.d.ts +3 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContext.js +6 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContext.js.map +1 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextTypes.d.ts +19 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextTypes.js +3 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextTypes.js.map +1 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextWrapper.d.ts +6 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextWrapper.js +204 -0
- package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextWrapper.js.map +1 -0
- package/dist/src/contexts/HotelOverridesContext.d.ts +10 -0
- package/dist/src/contexts/HotelOverridesContext.js +63 -0
- package/dist/src/contexts/HotelOverridesContext.js.map +1 -0
- package/dist/src/contexts/ModalContext.d.ts +14 -0
- package/dist/src/contexts/ModalContext.js +34 -0
- package/dist/src/contexts/ModalContext.js.map +1 -0
- package/dist/src/contexts/NotificationContext.d.ts +14 -0
- package/dist/src/contexts/NotificationContext.js +34 -0
- package/dist/src/contexts/NotificationContext.js.map +1 -0
- package/dist/src/contexts/index.d.ts +19 -0
- package/dist/src/contexts/index.js +32 -0
- package/dist/src/contexts/index.js.map +1 -0
- package/dist/src/engines/BaseEngine.d.ts +20 -0
- package/dist/src/engines/BaseEngine.js +62 -0
- package/dist/src/engines/BaseEngine.js.map +1 -0
- package/dist/src/engines/CustomEngine/CustomEngine.d.ts +4 -0
- package/dist/src/engines/CustomEngine/CustomEngine.js +23 -0
- package/dist/src/engines/CustomEngine/CustomEngine.js.map +1 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngine.d.ts +5 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngine.js +31 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngine.js.map +1 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngineElement.d.ts +8 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngineElement.js +34 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngineElement.js.map +1 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngineElementEvents.d.ts +3 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngineElementEvents.js +9 -0
- package/dist/src/engines/FullPageBookingEngine/FullPageBookingEngineElementEvents.js.map +1 -0
- package/dist/src/engines/InlineRoomMiniEngine/InlineRoomMiniEngine.d.ts +7 -0
- package/dist/src/engines/InlineRoomMiniEngine/InlineRoomMiniEngine.js +32 -0
- package/dist/src/engines/InlineRoomMiniEngine/InlineRoomMiniEngine.js.map +1 -0
- package/dist/src/engines/InlineRoomMiniEngine/InlineRoomMiniEngineElement.d.ts +7 -0
- package/dist/src/engines/InlineRoomMiniEngine/InlineRoomMiniEngineElement.js +246 -0
- package/dist/src/engines/InlineRoomMiniEngine/InlineRoomMiniEngineElement.js.map +1 -0
- package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngine.d.ts +7 -0
- package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngine.js +31 -0
- package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngine.js.map +1 -0
- package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngineElement.d.ts +7 -0
- package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngineElement.js +112 -0
- package/dist/src/engines/RecentSearchesEngine/RecentSearchesEngineElement.js.map +1 -0
- package/dist/src/errors/GetAvailabilityError.d.ts +7 -0
- package/dist/src/errors/GetAvailabilityError.js +21 -0
- package/dist/src/errors/GetAvailabilityError.js.map +1 -0
- package/dist/src/errors/NoCompanyContextError.d.ts +4 -0
- package/dist/src/errors/NoCompanyContextError.js +11 -0
- package/dist/src/errors/NoCompanyContextError.js.map +1 -0
- package/dist/src/errors/NoHotelSelectedError.d.ts +4 -0
- package/dist/src/errors/NoHotelSelectedError.js +11 -0
- package/dist/src/errors/NoHotelSelectedError.js.map +1 -0
- package/dist/src/errors/RoomstayError.d.ts +3 -0
- package/dist/src/errors/RoomstayError.js +10 -0
- package/dist/src/errors/RoomstayError.js.map +1 -0
- package/dist/src/events/RoomstayEvent.d.ts +4 -0
- package/dist/src/events/RoomstayEvent.js +11 -0
- package/dist/src/events/RoomstayEvent.js.map +1 -0
- package/dist/src/events/RoomstayEventManager.d.ts +13 -0
- package/dist/src/events/RoomstayEventManager.js +72 -0
- package/dist/src/events/RoomstayEventManager.js.map +1 -0
- package/dist/src/events/actions/AddToCartEvent.d.ts +8 -0
- package/dist/src/events/actions/AddToCartEvent.js +16 -0
- package/dist/src/events/actions/AddToCartEvent.js.map +1 -0
- package/dist/src/events/actions/RemoveFromCartEvent.d.ts +8 -0
- package/dist/src/events/actions/RemoveFromCartEvent.js +16 -0
- package/dist/src/events/actions/RemoveFromCartEvent.js.map +1 -0
- package/dist/src/events/index.d.ts +3 -0
- package/dist/src/events/index.js +16 -0
- package/dist/src/events/index.js.map +1 -0
- package/dist/src/events/views/StepCheckoutViewEvent.d.ts +7 -0
- package/dist/src/events/views/StepCheckoutViewEvent.js +15 -0
- package/dist/src/events/views/StepCheckoutViewEvent.js.map +1 -0
- package/dist/src/handlers/BasketContextErrorHandler.d.ts +4 -0
- package/dist/src/handlers/BasketContextErrorHandler.js +5 -0
- package/dist/src/handlers/BasketContextErrorHandler.js.map +1 -0
- package/dist/src/handlers/HotelContextEventHandler.d.ts +3 -0
- package/dist/src/handlers/HotelContextEventHandler.js +9 -0
- package/dist/src/handlers/HotelContextEventHandler.js.map +1 -0
- package/dist/src/hooks/CurrentHotelHook.d.ts +4 -0
- package/dist/src/hooks/CurrentHotelHook.js +26 -0
- package/dist/src/hooks/CurrentHotelHook.js.map +1 -0
- package/dist/src/hooks/ElementSortHook.d.ts +11 -0
- package/dist/src/hooks/ElementSortHook.js +20 -0
- package/dist/src/hooks/ElementSortHook.js.map +1 -0
- package/dist/src/hooks/EventHook.d.ts +6 -0
- package/dist/src/hooks/EventHook.js +16 -0
- package/dist/src/hooks/EventHook.js.map +1 -0
- package/dist/src/hooks/ScrollFocusHook.d.ts +3 -0
- package/dist/src/hooks/ScrollFocusHook.js +14 -0
- package/dist/src/hooks/ScrollFocusHook.js.map +1 -0
- package/dist/src/hooks/ScrollLock.d.ts +1 -0
- package/dist/src/hooks/ScrollLock.js +17 -0
- package/dist/src/hooks/ScrollLock.js.map +1 -0
- package/dist/src/hooks/index.d.ts +5 -0
- package/dist/src/hooks/index.js +18 -0
- package/dist/src/hooks/index.js.map +1 -0
- package/dist/src/icons/Check.d.ts +6 -0
- package/dist/src/icons/Check.js +12 -0
- package/dist/src/icons/Check.js.map +1 -0
- package/dist/src/index.d.ts +71 -0
- package/dist/src/index.js +152 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/mockApi/AddonAPI.d.ts +7 -0
- package/dist/src/mockApi/AddonAPI.js +78 -0
- package/dist/src/mockApi/AddonAPI.js.map +1 -0
- package/dist/src/mockApi/BookingAPI.d.ts +15 -0
- package/dist/src/mockApi/BookingAPI.js +18 -0
- package/dist/src/mockApi/BookingAPI.js.map +1 -0
- package/dist/src/mockApi/ExchangeRateAPI.d.ts +5 -0
- package/dist/src/mockApi/ExchangeRateAPI.js +23 -0
- package/dist/src/mockApi/ExchangeRateAPI.js.map +1 -0
- package/dist/src/mockApi/HotelAPI.d.ts +6 -0
- package/dist/src/mockApi/HotelAPI.js +23 -0
- package/dist/src/mockApi/HotelAPI.js.map +1 -0
- package/dist/src/mockApi/MemberAPI.d.ts +4 -0
- package/dist/src/mockApi/MemberAPI.js +26 -0
- package/dist/src/mockApi/MemberAPI.js.map +1 -0
- package/dist/src/mockApi/MockAPI.d.ts +31 -0
- package/dist/src/mockApi/MockAPI.js +110 -0
- package/dist/src/mockApi/MockAPI.js.map +1 -0
- package/dist/src/mockApi/ReservationAPI.d.ts +14 -0
- package/dist/src/mockApi/ReservationAPI.js +109 -0
- package/dist/src/mockApi/ReservationAPI.js.map +1 -0
- package/dist/src/models/Addon/Addon.d.ts +131 -0
- package/dist/src/models/Addon/Addon.js +76 -0
- package/dist/src/models/Addon/Addon.js.map +1 -0
- package/dist/src/models/Api/ExchangeRateDTO.d.ts +3 -0
- package/dist/src/models/Api/ExchangeRateDTO.js +3 -0
- package/dist/src/models/Api/ExchangeRateDTO.js.map +1 -0
- package/dist/src/models/Api/HotelDTO.d.ts +68 -0
- package/dist/src/models/Api/HotelDTO.js +13 -0
- package/dist/src/models/Api/HotelDTO.js.map +1 -0
- package/dist/src/models/Api/HotelOverrideDTO.d.ts +18 -0
- package/dist/src/models/Api/HotelOverrideDTO.js +3 -0
- package/dist/src/models/Api/HotelOverrideDTO.js.map +1 -0
- package/dist/src/models/Api/RatePlanDTO.d.ts +8 -0
- package/dist/src/models/Api/RatePlanDTO.js +3 -0
- package/dist/src/models/Api/RatePlanDTO.js.map +1 -0
- package/dist/src/models/Api/ReservationsDTO.d.ts +66 -0
- package/dist/src/models/Api/ReservationsDTO.js +3 -0
- package/dist/src/models/Api/ReservationsDTO.js.map +1 -0
- package/dist/src/models/Api/RoomNightDTO.d.ts +11 -0
- package/dist/src/models/Api/RoomNightDTO.js +3 -0
- package/dist/src/models/Api/RoomNightDTO.js.map +1 -0
- package/dist/src/models/Api/RoomNightRateDTO.d.ts +8 -0
- package/dist/src/models/Api/RoomNightRateDTO.js +3 -0
- package/dist/src/models/Api/RoomNightRateDTO.js.map +1 -0
- package/dist/src/models/Api/RoomTypeDTO.d.ts +8 -0
- package/dist/src/models/Api/RoomTypeDTO.js +3 -0
- package/dist/src/models/Api/RoomTypeDTO.js.map +1 -0
- package/dist/src/models/BasketAddonRow.d.ts +36 -0
- package/dist/src/models/BasketAddonRow.js +125 -0
- package/dist/src/models/BasketAddonRow.js.map +1 -0
- package/dist/src/models/BasketRow.d.ts +49 -0
- package/dist/src/models/BasketRow.js +155 -0
- package/dist/src/models/BasketRow.js.map +1 -0
- package/dist/src/models/BasketRowDifferences.d.ts +9 -0
- package/dist/src/models/BasketRowDifferences.js +3 -0
- package/dist/src/models/BasketRowDifferences.js.map +1 -0
- package/dist/src/models/Client/Client.d.ts +4 -0
- package/dist/src/models/Client/Client.js +7 -0
- package/dist/src/models/Client/Client.js.map +1 -0
- package/dist/src/models/Client/Hotel/ColorProfile.d.ts +12 -0
- package/dist/src/models/Client/Hotel/ColorProfile.js +3 -0
- package/dist/src/models/Client/Hotel/ColorProfile.js.map +1 -0
- package/dist/src/models/Client/Hotel/Company.d.ts +25 -0
- package/dist/src/models/Client/Hotel/Company.js +3 -0
- package/dist/src/models/Client/Hotel/Company.js.map +1 -0
- package/dist/src/models/Client/Hotel/DistanceUnitType.types.d.ts +5 -0
- package/dist/src/models/Client/Hotel/DistanceUnitType.types.js +10 -0
- package/dist/src/models/Client/Hotel/DistanceUnitType.types.js.map +1 -0
- package/dist/src/models/Client/Hotel/Hotel.d.ts +89 -0
- package/dist/src/models/Client/Hotel/Hotel.js +3 -0
- package/dist/src/models/Client/Hotel/Hotel.js.map +1 -0
- package/dist/src/models/Client/Hotel/HotelAddress.d.ts +10 -0
- package/dist/src/models/Client/Hotel/HotelAddress.js +3 -0
- package/dist/src/models/Client/Hotel/HotelAddress.js.map +1 -0
- package/dist/src/models/Client/Hotel/HotelDataSource.types.d.ts +4 -0
- package/dist/src/models/Client/Hotel/HotelDataSource.types.js +9 -0
- package/dist/src/models/Client/Hotel/HotelDataSource.types.js.map +1 -0
- package/dist/src/models/Client/Hotel/HotelPerk.d.ts +9 -0
- package/dist/src/models/Client/Hotel/HotelPerk.js +3 -0
- package/dist/src/models/Client/Hotel/HotelPerk.js.map +1 -0
- package/dist/src/models/Client/Hotel/HotelRoomOverwrite.d.ts +3 -0
- package/dist/src/models/Client/Hotel/HotelRoomOverwrite.js +3 -0
- package/dist/src/models/Client/Hotel/HotelRoomOverwrite.js.map +1 -0
- package/dist/src/models/Client/Hotel/WeekdayStartsOn.types.d.ts +4 -0
- package/dist/src/models/Client/Hotel/WeekdayStartsOn.types.js +9 -0
- package/dist/src/models/Client/Hotel/WeekdayStartsOn.types.js.map +1 -0
- package/dist/src/models/CountryCodesAndNumbers.d.ts +8 -0
- package/dist/src/models/CountryCodesAndNumbers.js +259 -0
- package/dist/src/models/CountryCodesAndNumbers.js.map +1 -0
- package/dist/src/models/Currency.d.ts +11 -0
- package/dist/src/models/Currency.js +13 -0
- package/dist/src/models/Currency.js.map +1 -0
- package/dist/src/models/PaymentCard.d.ts +8 -0
- package/dist/src/models/PaymentCard.js +3 -0
- package/dist/src/models/PaymentCard.js.map +1 -0
- package/dist/src/models/Room/Filters/BudgetFilter.d.ts +11 -0
- package/dist/src/models/Room/Filters/BudgetFilter.js +35 -0
- package/dist/src/models/Room/Filters/BudgetFilter.js.map +1 -0
- package/dist/src/models/Room/Filters/Filter.d.ts +5 -0
- package/dist/src/models/Room/Filters/Filter.js +6 -0
- package/dist/src/models/Room/Filters/Filter.js.map +1 -0
- package/dist/src/models/Room/Filters/RateTypeFilter.d.ts +9 -0
- package/dist/src/models/Room/Filters/RateTypeFilter.js +21 -0
- package/dist/src/models/Room/Filters/RateTypeFilter.js.map +1 -0
- package/dist/src/models/Room/Filters/RoomTypeFilter.d.ts +9 -0
- package/dist/src/models/Room/Filters/RoomTypeFilter.js +23 -0
- package/dist/src/models/Room/Filters/RoomTypeFilter.js.map +1 -0
- package/dist/src/models/Room/Room.d.ts +40 -0
- package/dist/src/models/Room/Room.js +117 -0
- package/dist/src/models/Room/Room.js.map +1 -0
- package/dist/src/models/Room/RoomRate.d.ts +72 -0
- package/dist/src/models/Room/RoomRate.js +179 -0
- package/dist/src/models/Room/RoomRate.js.map +1 -0
- package/dist/src/models/Room/RoomRateNight.d.ts +22 -0
- package/dist/src/models/Room/RoomRateNight.js +31 -0
- package/dist/src/models/Room/RoomRateNight.js.map +1 -0
- package/dist/src/models/Room/RoomRateSortable.d.ts +3 -0
- package/dist/src/models/Room/RoomRateSortable.js +3 -0
- package/dist/src/models/Room/RoomRateSortable.js.map +1 -0
- package/dist/src/models/RoomstaySession.d.ts +37 -0
- package/dist/src/models/RoomstaySession.js +5 -0
- package/dist/src/models/RoomstaySession.js.map +1 -0
- package/dist/src/models/Serializable.d.ts +4 -0
- package/dist/src/models/Serializable.js +3 -0
- package/dist/src/models/Serializable.js.map +1 -0
- package/dist/src/models/UserProfile.d.ts +20 -0
- package/dist/src/models/UserProfile.js +3 -0
- package/dist/src/models/UserProfile.js.map +1 -0
- package/dist/src/pages/findReservation/FindReservation.d.ts +2 -0
- package/dist/src/pages/findReservation/FindReservation.js +142 -0
- package/dist/src/pages/findReservation/FindReservation.js.map +1 -0
- package/dist/src/pages/findReservation/FindReservationResults.d.ts +2 -0
- package/dist/src/pages/findReservation/FindReservationResults.js +102 -0
- package/dist/src/pages/findReservation/FindReservationResults.js.map +1 -0
- package/dist/src/pages/findReservation/ReservationRow.d.ts +8 -0
- package/dist/src/pages/findReservation/ReservationRow.js +147 -0
- package/dist/src/pages/findReservation/ReservationRow.js.map +1 -0
- package/dist/src/pages/findReservation/ReservationRowModal.d.ts +10 -0
- package/dist/src/pages/findReservation/ReservationRowModal.js +101 -0
- package/dist/src/pages/findReservation/ReservationRowModal.js.map +1 -0
- package/dist/src/pages/hotel/HotelInfo.d.ts +2 -0
- package/dist/src/pages/hotel/HotelInfo.js +164 -0
- package/dist/src/pages/hotel/HotelInfo.js.map +1 -0
- package/dist/src/pages/hotel/HotelInfoPlaceholder.d.ts +2 -0
- package/dist/src/pages/hotel/HotelInfoPlaceholder.js +11 -0
- package/dist/src/pages/hotel/HotelInfoPlaceholder.js.map +1 -0
- package/dist/src/pages/steps/Step.d.ts +22 -0
- package/dist/src/pages/steps/Step.js +32 -0
- package/dist/src/pages/steps/Step.js.map +1 -0
- package/dist/src/pages/steps/StepAddon/StepAddon.d.ts +15 -0
- package/dist/src/pages/steps/StepAddon/StepAddon.js +27 -0
- package/dist/src/pages/steps/StepAddon/StepAddon.js.map +1 -0
- package/dist/src/pages/steps/StepAddon/StepAddonComponent.d.ts +2 -0
- package/dist/src/pages/steps/StepAddon/StepAddonComponent.js +35 -0
- package/dist/src/pages/steps/StepAddon/StepAddonComponent.js.map +1 -0
- package/dist/src/pages/steps/StepAddon/StepAddonLoader.d.ts +2 -0
- package/dist/src/pages/steps/StepAddon/StepAddonLoader.js +60 -0
- package/dist/src/pages/steps/StepAddon/StepAddonLoader.js.map +1 -0
- package/dist/src/pages/steps/StepAddon/StepAddonValidator.d.ts +5 -0
- package/dist/src/pages/steps/StepAddon/StepAddonValidator.js +10 -0
- package/dist/src/pages/steps/StepAddon/StepAddonValidator.js.map +1 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmation.d.ts +15 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmation.js +27 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmation.js.map +1 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationComponent.d.ts +3 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationComponent.js +62 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationComponent.js.map +1 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationLoader.d.ts +2 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationLoader.js +81 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationLoader.js.map +1 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationValidator.d.ts +5 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationValidator.js +14 -0
- package/dist/src/pages/steps/StepConfirmation/StepConfirmationValidator.js.map +1 -0
- package/dist/src/pages/steps/StepDate/StepDate.d.ts +15 -0
- package/dist/src/pages/steps/StepDate/StepDate.js +27 -0
- package/dist/src/pages/steps/StepDate/StepDate.js.map +1 -0
- package/dist/src/pages/steps/StepDate/StepDateComponent.d.ts +3 -0
- package/dist/src/pages/steps/StepDate/StepDateComponent.js +78 -0
- package/dist/src/pages/steps/StepDate/StepDateComponent.js.map +1 -0
- package/dist/src/pages/steps/StepDate/StepDateValidator.d.ts +5 -0
- package/dist/src/pages/steps/StepDate/StepDateValidator.js +10 -0
- package/dist/src/pages/steps/StepDate/StepDateValidator.js.map +1 -0
- package/dist/src/pages/steps/StepGuide.d.ts +7 -0
- package/dist/src/pages/steps/StepGuide.js +35 -0
- package/dist/src/pages/steps/StepGuide.js.map +1 -0
- package/dist/src/pages/steps/StepHotel/StepHotel.d.ts +14 -0
- package/dist/src/pages/steps/StepHotel/StepHotel.js +25 -0
- package/dist/src/pages/steps/StepHotel/StepHotel.js.map +1 -0
- package/dist/src/pages/steps/StepHotel/StepHotelComponent.d.ts +3 -0
- package/dist/src/pages/steps/StepHotel/StepHotelComponent.js +128 -0
- package/dist/src/pages/steps/StepHotel/StepHotelComponent.js.map +1 -0
- package/dist/src/pages/steps/StepHotel/StepHotelLoader.d.ts +2 -0
- package/dist/src/pages/steps/StepHotel/StepHotelLoader.js +56 -0
- package/dist/src/pages/steps/StepHotel/StepHotelLoader.js.map +1 -0
- package/dist/src/pages/steps/StepHotel/StepHotelValidator.d.ts +4 -0
- package/dist/src/pages/steps/StepHotel/StepHotelValidator.js +10 -0
- package/dist/src/pages/steps/StepHotel/StepHotelValidator.js.map +1 -0
- package/dist/src/pages/steps/StepRoom/StepRoom.d.ts +15 -0
- package/dist/src/pages/steps/StepRoom/StepRoom.js +27 -0
- package/dist/src/pages/steps/StepRoom/StepRoom.js.map +1 -0
- package/dist/src/pages/steps/StepRoom/StepRoomComponent.d.ts +2 -0
- package/dist/src/pages/steps/StepRoom/StepRoomComponent.js +81 -0
- package/dist/src/pages/steps/StepRoom/StepRoomComponent.js.map +1 -0
- package/dist/src/pages/steps/StepRoom/StepRoomLoader.d.ts +2 -0
- package/dist/src/pages/steps/StepRoom/StepRoomLoader.js +83 -0
- package/dist/src/pages/steps/StepRoom/StepRoomLoader.js.map +1 -0
- package/dist/src/pages/steps/StepRoom/StepRoomValidator.d.ts +5 -0
- package/dist/src/pages/steps/StepRoom/StepRoomValidator.js +13 -0
- package/dist/src/pages/steps/StepRoom/StepRoomValidator.js.map +1 -0
- package/dist/src/pages/steps/StepThanks/StepThanks.d.ts +16 -0
- package/dist/src/pages/steps/StepThanks/StepThanks.js +32 -0
- package/dist/src/pages/steps/StepThanks/StepThanks.js.map +1 -0
- package/dist/src/pages/steps/StepThanks/StepThanksComponent.d.ts +2 -0
- package/dist/src/pages/steps/StepThanks/StepThanksComponent.js +92 -0
- package/dist/src/pages/steps/StepThanks/StepThanksComponent.js.map +1 -0
- package/dist/src/pages/steps/StepThanks/StepThanksValidator.d.ts +5 -0
- package/dist/src/pages/steps/StepThanks/StepThanksValidator.js +13 -0
- package/dist/src/pages/steps/StepThanks/StepThanksValidator.js.map +1 -0
- package/dist/src/pages/steps/StepValidator.d.ts +4 -0
- package/dist/src/pages/steps/StepValidator.js +6 -0
- package/dist/src/pages/steps/StepValidator.js.map +1 -0
- package/dist/src/providers/CurrencyProvider.d.ts +22 -0
- package/dist/src/providers/CurrencyProvider.js +180 -0
- package/dist/src/providers/CurrencyProvider.js.map +1 -0
- package/dist/src/providers/DIProvider.d.ts +3 -0
- package/dist/src/providers/DIProvider.js +20 -0
- package/dist/src/providers/DIProvider.js.map +1 -0
- package/dist/src/providers/DistanceProvider.d.ts +13 -0
- package/dist/src/providers/DistanceProvider.js +32 -0
- package/dist/src/providers/DistanceProvider.js.map +1 -0
- package/dist/src/providers/FeatureProvider.d.ts +5 -0
- package/dist/src/providers/FeatureProvider.js +36 -0
- package/dist/src/providers/FeatureProvider.js.map +1 -0
- package/dist/src/providers/FilterProvider.d.ts +8 -0
- package/dist/src/providers/FilterProvider.js +40 -0
- package/dist/src/providers/FilterProvider.js.map +1 -0
- package/dist/src/providers/ImageProvider.d.ts +31 -0
- package/dist/src/providers/ImageProvider.js +65 -0
- package/dist/src/providers/ImageProvider.js.map +1 -0
- package/dist/src/providers/LanguageProvider.d.ts +26 -0
- package/dist/src/providers/LanguageProvider.js +105 -0
- package/dist/src/providers/LanguageProvider.js.map +1 -0
- package/dist/src/providers/RatePillProvider.d.ts +33 -0
- package/dist/src/providers/RatePillProvider.js +68 -0
- package/dist/src/providers/RatePillProvider.js.map +1 -0
- package/dist/src/providers/RoomSortProvider.d.ts +9 -0
- package/dist/src/providers/RoomSortProvider.js +28 -0
- package/dist/src/providers/RoomSortProvider.js.map +1 -0
- package/dist/src/providers/RoomstayThemeEngine.d.ts +46 -0
- package/dist/src/providers/RoomstayThemeEngine.js +184 -0
- package/dist/src/providers/RoomstayThemeEngine.js.map +1 -0
- package/dist/src/providers/SessionProvider.d.ts +55 -0
- package/dist/src/providers/SessionProvider.js +245 -0
- package/dist/src/providers/SessionProvider.js.map +1 -0
- package/dist/src/providers/StaticContextProvider.d.ts +5 -0
- package/dist/src/providers/StaticContextProvider.js +11 -0
- package/dist/src/providers/StaticContextProvider.js.map +1 -0
- package/dist/src/providers/feature/ConfirmationVerifyFeature.d.ts +10 -0
- package/dist/src/providers/feature/ConfirmationVerifyFeature.js +16 -0
- package/dist/src/providers/feature/ConfirmationVerifyFeature.js.map +1 -0
- package/dist/src/providers/feature/DatePickerTypeFeature.d.ts +7 -0
- package/dist/src/providers/feature/DatePickerTypeFeature.js +18 -0
- package/dist/src/providers/feature/DatePickerTypeFeature.js.map +1 -0
- package/dist/src/providers/feature/E164PhoneNumberFieldFeature.d.ts +7 -0
- package/dist/src/providers/feature/E164PhoneNumberFieldFeature.js +13 -0
- package/dist/src/providers/feature/E164PhoneNumberFieldFeature.js.map +1 -0
- package/dist/src/providers/feature/Feature.d.ts +11 -0
- package/dist/src/providers/feature/Feature.js +26 -0
- package/dist/src/providers/feature/Feature.js.map +1 -0
- package/dist/src/providers/feature/FeaturedPromoFeature.d.ts +7 -0
- package/dist/src/providers/feature/FeaturedPromoFeature.js +14 -0
- package/dist/src/providers/feature/FeaturedPromoFeature.js.map +1 -0
- package/dist/src/providers/feature/InlineAddonStepFeature.d.ts +9 -0
- package/dist/src/providers/feature/InlineAddonStepFeature.js +26 -0
- package/dist/src/providers/feature/InlineAddonStepFeature.js.map +1 -0
- package/dist/src/providers/feature/RoomUpsellFeature.d.ts +7 -0
- package/dist/src/providers/feature/RoomUpsellFeature.js +13 -0
- package/dist/src/providers/feature/RoomUpsellFeature.js.map +1 -0
- package/dist/src/providers/feature/ShowIATANumberOnCheckoutFeature.d.ts +7 -0
- package/dist/src/providers/feature/ShowIATANumberOnCheckoutFeature.js +13 -0
- package/dist/src/providers/feature/ShowIATANumberOnCheckoutFeature.js.map +1 -0
- package/dist/src/providers/storage/LocalStorageProvider.d.ts +16 -0
- package/dist/src/providers/storage/LocalStorageProvider.js +95 -0
- package/dist/src/providers/storage/LocalStorageProvider.js.map +1 -0
- package/dist/src/providers/storage/StorageProvider.d.ts +9 -0
- package/dist/src/providers/storage/StorageProvider.js +13 -0
- package/dist/src/providers/storage/StorageProvider.js.map +1 -0
- package/dist/src/reducers/BasketReducer.d.ts +8 -0
- package/dist/src/reducers/BasketReducer.js +76 -0
- package/dist/src/reducers/BasketReducer.js.map +1 -0
- package/dist/src/routes/NaturallyProgressedStepRoute.d.ts +7 -0
- package/dist/src/routes/NaturallyProgressedStepRoute.js +17 -0
- package/dist/src/routes/NaturallyProgressedStepRoute.js.map +1 -0
- package/dist/src/translations/Translation.d.ts +301 -0
- package/dist/src/translations/Translation.js +305 -0
- package/dist/src/translations/Translation.js.map +1 -0
- package/dist/src/translations/languages/en-gb.d.ts +3 -0
- package/dist/src/translations/languages/en-gb.js +305 -0
- package/dist/src/translations/languages/en-gb.js.map +1 -0
- package/dist/src/translations/languages/es.d.ts +2 -0
- package/dist/src/translations/languages/es.js +5 -0
- package/dist/src/translations/languages/es.js.map +1 -0
- package/dist/src/translations/languages/fr.d.ts +2 -0
- package/dist/src/translations/languages/fr.js +5 -0
- package/dist/src/translations/languages/fr.js.map +1 -0
- package/dist/src/translations/languages/template.d.ts +2 -0
- package/dist/src/translations/languages/template.js +5 -0
- package/dist/src/translations/languages/template.js.map +1 -0
- package/dist/src/translations/languages/zh-cn.d.ts +2 -0
- package/dist/src/translations/languages/zh-cn.js +5 -0
- package/dist/src/translations/languages/zh-cn.js.map +1 -0
- package/dist/src/translations/languages/zh-tw.d.ts +2 -0
- package/dist/src/translations/languages/zh-tw.js +5 -0
- package/dist/src/translations/languages/zh-tw.js.map +1 -0
- package/dist/src/util/CalendarHelper.d.ts +16 -0
- package/dist/src/util/CalendarHelper.js +81 -0
- package/dist/src/util/CalendarHelper.js.map +1 -0
- package/dist/src/util/Color.d.ts +16 -0
- package/dist/src/util/Color.js +21 -0
- package/dist/src/util/Color.js.map +1 -0
- package/dist/src/util/CurrencyHelper.d.ts +3 -0
- package/dist/src/util/CurrencyHelper.js +9 -0
- package/dist/src/util/CurrencyHelper.js.map +1 -0
- package/dist/src/util/DataLayer.d.ts +65 -0
- package/dist/src/util/DataLayer.js +322 -0
- package/dist/src/util/DataLayer.js.map +1 -0
- package/dist/src/util/ScreenSize.d.ts +9 -0
- package/dist/src/util/ScreenSize.js +13 -0
- package/dist/src/util/ScreenSize.js.map +1 -0
- package/dist/src/util/StepManager.d.ts +19 -0
- package/dist/src/util/StepManager.js +67 -0
- package/dist/src/util/StepManager.js.map +1 -0
- package/dist/src/util/StringHelper.d.ts +7 -0
- package/dist/src/util/StringHelper.js +30 -0
- package/dist/src/util/StringHelper.js.map +1 -0
- package/dist/src/util/TextAlignment.d.ts +4 -0
- package/dist/src/util/TextAlignment.js +9 -0
- package/dist/src/util/TextAlignment.js.map +1 -0
- package/dist/src/util/TimeHelper.d.ts +3 -0
- package/dist/src/util/TimeHelper.js +16 -0
- package/dist/src/util/TimeHelper.js.map +1 -0
- package/dist/src/util/TotalCalculator.d.ts +9 -0
- package/dist/src/util/TotalCalculator.js +57 -0
- package/dist/src/util/TotalCalculator.js.map +1 -0
- package/dist/tests/jest/engines/RoomstayThemeEngine.test.d.ts +1 -0
- package/dist/tests/jest/engines/RoomstayThemeEngine.test.js +36 -0
- package/dist/tests/jest/engines/RoomstayThemeEngine.test.js.map +1 -0
- package/dist/tests/jest/events/EventManager.test.d.ts +1 -0
- package/dist/tests/jest/events/EventManager.test.js +99 -0
- package/dist/tests/jest/events/EventManager.test.js.map +1 -0
- package/dist/tests/jest/models/RoomRate.test.d.ts +1 -0
- package/dist/tests/jest/models/RoomRate.test.js +130 -0
- package/dist/tests/jest/models/RoomRate.test.js.map +1 -0
- package/dist/tests/jest/providers/LanguageProvider.test.d.ts +1 -0
- package/dist/tests/jest/providers/LanguageProvider.test.js +20 -0
- package/dist/tests/jest/providers/LanguageProvider.test.js.map +1 -0
- package/dist/tests/jest/providers/SessionProvider.test.d.ts +1 -0
- package/dist/tests/jest/providers/SessionProvider.test.js +217 -0
- package/dist/tests/jest/providers/SessionProvider.test.js.map +1 -0
- package/dist/tests/jest/providers/storage/LocalStorageProvider.test.d.ts +1 -0
- package/dist/tests/jest/providers/storage/LocalStorageProvider.test.js +126 -0
- package/dist/tests/jest/providers/storage/LocalStorageProvider.test.js.map +1 -0
- package/dist/tests/jest/reducers/BasketReducer.test.d.ts +1 -0
- package/dist/tests/jest/reducers/BasketReducer.test.js +99 -0
- package/dist/tests/jest/reducers/BasketReducer.test.js.map +1 -0
- package/dist/tests/offline/RoomstayBestRateAlert.d.ts +2 -0
- package/dist/tests/offline/RoomstayBestRateAlert.js +22 -0
- package/dist/tests/offline/RoomstayBestRateAlert.js.map +1 -0
- package/dist/tests/offline/entry/RSCompany.d.ts +2 -0
- package/dist/tests/offline/entry/RSCompany.js +111 -0
- package/dist/tests/offline/entry/RSCompany.js.map +1 -0
- package/dist/tests/offline/entry/ReactWrapper.d.ts +2 -0
- package/dist/tests/offline/entry/ReactWrapper.js +59 -0
- package/dist/tests/offline/entry/ReactWrapper.js.map +1 -0
- package/dist/tests/offline/entry/allEngines.d.ts +1 -0
- package/dist/tests/offline/entry/allEngines.js +24 -0
- package/dist/tests/offline/entry/allEngines.js.map +1 -0
- package/dist/tests/offline/entry/components/TestPicker.d.ts +2 -0
- package/dist/tests/offline/entry/components/TestPicker.js +99 -0
- package/dist/tests/offline/entry/components/TestPicker.js.map +1 -0
- package/package.json +180 -0
package/dist/src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.js
ADDED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EnhancedPhoneNumberField = void 0;
|
|
4
|
+
const core_1 = require("@material-ui/core");
|
|
5
|
+
const classnames_1 = require("classnames");
|
|
6
|
+
const React = require("react");
|
|
7
|
+
const react_1 = require("react");
|
|
8
|
+
const react_i18next_1 = require("react-i18next");
|
|
9
|
+
const CountryCodesAndNumbers_1 = require("../../../../models/CountryCodesAndNumbers");
|
|
10
|
+
const RoomstayThemeEngine_1 = require("../../../../providers/RoomstayThemeEngine");
|
|
11
|
+
const Translation_1 = require("../../../../translations/Translation");
|
|
12
|
+
const Icon_1 = require("../../Icon");
|
|
13
|
+
require("./EnhancedPhoneNumberField.global.scss");
|
|
14
|
+
const PHONE_AND_PREFIX_SPLIT = ' ';
|
|
15
|
+
exports.EnhancedPhoneNumberField = (props) => {
|
|
16
|
+
const { t } = react_i18next_1.useTranslation();
|
|
17
|
+
const organizedCountries = react_1.useMemo(() => {
|
|
18
|
+
return CountryCodesAndNumbers_1.ListOfCountriesAndCodes.sort((a, b) => {
|
|
19
|
+
return `${(a.suggested ? '000' : '') + a.label}`.localeCompare(`${(b.suggested ? '000' : '') + b.label}`);
|
|
20
|
+
});
|
|
21
|
+
}, [CountryCodesAndNumbers_1.ListOfCountriesAndCodes]);
|
|
22
|
+
const [isSuggestionOpen, setIsSuggestionOpen] = react_1.useState(false);
|
|
23
|
+
const container = react_1.useRef(null);
|
|
24
|
+
const { validationStatus, name, onChange, value } = props;
|
|
25
|
+
const [selectedCountry, subscriberCode] = react_1.useMemo(() => {
|
|
26
|
+
var _a;
|
|
27
|
+
const [prefix, number] = (_a = value === null || value === void 0 ? void 0 : value.split(PHONE_AND_PREFIX_SPLIT)) !== null && _a !== void 0 ? _a : [];
|
|
28
|
+
let selectedCountry;
|
|
29
|
+
if (prefix) {
|
|
30
|
+
for (const country of organizedCountries) {
|
|
31
|
+
if (prefix === `${country.phone}`) {
|
|
32
|
+
selectedCountry = country;
|
|
33
|
+
break;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
if (!selectedCountry) {
|
|
37
|
+
selectedCountry = organizedCountries[0];
|
|
38
|
+
}
|
|
39
|
+
return [selectedCountry, number];
|
|
40
|
+
}
|
|
41
|
+
return [organizedCountries[0], ''];
|
|
42
|
+
}, [value]);
|
|
43
|
+
react_1.useEffect(() => {
|
|
44
|
+
// Close the modal if we click off it, weird hack to avoid modal closing before click is registered
|
|
45
|
+
const clickListener = (e) => {
|
|
46
|
+
setTimeout(() => {
|
|
47
|
+
if (isSuggestionOpen) {
|
|
48
|
+
setIsSuggestionOpen(false);
|
|
49
|
+
}
|
|
50
|
+
}, 5);
|
|
51
|
+
};
|
|
52
|
+
document.body.addEventListener('click', clickListener);
|
|
53
|
+
return () => {
|
|
54
|
+
document.body.removeEventListener('click', clickListener);
|
|
55
|
+
};
|
|
56
|
+
}, [isSuggestionOpen]);
|
|
57
|
+
const onSuggestionsTriggerClick = (e) => {
|
|
58
|
+
e.preventDefault();
|
|
59
|
+
e.stopPropagation();
|
|
60
|
+
setIsSuggestionOpen((old) => !old);
|
|
61
|
+
};
|
|
62
|
+
const raiseOnChangeEvent = (prefix, suffix) => {
|
|
63
|
+
var _a;
|
|
64
|
+
let newSuffix = suffix !== null && suffix !== void 0 ? suffix : subscriberCode;
|
|
65
|
+
if (newSuffix.startsWith('0')) {
|
|
66
|
+
newSuffix = newSuffix.substring(1);
|
|
67
|
+
}
|
|
68
|
+
const newValue = `${(_a = prefix === null || prefix === void 0 ? void 0 : prefix.phone) !== null && _a !== void 0 ? _a : selectedCountry.phone}${PHONE_AND_PREFIX_SPLIT}${newSuffix}`;
|
|
69
|
+
if (value != newValue) {
|
|
70
|
+
onChange({ target: { name, value: newValue } });
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
const onInputChanged = (e) => {
|
|
74
|
+
raiseOnChangeEvent(undefined, e.target.value);
|
|
75
|
+
};
|
|
76
|
+
const onPrefixChanged = (selectedCountry) => {
|
|
77
|
+
raiseOnChangeEvent(selectedCountry, undefined);
|
|
78
|
+
};
|
|
79
|
+
const fieldClasses = classnames_1.default('rs-enhanced-phone-field', {
|
|
80
|
+
[`--${validationStatus}`]: !!validationStatus,
|
|
81
|
+
});
|
|
82
|
+
return (React.createElement("div", { className: fieldClasses },
|
|
83
|
+
React.createElement("div", { className: "rs-enhanced-phone-field--country", onClick: onSuggestionsTriggerClick },
|
|
84
|
+
React.createElement("div", { className: "rs-enhanced-phone-field--country-icon" }, CountryCodesAndNumbers_1.convertCountryCodeToFlag(selectedCountry.code)),
|
|
85
|
+
React.createElement(Icon_1.default, { icon: Icon_1.IconType.Dropdown })),
|
|
86
|
+
React.createElement("div", { className: "rs-enhanced-phone-field--number" },
|
|
87
|
+
React.createElement("span", { className: "rs-enhanced-phone-field--number-prefix" },
|
|
88
|
+
"+",
|
|
89
|
+
selectedCountry.phone),
|
|
90
|
+
React.createElement("input", { placeholder: t(Translation_1.Translation.Step.Confirmation.Inputs.Phone) + ' *', type: "number", style: { paddingLeft: selectedCountry.phone.length * 8 + 20 + 'px' }, onChange: onInputChanged, value: subscriberCode }),
|
|
91
|
+
React.createElement("div", { className: "rs-enhanced-phone-field--number-status" })),
|
|
92
|
+
React.createElement("div", { className: "rs-enhanced-phone-field--anchor", ref: container }),
|
|
93
|
+
React.createElement(core_1.Popper, { container: RoomstayThemeEngine_1.default.EngineContainer, anchorEl: container === null || container === void 0 ? void 0 : container.current, placement: "bottom-start", disablePortal: false, open: isSuggestionOpen, className: "rs-enhanced-phone-field--suggest-list", role: "presentation", modifiers: {
|
|
94
|
+
flip: {
|
|
95
|
+
enabled: true,
|
|
96
|
+
},
|
|
97
|
+
preventOverflow: {
|
|
98
|
+
enabled: false,
|
|
99
|
+
boundariesElement: 'scrollParent',
|
|
100
|
+
},
|
|
101
|
+
} }, organizedCountries.map((country) => {
|
|
102
|
+
const onCountryClick = (e) => {
|
|
103
|
+
onPrefixChanged(country);
|
|
104
|
+
setIsSuggestionOpen(false);
|
|
105
|
+
return;
|
|
106
|
+
};
|
|
107
|
+
const isSelected = country.code === selectedCountry.code;
|
|
108
|
+
return (React.createElement("div", { className: `rs-enhanced-phone-field--suggest-list-item ${isSelected ? '--selected' : ''}`, onClick: onCountryClick },
|
|
109
|
+
React.createElement("div", { className: "rs-enhanced-phone-field--suggest-list-country-icon" }, CountryCodesAndNumbers_1.convertCountryCodeToFlag(country.code)),
|
|
110
|
+
React.createElement("div", { className: "rs-enhanced-phone-field--suggest-list-country-name" },
|
|
111
|
+
country.label,
|
|
112
|
+
" ",
|
|
113
|
+
React.createElement("span", null,
|
|
114
|
+
"+",
|
|
115
|
+
country.phone)),
|
|
116
|
+
isSelected && (React.createElement("span", { className: "rs-enhanced-phone-field--suggest-list-selected" },
|
|
117
|
+
React.createElement(Icon_1.default, { icon: Icon_1.IconType.Check })))));
|
|
118
|
+
}))));
|
|
119
|
+
};
|
|
120
|
+
//# sourceMappingURL=EnhancedPhoneNumberField.js.map
|
package/dist/src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EnhancedPhoneNumberField.js","sourceRoot":"/","sources":["src/components/generic/custom/EnhancedPhoneNumberField/EnhancedPhoneNumberField.tsx"],"names":[],"mappings":";;;AAAA,4CAA2C;AAC3C,2CAAoC;AACpC,+BAA+B;AAC/B,iCAAsF;AACtF,iDAA+C;AAC/C,sFAA2H;AAC3H,mFAA4E;AAC5E,sEAAmE;AACnE,qCAA4C;AAE5C,kDAAgD;AAYhD,MAAM,sBAAsB,GAAG,GAAG,CAAC;AAEtB,QAAA,wBAAwB,GAAG,CAAC,KAAwC,EAAE,EAAE;IACjF,MAAM,EAAE,CAAC,EAAE,GAAG,8BAAc,EAAE,CAAC;IAE/B,MAAM,kBAAkB,GAAkB,eAAO,CAAC,GAAG,EAAE;QACnD,OAAO,gDAAuB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACzC,OAAO,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QAC9G,CAAC,CAAC,CAAC;IACP,CAAC,EAAE,CAAC,gDAAuB,CAAC,CAAC,CAAC;IAE9B,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,gBAAQ,CAAC,KAAK,CAAC,CAAC;IAChE,MAAM,SAAS,GAAG,cAAM,CAAC,IAAI,CAAC,CAAC;IAE/B,MAAM,EAAE,gBAAgB,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC;IAE1D,MAAM,CAAC,eAAe,EAAE,cAAc,CAAC,GAAG,eAAO,CAAC,GAAG,EAAE;;QACnD,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,SAAG,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,KAAK,CAAC,sBAAsB,oCAAK,EAAE,CAAC;QACpE,IAAI,eAA4B,CAAC;QAEjC,IAAI,MAAM,EAAE;YACR,KAAK,MAAM,OAAO,IAAI,kBAAkB,EAAE;gBACtC,IAAI,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,EAAE,EAAE;oBAC/B,eAAe,GAAG,OAAO,CAAC;oBAC1B,MAAM;iBACT;aACJ;YAED,IAAI,CAAC,eAAe,EAAE;gBAClB,eAAe,GAAG,kBAAkB,CAAC,CAAC,CAAC,CAAC;aAC3C;YAED,OAAO,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC;SACpC;QAED,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACvC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEZ,iBAAS,CAAC,GAAG,EAAE;QACX,mGAAmG;QACnG,MAAM,aAAa,GAAG,CAAC,CAAM,EAAE,EAAE;YAC7B,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,gBAAgB,EAAE;oBAClB,mBAAmB,CAAC,KAAK,CAAC,CAAC;iBAC9B;YACL,CAAC,EAAE,CAAC,CAAC,CAAC;QACV,CAAC,CAAC;QAEF,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QAEvD,OAAO,GAAG,EAAE;YACR,QAAQ,CAAC,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QAC9D,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAEvB,MAAM,yBAAyB,GAAG,CAAC,CAAa,EAAE,EAAE;QAChD,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;QAEpB,mBAAmB,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IACvC,CAAC,CAAC;IAEF,MAAM,kBAAkB,GAAG,CAAC,MAAoB,EAAE,MAAe,EAAE,EAAE;;QACjE,IAAI,SAAS,GAAG,MAAM,aAAN,MAAM,cAAN,MAAM,GAAI,cAAc,CAAC;QAEzC,IAAI,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;YAC3B,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;SACtC;QAED,MAAM,QAAQ,GAAG,GAAG,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,mCAAI,eAAe,CAAC,KAAK,GAAG,sBAAsB,GAAG,SAAS,EAAE,CAAC;QAElG,IAAI,KAAK,IAAI,QAAQ,EAAE;YACnB,QAAQ,CAAC,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAS,CAAC,CAAC;SAC1D;IACL,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,CAAC,CAAgC,EAAE,EAAE;QACxD,kBAAkB,CAAC,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC,CAAC;IAEF,MAAM,eAAe,GAAG,CAAC,eAA4B,EAAE,EAAE;QACrD,kBAAkB,CAAC,eAAe,EAAE,SAAS,CAAC,CAAC;IACnD,CAAC,CAAC;IAEF,MAAM,YAAY,GAAG,oBAAU,CAAC,yBAAyB,EAAE;QACvD,CAAC,KAAK,gBAAgB,EAAE,CAAC,EAAE,CAAC,CAAC,gBAAgB;KAChD,CAAC,CAAC;IAEH,OAAO,CACH,6BAAK,SAAS,EAAE,YAAY;QACxB,6BAAK,SAAS,EAAC,kCAAkC,EAAC,OAAO,EAAE,yBAAyB;YAChF,6BAAK,SAAS,EAAC,uCAAuC,IAAE,iDAAwB,CAAC,eAAe,CAAC,IAAI,CAAC,CAAO;YAC7G,oBAAC,cAAI,IAAC,IAAI,EAAE,eAAQ,CAAC,QAAQ,GAAI,CAC/B;QACN,6BAAK,SAAS,EAAC,iCAAiC;YAC5C,8BAAM,SAAS,EAAC,wCAAwC;;gBAAG,eAAe,CAAC,KAAK,CAAQ;YACxF,+BACI,WAAW,EAAE,CAAC,CAAC,yBAAW,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,EACjE,IAAI,EAAC,QAAQ,EACb,KAAK,EAAE,EAAE,WAAW,EAAE,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,GAAG,EAAE,GAAG,IAAI,EAAE,EACpE,QAAQ,EAAE,cAAc,EACxB,KAAK,EAAE,cAAc,GACvB;YAEF,6BAAK,SAAS,EAAC,wCAAwC,GAAO,CAC5D;QACN,6BAAK,SAAS,EAAC,iCAAiC,EAAC,GAAG,EAAE,SAAS,GAAQ;QACvE,oBAAC,aAAM,IACH,SAAS,EAAE,6BAAmB,CAAC,eAAe,EAC9C,QAAQ,EAAE,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,EAC5B,SAAS,EAAC,cAAc,EACxB,aAAa,EAAE,KAAK,EACpB,IAAI,EAAE,gBAAgB,EACtB,SAAS,EAAC,uCAAuC,EACjD,IAAI,EAAC,cAAc,EACnB,SAAS,EAAE;gBACP,IAAI,EAAE;oBACF,OAAO,EAAE,IAAI;iBAChB;gBACD,eAAe,EAAE;oBACb,OAAO,EAAE,KAAK;oBACd,iBAAiB,EAAE,cAAc;iBACpC;aACJ,IAEA,kBAAkB,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YAChC,MAAM,cAAc,GAAG,CAAC,CAAa,EAAE,EAAE;gBACrC,eAAe,CAAC,OAAO,CAAC,CAAC;gBACzB,mBAAmB,CAAC,KAAK,CAAC,CAAC;gBAE3B,OAAO;YACX,CAAC,CAAC;YAEF,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,KAAK,eAAe,CAAC,IAAI,CAAC;YAEzD,OAAO,CACH,6BAAK,SAAS,EAAE,8CAA8C,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,OAAO,EAAE,cAAc;gBACnH,6BAAK,SAAS,EAAC,oDAAoD,IAAE,iDAAwB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAO;gBAClH,6BAAK,SAAS,EAAC,oDAAoD;oBAC9D,OAAO,CAAC,KAAK;;oBAAE;;wBAAQ,OAAO,CAAC,KAAK,CAAQ,CAC3C;gBACL,UAAU,IAAI,CACX,8BAAM,SAAS,EAAC,gDAAgD;oBAC5D,oBAAC,cAAI,IAAC,IAAI,EAAE,eAAQ,CAAC,KAAK,GAAI,CAC3B,CACV,CACC,CACT,CAAC;QACN,CAAC,CAAC,CACG,CACP,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import { Popper } from '@material-ui/core';\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { ChangeEvent, MouseEvent, useEffect, useMemo, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { convertCountryCodeToFlag, CountryType, ListOfCountriesAndCodes } from '../../../../models/CountryCodesAndNumbers';\nimport RoomstayThemeEngine from '../../../../providers/RoomstayThemeEngine';\nimport { Translation } from '../../../../translations/Translation';\nimport Icon, { IconType } from '../../Icon';\n\nimport './EnhancedPhoneNumberField.global.scss';\n\ninterface EnhancedPhoneNumberField {\n validationStatus: 'success' | 'error';\n\n name: string;\n\n value?: string;\n\n onChange: (e: ChangeEvent<HTMLInputElement>) => void;\n}\n\nconst PHONE_AND_PREFIX_SPLIT = ' ';\n\nexport const EnhancedPhoneNumberField = (props: Partial<EnhancedPhoneNumberField>) => {\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 [isSuggestionOpen, setIsSuggestionOpen] = useState(false);\n const container = useRef(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 useEffect(() => {\n // Close the modal if we click off it, weird hack to avoid modal closing before click is registered\n const clickListener = (e: any) => {\n setTimeout(() => {\n if (isSuggestionOpen) {\n setIsSuggestionOpen(false);\n }\n }, 5);\n };\n\n document.body.addEventListener('click', clickListener);\n\n return () => {\n document.body.removeEventListener('click', clickListener);\n };\n }, [isSuggestionOpen]);\n\n const onSuggestionsTriggerClick = (e: MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n\n setIsSuggestionOpen((old) => !old);\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 raiseOnChangeEvent(undefined, e.target.value);\n };\n\n const onPrefixChanged = (selectedCountry: CountryType) => {\n raiseOnChangeEvent(selectedCountry, undefined);\n };\n\n const fieldClasses = classNames('rs-enhanced-phone-field', {\n [`--${validationStatus}`]: !!validationStatus,\n });\n\n return (\n <div className={fieldClasses}>\n <div className=\"rs-enhanced-phone-field--country\" onClick={onSuggestionsTriggerClick}>\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 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={container}></div>\n <Popper\n container={RoomstayThemeEngine.EngineContainer}\n anchorEl={container?.current}\n placement=\"bottom-start\"\n disablePortal={false}\n open={isSuggestionOpen}\n className=\"rs-enhanced-phone-field--suggest-list\"\n role=\"presentation\"\n modifiers={{\n flip: {\n enabled: true,\n },\n preventOverflow: {\n enabled: false,\n boundariesElement: 'scrollParent',\n },\n }}\n >\n {organizedCountries.map((country) => {\n const onCountryClick = (e: MouseEvent) => {\n onPrefixChanged(country);\n setIsSuggestionOpen(false);\n\n return;\n };\n\n const isSelected = country.code === selectedCountry.code;\n\n return (\n <div className={`rs-enhanced-phone-field--suggest-list-item ${isSelected ? '--selected' : ''}`} onClick={onCountryClick}>\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 {isSelected && (\n <span className=\"rs-enhanced-phone-field--suggest-list-selected\">\n <Icon icon={IconType.Check} />\n </span>\n )}\n </div>\n );\n })}\n </Popper>\n </div>\n );\n};\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import * as dayjs from 'dayjs';
|
|
3
|
+
export interface DatePickerProps {
|
|
4
|
+
showMonthOnLoad?: dayjs.Dayjs;
|
|
5
|
+
selectedStartDate?: dayjs.Dayjs;
|
|
6
|
+
selectedEndDate?: dayjs.Dayjs;
|
|
7
|
+
canSelect?: boolean;
|
|
8
|
+
showArrows?: boolean;
|
|
9
|
+
showMultipleMonths?: boolean;
|
|
10
|
+
small?: boolean;
|
|
11
|
+
supportsMultiSelecting?: boolean;
|
|
12
|
+
showMinNightStay?: boolean;
|
|
13
|
+
supportsWeek?: boolean;
|
|
14
|
+
onDateClicked?: (date: dayjs.Dayjs) => void;
|
|
15
|
+
onStartDateChanged?: (date: dayjs.Dayjs) => void;
|
|
16
|
+
onEndDateChanged?: (date: dayjs.Dayjs) => void;
|
|
17
|
+
}
|
|
18
|
+
export default function DatePicker(props: DatePickerProps): JSX.Element;
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
const React = require("react");
|
|
13
|
+
const Color_1 = require("../../../util/Color");
|
|
14
|
+
const Icon_1 = require("../Icon");
|
|
15
|
+
const react_1 = require("react");
|
|
16
|
+
const classNames = require("classnames");
|
|
17
|
+
const dayjs = require("dayjs");
|
|
18
|
+
const DatePickerContext_1 = require("../../../contexts/DatePickerContext");
|
|
19
|
+
const DatePickerMonth_1 = require("./DatePickerMonth");
|
|
20
|
+
const BookingAPI_1 = require("../../../api/BookingAPI");
|
|
21
|
+
const contexts_1 = require("@frontend/contexts");
|
|
22
|
+
const DataLayer_1 = require("../../../util/DataLayer");
|
|
23
|
+
const MinimumNightStayPill_1 = require("../../steps/MinimumNightStayPill");
|
|
24
|
+
const DaysSelectedInformer_1 = require("../../steps/DaysSelectedInformer");
|
|
25
|
+
const hooks_1 = require("@frontend/hooks");
|
|
26
|
+
const DatePickerWeek = react_1.lazy(() => Promise.resolve().then(() => require('./DatePickerWeek')));
|
|
27
|
+
var DateRangePickingState;
|
|
28
|
+
(function (DateRangePickingState) {
|
|
29
|
+
DateRangePickingState[DateRangePickingState["StartDate"] = 1] = "StartDate";
|
|
30
|
+
DateRangePickingState[DateRangePickingState["EndDate"] = 2] = "EndDate";
|
|
31
|
+
})(DateRangePickingState || (DateRangePickingState = {}));
|
|
32
|
+
function DatePicker(props) {
|
|
33
|
+
var _a, _b;
|
|
34
|
+
const { hotel } = hooks_1.useCurrentHotel();
|
|
35
|
+
const [currentMonth, setCurrentMonth] = react_1.useState(props.showMonthOnLoad ? props.showMonthOnLoad : props.selectedStartDate ? props.selectedStartDate : dayjs());
|
|
36
|
+
const [selectedStartDate, setSelectedStartDate] = react_1.useState((_a = props.selectedStartDate) !== null && _a !== void 0 ? _a : null);
|
|
37
|
+
const [selectedEndDate, setSelectedEndDate] = react_1.useState((_b = props.selectedEndDate) !== null && _b !== void 0 ? _b : null);
|
|
38
|
+
const [hoveringOverDate, setHoveringOverDate] = react_1.useState(null);
|
|
39
|
+
const [pickingState, setPickingState] = react_1.useState(DateRangePickingState.StartDate);
|
|
40
|
+
const [calendarStyle, setCalendarStyle] = react_1.useState((hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType) ? hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType : 'Month');
|
|
41
|
+
react_1.useEffect(() => {
|
|
42
|
+
setCalendarStyle((hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType) ? hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType : 'Month');
|
|
43
|
+
}, [hotel === null || hotel === void 0 ? void 0 : hotel.defaultDatepickerType]);
|
|
44
|
+
const [months, setMonths] = react_1.useState(props.showMultipleMonths ? [currentMonth, currentMonth.add(1, 'month')] : [currentMonth]);
|
|
45
|
+
const [maxPrice, setMaxPrice] = react_1.useState(0);
|
|
46
|
+
const basketContext = react_1.useContext(contexts_1.BasketContext);
|
|
47
|
+
const onClickDate = (newDate) => __awaiter(this, void 0, void 0, function* () {
|
|
48
|
+
let newPickingState = null;
|
|
49
|
+
const selectedBasketRow = basketContext.selectedBasketRow;
|
|
50
|
+
const adults = selectedBasketRow ? selectedBasketRow.getAdults() : 0;
|
|
51
|
+
const children = selectedBasketRow ? selectedBasketRow.getChildren() : 0;
|
|
52
|
+
const promoCode = selectedBasketRow ? selectedBasketRow.getPromoCode() : '';
|
|
53
|
+
const newDatePrice = yield BookingAPI_1.default.Availability.getCheapestPriceForDay(newDate, adults, children, promoCode, hotel === null || hotel === void 0 ? void 0 : hotel.hotelID, false);
|
|
54
|
+
switch (pickingState) {
|
|
55
|
+
default:
|
|
56
|
+
case DateRangePickingState.StartDate:
|
|
57
|
+
if (newDatePrice.price || !hotel) {
|
|
58
|
+
newPickingState = DateRangePickingState.EndDate;
|
|
59
|
+
setSelectedStartDate(newDate);
|
|
60
|
+
setSelectedEndDate(null);
|
|
61
|
+
}
|
|
62
|
+
break;
|
|
63
|
+
case DateRangePickingState.EndDate:
|
|
64
|
+
if (newDate.isBefore(selectedStartDate)) {
|
|
65
|
+
setSelectedStartDate(newDate);
|
|
66
|
+
newPickingState = DateRangePickingState.EndDate;
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
newPickingState = DateRangePickingState.StartDate;
|
|
70
|
+
setHoveringOverDate(null);
|
|
71
|
+
const nextAvailableDay = yield getLastValidDay(selectedStartDate, newDate);
|
|
72
|
+
if (newDate.isSame(selectedStartDate)) {
|
|
73
|
+
setSelectedEndDate(nextAvailableDay.add(1, 'day'));
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
setSelectedEndDate(nextAvailableDay);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
break;
|
|
80
|
+
}
|
|
81
|
+
if (props.supportsMultiSelecting) {
|
|
82
|
+
setPickingState(newPickingState);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
const getLastValidDay = (fromDate, toDate) => new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {
|
|
86
|
+
const selectedBasketRow = basketContext.selectedBasketRow;
|
|
87
|
+
const adults = selectedBasketRow ? selectedBasketRow.getAdults() : 0;
|
|
88
|
+
const children = selectedBasketRow ? selectedBasketRow.getChildren() : 0;
|
|
89
|
+
const promoCode = selectedBasketRow ? selectedBasketRow.getPromoCode() : '';
|
|
90
|
+
const diff = toDate === null || toDate === void 0 ? void 0 : toDate.diff(fromDate, 'day');
|
|
91
|
+
let nextMustBreak = false;
|
|
92
|
+
for (let i = 0; i <= diff; i++) {
|
|
93
|
+
const dayToCheck = fromDate.add(i, 'day');
|
|
94
|
+
const price = yield BookingAPI_1.default.Availability.getCheapestPriceForDay(dayToCheck, adults, children, promoCode, hotel === null || hotel === void 0 ? void 0 : hotel.hotelID, false);
|
|
95
|
+
if (nextMustBreak) {
|
|
96
|
+
return resolve(dayToCheck.subtract(1, 'day'));
|
|
97
|
+
}
|
|
98
|
+
if (!price.price && hotel) {
|
|
99
|
+
nextMustBreak = true;
|
|
100
|
+
continue;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
resolve(toDate);
|
|
104
|
+
}));
|
|
105
|
+
const onHoveredOverDay = (day) => {
|
|
106
|
+
if (selectedStartDate && !selectedEndDate) {
|
|
107
|
+
getLastValidDay(selectedStartDate, day).then((lastValidDay) => {
|
|
108
|
+
setHoveringOverDate(lastValidDay);
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
const firstUpdate = react_1.useRef();
|
|
113
|
+
react_1.useEffect(() => {
|
|
114
|
+
if (props.showMonthOnLoad) {
|
|
115
|
+
setCurrentMonth(props.showMonthOnLoad);
|
|
116
|
+
}
|
|
117
|
+
}, [props.showMonthOnLoad]);
|
|
118
|
+
react_1.useEffect(() => {
|
|
119
|
+
if (props.showMultipleMonths) {
|
|
120
|
+
setMonths([currentMonth, currentMonth.add(1, 'month')]);
|
|
121
|
+
}
|
|
122
|
+
}, [currentMonth, props.showMultipleMonths]);
|
|
123
|
+
react_1.useEffect(() => {
|
|
124
|
+
if (firstUpdate.current) {
|
|
125
|
+
firstUpdate.current = undefined;
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
if (props.onStartDateChanged) {
|
|
129
|
+
props.onStartDateChanged(selectedStartDate);
|
|
130
|
+
}
|
|
131
|
+
}, [selectedStartDate]);
|
|
132
|
+
react_1.useLayoutEffect(() => {
|
|
133
|
+
if (firstUpdate.current) {
|
|
134
|
+
firstUpdate.current = undefined;
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
if (props.onEndDateChanged) {
|
|
138
|
+
props.onEndDateChanged(selectedEndDate);
|
|
139
|
+
}
|
|
140
|
+
}, [selectedEndDate]);
|
|
141
|
+
const context = {
|
|
142
|
+
today: dayjs(),
|
|
143
|
+
todayInUnix: dayjs().unix(),
|
|
144
|
+
startDate: selectedStartDate,
|
|
145
|
+
endDate: selectedEndDate,
|
|
146
|
+
hoveredMonth: hoveringOverDate,
|
|
147
|
+
maxPrice,
|
|
148
|
+
onHoverOver: onHoveredOverDay,
|
|
149
|
+
currentMonth,
|
|
150
|
+
onDayClicked: (date) => {
|
|
151
|
+
onClickDate(date);
|
|
152
|
+
},
|
|
153
|
+
setMaxPrice,
|
|
154
|
+
};
|
|
155
|
+
const printMonths = react_1.useMemo(() => (React.createElement(React.Fragment, null, calendarStyle === 'Month' ? (React.createElement(React.Fragment, null,
|
|
156
|
+
React.createElement(DatePickerMonth_1.default, { small: props.small, showingMonth: currentMonth }),
|
|
157
|
+
props.showMultipleMonths && React.createElement(DatePickerMonth_1.default, { showingMonth: currentMonth.add(1, 'month') }))) : (React.createElement(React.Fragment, null,
|
|
158
|
+
React.createElement(React.Suspense, { fallback: "Loading..." },
|
|
159
|
+
React.createElement(DatePickerWeek, null)))))), [currentMonth, props.showMultipleMonths, calendarStyle]);
|
|
160
|
+
const calendarClassNames = classNames('diji-calendar', {
|
|
161
|
+
'--single': !props.showMultipleMonths,
|
|
162
|
+
'--small': props.small,
|
|
163
|
+
'--week': calendarStyle === 'Week',
|
|
164
|
+
});
|
|
165
|
+
const previousMonthOnClick = () => {
|
|
166
|
+
DataLayer_1.default.instance.sendInteraction('Show Previous Month', DataLayer_1.InteractionType.CALENDAR, DataLayer_1.InteractionStep.DATES);
|
|
167
|
+
setCurrentMonth(currentMonth.subtract(1, 'month'));
|
|
168
|
+
};
|
|
169
|
+
const nextMonthOnClick = () => {
|
|
170
|
+
DataLayer_1.default.instance.sendInteraction('Show Next Month', DataLayer_1.InteractionType.CALENDAR, DataLayer_1.InteractionStep.DATES);
|
|
171
|
+
setCurrentMonth(currentMonth.add(1, 'month'));
|
|
172
|
+
};
|
|
173
|
+
const setCalendarStyleAsMonth = () => {
|
|
174
|
+
DataLayer_1.default.instance.sendInteraction('Set Calendar Style - Month', DataLayer_1.InteractionType.CALENDAR, DataLayer_1.InteractionStep.DATES);
|
|
175
|
+
setCalendarStyle('Month');
|
|
176
|
+
};
|
|
177
|
+
const setCalendarStyleAsWeek = () => {
|
|
178
|
+
DataLayer_1.default.instance.sendInteraction('Set Calendar Style - Week', DataLayer_1.InteractionType.CALENDAR, DataLayer_1.InteractionStep.DATES);
|
|
179
|
+
setCalendarStyle('Week');
|
|
180
|
+
};
|
|
181
|
+
return (React.createElement(DatePickerContext_1.DatePickerContext.Provider, { value: context },
|
|
182
|
+
React.createElement("div", { ref: firstUpdate, className: calendarClassNames },
|
|
183
|
+
calendarStyle === 'Month' && (React.createElement("div", { className: "diji-calendar-navigation" },
|
|
184
|
+
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" }),
|
|
185
|
+
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" }))),
|
|
186
|
+
props.supportsWeek && (React.createElement("div", { className: "diji-calendar-picker-type" },
|
|
187
|
+
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 }),
|
|
188
|
+
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 }))),
|
|
189
|
+
printMonths,
|
|
190
|
+
props.showMinNightStay && props.showMultipleMonths && (React.createElement("div", { className: "diji-calendar--min-night-stay u-flex u-flex-direction-column u-flex-align-center" },
|
|
191
|
+
React.createElement(DaysSelectedInformer_1.default, null),
|
|
192
|
+
React.createElement("div", { className: "u-marg-top--light" },
|
|
193
|
+
React.createElement(MinimumNightStayPill_1.default, null))))),
|
|
194
|
+
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" },
|
|
195
|
+
React.createElement(DaysSelectedInformer_1.default, null),
|
|
196
|
+
React.createElement("div", { className: "u-marg-top--light" },
|
|
197
|
+
React.createElement(MinimumNightStayPill_1.default, null))))));
|
|
198
|
+
}
|
|
199
|
+
exports.default = DatePicker;
|
|
200
|
+
//# sourceMappingURL=DatePicker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DatePicker.js","sourceRoot":"/","sources":["src/components/generic/date/DatePicker.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport { Color } from '../../../util/Color';\nimport Icon, { IconType } from '../Icon';\nimport { useEffect, useState, useRef, useLayoutEffect, useMemo, useContext, lazy } from 'react';\n\nimport * as classNames from 'classnames';\n\nimport * as dayjs from 'dayjs';\nimport { DatePickerContext } from '../../../contexts/DatePickerContext';\nimport DatePickerMonth from './DatePickerMonth';\nimport API from '../../../api/BookingAPI';\nimport { BasketContext } from '@frontend/contexts';\nimport DataLayer, { InteractionStep, InteractionType } from '../../../util/DataLayer';\nimport MinimumNightStayPill from '../../steps/MinimumNightStayPill';\nimport DaysSelectedInformer from '../../steps/DaysSelectedInformer';\nimport { useCurrentHotel } from '@frontend/hooks';\n\nconst DatePickerWeek = lazy(() => import('./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 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=\"Loading...\">\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"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import * as dayjs from 'dayjs';
|
|
3
|
+
interface DatePickerDayProps {
|
|
4
|
+
text: any;
|
|
5
|
+
day?: dayjs.Dayjs | any;
|
|
6
|
+
unix: number;
|
|
7
|
+
price?: Promise<number>;
|
|
8
|
+
statuses?: DatePickerDayStatus[];
|
|
9
|
+
selectable?: boolean;
|
|
10
|
+
onClick?: (day: string) => void;
|
|
11
|
+
onHover?: (day: string, status: boolean) => void;
|
|
12
|
+
displayType?: 'month' | 'week';
|
|
13
|
+
}
|
|
14
|
+
export declare enum DatePickerDayStatus {
|
|
15
|
+
Inactive = 0,
|
|
16
|
+
Selecting = "--selecting",
|
|
17
|
+
Loading = "--loading",
|
|
18
|
+
Selected = "--selected"
|
|
19
|
+
}
|
|
20
|
+
export default function DatePickerDay(props: DatePickerDayProps): JSX.Element;
|
|
21
|
+
export {};
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DatePickerDayStatus = void 0;
|
|
4
|
+
const React = require("react");
|
|
5
|
+
const Text_1 = require("../Text");
|
|
6
|
+
const react_1 = require("react");
|
|
7
|
+
const Currency_1 = require("../Currency");
|
|
8
|
+
const DatePickerContext_1 = require("../../../contexts/DatePickerContext");
|
|
9
|
+
const BookingAPI_1 = require("../../../api/BookingAPI");
|
|
10
|
+
const Icon_1 = require("../Icon");
|
|
11
|
+
const Color_1 = require("../../../util/Color");
|
|
12
|
+
const contexts_1 = require("@frontend/contexts");
|
|
13
|
+
const AvailabilityAPI_1 = require("../../../api/AvailabilityAPI");
|
|
14
|
+
const classnames_1 = require("classnames");
|
|
15
|
+
const hooks_1 = require("@frontend/hooks");
|
|
16
|
+
var DatePickerDayStatus;
|
|
17
|
+
(function (DatePickerDayStatus) {
|
|
18
|
+
DatePickerDayStatus[DatePickerDayStatus["Inactive"] = 0] = "Inactive";
|
|
19
|
+
DatePickerDayStatus["Selecting"] = "--selecting";
|
|
20
|
+
DatePickerDayStatus["Loading"] = "--loading";
|
|
21
|
+
DatePickerDayStatus["Selected"] = "--selected";
|
|
22
|
+
})(DatePickerDayStatus = exports.DatePickerDayStatus || (exports.DatePickerDayStatus = {}));
|
|
23
|
+
function DatePickerDay(props) {
|
|
24
|
+
const { hotel } = hooks_1.useCurrentHotel();
|
|
25
|
+
const datePickerContext = react_1.useContext(DatePickerContext_1.DatePickerContext);
|
|
26
|
+
const basketContext = react_1.useContext(contexts_1.BasketContext);
|
|
27
|
+
const [price, setPrice] = react_1.useState();
|
|
28
|
+
const [isLoading, setIsLoading] = react_1.useState(false);
|
|
29
|
+
const [isHovering, setIsHovering] = react_1.useState(false);
|
|
30
|
+
const [isSelected, setIsSelected] = react_1.useState(false);
|
|
31
|
+
const [isSelecting, setIsSelecting] = react_1.useState(false);
|
|
32
|
+
const [isFirst, setIsFirst] = react_1.useState(false);
|
|
33
|
+
const [isLast, setIsLast] = react_1.useState(false);
|
|
34
|
+
const isCurrent = props.day && datePickerContext.today.isSame(props.day, 'date');
|
|
35
|
+
const isPast = props.unix < datePickerContext.todayInUnix && !isCurrent;
|
|
36
|
+
const { selectedBasketRow } = basketContext;
|
|
37
|
+
react_1.useEffect(() => {
|
|
38
|
+
let cancelled = false;
|
|
39
|
+
const adults = selectedBasketRow ? selectedBasketRow.getAdults() : 1;
|
|
40
|
+
const children = selectedBasketRow ? selectedBasketRow.getChildren() : 0;
|
|
41
|
+
const promoCode = selectedBasketRow ? selectedBasketRow.getPromoCode() : '';
|
|
42
|
+
if (props.day && !isPast) {
|
|
43
|
+
if (hotel) {
|
|
44
|
+
setPrice(0);
|
|
45
|
+
setIsLoading(true);
|
|
46
|
+
BookingAPI_1.default.Availability.getCheapestPriceForDay(props.day, adults, children, promoCode, hotel.hotelID).then((foundedPrice) => {
|
|
47
|
+
if (!cancelled) {
|
|
48
|
+
if (foundedPrice) {
|
|
49
|
+
setPrice(foundedPrice.price);
|
|
50
|
+
if (datePickerContext.maxPrice < AvailabilityAPI_1.default.maxNightPrice) {
|
|
51
|
+
datePickerContext.setMaxPrice(AvailabilityAPI_1.default.maxNightPrice);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
setIsLoading(false);
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
datePickerContext.setMaxPrice(-1);
|
|
60
|
+
setPrice(-1);
|
|
61
|
+
setIsLoading(false);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
return () => {
|
|
65
|
+
cancelled = true;
|
|
66
|
+
};
|
|
67
|
+
}, [props.day, selectedBasketRow === null || selectedBasketRow === void 0 ? void 0 : selectedBasketRow.getAdults(), selectedBasketRow === null || selectedBasketRow === void 0 ? void 0 : selectedBasketRow.getChildren(), selectedBasketRow === null || selectedBasketRow === void 0 ? void 0 : selectedBasketRow.getPromoCode()]);
|
|
68
|
+
react_1.useEffect(() => {
|
|
69
|
+
if (datePickerContext.hoveredMonth) {
|
|
70
|
+
if (props.unix && datePickerContext.startDate.isBefore(props.day, 'date') && datePickerContext.hoveredMonth.isSameOrAfter(props.day, 'date')) {
|
|
71
|
+
setIsSelecting(true);
|
|
72
|
+
if (datePickerContext.hoveredMonth.isSame(props.day, 'date') || (datePickerContext.endDate && datePickerContext.endDate.isSame(props.day))) {
|
|
73
|
+
setIsLast(true);
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
setIsLast(false);
|
|
77
|
+
}
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
setIsSelecting(false);
|
|
82
|
+
setIsLast(false);
|
|
83
|
+
}, [datePickerContext.hoveredMonth, props.day]);
|
|
84
|
+
react_1.useEffect(() => {
|
|
85
|
+
var _a, _b, _c;
|
|
86
|
+
if (props.unix && datePickerContext.startDate) {
|
|
87
|
+
if (((_a = datePickerContext.startDate) === null || _a === void 0 ? void 0 : _a.isSameOrBefore(props.day, 'date')) && ((_b = datePickerContext.endDate) === null || _b === void 0 ? void 0 : _b.isSameOrAfter(props.day, 'date'))) {
|
|
88
|
+
setIsSelected(true);
|
|
89
|
+
if ((_c = datePickerContext.endDate) === null || _c === void 0 ? void 0 : _c.isSame(props.day, 'date')) {
|
|
90
|
+
setIsLast(true);
|
|
91
|
+
}
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
if (datePickerContext.startDate.isSame(props.day, 'date')) {
|
|
95
|
+
setIsFirst(true);
|
|
96
|
+
setIsSelected(true);
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
setIsSelected(false);
|
|
101
|
+
setIsFirst(false);
|
|
102
|
+
setIsLast(false);
|
|
103
|
+
}, [datePickerContext.startDate, datePickerContext.endDate, props.day]);
|
|
104
|
+
const memo = react_1.useMemo(() => {
|
|
105
|
+
var _a, _b;
|
|
106
|
+
const onHoverIn = (e) => {
|
|
107
|
+
datePickerContext.onHoverOver(props.day);
|
|
108
|
+
setIsHovering(true);
|
|
109
|
+
};
|
|
110
|
+
const onHoverOut = (e) => {
|
|
111
|
+
setIsHovering(false);
|
|
112
|
+
};
|
|
113
|
+
const onClick = (e) => {
|
|
114
|
+
datePickerContext.onDayClicked(props.day);
|
|
115
|
+
};
|
|
116
|
+
const isSelectable = () => {
|
|
117
|
+
return props.day && props.selectable && !isLoading && !isPast && (price || !hotel);
|
|
118
|
+
};
|
|
119
|
+
const classes = classnames_1.default(`diji-calendar-${(_a = props.displayType) !== null && _a !== void 0 ? _a : 'month'}--item`, {
|
|
120
|
+
'--selectable': isSelectable(),
|
|
121
|
+
'--hovered': isHovering && isSelectable(),
|
|
122
|
+
'--past': !isSelectable(),
|
|
123
|
+
'--current': isCurrent,
|
|
124
|
+
'--first': isFirst,
|
|
125
|
+
'--last': isLast,
|
|
126
|
+
'--loading': isLoading,
|
|
127
|
+
'--selected': isSelected,
|
|
128
|
+
'--selecting': isSelecting && !isSelected,
|
|
129
|
+
});
|
|
130
|
+
const events = {};
|
|
131
|
+
events.onMouseEnter = onHoverIn;
|
|
132
|
+
events.onMouseLeave = onHoverOut;
|
|
133
|
+
events.onClick = onClick;
|
|
134
|
+
const priceBlock = props.day && props.selectable && !isPast && (price || (isLoading && !price)) && price >= 0 && (React.createElement("div", { className: `diji-calendar-${(_b = props.displayType) !== null && _b !== void 0 ? _b : 'month'}--item-cost` }, isLoading ? (React.createElement("div", { className: "u-inline-flex a-spin" },
|
|
135
|
+
React.createElement(Icon_1.default, { color: Color_1.Color.Accent, icon: Icon_1.IconType.Spinner, size: "14px" }))) : (React.createElement(Text_1.default, { type: Text_1.TextType.Label },
|
|
136
|
+
React.createElement(Currency_1.default, { shortenThousandsAfter: 6, removeCurrencyAfterChar: 5, hideDecimals: true, disableLocalization: true }, price)))));
|
|
137
|
+
if (props.displayType === 'week') {
|
|
138
|
+
let height = 0;
|
|
139
|
+
const range = (price / AvailabilityAPI_1.default.maxNightPrice) * 100;
|
|
140
|
+
if (isSelectable()) {
|
|
141
|
+
if (range < 10) {
|
|
142
|
+
height = 10;
|
|
143
|
+
}
|
|
144
|
+
else if (range > 90) {
|
|
145
|
+
height = 90;
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
height = range;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
if (!isLoading) {
|
|
153
|
+
height = 95;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
return (React.createElement("div", Object.assign({ className: classes }, events),
|
|
157
|
+
props.text === '1' && React.createElement("div", { className: "diji-calendar-week--month-indicator" }, props.day.format('MMMM')),
|
|
158
|
+
React.createElement("div", { className: "diji-calendar-week--day-label" }, props.day.format('dd')),
|
|
159
|
+
React.createElement("div", { className: "diji-calendar-week--day-digit" },
|
|
160
|
+
React.createElement(Text_1.default, null, props.text)),
|
|
161
|
+
React.createElement("div", { className: "diji-calendar-week--price-indicator" },
|
|
162
|
+
React.createElement("div", { className: "diji-calendar-week--price-indicator-block", style: { maxHeight: `${height}%` } })),
|
|
163
|
+
priceBlock));
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
return (React.createElement("div", Object.assign({ className: classes }, events),
|
|
167
|
+
React.createElement(Text_1.default, null, props.text),
|
|
168
|
+
priceBlock));
|
|
169
|
+
}
|
|
170
|
+
}, [
|
|
171
|
+
isFirst,
|
|
172
|
+
isLast,
|
|
173
|
+
isSelecting,
|
|
174
|
+
isSelected,
|
|
175
|
+
isHovering,
|
|
176
|
+
isLoading,
|
|
177
|
+
props.unix,
|
|
178
|
+
datePickerContext.hoveredMonth,
|
|
179
|
+
datePickerContext.startDate,
|
|
180
|
+
datePickerContext.endDate,
|
|
181
|
+
basketContext,
|
|
182
|
+
datePickerContext.maxPrice,
|
|
183
|
+
hotel,
|
|
184
|
+
]);
|
|
185
|
+
return memo;
|
|
186
|
+
}
|
|
187
|
+
exports.default = DatePickerDay;
|
|
188
|
+
//# sourceMappingURL=DatePickerDay.js.map
|