@shopgate/engage 7.29.7-alpha.1 → 7.30.0-alpha.10
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/a11y/action-creators/index.js +13 -3
- package/a11y/components/FocusTrap/index.js +2 -1
- package/a11y/components/LiveMessage/index.js +24 -2
- package/a11y/components/LiveMessage/styles.js +12 -1
- package/a11y/components/LiveMessenger/constants.js +3 -1
- package/a11y/components/LiveMessenger/helpers.js +24 -3
- package/a11y/components/LiveMessenger/index.js +62 -4
- package/a11y/components/ModalStateTracker/index.js +20 -2
- package/a11y/components/Navigation/index.js +40 -2
- package/a11y/components/Navigation/style.js +12 -1
- package/a11y/components/Section/index.js +64 -4
- package/a11y/components/VisuallyHidden/index.js +26 -2
- package/a11y/components/index.js +7 -1
- package/a11y/constants/index.js +3 -1
- package/a11y/helpers/index.js +1 -1
- package/a11y/hooks/index.js +49 -6
- package/a11y/index.js +5 -1
- package/a11y/reducers/index.js +37 -2
- package/a11y/selectors/index.js +9 -3
- package/a11y/styles.js +16 -2
- package/account/actions/addContacts.js +31 -2
- package/account/actions/deleteContact.js +25 -2
- package/account/actions/deleteCustomer.js +24 -2
- package/account/actions/fetchContacts.js +26 -2
- package/account/actions/fetchCustomer.js +27 -2
- package/account/actions/updateContact.js +32 -2
- package/account/actions/updateCustomer.js +27 -2
- package/account/components/Account/Account.connector.js +9 -2
- package/account/components/Account/Account.js +64 -2
- package/account/components/Account/Account.style.js +31 -1
- package/account/components/Account/index.js +1 -1
- package/account/components/Profile/Profile.config.js +35 -2
- package/account/components/Profile/Profile.constraints.js +25 -1
- package/account/components/Profile/Profile.js +24 -1
- package/account/components/Profile/Profile.provider.js +226 -14
- package/account/components/Profile/ProfileAddressBook.js +92 -3
- package/account/components/Profile/ProfileAddressCard.js +159 -2
- package/account/components/Profile/ProfileForm.js +130 -2
- package/account/components/Profile/ProfileHeader.js +35 -2
- package/account/components/Profile/index.js +1 -1
- package/account/components/ProfileContact/ProfileContact.config.js +106 -2
- package/account/components/ProfileContact/ProfileContact.constraints.js +62 -2
- package/account/components/ProfileContact/ProfileContact.js +192 -5
- package/account/components/ProfileContact/index.js +1 -1
- package/account/components/index.js +1 -1
- package/account/constants/actions.js +24 -1
- package/account/constants/index.js +3 -1
- package/account/constants/pipelines.js +1 -1
- package/account/constants/routes.js +6 -1
- package/account/helper/form.js +215 -24
- package/account/index.js +2 -1
- package/account/reducers/index.js +65 -2
- package/account/selectors/contacts.js +6 -2
- package/account/selectors/customer.js +6 -2
- package/app-rating/action-creators/appStart.js +13 -3
- package/app-rating/action-creators/ordersPlaced.js +13 -3
- package/app-rating/action-creators/popup.js +20 -4
- package/app-rating/action-creators/timer.js +13 -3
- package/app-rating/actions/showModal.js +110 -9
- package/app-rating/constants/index.js +14 -2
- package/app-rating/helpers/index.js +23 -2
- package/app-rating/reducers/index.js +102 -2
- package/app-rating/selectors/appRating.js +2 -1
- package/app-rating/subscriptions/index.js +133 -23
- package/back-in-stock/actions/index.js +86 -4
- package/back-in-stock/components/BackInStockButton/connector.js +8 -1
- package/back-in-stock/components/BackInStockButton/index.js +100 -3
- package/back-in-stock/components/BackInStockButton/style.js +43 -1
- package/back-in-stock/components/CharacteristicsButton/connector.js +21 -2
- package/back-in-stock/components/CharacteristicsButton/index.js +29 -2
- package/back-in-stock/components/ProductInfoBackInStockButton/connector.js +17 -2
- package/back-in-stock/components/ProductInfoBackInStockButton/index.js +38 -2
- package/back-in-stock/components/Subscriptions/components/List/index.js +56 -2
- package/back-in-stock/components/Subscriptions/components/Subscription/index.js +163 -3
- package/back-in-stock/components/Subscriptions/index.js +8 -2
- package/back-in-stock/components/index.js +4 -1
- package/back-in-stock/constants/Actions.js +9 -1
- package/back-in-stock/constants/Common.js +1 -1
- package/back-in-stock/constants/Pipelines.js +3 -1
- package/back-in-stock/constants/Portals.js +18 -4
- package/back-in-stock/constants/index.js +4 -1
- package/back-in-stock/hooks/index.js +6 -2
- package/back-in-stock/providers/BackInStockSubscriptionsProvider.connector.js +21 -3
- package/back-in-stock/providers/BackInStockSubscriptionsProvider.context.js +3 -1
- package/back-in-stock/providers/BackInStockSubscriptionsProvider.js +49 -3
- package/back-in-stock/providers/index.js +2 -1
- package/back-in-stock/reducers/index.js +92 -2
- package/back-in-stock/selectors/index.js +97 -19
- package/back-in-stock/streams/index.js +13 -1
- package/back-in-stock/subscriptions/index.js +46 -3
- package/cart/cart.constants.js +6 -1
- package/cart/cart.context.js +25 -3
- package/cart/cart.helpers.js +125 -6
- package/cart/cart.hooks.js +11 -3
- package/cart/cart.selectors.js +113 -10
- package/cart/cart.types.js +18 -6
- package/cart/components/CartHeaderWide/CartHeaderWide.js +10 -2
- package/cart/components/CartHeaderWide/CartHeaderWide.style.js +10 -1
- package/cart/components/CartHeaderWide/index.js +1 -1
- package/cart/components/CartItem/CartItem.hooks.js +10 -3
- package/cart/components/CartItem/CartItem.js +53 -2
- package/cart/components/CartItem/CartItem.style.js +23 -1
- package/cart/components/CartItem/CartItemCoupon.connector.js +19 -4
- package/cart/components/CartItem/CartItemCoupon.js +144 -17
- package/cart/components/CartItem/CartItemCoupon.style.js +30 -2
- package/cart/components/CartItem/CartItemCoupon.types.js +9 -3
- package/cart/components/CartItem/CartItemCouponCode.js +15 -2
- package/cart/components/CartItem/CartItemCouponDelete.js +19 -2
- package/cart/components/CartItem/CartItemCouponDelete.style.js +7 -1
- package/cart/components/CartItem/CartItemCouponFreeShipping.js +17 -2
- package/cart/components/CartItem/CartItemCouponIcon.js +23 -2
- package/cart/components/CartItem/CartItemCouponLayout.js +65 -2
- package/cart/components/CartItem/CartItemCouponLayout.style.js +29 -5
- package/cart/components/CartItem/CartItemCouponPrice.js +29 -3
- package/cart/components/CartItem/CartItemCouponPrice.style.js +10 -1
- package/cart/components/CartItem/CartItemCouponTitle.js +18 -2
- package/cart/components/CartItem/CartItemCouponTitle.style.js +7 -1
- package/cart/components/CartItem/CartItemProduct.js +52 -2
- package/cart/components/CartItem/CartItemProduct.style.js +5 -1
- package/cart/components/CartItem/CartItemProductLayout.js +149 -4
- package/cart/components/CartItem/CartItemProductLayout.style.js +94 -1
- package/cart/components/CartItem/CartItemProductLayoutWide.js +126 -2
- package/cart/components/CartItem/CartItemProductLayoutWide.style.js +113 -1
- package/cart/components/CartItem/CartItemProductLayoutWideFulfillmentLabel.js +24 -2
- package/cart/components/CartItem/CartItemProductLayoutWideFulfillmentLabel.style.js +10 -1
- package/cart/components/CartItem/CartItemProductLayoutWideOrderDetails.js +32 -2
- package/cart/components/CartItem/CartItemProductLayoutWideRemoveItem.js +22 -2
- package/cart/components/CartItem/CartItemProductLayoutWideRemoveItem.style.js +16 -1
- package/cart/components/CartItem/CartItemProductOrderDetails.js +68 -2
- package/cart/components/CartItem/CartItemProductOrderDetails.style.js +28 -1
- package/cart/components/CartItem/CartItemProductPriceCaption.js +39 -3
- package/cart/components/CartItem/CartItemProductPriceCaption.style.js +11 -1
- package/cart/components/CartItem/CartItemProductPriceList.js +88 -3
- package/cart/components/CartItem/CartItemProductPriceListPromotion.js +170 -4
- package/cart/components/CartItem/CartItemProductProvider.connector.js +35 -6
- package/cart/components/CartItem/CartItemProductProvider.context.js +3 -1
- package/cart/components/CartItem/CartItemProductProvider.js +130 -6
- package/cart/components/CartItem/CartItemProductProvider.types.js +14 -5
- package/cart/components/CartItem/CartItemProductProviderLegacy.js +67 -7
- package/cart/components/CartItem/CartItemProductTitle.js +92 -2
- package/cart/components/CartItem/CartItemProductTitle.style.js +28 -1
- package/cart/components/CartItem/CartItemProvider.connector.js +24 -2
- package/cart/components/CartItem/CartItemProvider.context.js +3 -1
- package/cart/components/CartItem/CartItemProvider.js +55 -2
- package/cart/components/CartItem/CartItemQuantityPicker.js +139 -20
- package/cart/components/CartItem/CartItemQuantityPicker.style.js +18 -1
- package/cart/components/CartItem/CartItemSubstitution.connector.js +12 -2
- package/cart/components/CartItem/CartItemSubstitution.js +38 -2
- package/cart/components/CartItem/CartItemSubstitution.style.js +9 -1
- package/cart/components/CartItem/index.js +3 -1
- package/cart/components/CartItems/CartItem.connector.js +12 -2
- package/cart/components/CartItems/CartItemCard.js +30 -2
- package/cart/components/CartItems/CartItemCard.style.js +52 -1
- package/cart/components/CartItems/CartItemCardReservation.js +62 -3
- package/cart/components/CartItems/CartItemCardReservationAccordion.js +44 -3
- package/cart/components/CartItems/CartItemCardReservationLabel.js +47 -2
- package/cart/components/CartItems/CartItemCardReservationLabelChangeStore.js +34 -2
- package/cart/components/CartItems/CartItemCardReservationLabelChangeStore.style.js +12 -1
- package/cart/components/CartItems/CartItemGroup.js +26 -2
- package/cart/components/CartItems/CartItemGroup.style.js +39 -1
- package/cart/components/CartItems/CartItemGroupReservation.js +56 -3
- package/cart/components/CartItems/CartItemGroupReservationLabel.js +27 -2
- package/cart/components/CartItems/CartItemGroupShipping.js +15 -2
- package/cart/components/CartItems/CartItems.js +84 -3
- package/cart/components/CartItems/CartItems.style.js +21 -1
- package/cart/components/CartItems/CartItemsHeaderWide.connector.js +20 -2
- package/cart/components/CartItems/CartItemsHeaderWide.js +59 -2
- package/cart/components/CartItems/CartItemsHeaderWide.style.js +60 -1
- package/cart/components/CartItems/CartItemsSubscription.connector.js +9 -2
- package/cart/components/CartItems/CartItemsSubstitution.js +43 -2
- package/cart/components/CartItems/index.js +2 -1
- package/cart/components/CartSummaryWide/CartSummaryWide.connector.js +13 -2
- package/cart/components/CartSummaryWide/CartSummaryWide.js +46 -2
- package/cart/components/CartSummaryWide/CartSummaryWide.style.js +37 -1
- package/cart/components/CartSummaryWide/CartSummaryWideCheckoutButton.connector.js +9 -2
- package/cart/components/CartSummaryWide/CartSummaryWideCheckoutButton.js +45 -2
- package/cart/components/CartSummaryWide/CartSummaryWideCheckoutButton.style.js +21 -1
- package/cart/components/CartSummaryWide/CartSummaryWideFooter.js +18 -2
- package/cart/components/CartSummaryWide/index.js +1 -1
- package/cart/components/PaymentBar/PaymentBar.js +24 -2
- package/cart/components/PaymentBar/PaymentBarAppliedPromotions.connector.js +9 -2
- package/cart/components/PaymentBar/PaymentBarAppliedPromotions.js +56 -2
- package/cart/components/PaymentBar/PaymentBarCheckoutButton.connector.js +9 -2
- package/cart/components/PaymentBar/PaymentBarCheckoutButton.js +42 -2
- package/cart/components/PaymentBar/PaymentBarCheckoutButton.style.js +15 -1
- package/cart/components/PaymentBar/PaymentBarContent.js +53 -2
- package/cart/components/PaymentBar/PaymentBarContent.style.js +40 -1
- package/cart/components/PaymentBar/PaymentBarDiscounts.connector.js +9 -2
- package/cart/components/PaymentBar/PaymentBarDiscounts.js +53 -2
- package/cart/components/PaymentBar/PaymentBarGrandTotal.connector.js +9 -2
- package/cart/components/PaymentBar/PaymentBarGrandTotal.js +50 -2
- package/cart/components/PaymentBar/PaymentBarPromotionCouponMessages.js +69 -2
- package/cart/components/PaymentBar/PaymentBarPromotionCoupons.connector.js +15 -3
- package/cart/components/PaymentBar/PaymentBarPromotionCoupons.js +107 -2
- package/cart/components/PaymentBar/PaymentBarPromotionalText.js +111 -2
- package/cart/components/PaymentBar/PaymentBarReserveButton.connector.js +6 -1
- package/cart/components/PaymentBar/PaymentBarReserveButton.js +48 -3
- package/cart/components/PaymentBar/PaymentBarShippingCost.connector.js +9 -2
- package/cart/components/PaymentBar/PaymentBarShippingCost.js +48 -2
- package/cart/components/PaymentBar/PaymentBarSubTotal.connector.js +9 -2
- package/cart/components/PaymentBar/PaymentBarSubTotal.js +44 -2
- package/cart/components/PaymentBar/PaymentBarTax.connector.js +9 -2
- package/cart/components/PaymentBar/PaymentBarTax.js +53 -2
- package/cart/components/PaymentBar/index.js +1 -1
- package/cart/components/Substitution/connector.js +9 -2
- package/cart/components/Substitution/index.js +50 -3
- package/cart/components/Substitution/style.js +32 -1
- package/cart/components/SupplementalContent/SupplementalContent.connector.js +12 -2
- package/cart/components/SupplementalContent/SupplementalContent.js +30 -2
- package/cart/components/SupplementalContent/SupplementalContent.styles.js +29 -1
- package/cart/components/SupplementalContent/index.js +1 -1
- package/cart/index.js +54 -11
- package/cart/streams/index.js +1 -1
- package/category/actions/index.js +5 -1
- package/category/components/CategoryImage/connector.js +9 -2
- package/category/components/CategoryImage/index.js +38 -2
- package/category/components/CategoryList/index.js +97 -2
- package/category/components/CategoryList/style.js +20 -1
- package/category/components/index.js +2 -1
- package/category/constants/index.js +3 -1
- package/category/helpers/index.js +1 -1
- package/category/index.js +10 -1
- package/category/selectors/index.js +1 -1
- package/category/streams/index.js +5 -1
- package/checkout/action-creators/addCheckoutCampaign.js +8 -2
- package/checkout/action-creators/clearCheckoutCampaign.js +7 -2
- package/checkout/action-creators/clearCheckoutOrder.js +7 -2
- package/checkout/action-creators/index.js +3 -1
- package/checkout/action-creators/validationErrorsCheckout.js +8 -2
- package/checkout/actions/errorCheckout.js +69 -7
- package/checkout/actions/fetchCheckoutOrder.js +28 -2
- package/checkout/actions/fetchPaymentMethods.js +25 -2
- package/checkout/actions/index.js +7 -1
- package/checkout/actions/initializeCheckout.js +26 -2
- package/checkout/actions/prepareCheckout.js +84 -6
- package/checkout/actions/submitCheckoutOrder.js +34 -2
- package/checkout/actions/updateCheckoutOrder.js +33 -2
- package/checkout/components/AddressBook/AddressBook.js +9 -2
- package/checkout/components/AddressBook/AddressList.js +142 -4
- package/checkout/components/AddressBook/index.js +1 -1
- package/checkout/components/AddressBookContact/AddressBookContact.js +41 -2
- package/checkout/components/AddressBookContact/index.js +1 -1
- package/checkout/components/Checkout/Checkout.js +70 -2
- package/checkout/components/Checkout/CheckoutActions.js +42 -2
- package/checkout/components/Checkout/CheckoutAddress.js +109 -3
- package/checkout/components/Checkout/CheckoutHeader.js +55 -2
- package/checkout/components/Checkout/CheckoutPickupContactForm.config.js +62 -2
- package/checkout/components/Checkout/CheckoutPickupContactForm.js +90 -2
- package/checkout/components/Checkout/CheckoutSection.js +147 -2
- package/checkout/components/Checkout/CheckoutSectionInfo.js +73 -2
- package/checkout/components/Checkout/CheckoutSectionMessages.js +54 -2
- package/checkout/components/Checkout/CheckoutSummary.js +67 -2
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmation.connector.js +13 -2
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmation.js +241 -5
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmationBilledTo.js +58 -2
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmationOrderContact.js +53 -2
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmationOrderSummary.js +58 -2
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmationPickUpContact.js +59 -2
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmationPickupNotes.js +23 -2
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmationSection.js +164 -2
- package/checkout/components/CheckoutConfirmation/CheckoutConfirmationShippedTo.js +48 -2
- package/checkout/components/CheckoutConfirmation/index.js +6 -1
- package/checkout/components/GuestCheckout/GuestCheckout.js +68 -2
- package/checkout/components/GuestCheckout/GuestCheckoutOptIn.config.js +13 -2
- package/checkout/components/GuestCheckout/GuestCheckoutOptIn.js +64 -2
- package/checkout/components/GuestCheckout/GuestCheckoutPickup.js +45 -2
- package/checkout/components/GuestCheckout/GuestCheckoutPickupNotes.config.js +13 -2
- package/checkout/components/GuestCheckout/GuestCheckoutPickupNotes.js +54 -2
- package/checkout/components/PaymentMethodButton/PaymentMethodButton.js +59 -2
- package/checkout/components/PaymentMethodButton/index.js +1 -1
- package/checkout/components/ResponsiveBackButton/ResponsiveBackButton.js +40 -2
- package/checkout/components/ResponsiveBackButton/ResponsiveBackButton.style.js +25 -1
- package/checkout/components/ResponsiveBackButton/index.js +1 -1
- package/checkout/components/ShippingMethods/ShippingMethod.js +66 -2
- package/checkout/components/ShippingMethods/ShippingMethods.js +200 -12
- package/checkout/components/ShippingMethods/connector.js +12 -3
- package/checkout/components/ShippingMethods/index.js +1 -1
- package/checkout/components/SupplementalContent/SupplementalContent.connector.js +12 -2
- package/checkout/components/SupplementalContent/SupplementalContent.js +30 -2
- package/checkout/components/SupplementalContent/SupplementalContent.styles.js +29 -1
- package/checkout/components/SupplementalContent/index.js +1 -1
- package/checkout/components/index.js +7 -1
- package/checkout/constants/actionTypes.js +19 -1
- package/checkout/constants/errorCodes.js +1 -1
- package/checkout/constants/index.js +11 -1
- package/checkout/constants/routes.js +8 -1
- package/checkout/helpers/index.js +221 -10
- package/checkout/hooks/common.js +11 -3
- package/checkout/index.js +25 -6
- package/checkout/paymentMethods/context.js +2 -1
- package/checkout/paymentMethods/index.js +183 -19
- package/checkout/paymentMethods/paypal/PaypalButton.js +14 -2
- package/checkout/paymentMethods/paypal/PaypalButtonApp.js +48 -2
- package/checkout/paymentMethods/paypal/PaypalButtonWeb.js +88 -5
- package/checkout/paymentMethods/paypal/PaypalPayButton.js +120 -10
- package/checkout/paymentMethods/paypal/PaypalProvider.js +41 -4
- package/checkout/paymentMethods/paypal/index.js +13 -1
- package/checkout/paymentMethods/paypal/sdk.js +50 -3
- package/checkout/paymentMethods/stripe/StripeButton.connector.js +13 -3
- package/checkout/paymentMethods/stripe/StripeButton.js +88 -2
- package/checkout/paymentMethods/stripe/StripeCreditCard.js +173 -5
- package/checkout/paymentMethods/stripe/StripePayButton.js +56 -4
- package/checkout/paymentMethods/stripe/StripeProvider.connector.js +13 -3
- package/checkout/paymentMethods/stripe/StripeProvider.context.js +3 -1
- package/checkout/paymentMethods/stripe/StripeProvider.js +174 -16
- package/checkout/paymentMethods/stripe/index.js +11 -1
- package/checkout/paymentMethods/stripe/sdk.js +40 -4
- package/checkout/providers/AddressBookProvider.context.js +3 -1
- package/checkout/providers/AddressBookProvider.js +166 -4
- package/checkout/providers/CheckoutProvider.connector.js +48 -3
- package/checkout/providers/CheckoutProvider.constraints.js +34 -1
- package/checkout/providers/CheckoutProvider.context.js +3 -1
- package/checkout/providers/CheckoutProvider.js +430 -23
- package/checkout/reducers/index.js +89 -2
- package/checkout/selectors/campaign.js +20 -2
- package/checkout/selectors/guestCheckout.js +11 -3
- package/checkout/selectors/order.js +146 -17
- package/checkout/selectors/payment.js +23 -5
- package/checkout/selectors/route.js +13 -2
- package/checkout/streams/index.js +13 -1
- package/checkout/subscriptions/index.js +53 -2
- package/components/BrandingColorBanner/BrandingColorBanner.js +20 -2
- package/components/BrandingColorBanner/index.js +1 -1
- package/components/ChipLayout/index.js +150 -18
- package/components/ChipLayout/spec.js +30 -2
- package/components/ChipLayout/style.js +48 -2
- package/components/ConditionalWrapper/ConditionalWrapper.js +29 -3
- package/components/ConditionalWrapper/index.js +1 -1
- package/components/ConnectedReactPortal/index.js +20 -3
- package/components/Footer/Footer.js +63 -2
- package/components/Footer/Footer.style.js +11 -1
- package/components/Footer/constants.js +2 -1
- package/components/Footer/helpers.js +168 -36
- package/components/Footer/index.js +1 -1
- package/components/Form/Builder/Builder.constants.js +13 -1
- package/components/Form/Builder/Builder.js +298 -59
- package/components/Form/Builder/ElementCheckbox.js +46 -2
- package/components/Form/Builder/ElementMultiSelect.js +70 -2
- package/components/Form/Builder/ElementPhoneNumber.js +232 -12
- package/components/Form/Builder/ElementRadio.js +53 -2
- package/components/Form/Builder/ElementSelect.js +60 -2
- package/components/Form/Builder/ElementText.js +67 -3
- package/components/Form/Builder/FormHelper.js +33 -2
- package/components/Form/Builder/classes/ActionListener.constants.js +22 -2
- package/components/Form/Builder/classes/ActionListener.js +441 -93
- package/components/Form/Builder/helpers/buildCountryList.js +30 -6
- package/components/Form/Builder/helpers/buildFormDefaults.js +35 -6
- package/components/Form/Builder/helpers/buildFormElements.js +68 -10
- package/components/Form/Builder/helpers/buildProvinceList.js +19 -2
- package/components/Form/Builder/helpers/buildValidationErrorList.js +7 -2
- package/components/Form/Builder/helpers/common.js +3 -1
- package/components/Form/Builder/helpers/iso-3166-2.js +4943 -1
- package/components/Form/Builder/index.js +1 -1
- package/components/Form/Builder/stylePresets.js +153 -1
- package/components/Form/Form.js +56 -13
- package/components/Form/index.js +4 -1
- package/components/IntersectionVisibility/index.js +80 -14
- package/components/Logo/connector.js +13 -2
- package/components/Logo/index.js +35 -2
- package/components/Logo/spec.js +11 -1
- package/components/Logo/style.js +22 -1
- package/components/Menu/components/Item/index.js +39 -3
- package/components/Menu/components/Item/style.js +25 -2
- package/components/Menu/components/Position/index.js +61 -10
- package/components/Menu/components/Position/style.js +11 -1
- package/components/Menu/index.js +85 -7
- package/components/Menu/style.js +39 -1
- package/components/MessageBar/MessageBar.js +72 -2
- package/components/MessageBar/MessageBar.style.js +121 -5
- package/components/MessageBar/index.js +1 -1
- package/components/NavigationHandler/connector.js +17 -2
- package/components/NavigationHandler/index.js +43 -6
- package/components/NavigationHandler/spec.js +78 -1
- package/components/NullComponent/index.js +4 -1
- package/components/Picker/components/Button/index.js +23 -2
- package/components/Picker/components/Button/style.js +19 -1
- package/components/Picker/components/List/index.js +52 -2
- package/components/Picker/components/List/style.js +17 -1
- package/components/Picker/components/Modal/index.js +63 -7
- package/components/Picker/components/Modal/style.js +78 -1
- package/components/Picker/index.js +167 -21
- package/components/Picker/spec.js +82 -2
- package/components/PickerUtilize/components/Button/index.js +25 -2
- package/components/PickerUtilize/components/Button/style.js +42 -1
- package/components/PickerUtilize/index.js +90 -11
- package/components/PickerUtilize/spec.js +32 -2
- package/components/PickerUtilize/style.js +10 -1
- package/components/QuantityInput/QuantityInput.js +121 -7
- package/components/QuantityInput/helper.js +25 -4
- package/components/QuantityInput/index.js +1 -1
- package/components/QuantityLabel/QuantityLabel.js +26 -2
- package/components/QuantityLabel/index.js +1 -1
- package/components/Radio/Radio.js +115 -2
- package/components/Radio/index.js +1 -1
- package/components/RadioCard/RadioCard.js +104 -3
- package/components/RadioCard/index.js +1 -1
- package/components/RadioGroup/RadioGroup.context.js +3 -1
- package/components/RadioGroup/RadioGroup.js +56 -2
- package/components/RadioGroup/index.js +2 -1
- package/components/RadioGroup/useRadioGroup.js +8 -2
- package/components/RangeSlider/components/Handle/index.js +37 -2
- package/components/RangeSlider/components/Handle/style.js +15 -1
- package/components/RangeSlider/helper.js +48 -8
- package/components/RangeSlider/index.js +265 -39
- package/components/RangeSlider/spec.js +172 -23
- package/components/RangeSlider/style.js +18 -1
- package/components/ResponsiveContainer/ResponsiveContainer.js +42 -3
- package/components/ResponsiveContainer/breakpoints.js +62 -8
- package/components/ResponsiveContainer/condition.js +15 -2
- package/components/ResponsiveContainer/hooks.js +54 -5
- package/components/ResponsiveContainer/index.js +1 -1
- package/components/ResponsiveContainer/listener.js +29 -4
- package/components/ResponsiveContainer/mediaQuery.js +24 -4
- package/components/ScrollHeader/index.js +74 -2
- package/components/ScrollHeader/style.js +25 -1
- package/components/SheetDrawer/index.js +18 -3
- package/components/SheetList/components/Item/index.js +135 -7
- package/components/SheetList/components/Item/spec.js +106 -4
- package/components/SheetList/components/Item/style.js +76 -1
- package/components/SheetList/index.js +63 -5
- package/components/SheetList/spec.js +38 -1
- package/components/SheetList/style.js +36 -1
- package/components/SideNavigation/SideNavigation.hooks.js +6 -2
- package/components/SideNavigation/SideNavigation.js +23 -2
- package/components/SideNavigation/SideNavigationCategories.connector.js +25 -3
- package/components/SideNavigation/SideNavigationCategories.js +44 -2
- package/components/SideNavigation/SideNavigationCategories.style.js +12 -1
- package/components/SideNavigation/SideNavigationCategoriesItem.connector.js +31 -3
- package/components/SideNavigation/SideNavigationCategoriesItem.js +79 -3
- package/components/SideNavigation/SideNavigationCategoriesItem.style.js +41 -2
- package/components/SideNavigation/SideNavigationCategoriesItemChildren.js +16 -3
- package/components/SideNavigation/SideNavigationContent.js +40 -2
- package/components/SideNavigation/SideNavigationContent.style.js +6 -2
- package/components/SideNavigation/SideNavigationItem.js +56 -2
- package/components/SideNavigation/SideNavigationItem.style.js +39 -2
- package/components/SideNavigation/SideNavigationLinks.js +52 -2
- package/components/SideNavigation/SideNavigationLinksLegal.connector.js +15 -2
- package/components/SideNavigation/SideNavigationLinksLegal.js +27 -2
- package/components/SideNavigation/SideNavigationLinksQuicklinks.connector.js +15 -2
- package/components/SideNavigation/SideNavigationLinksQuicklinks.js +26 -2
- package/components/SideNavigation/SideNavigationNestedItem.js +45 -2
- package/components/SideNavigation/SideNavigationProvider.connector.js +20 -3
- package/components/SideNavigation/SideNavigationProvider.context.js +3 -1
- package/components/SideNavigation/SideNavigationProvider.js +62 -2
- package/components/SideNavigation/index.js +1 -1
- package/components/SideNavigation/selectors.js +28 -11
- package/components/SnackBarContainer/index.js +13 -2
- package/components/Switch/index.js +40 -2
- package/components/Switch/style.js +46 -1
- package/components/Tabs/TabContext.js +22 -3
- package/components/Tabs/components/Tab.js +64 -4
- package/components/Tabs/components/Tab.style.js +32 -1
- package/components/Tabs/components/TabIndicator.js +18 -2
- package/components/Tabs/components/TabIndicator.style.js +13 -1
- package/components/Tabs/components/TabPanel.js +24 -2
- package/components/Tabs/components/Tabs.js +138 -6
- package/components/Tabs/components/Tabs.style.js +19 -2
- package/components/Tabs/debounce.js +18 -3
- package/components/Tabs/index.js +3 -1
- package/components/Tabs/ownerDocument.js +4 -1
- package/components/Tabs/ownerWindow.js +8 -2
- package/components/Tabs/useEventCallback.js +12 -2
- package/components/TextLink/TextLink.js +19 -2
- package/components/TextLink/TextLink.style.js +10 -1
- package/components/TimeBoundary/index.js +69 -10
- package/components/TimeBoundary/spec.js +79 -6
- package/components/Toggle/index.js +38 -2
- package/components/Toggle/style.js +63 -1
- package/components/Typography/Typography.js +186 -4
- package/components/Typography/index.js +1 -1
- package/components/VideoPlayer/index.js +100 -10
- package/components/View/components/Above/index.js +24 -2
- package/components/View/components/Below/index.js +24 -2
- package/components/View/components/Content/components/ParallaxProvider/index.js +58 -7
- package/components/View/components/Content/index.js +195 -21
- package/components/View/components/Content/style.js +41 -3
- package/components/View/context.js +16 -1
- package/components/View/index.js +66 -4
- package/components/View/provider.js +141 -23
- package/components/View/style.js +12 -1
- package/components/constants.js +5 -1
- package/components/index.js +199 -9
- package/core/action-creators/app.js +7 -2
- package/core/action-creators/appPermissions.js +14 -2
- package/core/action-creators/index.js +5 -1
- package/core/action-creators/merchantSettings.js +8 -2
- package/core/action-creators/optIns.js +71 -7
- package/core/action-creators/shopSettings.js +15 -3
- package/core/actions/getGeolocation.js +24 -2
- package/core/actions/grantAppTrackingTransparencyPermission.js +15 -2
- package/core/actions/grantCameraPermissions.js +23 -2
- package/core/actions/grantGeolocationPermissions.js +28 -2
- package/core/actions/grantPermissions.js +152 -8
- package/core/actions/grantPushPermissions.js +28 -2
- package/core/actions/index.js +40 -7
- package/core/actions/requestAppPermission.js +37 -4
- package/core/actions/requestAppPermissionStatus.js +34 -4
- package/core/actions/updateStatusBarBackground.js +19 -2
- package/core/classes/GeolocationRequest.js +31 -5
- package/core/classes/GeolocationRequestApp.js +76 -8
- package/core/classes/GeolocationRequestBrowser.js +38 -3
- package/core/classes/index.js +15 -1
- package/core/collections/AppInitialization.js +52 -8
- package/core/collections/index.js +9 -1
- package/core/commands/analyticsSetConsent.js +13 -3
- package/core/commands/index.js +28 -1
- package/core/config/ThemeConfigResolver.js +131 -18
- package/core/config/config.action-creators.js +21 -4
- package/core/config/config.actions.js +23 -2
- package/core/config/config.constants.js +5 -1
- package/core/config/config.reducers.js +29 -2
- package/core/config/config.selectors.js +86 -13
- package/core/config/config.streams.js +17 -1
- package/core/config/config.subscriptions.js +16 -2
- package/core/config/config.types.js +6 -2
- package/core/config/getPageConfig.js +14 -2
- package/core/config/getPageSettings.js +25 -6
- package/core/config/getThemeAssets.js +10 -2
- package/core/config/getThemeColors.js +10 -2
- package/core/config/getThemeConfig.js +7 -2
- package/core/config/getThemeSettings.js +10 -2
- package/core/config/getThemeStyles.js +10 -2
- package/core/config/getWidgetConfig.js +19 -2
- package/core/config/getWidgetSettings.js +20 -5
- package/core/config/index.js +16 -1
- package/core/config/isBeta.js +7 -2
- package/core/constants/actionTypes.js +2 -1
- package/core/constants/appFeatures.js +3 -1
- package/core/constants/deviceTypes.js +2 -1
- package/core/constants/geolocationRequest.js +5 -1
- package/core/constants/index.js +44 -8
- package/core/constants/merchantSettings.js +11 -1
- package/core/constants/optIns.js +4 -1
- package/core/constants/pipelines.js +3 -1
- package/core/constants/shopSettings.js +27 -2
- package/core/contexts/AppContext.js +2 -1
- package/core/contexts/ThemeResourcesContext.js +13 -2
- package/core/contexts/index.js +3 -1
- package/core/events/index.js +1 -1
- package/core/helpers/androidNavigationBar.js +32 -4
- package/core/helpers/appFeatures.js +54 -13
- package/core/helpers/appPermissions.js +159 -15
- package/core/helpers/baseUrl.js +10 -3
- package/core/helpers/bridge.js +11 -2
- package/core/helpers/deviceType.js +8 -3
- package/core/helpers/environment.js +6 -2
- package/core/helpers/errorBehavior.js +152 -10
- package/core/helpers/featureFlag.js +32 -5
- package/core/helpers/getFullImageSource.js +83 -8
- package/core/helpers/getImageFormat.js +9 -2
- package/core/helpers/googleMaps.js +9 -2
- package/core/helpers/i18n.js +70 -7
- package/core/helpers/index.js +53 -4
- package/core/helpers/isIOSTheme.js +7 -1
- package/core/helpers/isTouchDevice.js +9 -1
- package/core/helpers/nl2br.js +5 -1
- package/core/helpers/scrollContainer.js +6 -2
- package/core/helpers/string.js +6 -2
- package/core/helpers/svgToDataUrl.js +18 -4
- package/core/helpers/updateLegacyNavigationBar.js +78 -5
- package/core/hocs/index.js +10 -1
- package/core/hocs/withApp.js +16 -3
- package/core/hocs/withCurrentProduct.js +35 -4
- package/core/hocs/withForwardedRef.js +18 -3
- package/core/hocs/withNavigation.js +34 -4
- package/core/hocs/withRoute.js +27 -4
- package/core/hocs/withTheme.js +33 -5
- package/core/hocs/withThemeResources.js +33 -4
- package/core/hocs/withWidgetSettings.js +19 -3
- package/core/hocs/withWidgetStyles.js +19 -3
- package/core/hooks/events/appEvents.js +74 -7
- package/core/hooks/events/index.js +4 -1
- package/core/hooks/events/useLongPress.js +47 -4
- package/core/hooks/events/usePressHandler.js +33 -5
- package/core/hooks/events/useScrollDirectionChange.js +86 -11
- package/core/hooks/html/index.js +1 -1
- package/core/hooks/html/useLoadImage.js +14 -2
- package/core/hooks/index.js +18 -1
- package/core/hooks/layout/index.js +1 -1
- package/core/hooks/layout/useElementSize.js +83 -7
- package/core/hooks/useApp.js +9 -2
- package/core/hooks/useAsyncMemo.js +26 -3
- package/core/hooks/useCurrentProduct.js +15 -3
- package/core/hooks/useFormState.js +146 -11
- package/core/hooks/useLocalStorage.js +33 -4
- package/core/hooks/useNavigation.js +13 -2
- package/core/hooks/usePageConfig.js +11 -2
- package/core/hooks/usePageSettings.js +11 -2
- package/core/hooks/usePrevious.js +10 -2
- package/core/hooks/useRoute.js +9 -2
- package/core/hooks/useScrollTo.js +35 -2
- package/core/hooks/useTheme.js +13 -3
- package/core/hooks/useThemeResources.js +35 -7
- package/core/hooks/useWidgetConfig.js +11 -2
- package/core/hooks/useWidgetSettings.js +11 -2
- package/core/hooks/useWidgetStyles.js +13 -2
- package/core/index.js +35 -5
- package/core/initialization/index.js +146 -12
- package/core/providers/AppProvider.js +67 -10
- package/core/providers/ThemeResourcesProvider.js +33 -4
- package/core/providers/index.js +6 -1
- package/core/reducers/app.js +30 -2
- package/core/reducers/index.js +10 -1
- package/core/reducers/merchantSettings.js +38 -2
- package/core/reducers/shopSettings.js +52 -2
- package/core/router/helpers.js +36 -6
- package/core/selectors/app.js +9 -3
- package/core/selectors/index.js +20 -6
- package/core/selectors/merchantSettings.js +24 -4
- package/core/selectors/shopSettings.js +61 -10
- package/core/streams/app.js +36 -6
- package/core/streams/appPermissions.js +38 -7
- package/core/streams/index.js +15 -4
- package/core/streams/optIns.js +26 -5
- package/core/subscriptions/app.js +37 -6
- package/core/validation/index.js +2 -1
- package/core/validation/validation.hooks.js +31 -2
- package/core/validation/validation.js +52 -6
- package/development/action-creators/index.js +2 -1
- package/development/action-creators/settings.js +22 -4
- package/development/action-creators/storage.js +8 -2
- package/development/components/ClientInformation/ClientInformation.js +70 -3
- package/development/components/ClientInformation/actions.js +9 -2
- package/development/components/ClientInformation/index.js +1 -1
- package/development/components/DevelopmentSettings/DevelopmentSettings.js +56 -4
- package/development/components/DevelopmentSettings/index.js +1 -1
- package/development/components/DevelopmentTools/DevelopmentTools.js +17 -2
- package/development/components/DevelopmentTools/Shortcuts.js +16 -2
- package/development/components/DevelopmentTools/hooks.js +27 -3
- package/development/components/DevelopmentTools/index.js +1 -1
- package/development/components/SimulatedInsets/SimulatedInsetBottom.js +52 -2
- package/development/components/SimulatedInsets/SimulatedInsetTop.js +99 -5
- package/development/components/SimulatedInsets/SimulatedInsets.js +33 -2
- package/development/components/SimulatedInsets/index.js +1 -1
- package/development/components/index.js +2 -1
- package/development/constants/actionTypes.js +4 -1
- package/development/constants/index.js +1 -1
- package/development/reducers/index.js +7 -1
- package/development/reducers/settings.js +46 -3
- package/development/reducers/storage.js +35 -3
- package/development/selectors/index.js +2 -1
- package/development/selectors/settings.js +56 -11
- package/development/selectors/storage.js +15 -5
- package/development/streams/index.js +1 -1
- package/development/streams/insets.js +8 -2
- package/development/subscriptions/index.js +17 -4
- package/favorites/components/CommentDialog/CommentDialog.js +145 -6
- package/favorites/components/CommentDialog/index.js +1 -1
- package/favorites/components/FavoriteButtonWide/FavoriteButtonWide.js +74 -4
- package/favorites/components/FavoriteButtonWide/index.js +1 -1
- package/favorites/components/Item/Item.js +360 -9
- package/favorites/components/Item/ItemCharacteristics.js +31 -2
- package/favorites/components/Item/ItemNotes.js +88 -3
- package/favorites/components/Item/ItemQuantity.js +50 -3
- package/favorites/components/Item/index.js +1 -1
- package/favorites/components/ItemFulfillmentMethod/ItemFulfillmentMethod.js +27 -2
- package/favorites/components/ItemFulfillmentMethod/index.js +1 -1
- package/favorites/components/List/List.js +116 -8
- package/favorites/components/List/ListAccordionHeader.js +24 -2
- package/favorites/components/List/ListAccordionLabel.js +12 -2
- package/favorites/components/List/ListContent.js +67 -3
- package/favorites/components/List/ListItemWrapper.js +40 -2
- package/favorites/components/List/index.js +1 -1
- package/favorites/components/List/styles.js +35 -1
- package/favorites/components/ListChooser/ListChooser.js +57 -4
- package/favorites/components/ListChooser/ListChooserItem.js +48 -3
- package/favorites/components/ListChooser/index.js +1 -1
- package/favorites/components/Lists/Lists.js +283 -18
- package/favorites/components/Lists/ListsModal.js +67 -3
- package/favorites/components/Lists/index.js +1 -1
- package/favorites/components/RemoveButton/RemoveButton.js +37 -2
- package/favorites/components/RemoveButton/index.js +1 -1
- package/favorites/constants/Portals.js +7 -1
- package/favorites/constants/index.js +2 -1
- package/favorites/index.js +20 -5
- package/filter/actions/index.js +1 -1
- package/filter/components/FilterItem/index.js +12 -2
- package/filter/components/FilterItem/spec.js +9 -1
- package/filter/components/FilterItem/style.js +9 -1
- package/filter/components/FilterPageContent/components/ApplyButton/index.js +46 -2
- package/filter/components/FilterPageContent/components/ApplyButton/spec.js +45 -1
- package/filter/components/FilterPageContent/components/ApplyButton/style.js +11 -1
- package/filter/components/FilterPageContent/components/ResetButton/index.js +32 -2
- package/filter/components/FilterPageContent/components/ResetButton/spec.js +28 -1
- package/filter/components/FilterPageContent/components/ResetButton/style.js +6 -1
- package/filter/components/FilterPageContent/components/Selector/components/Selected/index.js +43 -4
- package/filter/components/FilterPageContent/components/Selector/components/Selected/spec.js +25 -1
- package/filter/components/FilterPageContent/components/Selector/components/Selected/style.js +19 -1
- package/filter/components/FilterPageContent/components/Selector/components/Toggle/index.js +42 -4
- package/filter/components/FilterPageContent/components/Selector/components/Toggle/spec.js +33 -1
- package/filter/components/FilterPageContent/components/Selector/components/Toggle/style.js +30 -1
- package/filter/components/FilterPageContent/components/Selector/components/ValueButton/index.js +47 -4
- package/filter/components/FilterPageContent/components/Selector/components/ValueButton/spec.js +31 -1
- package/filter/components/FilterPageContent/components/Selector/components/ValueButton/style.js +23 -1
- package/filter/components/FilterPageContent/components/Selector/index.js +145 -16
- package/filter/components/FilterPageContent/components/Selector/spec.js +32 -1
- package/filter/components/FilterPageContent/components/Selector/style.js +8 -1
- package/filter/components/FilterPageContent/index.js +72 -2
- package/filter/components/FilterPageContentWithProvider/index.js +34 -3
- package/filter/components/PriceSlider/components/Label/index.js +145 -7
- package/filter/components/PriceSlider/components/Label/spec.js +16 -1
- package/filter/components/PriceSlider/index.js +87 -10
- package/filter/components/PriceSlider/spec.js +24 -1
- package/filter/components/PriceSlider/style.js +95 -1
- package/filter/components/index.js +2 -1
- package/filter/constants/index.js +4 -1
- package/filter/constants/sort.js +30 -5
- package/filter/helpers/buildFilterParamsForFetchFiltersRequest.js +44 -6
- package/filter/helpers/buildInitialFilters.js +26 -2
- package/filter/helpers/buildUpdatedFilters.js +27 -5
- package/filter/helpers/index.js +4 -1
- package/filter/helpers/translateFilterLabel.js +7 -2
- package/filter/hocs/index.js +1 -1
- package/filter/hocs/withSort.js +28 -4
- package/filter/hooks/filterPage.js +6 -2
- package/filter/hooks/index.js +7 -2
- package/filter/index.js +12 -2
- package/filter/providers/FilterPageProvider.context.js +42 -9
- package/filter/providers/FilterPageProvider.js +229 -46
- package/filter/providers/SortProvider.connector.js +27 -2
- package/filter/providers/SortProvider.context.js +3 -1
- package/filter/providers/SortProvider.helpers.js +25 -4
- package/filter/providers/SortProvider.js +70 -4
- package/filter/providers/index.js +2 -1
- package/filter/selectors/index.js +59 -10
- package/filter/streams/index.js +1 -1
- package/i18n/countries.helpers.js +24 -2
- package/i18n/countries.hooks.js +6 -2
- package/i18n/index.js +1 -1
- package/index.js +4 -1
- package/locations/action-creators/errorInventories.js +11 -2
- package/locations/action-creators/errorLocations.js +10 -2
- package/locations/action-creators/errorProductInventories.js +11 -2
- package/locations/action-creators/errorProductLocations.js +10 -2
- package/locations/action-creators/index.js +25 -1
- package/locations/action-creators/provideProductAlternativeLocation.js +9 -2
- package/locations/action-creators/receiveInventories.js +9 -2
- package/locations/action-creators/receiveLocations.js +10 -2
- package/locations/action-creators/receiveProductInventories.js +11 -2
- package/locations/action-creators/receiveProductLocations.js +11 -2
- package/locations/action-creators/requestInventories.js +10 -2
- package/locations/action-creators/requestLocations.js +9 -2
- package/locations/action-creators/requestProductInventories.js +10 -2
- package/locations/action-creators/requestProductLocations.js +9 -2
- package/locations/action-creators/selectGlobalLocation.js +9 -2
- package/locations/action-creators/selectLocation.js +32 -2
- package/locations/action-creators/sendDefaultLocationCode.js +23 -4
- package/locations/action-creators/setStoreFinderSearchRadius.js +9 -2
- package/locations/action-creators/setUserGeolocation.js +10 -2
- package/locations/action-creators/setUserSearchCountryCode.js +14 -3
- package/locations/action-creators/setUserSearchGeolocation.js +12 -2
- package/locations/action-creators/setUserSearchPostalCode.js +14 -3
- package/locations/action-creators/storeFormInput.js +9 -2
- package/locations/action-creators/storeFulfillmentMethod.js +9 -2
- package/locations/action-creators/submitReservationError.js +11 -2
- package/locations/action-creators/submitReservationRequest.js +11 -2
- package/locations/action-creators/submitReservationSuccess.js +11 -2
- package/locations/actions/fetchDefaultLocation.js +22 -2
- package/locations/actions/fetchFulfillmentSlots.js +34 -2
- package/locations/actions/fetchInventories.js +39 -2
- package/locations/actions/fetchLocations.js +49 -2
- package/locations/actions/fetchProductInventories.js +28 -2
- package/locations/actions/fetchProductLocations.js +38 -2
- package/locations/actions/index.js +18 -2
- package/locations/actions/sendDefaultLocationCode.js +18 -2
- package/locations/actions/setUserGeolocation.js +22 -1
- package/locations/actions/setUserSearchGeolocation.js +19 -1
- package/locations/actions/submitReservation.js +35 -2
- package/locations/components/Cart/CartChangeFulfillmentMethod.connector.js +12 -3
- package/locations/components/Cart/CartChangeFulfillmentMethod.js +50 -4
- package/locations/components/Cart/CartChangeFulfillmentMethod.types.js +6 -2
- package/locations/components/Cart/CartContextMenuChangeFulfillment.js +26 -4
- package/locations/components/Cart/CartContextMenuChangeFulfillmentContent.js +48 -2
- package/locations/components/Cart/CartContextMenuChangeFulfillmentContent.style.js +24 -1
- package/locations/components/Cart/CartContextMenuItemChangeFulfillment.connector.js +12 -2
- package/locations/components/Cart/CartContextMenuItemChangeFulfillment.js +27 -2
- package/locations/components/Cart/CartContextMenuItemChangeLocation.js +27 -2
- package/locations/components/Cart/CartItemProductChangeLocation.connector.js +26 -3
- package/locations/components/Cart/CartItemProductChangeLocation.js +70 -6
- package/locations/components/Cart/CartItemProductChangeLocation.types.js +3 -1
- package/locations/components/Cart/index.js +5 -1
- package/locations/components/ChangeLocationButton/ChangeLocationButton.js +31 -2
- package/locations/components/ChangeLocationButton/ChangeLocationButton.style.js +17 -2
- package/locations/components/ChangeLocationButton/index.js +1 -1
- package/locations/components/FulfillmentPath/FulfillmentPath.js +68 -2
- package/locations/components/FulfillmentPath/FulfillmentPath.style.js +35 -2
- package/locations/components/FulfillmentPath/FulfillmentPathItem.js +23 -2
- package/locations/components/FulfillmentPath/index.js +1 -1
- package/locations/components/FulfillmentPathSelector/FulfillmentPathSelector.js +77 -7
- package/locations/components/FulfillmentPathSelector/FulfillmentPathSelector.style.js +4 -1
- package/locations/components/FulfillmentPathSelector/index.js +1 -1
- package/locations/components/FulfillmentSelector/FulfillmentSelector.connector.js +71 -8
- package/locations/components/FulfillmentSelector/FulfillmentSelector.context.js +26 -1
- package/locations/components/FulfillmentSelector/FulfillmentSelector.hooks.js +10 -2
- package/locations/components/FulfillmentSelector/FulfillmentSelector.js +192 -6
- package/locations/components/FulfillmentSelector/FulfillmentSelector.style.js +8 -1
- package/locations/components/FulfillmentSelector/FulfillmentSelector.types.js +22 -7
- package/locations/components/FulfillmentSelector/FulfillmentSelectorAddToCart.js +77 -3
- package/locations/components/FulfillmentSelector/FulfillmentSelectorAlternativeLocation.js +109 -3
- package/locations/components/FulfillmentSelector/FulfillmentSelectorBOPIS.js +21 -2
- package/locations/components/FulfillmentSelector/FulfillmentSelectorDirectShip.js +45 -2
- package/locations/components/FulfillmentSelector/FulfillmentSelectorHeader.js +10 -2
- package/locations/components/FulfillmentSelector/FulfillmentSelectorHeader.style.js +9 -1
- package/locations/components/FulfillmentSelector/FulfillmentSelectorImpossibleError.js +40 -2
- package/locations/components/FulfillmentSelector/FulfillmentSelectorImpossibleError.style.js +4 -1
- package/locations/components/FulfillmentSelector/FulfillmentSelectorItem.js +61 -3
- package/locations/components/FulfillmentSelector/FulfillmentSelectorItem.style.js +60 -1
- package/locations/components/FulfillmentSelector/FulfillmentSelectorLocation.js +113 -2
- package/locations/components/FulfillmentSelector/FulfillmentSelectorLocation.style.js +22 -1
- package/locations/components/FulfillmentSelector/FulfillmentSelectorLocationMethodNotAvailable.js +35 -2
- package/locations/components/FulfillmentSelector/FulfillmentSelectorROPIS.js +21 -2
- package/locations/components/FulfillmentSelector/index.js +1 -1
- package/locations/components/FulfillmentSheet/FulfillmentSheet.js +17 -2
- package/locations/components/FulfillmentSheet/FulfillmentSheet.style.js +14 -1
- package/locations/components/FulfillmentSheet/FulfillmentSheetContent.js +36 -2
- package/locations/components/FulfillmentSheet/index.js +1 -1
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotDialog.js +292 -14
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotProvider.connector.js +16 -3
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotProvider.context.js +2 -1
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotProvider.js +69 -5
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotSwitcher.connector.js +14 -2
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotSwitcher.js +65 -3
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotSwitcherBar.js +42 -2
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotSwitcherBar.style.js +42 -1
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotSwitcherDefault.js +36 -2
- package/locations/components/FulfillmentSlotSwitcher/FulfillmentSlotSwitcherDefault.style.js +27 -1
- package/locations/components/FulfillmentSlotSwitcher/index.js +2 -1
- package/locations/components/FulfillmentSlotSwitcher/time.js +31 -2
- package/locations/components/GlobalLocationSelector/GlobalLocationSelector.js +78 -6
- package/locations/components/GlobalLocationSelector/index.js +1 -1
- package/locations/components/GlobalLocationSwitcher/GlobalLocationSwitcher.connector.js +20 -3
- package/locations/components/GlobalLocationSwitcher/GlobalLocationSwitcher.js +63 -4
- package/locations/components/GlobalLocationSwitcher/GlobalLocationSwitcherBar.js +38 -2
- package/locations/components/GlobalLocationSwitcher/GlobalLocationSwitcherBar.style.js +39 -1
- package/locations/components/GlobalLocationSwitcher/GlobalLocationSwitcherDefault.js +28 -2
- package/locations/components/GlobalLocationSwitcher/GlobalLocationSwitcherDefault.style.js +27 -1
- package/locations/components/GlobalLocationSwitcher/index.js +1 -1
- package/locations/components/ReservationResponses/ReservationError.js +15 -2
- package/locations/components/ReservationResponses/ReservationResponse.style.js +28 -1
- package/locations/components/ReservationResponses/ReservationSuccess.js +23 -2
- package/locations/components/ReservationResponses/index.js +2 -1
- package/locations/components/ReserveForm/ReserveForm.constraints.js +33 -1
- package/locations/components/ReserveForm/ReserveForm.js +194 -5
- package/locations/components/ReserveForm/ReserveForm.style.js +77 -1
- package/locations/components/ReserveForm/ReserveFormPhone.connector.js +12 -3
- package/locations/components/ReserveForm/ReserveFormPhone.js +133 -4
- package/locations/components/ReserveForm/ReserveFormPhone.types.js +3 -1
- package/locations/components/ReserveForm/index.js +1 -1
- package/locations/components/StockInfo/StockInfo.defaultSettings.js +49 -1
- package/locations/components/StockInfo/StockInfo.js +75 -3
- package/locations/components/StockInfo/StockInfoInventory.js +38 -2
- package/locations/components/StockInfo/index.js +1 -1
- package/locations/components/StockInfoLists/index.js +79 -3
- package/locations/components/StoreDetails/components/FindMoreStores.js +84 -2
- package/locations/components/StoreDetails/components/GetDirectionsButton.js +46 -3
- package/locations/components/StoreDetails/components/StoreDetails.js +172 -3
- package/locations/components/StoreDetails/components/StoreFinderMap.js +120 -7
- package/locations/components/StoreDetails/components/StoreFinderMap.style.js +14 -1
- package/locations/components/StoreDetails/components/StoreLocationMap.js +29 -2
- package/locations/components/StoreDetails/components/StoresNearby.js +32 -2
- package/locations/components/StoreDetails/components/StoresNearbyListItem.js +134 -3
- package/locations/components/StoreDetails/index.js +20 -2
- package/locations/components/StoreFinder/Store.context.js +6 -2
- package/locations/components/StoreFinder/StoreFinder.js +23 -2
- package/locations/components/StoreFinder/StoreFinder.style.js +25 -1
- package/locations/components/StoreFinder/StoreFinderGetDirectionsButton.connector.js +14 -2
- package/locations/components/StoreFinder/StoreFinderGetDirectionsButton.js +35 -2
- package/locations/components/StoreFinder/StoreFinderGetDirectionsButton.style.js +12 -1
- package/locations/components/StoreFinder/StoreFinderLocation.js +30 -2
- package/locations/components/StoreFinder/StoreFinderLocation.style.js +10 -1
- package/locations/components/StoreFinder/StoreFinderLocationDetails.js +30 -2
- package/locations/components/StoreFinder/StoreFinderLocationDetails.style.js +15 -1
- package/locations/components/StoreFinder/StoreFinderLocationHeader.js +60 -2
- package/locations/components/StoreFinder/StoreFinderLocationHeader.style.js +74 -1
- package/locations/components/StoreFinder/StoreFinderLocationHeaderPhoneNumber.js +30 -2
- package/locations/components/StoreFinder/StoreFinderLocations.js +29 -2
- package/locations/components/StoreFinder/StoreFinderLocations.style.js +26 -1
- package/locations/components/StoreFinder/StoreFinderSearch.js +12 -2
- package/locations/components/StoreFinder/StoreFinderSearch.style.js +5 -1
- package/locations/components/StoreFinder/StoreFinderSelectLocationButton.js +29 -2
- package/locations/components/StoreFinder/StoreFinderStoreInfoButton.js +59 -3
- package/locations/components/StoreFinder/index.js +1 -1
- package/locations/components/StoreList/Store.context.js +4 -1
- package/locations/components/StoreList/Store.style.js +121 -1
- package/locations/components/StoreList/StoreAddress.js +51 -2
- package/locations/components/StoreList/StoreAddressShort.js +47 -2
- package/locations/components/StoreList/StoreCard.js +15 -2
- package/locations/components/StoreList/StoreDetails.js +31 -2
- package/locations/components/StoreList/StoreDetailsLine.js +30 -2
- package/locations/components/StoreList/StoreDistance.js +24 -2
- package/locations/components/StoreList/StoreHeader.js +61 -2
- package/locations/components/StoreList/StoreHoursToday.js +31 -2
- package/locations/components/StoreList/StoreList.js +9 -2
- package/locations/components/StoreList/StoreListLocations.js +38 -2
- package/locations/components/StoreList/StoreListProduct.js +40 -2
- package/locations/components/StoreList/StoreListProduct.style.js +43 -1
- package/locations/components/StoreList/StoreListProductInfo.js +33 -2
- package/locations/components/StoreList/StoreListProductName.js +23 -2
- package/locations/components/StoreList/StoreListSearch.connector.js +21 -3
- package/locations/components/StoreList/StoreListSearch.js +168 -10
- package/locations/components/StoreList/StoreListSearch.style.js +84 -1
- package/locations/components/StoreList/StoreListSearchRadius.connector.js +21 -3
- package/locations/components/StoreList/StoreListSearchRadius.js +62 -2
- package/locations/components/StoreList/StoreListSearchRadius.style.js +3 -1
- package/locations/components/StoreList/StoreOpeningHours.js +40 -2
- package/locations/components/StoreList/StoreOpeningHoursLine.js +29 -2
- package/locations/components/StoreList/StorePhoneNumber.js +34 -2
- package/locations/components/StoreList/StoreSelectLocationButton.js +45 -2
- package/locations/components/StoreList/index.js +4 -1
- package/locations/components/index.js +12 -1
- package/locations/constants/ActionTypes.js +46 -8
- package/locations/constants/Pipelines.js +5 -1
- package/locations/constants/Portals.js +31 -2
- package/locations/constants/Stages.js +5 -1
- package/locations/constants/index.js +28 -6
- package/locations/constants/routes.js +3 -1
- package/locations/helpers/createOrder.js +154 -7
- package/locations/helpers/formatDistance.js +43 -5
- package/locations/helpers/getAvailabilitySettings.js +39 -7
- package/locations/helpers/index.js +4 -1
- package/locations/helpers/productInventory.js +21 -2
- package/locations/helpers/showInventoryInLists.js +30 -4
- package/locations/index.js +41 -8
- package/locations/locations.context.js +49 -3
- package/locations/locations.hooks.js +8 -2
- package/locations/locations.streams.js +174 -2
- package/locations/locations.types.js +60 -20
- package/locations/providers/FulfillmentProvider.connector.js +59 -5
- package/locations/providers/FulfillmentProvider.js +433 -22
- package/locations/providers/FulfillmentProvider.types.js +13 -5
- package/locations/providers/StoreDetailsContext.js +2 -1
- package/locations/providers/StoreDetailsProvider.js +52 -4
- package/locations/providers/StoreFinder.connector.js +22 -2
- package/locations/providers/StoreFinderProvider.js +73 -6
- package/locations/providers/index.js +4 -1
- package/locations/reducers/index.js +17 -2
- package/locations/reducers/storage.js +153 -21
- package/locations/reducers/storeFinderSearch.js +27 -2
- package/locations/reducers/user.js +21 -2
- package/locations/reducers/userFormInput.js +17 -2
- package/locations/reducers/userSearch.js +36 -2
- package/locations/selectors/index.js +428 -41
- package/locations/subscriptions.js +363 -15
- package/login/action-creators/index.js +1 -1
- package/login/action-creators/resetPassword.js +23 -4
- package/login/actions/index.js +1 -1
- package/login/actions/resetPassword.js +22 -2
- package/login/components/ForgotPassword/ForgotPassword.connector.js +11 -2
- package/login/components/ForgotPassword/ForgotPassword.js +95 -2
- package/login/components/ForgotPassword/ForgotPassword.style.js +88 -1
- package/login/components/ForgotPassword/index.js +1 -1
- package/login/constants/actions.js +3 -1
- package/login/constants/index.js +3 -1
- package/login/constants/pipelines.js +1 -1
- package/login/constants/routes.js +1 -1
- package/login/index.js +3 -1
- package/market/index.js +9 -3
- package/orders/action-creators/index.js +2 -1
- package/orders/action-creators/orderDetails.js +27 -5
- package/orders/action-creators/orders.js +36 -6
- package/orders/actions/cancelOrder.js +43 -2
- package/orders/actions/fetchOrderDetails.js +19 -2
- package/orders/actions/fetchOrderHistory.js +23 -2
- package/orders/actions/index.js +3 -1
- package/orders/components/OrderDetails/OrderDetails.js +26 -2
- package/orders/components/OrderDetails/OrderDetailsAuthenticate.js +95 -2
- package/orders/components/OrderDetails/OrderDetailsAuthenticate.style.js +33 -1
- package/orders/components/OrderDetails/OrderDetailsAuthenticateForm.config.js +28 -2
- package/orders/components/OrderDetails/OrderDetailsContent.js +22 -2
- package/orders/components/OrderDetails/OrderDetailsContent.style.js +18 -1
- package/orders/components/OrderDetails/OrderDetailsOrder.js +78 -2
- package/orders/components/OrderDetails/OrderDetailsOrder.style.js +62 -1
- package/orders/components/OrderDetails/OrderDetailsOrderHeader.js +65 -2
- package/orders/components/OrderDetails/OrderDetailsOrderHeader.style.js +42 -1
- package/orders/components/OrderDetails/OrderDetailsOrderPickupLocation.connector.js +22 -2
- package/orders/components/OrderDetails/OrderDetailsOrderPickupLocation.js +58 -2
- package/orders/components/OrderDetails/OrderDetailsOrderPickupLocation.style.js +7 -1
- package/orders/components/OrderDetails/index.js +1 -1
- package/orders/components/OrderHistory/OrderHistory.js +39 -2
- package/orders/components/OrderHistory/OrderHistory.style.js +7 -1
- package/orders/components/OrderHistory/OrderHistoryList.js +50 -3
- package/orders/components/OrderHistory/OrderHistoryList.style.js +36 -1
- package/orders/components/OrderHistory/OrderHistoryLoader.js +37 -2
- package/orders/components/OrderHistory/OrderHistoryTable.js +48 -3
- package/orders/components/OrderHistory/OrderHistoryTable.style.js +25 -1
- package/orders/components/OrderHistory/index.js +1 -1
- package/orders/components/index.js +1 -1
- package/orders/constants/actionTypes.js +8 -1
- package/orders/constants/index.js +4 -1
- package/orders/constants/pipelines.js +3 -1
- package/orders/constants/routes.js +3 -1
- package/orders/constants/status.js +52 -5
- package/orders/helpers/index.js +1 -1
- package/orders/helpers/orderDetails.js +5 -2
- package/orders/helpers/orderStatus.js +23 -4
- package/orders/hooks/index.js +11 -3
- package/orders/index.js +8 -2
- package/orders/providers/OrderDetailsPrivateProvider.connector.js +34 -4
- package/orders/providers/OrderDetailsPrivateProvider.js +63 -3
- package/orders/providers/OrderDetailsProvider.connector.js +36 -4
- package/orders/providers/OrderDetailsProvider.constraints.js +21 -1
- package/orders/providers/OrderDetailsProvider.context.js +3 -1
- package/orders/providers/OrderDetailsProvider.js +170 -6
- package/orders/providers/OrderHistoryProvider.connector.js +19 -3
- package/orders/providers/OrderHistoryProvider.context.js +3 -1
- package/orders/providers/OrderHistoryProvider.js +34 -2
- package/orders/reducers/index.js +9 -1
- package/orders/reducers/orders.js +45 -3
- package/orders/reducers/ordersById.js +59 -3
- package/orders/reducers/ordersByNumber.js +71 -3
- package/orders/selectors/index.js +29 -8
- package/orders/subscriptions/index.js +17 -2
- package/package.json +12 -14
- package/page/action-creators/index.js +39 -5
- package/page/actions/index.js +1 -1
- package/page/components/NotFound.js +72 -2
- package/page/components/ResponsiveWidgetImage/ResponsiveWidgetImage.js +163 -9
- package/page/components/ResponsiveWidgetImage/index.js +1 -1
- package/page/components/WidgetHeadline/WidgetHeadline.js +66 -4
- package/page/components/WidgetHeadline/index.js +1 -1
- package/page/components/WidgetRichText/WidgetRichText.js +82 -2
- package/page/components/WidgetRichText/index.js +1 -1
- package/page/components/WidgetVideo/WidgetVideo.js +143 -7
- package/page/components/WidgetVideo/index.js +1 -1
- package/page/components/Widgets/Overlay.js +252 -27
- package/page/components/Widgets/Tooltip.js +194 -17
- package/page/components/Widgets/Widget.js +125 -7
- package/page/components/Widgets/WidgetContext.js +10 -3
- package/page/components/Widgets/WidgetProvider.js +37 -2
- package/page/components/Widgets/Widgets.js +82 -6
- package/page/components/Widgets/WidgetsPreviewContext.js +13 -3
- package/page/components/Widgets/WidgetsPreviewProvider.js +29 -2
- package/page/components/Widgets/constants.js +5 -2
- package/page/components/Widgets/events.js +33 -6
- package/page/components/Widgets/helpers.js +37 -7
- package/page/components/Widgets/hooks.js +178 -27
- package/page/components/Widgets/index.js +2 -1
- package/page/components/index.js +4 -1
- package/page/constants/actionTypes.js +3 -1
- package/page/constants/index.js +20 -3
- package/page/helpers/index.js +60 -10
- package/page/hooks/index.js +128 -25
- package/page/index.js +6 -1
- package/page/reducers/index.js +126 -7
- package/page/selectors/index.js +177 -12
- package/page/subscriptions/index.js +7 -2
- package/page/widgets/Button/Button.js +53 -2
- package/page/widgets/Button/index.js +1 -1
- package/page/widgets/CategoryList/CategoryList.js +37 -2
- package/page/widgets/CategoryList/hooks.js +63 -6
- package/page/widgets/CategoryList/index.js +1 -1
- package/page/widgets/CategoryList/selectors.js +11 -3
- package/page/widgets/HTML/HTML.js +90 -3
- package/page/widgets/HTML/hooks.js +22 -4
- package/page/widgets/HTML/index.js +1 -1
- package/page/widgets/Headline/Headline.js +19 -2
- package/page/widgets/Headline/index.js +1 -1
- package/page/widgets/HeroBanner/HeroBanner.js +92 -2
- package/page/widgets/HeroBanner/hooks.js +42 -4
- package/page/widgets/HeroBanner/index.js +1 -1
- package/page/widgets/Image/Image.js +41 -2
- package/page/widgets/Image/hooks.js +48 -4
- package/page/widgets/Image/index.js +1 -1
- package/page/widgets/ImageRow/ImageRow.js +109 -2
- package/page/widgets/ImageRow/hooks.js +57 -4
- package/page/widgets/ImageRow/index.js +1 -1
- package/page/widgets/ImageSlider/ImageSlider.js +49 -2
- package/page/widgets/ImageSlider/hooks.js +140 -11
- package/page/widgets/ImageSlider/index.js +1 -1
- package/page/widgets/NestedCategoryFilter/NestedCategoryFilter.js +154 -8
- package/page/widgets/NestedCategoryFilter/components/Picker/components/Sheet/index.js +38 -2
- package/page/widgets/NestedCategoryFilter/components/Picker/components/SheetItem/index.js +53 -3
- package/page/widgets/NestedCategoryFilter/components/Picker/index.js +111 -2
- package/page/widgets/NestedCategoryFilter/hooks.js +21 -4
- package/page/widgets/NestedCategoryFilter/index.js +1 -1
- package/page/widgets/Placeholder/Placeholder.js +49 -2
- package/page/widgets/Placeholder/hooks.js +11 -4
- package/page/widgets/Placeholder/index.js +1 -1
- package/page/widgets/ProductList/ProductList.js +77 -5
- package/page/widgets/ProductList/hooks.js +50 -5
- package/page/widgets/ProductList/index.js +1 -1
- package/page/widgets/ProductSlider/ProductSlider.js +60 -3
- package/page/widgets/ProductSlider/hooks.js +71 -5
- package/page/widgets/ProductSlider/index.js +1 -1
- package/page/widgets/RichText/RichText.js +27 -2
- package/page/widgets/RichText/hooks.js +19 -4
- package/page/widgets/RichText/index.js +1 -1
- package/page/widgets/Video/Video.js +27 -2
- package/page/widgets/Video/hooks.js +40 -4
- package/page/widgets/Video/index.js +1 -1
- package/page/widgets/index.js +14 -1
- package/product/collections/index.js +1 -1
- package/product/components/Availability/Availability.connector.js +24 -3
- package/product/components/Availability/Availability.js +45 -3
- package/product/components/Availability/Availability.style.js +10 -1
- package/product/components/Availability/index.js +1 -1
- package/product/components/Characteristics/Characteristic/components/Sheet/index.js +158 -16
- package/product/components/Characteristics/Characteristic/components/SheetItem/index.js +80 -8
- package/product/components/Characteristics/Characteristic/components/SheetItem/style.js +69 -1
- package/product/components/Characteristics/Characteristic/index.js +158 -16
- package/product/components/Characteristics/Characteristic/style.js +40 -1
- package/product/components/Characteristics/Swatch/index.js +88 -9
- package/product/components/Characteristics/Swatch/style.js +28 -1
- package/product/components/Characteristics/index.js +71 -10
- package/product/components/Characteristics/transition.js +14 -1
- package/product/components/Description/connector.js +23 -3
- package/product/components/Description/index.js +46 -2
- package/product/components/Description/style.js +41 -1
- package/product/components/EffectivityDates/connector.js +18 -3
- package/product/components/EffectivityDates/constants.js +2 -1
- package/product/components/EffectivityDates/helpers.js +78 -5
- package/product/components/EffectivityDates/index.js +79 -2
- package/product/components/EffectivityDates/style.js +10 -1
- package/product/components/FilterBar/FilterBarProvider.connector.js +22 -3
- package/product/components/FilterBar/FilterBarProvider.context.js +8 -2
- package/product/components/FilterBar/FilterBarProvider.js +39 -3
- package/product/components/FilterBar/components/Content/actions/openFilterRoute.js +41 -2
- package/product/components/FilterBar/components/Content/components/FilterButton/index.js +32 -2
- package/product/components/FilterBar/components/Content/components/FilterButton/style.js +42 -1
- package/product/components/FilterBar/components/Content/components/FilterChips/connector.js +16 -3
- package/product/components/FilterBar/components/Content/components/FilterChips/index.js +152 -8
- package/product/components/FilterBar/components/Content/components/FilterChips/style.js +14 -1
- package/product/components/FilterBar/components/Content/components/Sort/components/Item/index.js +17 -2
- package/product/components/FilterBar/components/Content/components/Sort/components/Item/style.js +7 -1
- package/product/components/FilterBar/components/Content/components/Sort/index.js +31 -2
- package/product/components/FilterBar/components/Content/components/Sort/style.js +76 -1
- package/product/components/FilterBar/components/Content/index.js +45 -2
- package/product/components/FilterBar/components/Content/spec.js +135 -6
- package/product/components/FilterBar/components/Content/style.js +4 -1
- package/product/components/FilterBar/components/FilterModal/FilterModal.js +63 -2
- package/product/components/FilterBar/components/FilterModal/FilterModalContent.js +54 -2
- package/product/components/FilterBar/components/FilterModal/FilterModalTitle.js +64 -2
- package/product/components/FilterBar/components/FilterModal/index.js +1 -1
- package/product/components/FilterBar/index.js +50 -2
- package/product/components/FilterBar/mock.js +67 -4
- package/product/components/FilterBar/selectors.js +6 -2
- package/product/components/FilterBar/style.js +4 -1
- package/product/components/Header/PriceStriked/connector.js +20 -3
- package/product/components/Header/PriceStriked/index.js +46 -2
- package/product/components/Header/PriceStriked/style.js +26 -1
- package/product/components/Header/Shipping/components/Label/index.js +30 -3
- package/product/components/Header/Shipping/components/Label/style.js +11 -1
- package/product/components/Header/Shipping/connector.js +20 -3
- package/product/components/Header/Shipping/index.js +31 -2
- package/product/components/Header/Shipping/mock.js +38 -1
- package/product/components/Header/Shipping/spec.js +31 -2
- package/product/components/Header/Shipping/style.js +14 -1
- package/product/components/Header/Tiers/components/Tier/index.js +37 -4
- package/product/components/Header/Tiers/components/Tier/spec.js +47 -1
- package/product/components/Header/Tiers/connector.js +20 -3
- package/product/components/Header/Tiers/index.js +34 -2
- package/product/components/Header/Tiers/spec.js +63 -1
- package/product/components/Header/Tiers/style.js +17 -1
- package/product/components/Header/index.js +3 -1
- package/product/components/MapPriceHint/connector.js +14 -2
- package/product/components/MapPriceHint/helpers.js +26 -4
- package/product/components/MapPriceHint/index.js +44 -2
- package/product/components/Media/FeaturedMedia.js +29 -2
- package/product/components/Media/FeaturedVideo.js +10 -3
- package/product/components/Media/MediaImage.js +58 -2
- package/product/components/Media/MediaPlaceholder.js +22 -2
- package/product/components/Media/helpers.js +31 -2
- package/product/components/Media/index.js +2 -1
- package/product/components/Media/props.js +13 -1
- package/product/components/Media/style.js +41 -1
- package/product/components/MediaSlider/components/MediaImage/index.js +24 -2
- package/product/components/MediaSlider/components/MediaVideo/connector.js +9 -2
- package/product/components/MediaSlider/components/MediaVideo/index.js +36 -2
- package/product/components/MediaSlider/connector.js +28 -3
- package/product/components/MediaSlider/constants.js +12 -2
- package/product/components/MediaSlider/index.js +75 -3
- package/product/components/MediaSlider/style.js +32 -1
- package/product/components/Options/components/Content/connector.js +24 -3
- package/product/components/Options/components/Content/index.js +91 -9
- package/product/components/Options/components/Content/spec.js +72 -2
- package/product/components/Options/components/Option/index.js +39 -2
- package/product/components/Options/components/TextOption/components/OptionInfo/index.js +67 -3
- package/product/components/Options/components/TextOption/components/OptionInfo/spec.js +62 -1
- package/product/components/Options/components/TextOption/components/OptionInfo/style.js +23 -1
- package/product/components/Options/components/TextOption/index.js +155 -20
- package/product/components/Options/components/TextOption/style.js +37 -1
- package/product/components/Options/index.js +27 -3
- package/product/components/OrderQuantityHint/index.js +70 -3
- package/product/components/OrderQuantityHint/style.js +6 -1
- package/product/components/PriceDifference/index.js +30 -2
- package/product/components/PriceDifference/style.js +18 -1
- package/product/components/PriceInfo/PriceInfo.connector.js +13 -2
- package/product/components/PriceInfo/PriceInfo.js +79 -3
- package/product/components/PriceInfo/index.js +1 -1
- package/product/components/ProductBadges/index.js +57 -2
- package/product/components/ProductCard/index.js +115 -3
- package/product/components/ProductCard/style.js +18 -1
- package/product/components/ProductCharacteristics/connector.js +33 -4
- package/product/components/ProductCharacteristics/context.js +2 -1
- package/product/components/ProductCharacteristics/helpers/index.js +139 -21
- package/product/components/ProductCharacteristics/index.js +278 -34
- package/product/components/ProductDiscountBadge/connector.js +9 -2
- package/product/components/ProductDiscountBadge/index.js +47 -2
- package/product/components/ProductDiscountBadge/mock.js +35 -3
- package/product/components/ProductDiscountBadge/spec.js +53 -2
- package/product/components/ProductDiscountBadge/style.js +31 -1
- package/product/components/ProductFilters/index.js +69 -4
- package/product/components/ProductFilters/style.js +23 -1
- package/product/components/ProductGrid/components/Item/components/ItemDetails/index.js +78 -2
- package/product/components/ProductGrid/components/Item/components/ItemDetails/spec.js +68 -1
- package/product/components/ProductGrid/components/Item/components/ItemDiscount/index.js +40 -2
- package/product/components/ProductGrid/components/Item/components/ItemFavoritesButton/index.js +48 -2
- package/product/components/ProductGrid/components/Item/components/ItemFavoritesButton/spec.js +30 -1
- package/product/components/ProductGrid/components/Item/components/ItemImage/index.js +34 -2
- package/product/components/ProductGrid/components/Item/components/ItemImage/spec.js +15 -1
- package/product/components/ProductGrid/components/Item/components/ItemName/index.js +53 -2
- package/product/components/ProductGrid/components/Item/components/ItemName/spec.js +17 -1
- package/product/components/ProductGrid/components/Item/components/ItemPrice/index.js +33 -2
- package/product/components/ProductGrid/components/Item/components/ItemPrice/spec.js +34 -1
- package/product/components/ProductGrid/components/Item/index.js +84 -2
- package/product/components/ProductGrid/components/Iterator/index.js +36 -2
- package/product/components/ProductGrid/components/Layout/index.js +42 -2
- package/product/components/ProductGrid/index.js +80 -2
- package/product/components/ProductGrid/spec.js +51 -1
- package/product/components/ProductGridPrice/index.js +41 -2
- package/product/components/ProductGridPrice/style.js +21 -1
- package/product/components/ProductImage/ProductImagePlaceholder.js +55 -2
- package/product/components/ProductImage/connector.js +9 -2
- package/product/components/ProductImage/index.js +153 -17
- package/product/components/ProductImage/spec.js +82 -1
- package/product/components/ProductImage/style.js +52 -2
- package/product/components/ProductList/components/Item/index.js +184 -2
- package/product/components/ProductList/components/Item/style.js +66 -2
- package/product/components/ProductList/components/Iterator/index.js +42 -2
- package/product/components/ProductList/components/Iterator/style.js +15 -1
- package/product/components/ProductList/components/Layout/index.js +19 -2
- package/product/components/ProductList/components/Layout/style.js +11 -1
- package/product/components/ProductList/index.js +62 -2
- package/product/components/ProductName/ProductName.js +59 -2
- package/product/components/ProductName/ProductNameContent.js +26 -2
- package/product/components/ProductName/index.js +1 -1
- package/product/components/ProductProperties/Content.js +38 -4
- package/product/components/ProductProperties/Group.js +17 -2
- package/product/components/ProductProperties/GroupedProperties.js +29 -2
- package/product/components/ProductProperties/Lists.js +22 -2
- package/product/components/ProductProperties/ListsHTML.js +40 -2
- package/product/components/ProductProperties/ProductProperties.js +23 -2
- package/product/components/ProductProperties/Row.js +36 -2
- package/product/components/ProductProperties/RowHTML.js +38 -2
- package/product/components/ProductProperties/Rows.js +29 -2
- package/product/components/ProductProperties/Wrapper.js +25 -2
- package/product/components/ProductProperties/connector.js +12 -2
- package/product/components/ProductProperties/helpers/getGroupsFromProperties.js +44 -7
- package/product/components/ProductProperties/helpers/getPropertiesBySubgroup.js +6 -1
- package/product/components/ProductProperties/helpers/getPropertiesWithoutSubgroup.js +6 -1
- package/product/components/ProductProperties/helpers/getSubgroupsFromProperties.js +13 -1
- package/product/components/ProductProperties/style.js +44 -1
- package/product/components/ProductSlider/index.js +72 -3
- package/product/components/ProductSlider/spec.js +36 -1
- package/product/components/ProductSlider/style.js +8 -1
- package/product/components/ProductVariants/VariantAvailability.connector.js +9 -2
- package/product/components/ProductVariants/VariantAvailability.js +32 -2
- package/product/components/ProductVariants/VariantAvailability.style.js +5 -1
- package/product/components/ProductVariants/index.js +1 -1
- package/product/components/QuantityPicker/hooks.js +24 -3
- package/product/components/QuantityPicker/index.js +100 -10
- package/product/components/Rating/connector.js +20 -3
- package/product/components/Rating/index.js +58 -3
- package/product/components/Rating/mock.js +10 -1
- package/product/components/Rating/spec.js +52 -2
- package/product/components/Rating/style.js +12 -1
- package/product/components/RelationsSlider/RelationsSheet.connector.js +15 -3
- package/product/components/RelationsSlider/RelationsSheet.js +53 -2
- package/product/components/RelationsSlider/RelationsSlider.connector.js +29 -4
- package/product/components/RelationsSlider/RelationsSlider.js +32 -2
- package/product/components/RelationsSlider/RelationsSliderContent.js +70 -2
- package/product/components/RelationsSlider/constants.js +1 -1
- package/product/components/RelationsSlider/index.js +1 -1
- package/product/components/RelationsSlider/style.js +56 -1
- package/product/components/Swatch/Swatch.js +30 -2
- package/product/components/Swatch/SwatchContent.js +52 -2
- package/product/components/Swatch/VariantSwatch.js +34 -2
- package/product/components/Swatch/index.js +2 -1
- package/product/components/Swatch/style.js +27 -1
- package/product/components/Swatches/Swatches.js +52 -2
- package/product/components/Swatches/connector.js +12 -2
- package/product/components/Swatches/index.js +1 -1
- package/product/components/Swatches/style.js +9 -1
- package/product/components/UnitQuantityPicker/CartUnitQuantityPicker.js +40 -2
- package/product/components/UnitQuantityPicker/ProductUnitQuantityPicker.connector.js +18 -3
- package/product/components/UnitQuantityPicker/ProductUnitQuantityPicker.js +111 -3
- package/product/components/UnitQuantityPicker/UnitQuantityPicker.js +321 -9
- package/product/components/UnitQuantityPicker/UnitQuantityPickerWithSection.js +80 -3
- package/product/components/UnitQuantityPicker/helper.js +25 -4
- package/product/components/UnitQuantityPicker/index.js +4 -1
- package/product/components/UnitQuantityPicker/styles.js +7 -1
- package/product/components/context.js +3 -1
- package/product/components/index.js +32 -1
- package/product/constants/index.js +13 -2
- package/product/contexts/index.js +1 -1
- package/product/helpers/index.js +85 -6
- package/product/helpers/redirects.js +49 -3
- package/product/hocs/index.js +6 -1
- package/product/hocs/withMapPricing.js +48 -5
- package/product/hocs/withPriceCalculation.js +22 -5
- package/product/hocs/withProduct.js +9 -2
- package/product/hocs/withProductListEntry.js +16 -3
- package/product/hocs/withProductListEntryProduct.js +29 -4
- package/product/hocs/withProductListType.js +16 -3
- package/product/hocs/withProductStock.js +9 -2
- package/product/hooks/index.js +3 -1
- package/product/hooks/useLoadProductImage.js +19 -2
- package/product/hooks/useProductListEntry.js +11 -3
- package/product/hooks/useProductListType.js +11 -3
- package/product/index.js +48 -6
- package/product/product.types.js +9 -3
- package/product/providers/Product/connector.js +13 -2
- package/product/providers/Product/index.js +33 -2
- package/product/providers/ProductListEntry/context.js +13 -2
- package/product/providers/ProductListEntry/index.js +28 -2
- package/product/providers/ProductListType/context.js +21 -4
- package/product/providers/ProductListType/index.js +27 -2
- package/product/providers/index.js +3 -1
- package/product/selectors/helpers/filterProperties.js +29 -5
- package/product/selectors/helpers/index.js +2 -1
- package/product/selectors/helpers/wrapMemoizedSelector.js +8 -1
- package/product/selectors/media.js +25 -8
- package/product/selectors/price.js +23 -4
- package/product/selectors/product.js +190 -25
- package/product/selectors/relations.js +47 -7
- package/product/selectors/variants.js +77 -5
- package/product/streams/index.js +1 -1
- package/push-opt-in/action-creators/index.js +2 -1
- package/push-opt-in/action-creators/optInTrigger.js +43 -8
- package/push-opt-in/action-creators/pushOptIn.js +14 -3
- package/push-opt-in/actions/index.js +1 -1
- package/push-opt-in/actions/pushOptInModal.js +31 -3
- package/push-opt-in/components/PushOptInModal/connector.js +17 -3
- package/push-opt-in/components/PushOptInModal/index.js +92 -3
- package/push-opt-in/components/PushOptInModal/style.js +53 -1
- package/push-opt-in/components/index.js +1 -1
- package/push-opt-in/constants/index.js +2 -1
- package/push-opt-in/constants/optInModal.js +2 -1
- package/push-opt-in/constants/optInTrigger.js +9 -1
- package/push-opt-in/reducers/index.js +7 -1
- package/push-opt-in/reducers/optInModal.js +31 -2
- package/push-opt-in/reducers/optInTrigger.js +83 -2
- package/push-opt-in/selectors/index.js +2 -1
- package/push-opt-in/selectors/optInModal.js +13 -4
- package/push-opt-in/selectors/optInTrigger.js +38 -3
- package/push-opt-in/subscriptions/index.js +6 -1
- package/push-opt-in/subscriptions/optInTracking.js +103 -2
- package/push-opt-in/subscriptions/optInTrigger.js +109 -6
- package/registration/action-creators/index.js +30 -5
- package/registration/actions/index.js +1 -1
- package/registration/actions/submitRegistration.js +25 -2
- package/registration/components/GuestRegistration/GuestRegistration.js +20 -2
- package/registration/components/GuestRegistration/GuestRegistrationContent.js +59 -2
- package/registration/components/GuestRegistration/GuestRegistrationFormPickup.config.js +58 -2
- package/registration/components/GuestRegistration/GuestRegistrationFormPickup.js +81 -2
- package/registration/components/Registration/Registration.js +15 -2
- package/registration/components/Registration/RegistrationContent.js +28 -2
- package/registration/components/Registration/RegistrationContent.style.js +58 -2
- package/registration/components/Registration/RegistrationFormActions.js +40 -2
- package/registration/components/Registration/RegistrationFormBase.config.js +38 -2
- package/registration/components/Registration/RegistrationFormBase.js +36 -2
- package/registration/components/Registration/RegistrationFormBilling.config.js +93 -2
- package/registration/components/Registration/RegistrationFormBilling.js +63 -2
- package/registration/components/Registration/RegistrationFormExtra.config.js +28 -2
- package/registration/components/Registration/RegistrationFormExtra.js +50 -2
- package/registration/components/Registration/RegistrationFormShipping.config.js +82 -2
- package/registration/components/Registration/RegistrationFormShipping.js +56 -2
- package/registration/components/Registration/RegistrationFormToggle.js +52 -2
- package/registration/components/index.js +2 -1
- package/registration/constants/actionTypes.js +4 -1
- package/registration/constants/index.js +8 -1
- package/registration/constants/pipelines.js +1 -1
- package/registration/hooks/index.js +7 -2
- package/registration/index.js +2 -1
- package/registration/providers/GuestRegistrationProvider.actions.js +101 -2
- package/registration/providers/GuestRegistrationProvider.connector.js +44 -3
- package/registration/providers/GuestRegistrationProvider.constraints.js +144 -6
- package/registration/providers/GuestRegistrationProvider.context.js +3 -1
- package/registration/providers/GuestRegistrationProvider.js +346 -17
- package/registration/providers/RegistrationProvider.actions.js +105 -3
- package/registration/providers/RegistrationProvider.connector.js +27 -3
- package/registration/providers/RegistrationProvider.constraints.js +128 -7
- package/registration/providers/RegistrationProvider.context.js +3 -1
- package/registration/providers/RegistrationProvider.js +239 -12
- package/registration/streams/index.js +8 -2
- package/registration/subscriptions/index.js +40 -4
- package/reviews/actions/index.js +5 -1
- package/reviews/components/Reviews/components/AllReviewsLink/connector.js +19 -3
- package/reviews/components/Reviews/components/AllReviewsLink/index.js +31 -2
- package/reviews/components/Reviews/components/AllReviewsLink/style.js +15 -2
- package/reviews/components/Reviews/components/Header/components/AverageRating/index.js +45 -3
- package/reviews/components/Reviews/components/Header/components/AverageRating/style.js +9 -1
- package/reviews/components/Reviews/components/Header/components/NoReviews/index.js +27 -2
- package/reviews/components/Reviews/components/Header/components/NoReviews/style.js +18 -1
- package/reviews/components/Reviews/components/Header/components/ReviewsExcerpt/index.js +45 -2
- package/reviews/components/Reviews/components/Header/components/ReviewsExcerpt/style.js +27 -1
- package/reviews/components/Reviews/components/Header/components/WriteReviewLink/index.js +23 -2
- package/reviews/components/Reviews/components/Header/components/WriteReviewLink/spec.js +30 -2
- package/reviews/components/Reviews/components/Header/connector.js +10 -2
- package/reviews/components/Reviews/components/Header/index.js +38 -2
- package/reviews/components/Reviews/components/Header/spec.js +52 -2
- package/reviews/components/Reviews/components/List/components/Info/components/Author/index.js +23 -2
- package/reviews/components/Reviews/components/List/components/Info/components/ReviewDate/index.js +16 -2
- package/reviews/components/Reviews/components/List/components/Info/index.js +25 -3
- package/reviews/components/Reviews/components/List/components/Info/style.js +9 -1
- package/reviews/components/Reviews/components/List/components/Rating/index.js +19 -2
- package/reviews/components/Reviews/components/List/components/Rating/style.js +14 -1
- package/reviews/components/Reviews/components/List/components/Review/index.js +23 -2
- package/reviews/components/Reviews/components/List/components/Text/index.js +20 -2
- package/reviews/components/Reviews/components/List/components/Text/style.js +6 -1
- package/reviews/components/Reviews/components/List/components/Title/index.js +15 -2
- package/reviews/components/Reviews/components/List/components/Title/style.js +5 -1
- package/reviews/components/Reviews/components/List/index.js +48 -3
- package/reviews/components/Reviews/components/List/spec.js +68 -1
- package/reviews/components/Reviews/components/List/style.js +11 -1
- package/reviews/components/Reviews/components/RatingCount/index.js +26 -2
- package/reviews/components/Reviews/components/RatingCount/spec.js +17 -1
- package/reviews/components/Reviews/components/RatingCount/style.js +20 -1
- package/reviews/components/Reviews/components/ReviewsInfo/index.js +42 -2
- package/reviews/components/Reviews/connector.js +14 -2
- package/reviews/components/Reviews/index.js +42 -2
- package/reviews/components/Reviews/mock.js +83 -7
- package/reviews/components/Reviews/spec.js +67 -4
- package/reviews/components/Reviews/style.js +11 -1
- package/reviews/components/index.js +1 -1
- package/reviews/constants/index.js +3 -1
- package/reviews/index.js +11 -2
- package/reviews/selectors/index.js +1 -1
- package/reviews/streams/index.js +1 -1
- package/scanner/action-creators/index.js +3 -1
- package/scanner/actions/index.js +4 -1
- package/scanner/classes/index.js +1 -1
- package/scanner/constants/index.js +3 -1
- package/scanner/helpers/index.js +1 -1
- package/scanner/index.js +10 -1
- package/scanner/streams/index.js +1 -1
- package/search/actions/index.js +2 -1
- package/search/constants/index.js +3 -1
- package/search/helpers/index.js +3 -1
- package/search/index.js +9 -1
- package/search/selectors/index.js +1 -1
- package/search/streams/index.js +1 -1
- package/styles/helpers/color.js +19 -8
- package/styles/helpers/cssCustomProperties.js +35 -4
- package/styles/helpers/index.js +11 -1
- package/styles/helpers/initCSSCustomProperties.js +70 -4
- package/styles/helpers/loadCustomStyles.js +31 -3
- package/styles/helpers/setPageBackgroundColor.js +18 -3
- package/styles/helpers/setPageContentWidth.js +7 -2
- package/styles/helpers/setViewportHeight.js +11 -2
- package/styles/helpers/toggleBodyScroll.js +48 -2
- package/styles/helpers/updatePageInsets.js +38 -2
- package/styles/index.js +3 -1
- package/styles/reset/form.js +50 -4
- package/styles/reset/index.js +5 -1
- package/styles/reset/media.js +20 -1
- package/styles/reset/root.js +59 -3
- package/styles/reset/table.js +8 -1
- package/styles/reset/typography.js +24 -1
- package/styles/theme/createTheme/createBreakpoints.js +100 -15
- package/styles/theme/createTheme/createPalette.js +54 -2
- package/styles/theme/createTheme/createSpacing.js +38 -5
- package/styles/theme/createTheme/createTypography.js +74 -5
- package/styles/theme/createTheme/index.js +26 -2
- package/styles/theme/createTheme/transitions.js +81 -15
- package/styles/theme/createTheme/zIndex.js +7 -1
- package/styles/theme/hooks/index.js +4 -1
- package/styles/theme/hooks/useActiveBreakpoint.js +7 -2
- package/styles/theme/hooks/useMediaQuery.js +40 -7
- package/styles/theme/hooks/useResponsiveValue.js +23 -4
- package/styles/theme/hooks/useTheme.js +7 -2
- package/styles/theme/index.js +3 -1
- package/styles/theme/providers/ActiveBreakpointProvider.js +57 -6
- package/styles/theme/providers/ThemeProvider.js +18 -2
- package/styles/tss/index.js +21 -3
- package/tracking/action-creators/cookieConsent.js +41 -5
- package/tracking/action-creators/index.js +1 -1
- package/tracking/actions/cookieConsent.js +89 -10
- package/tracking/actions/index.js +1 -1
- package/tracking/components/CookieConsentModal/connector.js +23 -3
- package/tracking/components/CookieConsentModal/index.js +125 -3
- package/tracking/components/CookieConsentModal/style.js +59 -1
- package/tracking/components/PrivacySettings/connector.js +23 -3
- package/tracking/components/PrivacySettings/index.js +128 -2
- package/tracking/components/PrivacySettings/style.js +45 -1
- package/tracking/components/index.js +2 -1
- package/tracking/constants/index.js +5 -1
- package/tracking/helpers/index.js +1 -1
- package/tracking/reducers/cookieConsentModal.js +28 -2
- package/tracking/reducers/cookieSettings.js +23 -2
- package/tracking/reducers/index.js +7 -1
- package/tracking/selectors/cookieConsent.js +69 -11
- package/tracking/selectors/index.js +2 -1
- package/tracking/streams/cookieConsent.js +101 -14
- package/tracking/streams/index.js +1 -1
- package/tracking/subscriptions/analytics.js +194 -7
- package/tracking/subscriptions/cookieConsent.js +62 -8
- package/tracking/subscriptions/index.js +6 -1
- package/user/index.js +25 -6
- package/user/selectors/data.js +15 -3
- package/user/selectors/login.js +15 -3
|
@@ -1,4 +1,51 @@
|
|
|
1
|
-
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { makeStyles } from '@shopgate/engage/styles';
|
|
4
|
+
import { Swiper, Link, ConditionalWrapper } from '@shopgate/engage/components';
|
|
5
|
+
import { ResponsiveWidgetImage } from '@shopgate/engage/page/components';
|
|
6
|
+
import { useImageSliderWidget } from "./hooks";
|
|
7
|
+
const useStyles = makeStyles()({
|
|
8
|
+
image: {
|
|
9
|
+
width: '100%',
|
|
10
|
+
minHeight: 1
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
/**
|
|
2
15
|
* The ImageSliderWidget is used to display an image slider.
|
|
3
16
|
* @returns {JSX.Element}
|
|
4
|
-
*/
|
|
17
|
+
*/
|
|
18
|
+
const ImageSliderWidget = () => {
|
|
19
|
+
const {
|
|
20
|
+
slides,
|
|
21
|
+
swiperProps,
|
|
22
|
+
borderRadius
|
|
23
|
+
} = useImageSliderWidget();
|
|
24
|
+
const {
|
|
25
|
+
classes
|
|
26
|
+
} = useStyles();
|
|
27
|
+
if (slides.length === 0) {
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
return /*#__PURE__*/React.createElement(Swiper, _extends({
|
|
31
|
+
indicators: true
|
|
32
|
+
}, swiperProps), slides.map(slide => {
|
|
33
|
+
if (!slide.image.url) {
|
|
34
|
+
return null;
|
|
35
|
+
}
|
|
36
|
+
return /*#__PURE__*/React.createElement(Swiper.Item, {
|
|
37
|
+
key: slide.image.url
|
|
38
|
+
}, /*#__PURE__*/React.createElement(ConditionalWrapper, {
|
|
39
|
+
condition: !!slide.link,
|
|
40
|
+
wrapper: children => /*#__PURE__*/React.createElement(Link, {
|
|
41
|
+
href: slide.link
|
|
42
|
+
}, children)
|
|
43
|
+
}, /*#__PURE__*/React.createElement(ResponsiveWidgetImage, {
|
|
44
|
+
className: classes.image,
|
|
45
|
+
src: slide.image.url,
|
|
46
|
+
alt: slide.image.altText || '',
|
|
47
|
+
borderRadius: borderRadius
|
|
48
|
+
})));
|
|
49
|
+
}));
|
|
50
|
+
};
|
|
51
|
+
export default ImageSliderWidget;
|
|
@@ -1,14 +1,25 @@
|
|
|
1
|
-
|
|
1
|
+
import { useMemo } from 'react';
|
|
2
|
+
import { useWidget } from '@shopgate/engage/page/hooks';
|
|
3
|
+
import { useTheme } from '@shopgate/engage/styles';
|
|
4
|
+
import { resolveBorderRadiusFromWidgetConfig } from "../../helpers";
|
|
5
|
+
|
|
6
|
+
/**
|
|
2
7
|
* @typedef {import('swiper/react').SwiperProps} SwiperCmpProps
|
|
3
|
-
*/
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
/**
|
|
4
11
|
* @typedef {Object} ImageSliderImageData
|
|
5
12
|
* @property {string} url The image URL.
|
|
6
13
|
* @property {string} [altText] The image alt text.
|
|
7
|
-
*/
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
/**
|
|
8
17
|
* @typedef {Object} ImageSliderImage
|
|
9
18
|
* @property {ImageSliderImageData} image The image data object.
|
|
10
19
|
* @property {string} [link] The link URL.
|
|
11
|
-
*/
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
/**
|
|
12
23
|
* @typedef {Object} ImageSliderWidgetConfig
|
|
13
24
|
* @property {ImageSliderImage[]} images The image objects.
|
|
14
25
|
* @property {boolean} slideAutomatic Whether the slider should automatically slide.
|
|
@@ -23,20 +34,138 @@ function _defineProperty(obj,key,value){if(key in obj){Object.defineProperty(obj
|
|
|
23
34
|
* @property {"default"|"none"|"rounded"|"custom"} borderRadius The border radius option.
|
|
24
35
|
* @property {number} [borderRadiusCustom] The custom border radius value.
|
|
25
36
|
* the pagination type for the slider.
|
|
26
|
-
*/
|
|
37
|
+
*/
|
|
38
|
+
|
|
39
|
+
/**
|
|
27
40
|
* @typedef {ReturnType<typeof import('@shopgate/engage/page/hooks')
|
|
28
41
|
* .useWidget<ImageSliderWidgetConfig> >} UseWidgetReturnType
|
|
29
|
-
*/
|
|
42
|
+
*/
|
|
43
|
+
|
|
44
|
+
// eslint-disable-next-line valid-jsdoc
|
|
30
45
|
/**
|
|
31
46
|
* Hook to access the ImageSlider widget configuration and data.
|
|
32
|
-
*/
|
|
47
|
+
*/
|
|
48
|
+
export const useImageSliderWidget = () => {
|
|
49
|
+
/** @type {UseWidgetReturnType} */
|
|
50
|
+
const {
|
|
51
|
+
config,
|
|
52
|
+
isPreview,
|
|
53
|
+
layout
|
|
54
|
+
} = useWidget();
|
|
55
|
+
const theme = useTheme();
|
|
56
|
+
const {
|
|
57
|
+
images,
|
|
58
|
+
slideAutomatic,
|
|
59
|
+
endlessSlider,
|
|
60
|
+
sliderSpeed,
|
|
61
|
+
slidesPerView,
|
|
62
|
+
slidesPerViewCustomSmall,
|
|
63
|
+
slidesPerViewCustomMedium,
|
|
64
|
+
slidesPerViewCustomLarge,
|
|
65
|
+
imageSpacing,
|
|
66
|
+
paginationStyle = 'bullets',
|
|
67
|
+
borderRadius,
|
|
68
|
+
borderRadiusCustom
|
|
69
|
+
} = config;
|
|
70
|
+
const borderRadiusResolved = resolveBorderRadiusFromWidgetConfig({
|
|
71
|
+
borderRadius,
|
|
72
|
+
borderRadiusCustom
|
|
73
|
+
});
|
|
74
|
+
const paginationType = useMemo(() => paginationStyle === 'default' ? 'bullets' : paginationStyle.toLowerCase(), [paginationStyle]);
|
|
75
|
+
const imagesWithUrls = useMemo(() => images.filter(img => img?.image?.url), [images]);
|
|
76
|
+
|
|
77
|
+
/**
|
|
33
78
|
* @type {SwiperCmpProps}
|
|
34
|
-
*/
|
|
79
|
+
*/
|
|
80
|
+
const swiperProps = useMemo(() => {
|
|
81
|
+
let slidesPerViewSmall = 1.0;
|
|
82
|
+
let slidesPerViewMedium = 1.3;
|
|
83
|
+
let slidesPerViewLarge = 1.6;
|
|
84
|
+
if (slidesPerView === 'dense') {
|
|
85
|
+
slidesPerViewSmall = 1.3;
|
|
86
|
+
slidesPerViewMedium = 1.8;
|
|
87
|
+
slidesPerViewLarge = 2.3;
|
|
88
|
+
} else if (slidesPerView === 'custom') {
|
|
89
|
+
slidesPerViewSmall = slidesPerViewCustomSmall;
|
|
90
|
+
slidesPerViewMedium = slidesPerViewCustomMedium;
|
|
91
|
+
slidesPerViewLarge = slidesPerViewCustomLarge;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
35
95
|
* Special image spacing for slides with a SINGLE slide per view.
|
|
36
96
|
*
|
|
37
97
|
* Needs to be at least as large as the highest horizontal layout margin (when set) to avoid
|
|
38
98
|
* showing of more than one slide.
|
|
39
99
|
* @type {number}
|
|
40
|
-
*/
|
|
41
|
-
|
|
42
|
-
|
|
100
|
+
*/
|
|
101
|
+
const imageSpacingForSingleSlide = Math.max(layout?.marginLeft ?? 0, layout?.marginRight ?? 0, imageSpacing);
|
|
102
|
+
const breakpoints = {
|
|
103
|
+
[theme.breakpoints.values.sm]: {
|
|
104
|
+
slidesPerView: slidesPerViewMedium,
|
|
105
|
+
...(slidesPerViewMedium === 1 && imageSpacingForSingleSlide ? {
|
|
106
|
+
spaceBetween: imageSpacingForSingleSlide
|
|
107
|
+
} : {
|
|
108
|
+
spaceBetween: imageSpacing
|
|
109
|
+
})
|
|
110
|
+
},
|
|
111
|
+
[theme.breakpoints.values.md]: {
|
|
112
|
+
slidesPerView: slidesPerViewLarge,
|
|
113
|
+
...(slidesPerViewLarge === 1 && imageSpacingForSingleSlide ? {
|
|
114
|
+
spaceBetween: imageSpacingForSingleSlide
|
|
115
|
+
} : {
|
|
116
|
+
spaceBetween: imageSpacing
|
|
117
|
+
})
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
const showPagination = paginationType !== 'off' && imagesWithUrls.length > 1;
|
|
121
|
+
// Create a key that changes when relevant config changes, to force remount of Swiper
|
|
122
|
+
const componentKey = isPreview ? JSON.stringify({
|
|
123
|
+
slidesPerView,
|
|
124
|
+
spaceBetween: imageSpacing,
|
|
125
|
+
paginationType,
|
|
126
|
+
showPagination,
|
|
127
|
+
...breakpoints
|
|
128
|
+
}) : null;
|
|
129
|
+
return {
|
|
130
|
+
autoplay: slideAutomatic ? {
|
|
131
|
+
delay: sliderSpeed
|
|
132
|
+
} : false,
|
|
133
|
+
loop: endlessSlider,
|
|
134
|
+
slidesPerView: slidesPerViewSmall,
|
|
135
|
+
breakpoints,
|
|
136
|
+
pagination: showPagination ? {
|
|
137
|
+
type: paginationType,
|
|
138
|
+
clickable: true,
|
|
139
|
+
dynamicBullets: true
|
|
140
|
+
} : false,
|
|
141
|
+
// Prevent cut-off sliders when margins are used in the layout
|
|
142
|
+
...(layout.marginLeft || layout.marginRight ? {
|
|
143
|
+
style: {
|
|
144
|
+
...(layout.marginLeft ? {
|
|
145
|
+
marginLeft: layout.marginLeft * -1,
|
|
146
|
+
paddingLeft: layout.marginLeft
|
|
147
|
+
} : {}),
|
|
148
|
+
...(layout.marginRight ? {
|
|
149
|
+
marginRight: layout.marginRight * -1,
|
|
150
|
+
paddingRight: layout.marginRight
|
|
151
|
+
} : {})
|
|
152
|
+
}
|
|
153
|
+
} : null),
|
|
154
|
+
...(slidesPerViewSmall === 1 && imageSpacingForSingleSlide ? {
|
|
155
|
+
spaceBetween: imageSpacingForSingleSlide
|
|
156
|
+
} : {
|
|
157
|
+
spaceBetween: imageSpacing
|
|
158
|
+
}),
|
|
159
|
+
...(isPreview ? {
|
|
160
|
+
key: componentKey,
|
|
161
|
+
// Improves interaction with the slider in the CMS preview iframe
|
|
162
|
+
touchStartPreventDefault: true
|
|
163
|
+
} : {})
|
|
164
|
+
};
|
|
165
|
+
}, [slidesPerView, theme.breakpoints.values.sm, theme.breakpoints.values.md, paginationType, imagesWithUrls.length, imageSpacing, slideAutomatic, sliderSpeed, endlessSlider, isPreview, slidesPerViewCustomSmall, slidesPerViewCustomMedium, slidesPerViewCustomLarge, layout]);
|
|
166
|
+
return {
|
|
167
|
+
slides: imagesWithUrls,
|
|
168
|
+
swiperProps,
|
|
169
|
+
borderRadius: borderRadiusResolved
|
|
170
|
+
};
|
|
171
|
+
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export{default}from"./ImageSlider";
|
|
1
|
+
export { default } from "./ImageSlider";
|
|
@@ -1,13 +1,159 @@
|
|
|
1
|
-
|
|
1
|
+
import React, { useCallback, useEffect, useMemo, useState } from 'react';
|
|
2
|
+
import { I18n, ButtonLink } from '@shopgate/engage/components';
|
|
3
|
+
import { bin2hex } from '@shopgate/engage/core/helpers';
|
|
4
|
+
import { CATEGORY_PATH } from '@shopgate/engage/category';
|
|
5
|
+
import { makeStyles } from '@shopgate/engage/styles';
|
|
6
|
+
import { themeConfig } from '@shopgate/engage';
|
|
7
|
+
import { useRoute, usePrevious, useLocalStorage } from '@shopgate/engage/core/hooks';
|
|
8
|
+
import { router } from '@virtuous/conductor';
|
|
9
|
+
import CategoryPicker from "./components/Picker";
|
|
10
|
+
import { useNestedCategoryFilterWidget } from "./hooks";
|
|
11
|
+
import WidgetHeadline from "../../components/WidgetHeadline";
|
|
12
|
+
const {
|
|
13
|
+
colors,
|
|
14
|
+
variables
|
|
15
|
+
} = themeConfig;
|
|
16
|
+
const useStyles = makeStyles()({
|
|
17
|
+
container: {
|
|
18
|
+
background: colors.light,
|
|
19
|
+
display: 'flex',
|
|
20
|
+
flexDirection: 'column',
|
|
21
|
+
paddingBottom: variables.gap.big
|
|
22
|
+
},
|
|
23
|
+
buttonContainer: {
|
|
24
|
+
padding: `0 ${variables.gap.big}px`
|
|
25
|
+
},
|
|
26
|
+
button: {
|
|
27
|
+
width: '100%'
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
/**
|
|
2
32
|
* The NestedCategoryFilter component
|
|
3
33
|
* @returns {JSX.Element}
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
34
|
+
*/
|
|
35
|
+
const NestedCategoryFilter = () => {
|
|
36
|
+
const {
|
|
37
|
+
classes,
|
|
38
|
+
cx
|
|
39
|
+
} = useStyles();
|
|
40
|
+
const {
|
|
41
|
+
state: routeState,
|
|
42
|
+
id: routeId
|
|
43
|
+
} = useRoute();
|
|
44
|
+
const {
|
|
45
|
+
maxDepth = 3,
|
|
46
|
+
category = '',
|
|
47
|
+
code,
|
|
48
|
+
showHeadline,
|
|
49
|
+
headline,
|
|
50
|
+
rememberSelection,
|
|
51
|
+
...labels
|
|
52
|
+
} = useNestedCategoryFilterWidget();
|
|
53
|
+
const prevCategory = usePrevious(category);
|
|
54
|
+
const LOCAL_STORAGE_KEY = `nestedCategoryFilterState-${code}`;
|
|
55
|
+
const [localStorageState, setLocalStorageState] = useLocalStorage(LOCAL_STORAGE_KEY);
|
|
56
|
+
const defaultState = useMemo(() => ({
|
|
57
|
+
buttonCategoryId: null,
|
|
58
|
+
pickers: [{
|
|
59
|
+
categoryId: category,
|
|
60
|
+
selectedId: null
|
|
61
|
+
}]
|
|
62
|
+
}), [category]);
|
|
63
|
+
const initialState = useMemo(() => {
|
|
64
|
+
if (rememberSelection && Array.isArray(localStorageState?.pickers) && localStorageState.pickers.length > 0) {
|
|
65
|
+
const [firstPicker] = localStorageState.pickers;
|
|
66
|
+
// Only rehydrate state from local storage if the pickers belong to the current category
|
|
67
|
+
if (firstPicker.categoryId === category) {
|
|
68
|
+
return localStorageState;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
if (routeState[code]) {
|
|
72
|
+
return routeState[code];
|
|
73
|
+
}
|
|
74
|
+
return defaultState;
|
|
75
|
+
}, [category, code, defaultState, localStorageState, rememberSelection, routeState]);
|
|
76
|
+
const [state, setState] = useState(initialState);
|
|
77
|
+
useEffect(() => {
|
|
78
|
+
const stateToPersist = {
|
|
79
|
+
pickers: state.pickers,
|
|
80
|
+
buttonCategoryId: state.buttonCategoryId
|
|
81
|
+
};
|
|
82
|
+
if (rememberSelection) {
|
|
83
|
+
// Store state in local storage when selection should should survive app restarts
|
|
84
|
+
setLocalStorageState(stateToPersist);
|
|
85
|
+
} else {
|
|
86
|
+
// Store state in route otherwise
|
|
87
|
+
router.update(routeId, {
|
|
88
|
+
[code]: stateToPersist
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
}, [code, rememberSelection, routeId, setLocalStorageState, state]);
|
|
92
|
+
useEffect(() => {
|
|
93
|
+
if (typeof prevCategory === 'undefined') return;
|
|
94
|
+
if (typeof category === 'undefined') return;
|
|
95
|
+
if (prevCategory !== category) {
|
|
96
|
+
setState(defaultState);
|
|
97
|
+
}
|
|
98
|
+
}, [prevCategory, category, defaultState, rememberSelection, initialState]);
|
|
99
|
+
|
|
100
|
+
/**
|
|
8
101
|
* Handles the selection of a subcategory within a category picker.
|
|
9
102
|
* @param {string} categoryId The categoryId of the picker where a subcategory was selected.
|
|
10
103
|
* @param {Object} subcategory The subcategory entity which was selected.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
|
|
104
|
+
*/
|
|
105
|
+
const handleSelection = useCallback((categoryId, subcategory) => {
|
|
106
|
+
const {
|
|
107
|
+
id: subcategoryId,
|
|
108
|
+
childrenCount
|
|
109
|
+
} = subcategory;
|
|
110
|
+
const selectedIndex = state.pickers.findIndex(picker => picker.categoryId === categoryId);
|
|
111
|
+
|
|
112
|
+
// Get all pickers up to the selected picker and update its selectedId
|
|
113
|
+
let updatedPickers = state.pickers.slice(0, selectedIndex + 1);
|
|
114
|
+
updatedPickers[updatedPickers.length - 1].selectedId = subcategoryId;
|
|
115
|
+
// Check if a new picker should be added
|
|
116
|
+
const limitReached = updatedPickers?.length === Number(maxDepth);
|
|
117
|
+
const appendNewPicker = !!childrenCount && !limitReached;
|
|
118
|
+
if (appendNewPicker) {
|
|
119
|
+
updatedPickers = updatedPickers.concat([{
|
|
120
|
+
categoryId: subcategoryId,
|
|
121
|
+
selectedId: null
|
|
122
|
+
}]);
|
|
123
|
+
}
|
|
124
|
+
setState({
|
|
125
|
+
pickers: updatedPickers,
|
|
126
|
+
buttonCategoryId: !appendNewPicker ? subcategoryId : null
|
|
127
|
+
});
|
|
128
|
+
}, [maxDepth, state]);
|
|
129
|
+
const categoryPickers = useMemo(() => /*#__PURE__*/React.createElement(React.Fragment, null, state.pickers.slice(0, maxDepth).map((entry, index) => {
|
|
130
|
+
const {
|
|
131
|
+
categoryId,
|
|
132
|
+
selectedId
|
|
133
|
+
} = entry;
|
|
134
|
+
return /*#__PURE__*/React.createElement(CategoryPicker, {
|
|
135
|
+
key: `${categoryId}-${code}`,
|
|
136
|
+
categoryId: categoryId,
|
|
137
|
+
selectedId: selectedId,
|
|
138
|
+
onSelect: handleSelection,
|
|
139
|
+
label: labels[`level${index + 1}Label`] || ''
|
|
140
|
+
});
|
|
141
|
+
})), [code, handleSelection, labels, maxDepth, state.pickers]);
|
|
142
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
143
|
+
className: classes.container
|
|
144
|
+
}, showHeadline && headline ? /*#__PURE__*/React.createElement(WidgetHeadline, {
|
|
145
|
+
headline: headline,
|
|
146
|
+
className: "widget__nested-category-filter__headline"
|
|
147
|
+
}) : null, categoryPickers, /*#__PURE__*/React.createElement("div", {
|
|
148
|
+
className: cx(classes.buttonContainer, 'widget__nested-category-filter__button-container')
|
|
149
|
+
}, /*#__PURE__*/React.createElement(ButtonLink, {
|
|
150
|
+
className: cx(classes.button, 'widget__nested-category-filter__CTA-button'),
|
|
151
|
+
href: `${CATEGORY_PATH}/${bin2hex(state.buttonCategoryId)}`,
|
|
152
|
+
disabled: !state.buttonCategoryId,
|
|
153
|
+
flat: false
|
|
154
|
+
}, /*#__PURE__*/React.createElement(I18n.Text, {
|
|
155
|
+
string: "common.show_products",
|
|
156
|
+
className: "widget__nested-category-filter__CTA-button__text"
|
|
157
|
+
}))));
|
|
158
|
+
};
|
|
159
|
+
export default NestedCategoryFilter;
|
|
@@ -1,4 +1,9 @@
|
|
|
1
|
-
import React,{useCallback}from'react';
|
|
1
|
+
import React, { useCallback } from 'react';
|
|
2
|
+
import PropTypes from 'prop-types';
|
|
3
|
+
import { SheetDrawer, SheetList } from '@shopgate/engage/components';
|
|
4
|
+
import Item from "../SheetItem";
|
|
5
|
+
|
|
6
|
+
/**
|
|
2
7
|
* The CategorySheet component.
|
|
3
8
|
* @param {Object} props The component props.
|
|
4
9
|
* @param {Array} props.items The list of items to display.
|
|
@@ -8,4 +13,35 @@ import React,{useCallback}from'react';import PropTypes from'prop-types';import{S
|
|
|
8
13
|
* @param {Function} props.onSelect The selection handler.
|
|
9
14
|
* @param {string} props.selectedId The currently selected item id.
|
|
10
15
|
* @return {JSX.Element}
|
|
11
|
-
*/
|
|
16
|
+
*/
|
|
17
|
+
const CategorySheet = ({
|
|
18
|
+
items,
|
|
19
|
+
label,
|
|
20
|
+
onClose,
|
|
21
|
+
open,
|
|
22
|
+
selectedId,
|
|
23
|
+
onSelect
|
|
24
|
+
}) => {
|
|
25
|
+
const handleItemClick = useCallback(event => {
|
|
26
|
+
event.stopPropagation();
|
|
27
|
+
onSelect(event.target.value);
|
|
28
|
+
}, [onSelect]);
|
|
29
|
+
return /*#__PURE__*/React.createElement(SheetDrawer, {
|
|
30
|
+
title: label,
|
|
31
|
+
isOpen: open,
|
|
32
|
+
onClose: onClose
|
|
33
|
+
}, /*#__PURE__*/React.createElement(SheetList, {
|
|
34
|
+
className: "widget__nested-category-filter__sheet-list"
|
|
35
|
+
}, items.map(item => /*#__PURE__*/React.createElement(Item, {
|
|
36
|
+
item: item,
|
|
37
|
+
key: item.id,
|
|
38
|
+
onClick: handleItemClick,
|
|
39
|
+
isSelected: item.id === selectedId
|
|
40
|
+
}))));
|
|
41
|
+
};
|
|
42
|
+
CategorySheet.defaultProps = {
|
|
43
|
+
onClose: () => {},
|
|
44
|
+
onSelect: () => {},
|
|
45
|
+
selectedId: null
|
|
46
|
+
};
|
|
47
|
+
export default CategorySheet;
|
|
@@ -1,8 +1,58 @@
|
|
|
1
|
-
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import PropTypes from 'prop-types';
|
|
3
|
+
import { makeStyles } from '@shopgate/engage/styles';
|
|
4
|
+
import { themeConfig } from '@shopgate/engage';
|
|
5
|
+
const {
|
|
6
|
+
colors,
|
|
7
|
+
variables
|
|
8
|
+
} = themeConfig;
|
|
9
|
+
const bgColor = colors.darkGray;
|
|
10
|
+
const boxShadowOffset = variables.gap.bigger;
|
|
11
|
+
const useStyles = makeStyles()({
|
|
12
|
+
button: {
|
|
13
|
+
outline: 0,
|
|
14
|
+
padding: '16px 16px 16px 0',
|
|
15
|
+
textAlign: 'left',
|
|
16
|
+
width: '100%',
|
|
17
|
+
color: 'var(--color-text-high-emphasis)'
|
|
18
|
+
},
|
|
19
|
+
buttonSelected: {
|
|
20
|
+
background: `var(--color-background-accent, ${bgColor})`,
|
|
21
|
+
boxShadow: `-${boxShadowOffset}px 0px 0px var(--color-background-accent, ${bgColor}), ${boxShadowOffset}px 0px 0px var(--color-background-accent,${bgColor})`,
|
|
22
|
+
margin: '-1px 0',
|
|
23
|
+
paddingTop: 17,
|
|
24
|
+
paddingBottom: 17
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
/**
|
|
2
29
|
* The SheetItem component.
|
|
3
30
|
* @param {Object} props The component props.
|
|
4
31
|
* @param {Object} props.item The item data.
|
|
5
|
-
* @param {boolean} props.
|
|
32
|
+
* @param {boolean} props.isSelected Whether the item is selected.
|
|
6
33
|
* @param {Function} props.onClick The click handler.
|
|
7
34
|
* @return {JSX.Element}
|
|
8
|
-
*/
|
|
35
|
+
*/
|
|
36
|
+
const SheetItem = ({
|
|
37
|
+
item,
|
|
38
|
+
isSelected,
|
|
39
|
+
onClick
|
|
40
|
+
}) => {
|
|
41
|
+
const {
|
|
42
|
+
classes,
|
|
43
|
+
cx
|
|
44
|
+
} = useStyles();
|
|
45
|
+
return /*#__PURE__*/React.createElement("button", {
|
|
46
|
+
className: cx(classes.button, {
|
|
47
|
+
[classes.buttonSelected]: isSelected
|
|
48
|
+
}, isSelected ? 'engage__nested-category-filter__sheet-item__selected' : 'engage__nested-category-filter__sheet-item'),
|
|
49
|
+
value: item.id,
|
|
50
|
+
onClick: onClick,
|
|
51
|
+
type: "button"
|
|
52
|
+
}, item.name);
|
|
53
|
+
};
|
|
54
|
+
SheetItem.defaultProps = {
|
|
55
|
+
onClick() {},
|
|
56
|
+
isSelected: false
|
|
57
|
+
};
|
|
58
|
+
export default SheetItem;
|
|
@@ -1,4 +1,45 @@
|
|
|
1
|
-
|
|
1
|
+
import React, { useCallback, useState, useEffect, useMemo } from 'react';
|
|
2
|
+
import PropTypes from 'prop-types';
|
|
3
|
+
import { useSelector, useDispatch } from 'react-redux';
|
|
4
|
+
import { fetchCategoryOrRootCategories } from '@shopgate/engage/category';
|
|
5
|
+
import { makeStyles } from '@shopgate/engage/styles';
|
|
6
|
+
import { themeConfig } from '@shopgate/engage';
|
|
7
|
+
import { i18n } from '@shopgate/engage/core/helpers';
|
|
8
|
+
import Sheet from "./components/Sheet";
|
|
9
|
+
import { getCategoriesById } from "../../../CategoryList/selectors";
|
|
10
|
+
const {
|
|
11
|
+
colors
|
|
12
|
+
} = themeConfig;
|
|
13
|
+
const useStyles = makeStyles()({
|
|
14
|
+
button: {
|
|
15
|
+
background: `var(--color-background-accent, ${colors.overlay})`,
|
|
16
|
+
color: 'var(--color-text-high-emphasis)',
|
|
17
|
+
display: 'flex',
|
|
18
|
+
flexDirection: 'column',
|
|
19
|
+
justifyContent: 'center',
|
|
20
|
+
minHeight: 56,
|
|
21
|
+
outline: 0,
|
|
22
|
+
padding: '12px 16px',
|
|
23
|
+
marginBottom: 8,
|
|
24
|
+
transition: 'background 250ms ease-in, color 250ms ease-in',
|
|
25
|
+
cursor: 'pointer'
|
|
26
|
+
},
|
|
27
|
+
buttonDisabled: {
|
|
28
|
+
color: colors.shade4,
|
|
29
|
+
cursor: 'not-allowed'
|
|
30
|
+
},
|
|
31
|
+
label: {
|
|
32
|
+
fontSize: 12,
|
|
33
|
+
marginTop: -2,
|
|
34
|
+
marginBottom: 4
|
|
35
|
+
},
|
|
36
|
+
selection: {
|
|
37
|
+
fontWeight: 500,
|
|
38
|
+
lineHeight: 1.125
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
/**
|
|
2
43
|
* The CategoryPicker component.
|
|
3
44
|
* @param {Object} props The component props.
|
|
4
45
|
* @param {Function} props.onSelect The selection handler.
|
|
@@ -6,4 +47,72 @@ function _defineProperty(obj,key,value){if(key in obj){Object.defineProperty(obj
|
|
|
6
47
|
* @param {string} props.label The label for the picker.
|
|
7
48
|
* @param {string|null} props.selectedId The currently selected subcategoryId.
|
|
8
49
|
* @return {JSX.Element}
|
|
9
|
-
*/
|
|
50
|
+
*/
|
|
51
|
+
const CategoryPicker = ({
|
|
52
|
+
onSelect,
|
|
53
|
+
categoryId,
|
|
54
|
+
label,
|
|
55
|
+
selectedId
|
|
56
|
+
}) => {
|
|
57
|
+
const subcategories = useSelector(state => getCategoriesById(state, {
|
|
58
|
+
categoryId
|
|
59
|
+
}));
|
|
60
|
+
const dispatch = useDispatch();
|
|
61
|
+
const {
|
|
62
|
+
classes,
|
|
63
|
+
cx
|
|
64
|
+
} = useStyles();
|
|
65
|
+
const [sheetIsOpen, setSheetIsOpen] = useState(false);
|
|
66
|
+
const hasSubcategories = Array.isArray(subcategories) && subcategories.length > 0;
|
|
67
|
+
const disabled = !hasSubcategories || categoryId === null;
|
|
68
|
+
useEffect(() => {
|
|
69
|
+
if (categoryId !== null && subcategories === null) {
|
|
70
|
+
dispatch(fetchCategoryOrRootCategories(categoryId));
|
|
71
|
+
}
|
|
72
|
+
}, [categoryId, dispatch, subcategories]);
|
|
73
|
+
const buttonLabel = useMemo(() => {
|
|
74
|
+
if (!selectedId) {
|
|
75
|
+
return i18n.text('common.please_choose');
|
|
76
|
+
}
|
|
77
|
+
const subcategory = subcategories?.find(val => val.id === selectedId);
|
|
78
|
+
return subcategory?.name;
|
|
79
|
+
}, [selectedId, subcategories]);
|
|
80
|
+
const closeSheet = useCallback(() => {
|
|
81
|
+
setSheetIsOpen(false);
|
|
82
|
+
}, []);
|
|
83
|
+
const handlePickerClick = useCallback(event => {
|
|
84
|
+
event.preventDefault();
|
|
85
|
+
if (disabled) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
setSheetIsOpen(true);
|
|
89
|
+
}, [disabled]);
|
|
90
|
+
const handleSheetSelect = useCallback(subcategoryId => {
|
|
91
|
+
const subcategory = subcategories.find(item => item.id === subcategoryId);
|
|
92
|
+
onSelect(categoryId, subcategory);
|
|
93
|
+
closeSheet();
|
|
94
|
+
}, [categoryId, closeSheet, onSelect, subcategories]);
|
|
95
|
+
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
|
|
96
|
+
onClick: handlePickerClick,
|
|
97
|
+
className: cx(classes.button, {
|
|
98
|
+
[classes.buttonDisabled]: disabled
|
|
99
|
+
}, 'widget__nested-category-filter__category-picker')
|
|
100
|
+
}, label && /*#__PURE__*/React.createElement("div", {
|
|
101
|
+
className: classes.label
|
|
102
|
+
}, label), /*#__PURE__*/React.createElement("div", {
|
|
103
|
+
className: classes.selection
|
|
104
|
+
}, buttonLabel)), /*#__PURE__*/React.createElement(Sheet, {
|
|
105
|
+
items: subcategories || [],
|
|
106
|
+
onSelect: handleSheetSelect,
|
|
107
|
+
onClose: closeSheet,
|
|
108
|
+
open: sheetIsOpen,
|
|
109
|
+
selectedId: selectedId,
|
|
110
|
+
label: label
|
|
111
|
+
}));
|
|
112
|
+
};
|
|
113
|
+
CategoryPicker.defaultProps = {
|
|
114
|
+
categoryId: null,
|
|
115
|
+
label: '',
|
|
116
|
+
selectedId: null
|
|
117
|
+
};
|
|
118
|
+
export default CategoryPicker;
|