@faststore/core 3.99.1 → 4.0.0-dev.1
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/.turbo/turbo-generate.log +29 -0
- package/.turbo/turbo-test.log +47 -16
- package/@generated/cached-operations.json +24 -0
- package/@generated/gql.ts +134 -210
- package/@generated/graphql.ts +1628 -3037
- package/@generated/index.ts +1 -1
- package/@generated/persisted-documents.json +1 -1
- package/@generated/schema.graphql +1854 -1743
- package/CHANGELOG.md +11 -5
- package/README.md +2 -1
- package/api/index.ts +6 -7
- package/cms/faststore/base.jsonc +1 -1
- package/cms/faststore/components/cms_component__alert.jsonc +5 -1
- package/cms/faststore/components/cms_component__bannernewsletter.jsonc +5 -1
- package/cms/faststore/components/cms_component__bannertext.jsonc +5 -1
- package/cms/faststore/components/cms_component__breadcrumb.jsonc +16 -4
- package/cms/faststore/components/cms_component__cartsidebar.jsonc +21 -1
- package/cms/faststore/components/cms_component__children.jsonc +5 -1
- package/cms/faststore/components/cms_component__crosssellingshelf.jsonc +5 -1
- package/cms/faststore/components/cms_component__emptystate.jsonc +8 -3
- package/cms/faststore/components/cms_component__footer.jsonc +9 -3
- package/cms/faststore/components/cms_component__hero.jsonc +5 -1
- package/cms/faststore/components/cms_component__incentives.jsonc +5 -1
- package/cms/faststore/components/cms_component__navbar.jsonc +139 -1
- package/cms/faststore/components/cms_component__newsletter.jsonc +5 -1
- package/cms/faststore/components/cms_component__productdetails.jsonc +33 -1
- package/cms/faststore/components/cms_component__productgallery.jsonc +113 -15
- package/cms/faststore/components/cms_component__productshelf.jsonc +5 -1
- package/cms/faststore/components/cms_component__producttiles.jsonc +5 -1
- package/cms/faststore/components/cms_component__regionbar.jsonc +5 -1
- package/cms/faststore/components/cms_component__regionmodal.jsonc +5 -1
- package/cms/faststore/components/cms_component__regionpopover.jsonc +5 -1
- package/cms/faststore/components/cms_component__scrolltotopbutton.jsonc +29 -0
- package/cms/faststore/components/cms_component__search.jsonc +5 -1
- package/cms/faststore/content-types.json +115 -0
- package/cms/faststore/pages/cms_content_type__globalsections.jsonc +52 -0
- package/cms/faststore/pages/cms_content_type__home.jsonc +6 -0
- package/cms/faststore/pages/cms_content_type__landingpage.jsonc +8 -1
- package/cms/faststore/pages/cms_content_type__pdp.jsonc +6 -0
- package/cms/faststore/pages/cms_content_type__plp.jsonc +17 -0
- package/cms/faststore/pages/cms_content_type__search.jsonc +17 -0
- package/cms/faststore/schema.json +547 -43
- package/cms/faststore/sections.json +330 -21
- package/discovery.config.default.js +49 -3
- package/next-env.d.ts +2 -1
- package/next.config.js +48 -26
- package/package.json +47 -60
- package/public/icons.svg +5 -1
- package/scripts/i18n.js +76 -0
- package/src/components/account/MyAccountDrawer/OrganizationDrawer/OrganizationDrawer.tsx +2 -1
- package/src/components/account/MyAccountDrawer/OrganizationDrawer/section.module.scss +25 -24
- package/src/components/account/MyAccountDrawer/ProfileSummary/profile-summary.scss +8 -6
- package/src/components/account/MyAccountLayout/styles.scss +16 -12
- package/src/components/account/MyAccountMenu/styles.scss +21 -22
- package/src/components/account/MyAccountUserDetails/styles.module.scss +4 -2
- package/src/components/account/components/MyAccountAccordion/styles.scss +4 -2
- package/src/components/account/components/MyAccountHeader/styles.scss +3 -1
- package/src/components/account/components/MyAccountTable/styles.scss +6 -4
- package/src/components/account/orders/MyAccountListOrders/MyAccountFilterSlider/section.module.scss +21 -19
- package/src/components/account/orders/MyAccountListOrders/MyAccountListOrdersTable/MyAccountListOrdersTable.tsx +3 -1
- package/src/components/account/orders/MyAccountListOrders/MyAccountListOrdersTable/styles.scss +5 -3
- package/src/components/account/orders/MyAccountListOrders/styles.module.scss +25 -22
- package/src/components/account/orders/MyAccountOrderDetails/MyAccountBudgetsCard/styles.scss +7 -5
- package/src/components/account/orders/MyAccountOrderDetails/MyAccountDeliveryOptionAccordion/styles.scss +7 -5
- package/src/components/account/orders/MyAccountOrderDetails/MyAccountMoreInformationCard/styles.scss +3 -1
- package/src/components/account/orders/MyAccountOrderDetails/MyAccountOrderActionModal/styles.module.scss +8 -6
- package/src/components/account/orders/MyAccountOrderDetails/MyAccountOrderActions/styles.scss +3 -1
- package/src/components/account/orders/MyAccountOrderDetails/MyAccountStatusCard/styles.scss +8 -6
- package/src/components/account/orders/MyAccountOrderDetails/section.module.scss +36 -43
- package/src/components/account/profile/profile.module.scss +3 -1
- package/src/components/account/section.module.scss +3 -1
- package/src/components/account/security/styles.module.scss +14 -8
- package/src/components/cart/CartSidebar/CartSidebar.tsx +10 -1
- package/src/components/cart/CartSidebar/section.module.scss +19 -17
- package/src/components/cart/EmptyCart/EmptyCart.tsx +12 -4
- package/src/components/cms/GlobalSections.tsx +12 -12
- package/src/components/cms/RenderSections.tsx +10 -2
- package/src/components/cms/plp/Components.ts +9 -0
- package/src/components/common/Alert/section.module.scss +10 -5
- package/src/components/common/PreviewTag/section.module.scss +48 -40
- package/src/components/common/Toast/section.module.scss +4 -2
- package/src/components/localization/LocalizationSelector/LocalizationSelector.tsx +320 -0
- package/src/components/localization/LocalizationSelector/index.ts +1 -0
- package/src/components/localization/LocalizationSelector/section.module.scss +18 -0
- package/src/components/localization/index.ts +1 -0
- package/src/components/navigation/Navbar/Navbar.tsx +49 -1
- package/src/components/navigation/NavbarSlider/NavbarSlider.tsx +19 -1
- package/src/components/navigation/NavbarSlider/section.module.scss +12 -10
- package/src/components/product/OutOfStock/OutOfStock.tsx +6 -1
- package/src/components/product/ProductCard/ProductCard.tsx +1 -1
- package/src/components/region/RegionModal/RegionModal.tsx +4 -1
- package/src/components/region/RegionModal/section.module.scss +10 -8
- package/src/components/region/RegionPopover/RegionPopover.tsx +6 -5
- package/src/components/region/RegionPopover/section.module.scss +9 -7
- package/src/components/region/RegionSlider/RegionSlider.tsx +5 -2
- package/src/components/region/RegionSlider/section.module.scss +16 -13
- package/src/components/search/Filter/FilterDeliveryMethodFacet.tsx +5 -5
- package/src/components/search/Filter/FilterDesktop.tsx +13 -4
- package/src/components/search/Filter/FilterSlider.tsx +18 -6
- package/src/components/search/Filter/section.module.scss +21 -19
- package/src/components/search/SearchDropdown/SearchDropdown.tsx +9 -7
- package/src/components/search/SearchHistory/SearchHistory.tsx +7 -2
- package/src/components/search/SearchInput/SearchInput.tsx +21 -8
- package/src/components/search/SearchProductItem/SearchProductItem.tsx +10 -3
- package/src/components/search/SearchTop/SearchTop.tsx +30 -24
- package/src/components/search/Sort/Sort.tsx +17 -19
- package/src/components/sections/Alert/Alert.tsx +6 -1
- package/src/components/sections/BannerNewsletter/section.module.scss +6 -4
- package/src/components/sections/BannerText/section.module.scss +5 -3
- package/src/components/sections/Breadcrumb/Breadcrumb.tsx +6 -2
- package/src/components/sections/Breadcrumb/section.module.scss +7 -5
- package/src/components/sections/EmptyState/section.module.scss +5 -3
- package/src/components/sections/Footer/Footer.tsx +1 -5
- package/src/components/sections/Footer/section.module.scss +10 -8
- package/src/components/sections/Hero/Hero.tsx +3 -1
- package/src/components/sections/Hero/section.module.scss +6 -4
- package/src/components/sections/Incentives/section.module.scss +5 -3
- package/src/components/sections/Navbar/Navbar.tsx +45 -0
- package/src/components/sections/Navbar/section.module.scss +34 -33
- package/src/components/sections/Newsletter/section.module.scss +10 -8
- package/src/components/sections/ProductDetails/ProductDetails.tsx +23 -1
- package/src/components/sections/ProductDetails/section.module.scss +32 -30
- package/src/components/sections/ProductGallery/EmptyGallery.tsx +13 -16
- package/src/components/sections/ProductGallery/section.module.scss +42 -39
- package/src/components/sections/ProductShelf/section.module.scss +22 -17
- package/src/components/sections/ProductTiles/section.module.scss +15 -13
- package/src/components/sections/RegionBar/section.module.scss +5 -3
- package/src/components/sections/ScrollToTopButton/ScrollToTopButton.tsx +4 -3
- package/src/components/sections/ScrollToTopButton/section.module.scss +4 -2
- package/src/components/templates/LandingPage/LandingPage.tsx +22 -16
- package/src/components/templates/ProductListingPage/ProductListing.tsx +1 -13
- package/src/components/templates/ProductListingPage/ProductListingPage.tsx +8 -3
- package/src/components/ui/Breadcrumb/Breadcrumb.tsx +14 -11
- package/src/components/ui/Button/ButtonSignIn/ButtonSignIn.tsx +2 -1
- package/src/components/ui/Button/ButtonSignIn/ButtonSignInFallback/ButtonSignInFallback.tsx +3 -1
- package/src/components/ui/Link/Link.tsx +19 -2
- package/src/components/ui/LinkButton/LinkButton.tsx +28 -0
- package/src/components/ui/LinkButton/index.ts +2 -0
- package/src/components/ui/LocalizationButton/LocalizationButton.tsx +124 -0
- package/src/components/ui/LocalizationButton/index.ts +1 -0
- package/src/components/ui/PickupPoints/PickupPointCards.tsx +2 -4
- package/src/components/ui/ProductComparison/ProductComparisonSidebar.tsx +34 -17
- package/src/components/ui/ProductDescription/ProductDescription.tsx +8 -3
- package/src/components/ui/ProductDetails/AddToCartLoadingSkeleton.tsx +6 -2
- package/src/components/ui/ProductDetails/ProductDetailsSettings.tsx +17 -5
- package/src/components/ui/ProductGallery/ProductGallery.tsx +7 -3
- package/src/components/ui/ProductGallery/ProductGalleryPage.tsx +1 -3
- package/src/components/ui/ShippingSimulation/ShippingSimulation.tsx +6 -1
- package/src/customizations/src/styles/custom-mixins.scss +0 -2
- package/src/experimental/index.ts +26 -0
- package/src/experimental/myAccountServerSideProps.ts +11 -2
- package/src/experimental/searchServerSideFunctions/getServerSideProps.ts +13 -7
- package/src/experimental/searchServerSideFunctions/getStaticProps.ts +5 -4
- package/src/instrumentation.ts +20 -6
- package/src/pages/404.tsx +5 -4
- package/src/pages/500.tsx +5 -4
- package/src/pages/[...slug].tsx +7 -4
- package/src/pages/[slug]/p.tsx +26 -8
- package/src/pages/_app.tsx +9 -1
- package/src/pages/api/fs/logout.ts +3 -2
- package/src/pages/api/graphql.ts +7 -23
- package/src/pages/api/preview.ts +21 -8
- package/src/pages/checkout.tsx +15 -5
- package/src/pages/index.tsx +18 -9
- package/src/pages/login.tsx +5 -4
- package/src/pages/pvt/account/403.tsx +11 -2
- package/src/pages/pvt/account/404.tsx +13 -3
- package/src/pages/pvt/account/index.tsx +6 -4
- package/src/pages/pvt/account/orders/[id].tsx +11 -3
- package/src/pages/pvt/account/orders/index.tsx +11 -3
- package/src/pages/pvt/account/profile.tsx +11 -2
- package/src/pages/pvt/account/security.tsx +11 -2
- package/src/pages/pvt/account/user-details.tsx +11 -2
- package/src/pages/s.tsx +26 -6
- package/src/proxy.ts +154 -0
- package/src/sdk/account/refreshToken.ts +4 -4
- package/src/sdk/account/useReorder.ts +8 -2
- package/src/sdk/analytics/platform/vtex/search.ts +3 -2
- package/src/sdk/cart/redirectToCheckout.ts +14 -8
- package/src/sdk/cart/useCheckoutButton.ts +7 -1
- package/src/sdk/deliveryPromise/useDeliveryPromise.ts +10 -18
- package/src/sdk/graphql/request.ts +102 -50
- package/src/sdk/localization/bindingSelector.ts +91 -0
- package/src/sdk/localization/index.ts +4 -0
- package/src/sdk/localization/match-url.ts +64 -0
- package/src/sdk/localization/types.ts +31 -0
- package/src/sdk/localization/useBindingSelector.ts +183 -0
- package/src/sdk/localization/useLocaleValidation.ts +49 -0
- package/src/sdk/localization/useLocalizationConfig.tsx +160 -0
- package/src/sdk/offer/fetcher.ts +3 -2
- package/src/sdk/product/useLocalizedVariables.ts +1 -1
- package/src/sdk/product/usePageProductsQuery.ts +2 -2
- package/src/sdk/product/useProductGalleryQuery.ts +1 -2
- package/src/sdk/product/useProductLink.ts +3 -1
- package/src/sdk/search/formatSearchPath.ts +28 -3
- package/src/sdk/search/state.ts +22 -13
- package/src/sdk/search/useSearchBase.ts +10 -0
- package/src/sdk/search/useSearchHistory.ts +41 -7
- package/src/sdk/session/index.ts +21 -3
- package/src/sdk/shipping/useShippingSimulation.ts +10 -2
- package/src/sdk/tsconfig.json +6 -0
- package/src/sdk/ui/useLink.ts +48 -0
- package/src/server/cms/global.ts +40 -0
- package/src/server/cms/index.ts +18 -10
- package/src/server/cms/pdp.ts +1 -0
- package/src/server/cms/plp.ts +3 -0
- package/src/server/content/service.ts +36 -24
- package/src/server/content/types.ts +10 -3
- package/src/server/index.ts +27 -20
- package/src/server/options.ts +27 -2
- package/src/styles/global/index.scss +10 -7
- package/src/styles/main.scss +3 -3
- package/src/typings/locales.ts +41 -0
- package/src/utils/fetchProductGallerySSR.ts +3 -1
- package/src/utils/getBaseDomain.ts +2 -1
- package/src/utils/getRequestHostname.ts +26 -0
- package/src/utils/globalSettings.ts +11 -0
- package/src/utils/localization/bindingPaths.ts +337 -0
- package/src/utils/localization/validateLocaleForHostname.ts +69 -0
- package/src/utils/localization/withLocaleValidation.ts +36 -0
- package/src/utils/utilities.ts +22 -0
- package/test/pages/api/preview.test.ts +93 -0
- package/test/sdk/localization/bindingSelector.test.ts +246 -0
- package/test/sdk/localization/store-url.browser.test.ts +140 -0
- package/test/sdk/localization/store-url.test.ts +96 -0
- package/test/sdk/localization/useBindingSelector.test.tsx +219 -0
- package/test/sdk/search/useSearchHistory.test.ts +222 -0
- package/test/server/cms/index.test.ts +3 -4
- package/test/server/content/service.test.ts +98 -0
- package/test/server/index.test.ts +10 -22
- package/test/utils/cookieCacheBusting.test.ts +32 -24
- package/test/utils/getRequestHostname.test.ts +71 -0
- package/test/utils/localization/bindingPaths.test.ts +706 -0
- package/test/utils/match-url.test.ts +388 -0
- package/tsconfig.json +11 -3
- package/vitest.config.ts +61 -0
- package/.next/BUILD_ID +0 -1
- package/.next/build-manifest.json +0 -197
- package/.next/cache/.tsbuildinfo +0 -1
- package/.next/cache/config.json +0 -7
- package/.next/cache/webpack/client-production/0.pack +0 -0
- package/.next/cache/webpack/client-production/index.pack +0 -0
- package/.next/cache/webpack/edge-server-production/0.pack +0 -0
- package/.next/cache/webpack/edge-server-production/index.pack +0 -0
- package/.next/cache/webpack/server-production/0.pack +0 -0
- package/.next/cache/webpack/server-production/index.pack +0 -0
- package/.next/export-marker.json +0 -1
- package/.next/images-manifest.json +0 -1
- package/.next/next-minimal-server.js.nft.json +0 -1
- package/.next/next-server.js.nft.json +0 -1
- package/.next/package.json +0 -1
- package/.next/prerender-manifest.js +0 -1
- package/.next/prerender-manifest.json +0 -1
- package/.next/react-loadable-manifest.json +0 -478
- package/.next/required-server-files.json +0 -1
- package/.next/routes-manifest.json +0 -1
- package/.next/server/chunks/1280.js +0 -1
- package/.next/server/chunks/1454.js +0 -1
- package/.next/server/chunks/1554.js +0 -1
- package/.next/server/chunks/1607.js +0 -1
- package/.next/server/chunks/1780.js +0 -1
- package/.next/server/chunks/1917.js +0 -1
- package/.next/server/chunks/1972.js +0 -1
- package/.next/server/chunks/2230.js +0 -1
- package/.next/server/chunks/2249.js +0 -1
- package/.next/server/chunks/2430.js +0 -1
- package/.next/server/chunks/2445.js +0 -12
- package/.next/server/chunks/2570.js +0 -1
- package/.next/server/chunks/2792.js +0 -1
- package/.next/server/chunks/2903.js +0 -1
- package/.next/server/chunks/294.js +0 -1
- package/.next/server/chunks/2955.js +0 -1
- package/.next/server/chunks/3006.js +0 -1
- package/.next/server/chunks/3029.js +0 -1
- package/.next/server/chunks/3060.js +0 -1
- package/.next/server/chunks/3408.js +0 -1
- package/.next/server/chunks/3483.js +0 -1
- package/.next/server/chunks/3683.js +0 -1
- package/.next/server/chunks/3836.js +0 -1
- package/.next/server/chunks/3890.js +0 -494
- package/.next/server/chunks/3922.js +0 -1
- package/.next/server/chunks/3945.js +0 -1
- package/.next/server/chunks/3951.js +0 -7
- package/.next/server/chunks/416.js +0 -1
- package/.next/server/chunks/4194.js +0 -1
- package/.next/server/chunks/4365.js +0 -1
- package/.next/server/chunks/4451.js +0 -1
- package/.next/server/chunks/4803.js +0 -1
- package/.next/server/chunks/4913.js +0 -13
- package/.next/server/chunks/5402.js +0 -1
- package/.next/server/chunks/5723.js +0 -13
- package/.next/server/chunks/5796.js +0 -1
- package/.next/server/chunks/6393.js +0 -1
- package/.next/server/chunks/6457.js +0 -6
- package/.next/server/chunks/6698.js +0 -1
- package/.next/server/chunks/6804.js +0 -6
- package/.next/server/chunks/6886.js +0 -1
- package/.next/server/chunks/7098.js +0 -9
- package/.next/server/chunks/7169.js +0 -1
- package/.next/server/chunks/7228.js +0 -1
- package/.next/server/chunks/7275.js +0 -1
- package/.next/server/chunks/7371.js +0 -1
- package/.next/server/chunks/7692.js +0 -1
- package/.next/server/chunks/7799.js +0 -1
- package/.next/server/chunks/8068.js +0 -1
- package/.next/server/chunks/83.js +0 -1
- package/.next/server/chunks/831.js +0 -1
- package/.next/server/chunks/8563.js +0 -1
- package/.next/server/chunks/8569.js +0 -1
- package/.next/server/chunks/8687.js +0 -1
- package/.next/server/chunks/870.js +0 -1
- package/.next/server/chunks/8737.js +0 -1
- package/.next/server/chunks/8741.js +0 -1
- package/.next/server/chunks/9088.js +0 -1
- package/.next/server/chunks/9117.js +0 -1
- package/.next/server/chunks/9237.js +0 -1
- package/.next/server/chunks/948.js +0 -3
- package/.next/server/chunks/9563.js +0 -3
- package/.next/server/chunks/9570.js +0 -1
- package/.next/server/chunks/9740.js +0 -1
- package/.next/server/chunks/9853.js +0 -1
- package/.next/server/chunks/9984.js +0 -1
- package/.next/server/chunks/9985.js +0 -1
- package/.next/server/chunks/9990.js +0 -1
- package/.next/server/chunks/ButtonSignIn.js +0 -1
- package/.next/server/chunks/Dropdown.js +0 -1
- package/.next/server/chunks/DropdownButton.js +0 -1
- package/.next/server/chunks/DropdownItem.js +0 -1
- package/.next/server/chunks/DropdownMenu.js +0 -1
- package/.next/server/chunks/FilterSkeleton.js +0 -1
- package/.next/server/chunks/ScrollToTopButton.js +0 -1
- package/.next/server/chunks/UIBannerText.js +0 -1
- package/.next/server/chunks/UISKUMatrixSidebar.js +0 -1
- package/.next/server/chunks/font-manifest.json +0 -1
- package/.next/server/edge-instrumentation.js +0 -2
- package/.next/server/edge-instrumentation.js.map +0 -1
- package/.next/server/edge-runtime-webpack.js +0 -157
- package/.next/server/edge-runtime-webpack.js.map +0 -1
- package/.next/server/font-manifest.json +0 -1
- package/.next/server/functions-config-manifest.json +0 -1
- package/.next/server/instrumentation.js +0 -1
- package/.next/server/instrumentation.js.nft.json +0 -1
- package/.next/server/middleware-build-manifest.js +0 -1
- package/.next/server/middleware-manifest.json +0 -6
- package/.next/server/middleware-react-loadable-manifest.js +0 -1
- package/.next/server/next-font-manifest.js +0 -1
- package/.next/server/next-font-manifest.json +0 -1
- package/.next/server/pages/404.js +0 -1
- package/.next/server/pages/404.js.nft.json +0 -1
- package/.next/server/pages/500.js +0 -1
- package/.next/server/pages/500.js.nft.json +0 -1
- package/.next/server/pages/[...slug].js +0 -1
- package/.next/server/pages/[...slug].js.nft.json +0 -1
- package/.next/server/pages/[slug]/p.js +0 -1
- package/.next/server/pages/[slug]/p.js.nft.json +0 -1
- package/.next/server/pages/_app.js +0 -1
- package/.next/server/pages/_app.js.nft.json +0 -1
- package/.next/server/pages/_document.js +0 -1
- package/.next/server/pages/_document.js.nft.json +0 -1
- package/.next/server/pages/_error.js +0 -1
- package/.next/server/pages/_error.js.nft.json +0 -1
- package/.next/server/pages/api/fs/logout.js +0 -1
- package/.next/server/pages/api/fs/logout.js.nft.json +0 -1
- package/.next/server/pages/api/graphql.js +0 -3
- package/.next/server/pages/api/graphql.js.nft.json +0 -1
- package/.next/server/pages/api/health/live.js +0 -1
- package/.next/server/pages/api/health/live.js.nft.json +0 -1
- package/.next/server/pages/api/health/ready.js +0 -1
- package/.next/server/pages/api/health/ready.js.nft.json +0 -1
- package/.next/server/pages/api/preview.js +0 -1
- package/.next/server/pages/api/preview.js.nft.json +0 -1
- package/.next/server/pages/checkout.js +0 -1
- package/.next/server/pages/checkout.js.nft.json +0 -1
- package/.next/server/pages/en-US/404.html +0 -42
- package/.next/server/pages/en-US/404.json +0 -1
- package/.next/server/pages/en-US/500.html +0 -42
- package/.next/server/pages/en-US/500.json +0 -1
- package/.next/server/pages/en-US/checkout.html +0 -42
- package/.next/server/pages/en-US/checkout.json +0 -1
- package/.next/server/pages/en-US/login.html +0 -42
- package/.next/server/pages/en-US/login.json +0 -1
- package/.next/server/pages/en-US/s.html +0 -42
- package/.next/server/pages/en-US/s.json +0 -1
- package/.next/server/pages/en-US.html +0 -42
- package/.next/server/pages/en-US.json +0 -1
- package/.next/server/pages/index.js +0 -1
- package/.next/server/pages/index.js.nft.json +0 -1
- package/.next/server/pages/login.js +0 -1
- package/.next/server/pages/login.js.nft.json +0 -1
- package/.next/server/pages/pvt/account/403.js +0 -1
- package/.next/server/pages/pvt/account/403.js.nft.json +0 -1
- package/.next/server/pages/pvt/account/404.js +0 -1
- package/.next/server/pages/pvt/account/404.js.nft.json +0 -1
- package/.next/server/pages/pvt/account/[...unknown].js +0 -1
- package/.next/server/pages/pvt/account/[...unknown].js.nft.json +0 -1
- package/.next/server/pages/pvt/account/orders/[id].js +0 -1
- package/.next/server/pages/pvt/account/orders/[id].js.nft.json +0 -1
- package/.next/server/pages/pvt/account/orders.js +0 -1
- package/.next/server/pages/pvt/account/orders.js.nft.json +0 -1
- package/.next/server/pages/pvt/account/profile.js +0 -1
- package/.next/server/pages/pvt/account/profile.js.nft.json +0 -1
- package/.next/server/pages/pvt/account/security.js +0 -1
- package/.next/server/pages/pvt/account/security.js.nft.json +0 -1
- package/.next/server/pages/pvt/account/user-details.js +0 -1
- package/.next/server/pages/pvt/account/user-details.js.nft.json +0 -1
- package/.next/server/pages/pvt/account.js +0 -1
- package/.next/server/pages/pvt/account.js.nft.json +0 -1
- package/.next/server/pages/s.js +0 -1
- package/.next/server/pages/s.js.nft.json +0 -1
- package/.next/server/pages-manifest.json +0 -1
- package/.next/server/webpack-api-runtime.js +0 -1
- package/.next/server/webpack-runtime.js +0 -1
- package/.next/static/NAuY8lqaeBBZf9CMZuYI2/_buildManifest.js +0 -1
- package/.next/static/NAuY8lqaeBBZf9CMZuYI2/_ssgManifest.js +0 -1
- package/.next/static/chunks/227-f109b24190a008ab.js +0 -8
- package/.next/static/chunks/2284.185d834d9829b652.js +0 -1
- package/.next/static/chunks/2851.e68ed3c8d27a032a.js +0 -1
- package/.next/static/chunks/2927.5a79877943a6bf7c.js +0 -1
- package/.next/static/chunks/3155.7bc4c730a79d9ecb.js +0 -1
- package/.next/static/chunks/3166-0b30a3887c0c346d.js +0 -1
- package/.next/static/chunks/3399.017c5209b74b0d97.js +0 -1
- package/.next/static/chunks/3483.ef53d632a763da3f.js +0 -1
- package/.next/static/chunks/349.b3b38e1e9f719dda.js +0 -1
- package/.next/static/chunks/3802.5e8b0b689eacc0f8.js +0 -1
- package/.next/static/chunks/3836.620480018be48233.js +0 -1
- package/.next/static/chunks/4436.e7af66f0b654ee36.js +0 -1
- package/.next/static/chunks/4803.b1920b6e3a1a6304.js +0 -1
- package/.next/static/chunks/5796.4351370494d8b8b6.js +0 -1
- package/.next/static/chunks/6393.55f991b1a6bb4fe7.js +0 -1
- package/.next/static/chunks/6700.b23221a57514e737.js +0 -1
- package/.next/static/chunks/6789.960162355435a81d.js +0 -1
- package/.next/static/chunks/7191-befad64ba238a817.js +0 -1
- package/.next/static/chunks/7692.8d5bf4560341a2f6.js +0 -1
- package/.next/static/chunks/7861.7f9f1a124a43da30.js +0 -6
- package/.next/static/chunks/8068.43663fb64762f7b8.js +0 -1
- package/.next/static/chunks/83.e0c16f0299b364a5.js +0 -1
- package/.next/static/chunks/8325.dabe9aa22eaadeed.js +0 -1
- package/.next/static/chunks/8587.53c8ce185ed1a2cb.js +0 -1
- package/.next/static/chunks/9173-e89da04079c35360.js +0 -2
- package/.next/static/chunks/9237.7555603703f81bf7.js +0 -1
- package/.next/static/chunks/9298-1d1ed0a54133cb59.js +0 -28
- package/.next/static/chunks/9399.d116a7fd62024783.js +0 -1
- package/.next/static/chunks/941.3e2782ab9c490eb0.js +0 -1
- package/.next/static/chunks/9701.f9a0bfffba8807dc.js +0 -1
- package/.next/static/chunks/9909.787576b171184aa5.js +0 -1
- package/.next/static/chunks/9960.7ef77f8a8b046170.js +0 -1
- package/.next/static/chunks/9979.aedbc094bdc2c599.js +0 -1
- package/.next/static/chunks/BannerNewsletter.00328ad162109908.js +0 -1
- package/.next/static/chunks/BannerText.dbbec87cadb8a521.js +0 -1
- package/.next/static/chunks/ButtonSignIn.f6e210eaca873e48.js +0 -1
- package/.next/static/chunks/CartItem.b34e295377f6f94f.js +0 -1
- package/.next/static/chunks/CartSidebar.ac447d1ef6276da1.js +0 -1
- package/.next/static/chunks/Dropdown.38b48c749bad6b60.js +0 -1
- package/.next/static/chunks/DropdownButton.66fa6b25dddb3a07.js +0 -1
- package/.next/static/chunks/DropdownItem.38b8f5a07c7f422a.js +0 -1
- package/.next/static/chunks/DropdownMenu.48b11521a24c6efd.js +0 -1
- package/.next/static/chunks/EmptyCart.320e2f94a0d5e6b1.js +0 -1
- package/.next/static/chunks/FilterSkeleton.7ab99e28f92341c9.js +0 -1
- package/.next/static/chunks/Footer.166b02c2f13980c6.js +0 -1
- package/.next/static/chunks/Gift.c49ba26da2fbab5e.js +0 -1
- package/.next/static/chunks/Newsletter.fc406f6029057022.js +0 -1
- package/.next/static/chunks/OrderSummary.5957d69f990d9add.js +0 -1
- package/.next/static/chunks/PreviewTag.f4f0c8710a7bcad9.js +0 -1
- package/.next/static/chunks/ProductShelf.cc46f5cdeeaeaff6.js +0 -1
- package/.next/static/chunks/ProductTiles.9b804e51b0704d60.js +0 -1
- package/.next/static/chunks/RegionModal.319ad44250cb12d2.js +0 -1
- package/.next/static/chunks/RegionSlider.0e0e93369f4f9c92.js +0 -1
- package/.next/static/chunks/ScrollToTopButton.c15431f2e8bb93ef.js +0 -1
- package/.next/static/chunks/ShoppingAssistant.ba191eb4dbed67e5.js +0 -1
- package/.next/static/chunks/Toast.5f90f0436708be5e.js +0 -1
- package/.next/static/chunks/UIBannerText.7315b16af4457059.js +0 -1
- package/.next/static/chunks/UISKUMatrixSidebar.b4349b2682bbe183.js +0 -1
- package/.next/static/chunks/UIToast.19a8664c01a00d3a.js +0 -1
- package/.next/static/chunks/framework-d514426edf885c68.js +0 -33
- package/.next/static/chunks/main-ec03882c4375091d.js +0 -1
- package/.next/static/chunks/pages/404-e3dfbbac003b02a2.js +0 -1
- package/.next/static/chunks/pages/500-c7814e085081d7b8.js +0 -1
- package/.next/static/chunks/pages/[...slug]-dc8a395a43b081f1.js +0 -1
- package/.next/static/chunks/pages/[slug]/p-644f1132f5a0f736.js +0 -1
- package/.next/static/chunks/pages/_app-84aaff8a9d4de60e.js +0 -1
- package/.next/static/chunks/pages/_error-2b0148be56a716e9.js +0 -1
- package/.next/static/chunks/pages/checkout-2071467ad42dfb99.js +0 -1
- package/.next/static/chunks/pages/index-8774d5b4a8744eb2.js +0 -1
- package/.next/static/chunks/pages/login-e74747c9f9cb5b49.js +0 -1
- package/.next/static/chunks/pages/pvt/account/403-491e6b062487b30f.js +0 -1
- package/.next/static/chunks/pages/pvt/account/404-5ad472d9f2ee1980.js +0 -1
- package/.next/static/chunks/pages/pvt/account/[...unknown]-f80f645594d2740c.js +0 -1
- package/.next/static/chunks/pages/pvt/account/orders/[id]-64e42157c0974c48.js +0 -1
- package/.next/static/chunks/pages/pvt/account/orders-faab39f2aff05fae.js +0 -1
- package/.next/static/chunks/pages/pvt/account/profile-9672177ee2665bc0.js +0 -1
- package/.next/static/chunks/pages/pvt/account/security-03eb1ccab9a30563.js +0 -1
- package/.next/static/chunks/pages/pvt/account/user-details-7838e3f79781596c.js +0 -1
- package/.next/static/chunks/pages/pvt/account-65fefcc699344bdb.js +0 -1
- package/.next/static/chunks/pages/s-162ba789e6611175.js +0 -1
- package/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +0 -1
- package/.next/static/chunks/webpack-f621ff3e951d2982.js +0 -1
- package/.next/static/css/02259c549b2179f2.css +0 -1
- package/.next/static/css/02eaf202d3d11fd1.css +0 -1
- package/.next/static/css/033e241c58ba6fbb.css +0 -1
- package/.next/static/css/042d012bc1895b5c.css +0 -1
- package/.next/static/css/14176a4704ff97b2.css +0 -1
- package/.next/static/css/146a8678babc61bf.css +0 -1
- package/.next/static/css/16d65422bfa80f51.css +0 -1
- package/.next/static/css/1c4983f11b861ea0.css +0 -1
- package/.next/static/css/204754bbd8cc4bef.css +0 -1
- package/.next/static/css/24d91007fc96be10.css +0 -1
- package/.next/static/css/2980acad3f8e1028.css +0 -1
- package/.next/static/css/2c19433e38fd7533.css +0 -1
- package/.next/static/css/31380ebc6e671486.css +0 -1
- package/.next/static/css/42df884711219edb.css +0 -1
- package/.next/static/css/4f0597b0bf0ef2e1.css +0 -1
- package/.next/static/css/54cedf4b65e5863f.css +0 -1
- package/.next/static/css/6580147d7ab8fcca.css +0 -1
- package/.next/static/css/6819dddf2b1b5ea7.css +0 -1
- package/.next/static/css/7ef7762f412ed665.css +0 -1
- package/.next/static/css/82f3cd529b672812.css +0 -1
- package/.next/static/css/837662922091162f.css +0 -1
- package/.next/static/css/8e6ab59ace21e03b.css +0 -1
- package/.next/static/css/a852afa9be31e946.css +0 -1
- package/.next/static/css/b684b347c5cc6514.css +0 -1
- package/.next/static/css/bcdaef0a83277ef5.css +0 -1
- package/.next/static/css/c33615999008d3f9.css +0 -1
- package/.next/static/css/c34f6ea9953e2f63.css +0 -1
- package/.next/static/css/ea11d74a2848b093.css +0 -1
- package/.next/static/css/f16438bcf4508fb3.css +0 -1
- package/.next/static/css/f60366555f563deb.css +0 -1
- package/.next/trace +0 -143
- package/.turbo/turbo-build.log +0 -140
- package/jest.config.js +0 -17
- package/public/~partytown/debug/partytown-atomics.js +0 -556
- package/public/~partytown/debug/partytown-media.js +0 -374
- package/public/~partytown/debug/partytown-sandbox-sw.js +0 -543
- package/public/~partytown/debug/partytown-sw.js +0 -59
- package/public/~partytown/debug/partytown-ww-atomics.js +0 -1789
- package/public/~partytown/debug/partytown-ww-sw.js +0 -1781
- package/public/~partytown/debug/partytown.js +0 -72
- package/public/~partytown/partytown-atomics.js +0 -2
- package/public/~partytown/partytown-media.js +0 -2
- package/public/~partytown/partytown-sw.js +0 -2
- package/public/~partytown/partytown.js +0 -2
- package/src/middleware__DISABLED.ts +0 -65
- package/src/server/generator/generateGraphQLSchemaFile.ts +0 -3
- package/src/server/generator/schema.ts +0 -81
|
@@ -17,15 +17,19 @@ import styles from './section.module.scss'
|
|
|
17
17
|
interface BreadcrumbSectionProps {
|
|
18
18
|
icon: string
|
|
19
19
|
alt: string
|
|
20
|
+
fallbackLabel: string
|
|
20
21
|
}
|
|
21
22
|
|
|
22
|
-
function BreadcrumbSection({
|
|
23
|
+
function BreadcrumbSection({
|
|
24
|
+
fallbackLabel,
|
|
25
|
+
...otherProps
|
|
26
|
+
}: BreadcrumbSectionProps) {
|
|
23
27
|
const { Breadcrumb } = useOverrideComponents<'Breadcrumb'>()
|
|
24
28
|
|
|
25
29
|
const context = usePage<PDPContext | PLPContext>()
|
|
26
30
|
const title = isPLP(context)
|
|
27
31
|
? context?.data?.collection?.seo?.title
|
|
28
|
-
:
|
|
32
|
+
: fallbackLabel
|
|
29
33
|
const fallback = [{ item: '/', name: title, position: 1 }]
|
|
30
34
|
|
|
31
35
|
const breadcrumbList = isPDP(context)
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
+
@use "sass:meta";
|
|
2
|
+
|
|
1
3
|
@layer components {
|
|
2
4
|
.section {
|
|
3
|
-
@
|
|
4
|
-
@
|
|
5
|
-
@
|
|
6
|
-
@
|
|
7
|
-
@
|
|
5
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Button/styles.scss");
|
|
6
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Icon/styles.scss");
|
|
7
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Link/styles.scss");
|
|
8
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/List/styles.scss");
|
|
9
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Breadcrumb/styles.scss");
|
|
8
10
|
}
|
|
9
11
|
}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
+
@use "sass:meta";
|
|
2
|
+
|
|
1
3
|
@layer components {
|
|
2
4
|
.section {
|
|
3
|
-
@
|
|
4
|
-
@
|
|
5
|
-
@
|
|
5
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Icon/styles.scss");
|
|
6
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Loader/styles.scss");
|
|
7
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/EmptyState/styles.scss");
|
|
6
8
|
}
|
|
7
9
|
}
|
|
@@ -53,7 +53,6 @@ const Footer = ({
|
|
|
53
53
|
paymentMethods,
|
|
54
54
|
},
|
|
55
55
|
}: FooterProps) => {
|
|
56
|
-
const homeLabel = 'Go to Home'
|
|
57
56
|
return (
|
|
58
57
|
<Section
|
|
59
58
|
className={`section ${styles.section} section-footer layout__section`}
|
|
@@ -68,10 +67,7 @@ const Footer = ({
|
|
|
68
67
|
/>
|
|
69
68
|
</UIFooterNavigation>
|
|
70
69
|
<UIFooterInfo>
|
|
71
|
-
<Link
|
|
72
|
-
href={logoLink ? logoLink.url : '/'}
|
|
73
|
-
title={logoLink ? logoLink.title : homeLabel}
|
|
74
|
-
>
|
|
70
|
+
<Link href={logoLink?.url} title={logoLink?.title}>
|
|
75
71
|
<Logo alt={logoAlt} src={logoSrc} />
|
|
76
72
|
</Link>
|
|
77
73
|
|
|
@@ -1,14 +1,16 @@
|
|
|
1
|
+
@use "sass:meta";
|
|
2
|
+
|
|
1
3
|
@layer components {
|
|
2
4
|
.section {
|
|
3
5
|
margin-bottom: 0;
|
|
4
6
|
|
|
5
|
-
@
|
|
6
|
-
@
|
|
7
|
-
@
|
|
8
|
-
@
|
|
9
|
-
@
|
|
10
|
-
@
|
|
11
|
-
@
|
|
12
|
-
@
|
|
7
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Button/styles.scss");
|
|
8
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Link/styles.scss");
|
|
9
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/List/styles.scss");
|
|
10
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Logo/styles.scss");
|
|
11
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Accordion/styles.scss");
|
|
12
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/PaymentMethods/styles.scss");
|
|
13
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/Incentives/styles.scss");
|
|
14
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/Footer/styles.scss");
|
|
13
15
|
}
|
|
14
16
|
}
|
|
@@ -12,6 +12,7 @@ import Section from '../Section'
|
|
|
12
12
|
import styles from './section.module.scss'
|
|
13
13
|
import { HeroDefaultComponents } from './DefaultComponents'
|
|
14
14
|
import { getOverridableSection } from '../../../sdk/overrides/getOverriddenSection'
|
|
15
|
+
import { useLink } from '../../../sdk/ui/useLink'
|
|
15
16
|
|
|
16
17
|
export type HeroProps = {
|
|
17
18
|
title: UIHeroHeaderProps['title']
|
|
@@ -44,6 +45,7 @@ const Hero = ({
|
|
|
44
45
|
HeroImage,
|
|
45
46
|
HeroHeader,
|
|
46
47
|
} = useOverrideComponents<'Hero'>()
|
|
48
|
+
const { resolveLink } = useLink()
|
|
47
49
|
|
|
48
50
|
return (
|
|
49
51
|
<Section className={`${styles.section} section-hero`}>
|
|
@@ -66,7 +68,7 @@ const Hero = ({
|
|
|
66
68
|
<HeroHeader.Component
|
|
67
69
|
title={title}
|
|
68
70
|
subtitle={subtitle}
|
|
69
|
-
link={link?.url}
|
|
71
|
+
link={resolveLink(link?.url)}
|
|
70
72
|
linkText={link?.text}
|
|
71
73
|
linkTargetBlank={link?.linkTargetBlank}
|
|
72
74
|
icon={icon}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
|
+
@use "sass:meta";
|
|
2
|
+
|
|
1
3
|
@layer components {
|
|
2
4
|
.section {
|
|
3
|
-
@
|
|
4
|
-
@
|
|
5
|
-
@
|
|
6
|
-
@
|
|
5
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/Hero/styles.scss");
|
|
6
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/LinkButton/styles.scss");
|
|
7
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Icon/styles.scss");
|
|
8
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Button/styles.scss");
|
|
7
9
|
}
|
|
8
10
|
}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
+
@use "sass:meta";
|
|
2
|
+
|
|
1
3
|
@layer components {
|
|
2
4
|
.section {
|
|
3
5
|
margin-top: 0;
|
|
4
6
|
|
|
5
|
-
@
|
|
6
|
-
@
|
|
7
|
-
@
|
|
7
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Icon/styles.scss");
|
|
8
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/List/styles.scss");
|
|
9
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/Incentives/styles.scss");
|
|
8
10
|
}
|
|
9
11
|
}
|
|
@@ -23,8 +23,16 @@ export interface NavbarProps {
|
|
|
23
23
|
searchInput: {
|
|
24
24
|
placeholder?: string
|
|
25
25
|
sort: string
|
|
26
|
+
submitButtonAriaLabel?: string
|
|
27
|
+
searchHistoryTitle?: string
|
|
28
|
+
searchTopTitle?: string
|
|
29
|
+
collapseSearchAriaLabel?: string
|
|
26
30
|
quickOrderSettings?: {
|
|
27
31
|
quickOrder: boolean
|
|
32
|
+
invalidQuantityToastLabels?: {
|
|
33
|
+
title?: string
|
|
34
|
+
message?: string
|
|
35
|
+
}
|
|
28
36
|
attachmentButton?: {
|
|
29
37
|
icon: {
|
|
30
38
|
icon: string
|
|
@@ -45,6 +53,7 @@ export interface NavbarProps {
|
|
|
45
53
|
}
|
|
46
54
|
}
|
|
47
55
|
}
|
|
56
|
+
outOfStockLabel?: string
|
|
48
57
|
drawer?: {
|
|
49
58
|
defaultTitle?: string
|
|
50
59
|
columns?: {
|
|
@@ -106,6 +115,7 @@ export interface NavbarProps {
|
|
|
106
115
|
>
|
|
107
116
|
}
|
|
108
117
|
}
|
|
118
|
+
loadingLabel?: string
|
|
109
119
|
}
|
|
110
120
|
signInButton: {
|
|
111
121
|
icon: {
|
|
@@ -128,6 +138,19 @@ export interface NavbarProps {
|
|
|
128
138
|
}
|
|
129
139
|
label: string
|
|
130
140
|
}
|
|
141
|
+
localizationButton?: {
|
|
142
|
+
shouldDisplayLocalizationButton: boolean
|
|
143
|
+
icon: {
|
|
144
|
+
icon: string
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
localizationSelector: {
|
|
148
|
+
title?: string
|
|
149
|
+
languageLabel?: string
|
|
150
|
+
currencyLabel?: string
|
|
151
|
+
description?: string
|
|
152
|
+
saveLabel?: string
|
|
153
|
+
}
|
|
131
154
|
pageLinks: PageLinks[]
|
|
132
155
|
menu: {
|
|
133
156
|
icon: {
|
|
@@ -155,6 +178,17 @@ function NavbarSection({
|
|
|
155
178
|
icon: { icon: regionIcon },
|
|
156
179
|
enabled: shouldDisplayRegion,
|
|
157
180
|
},
|
|
181
|
+
localizationButton: {
|
|
182
|
+
icon: { icon: localizationIcon },
|
|
183
|
+
shouldDisplayLocalizationButton,
|
|
184
|
+
} = { icon: { icon: '' }, shouldDisplayLocalizationButton: false },
|
|
185
|
+
localizationSelector: {
|
|
186
|
+
title: localizationTitle,
|
|
187
|
+
languageLabel: localizationLanguageLabel,
|
|
188
|
+
currencyLabel: localizationCurrencyLabel,
|
|
189
|
+
description: localizationDescription,
|
|
190
|
+
saveLabel: localizationSaveLabel,
|
|
191
|
+
} = {},
|
|
158
192
|
},
|
|
159
193
|
}: NavbarProps) {
|
|
160
194
|
return (
|
|
@@ -172,6 +206,17 @@ function NavbarSection({
|
|
|
172
206
|
label: regionLabel,
|
|
173
207
|
shouldDisplayRegion,
|
|
174
208
|
}}
|
|
209
|
+
localizationButton={{
|
|
210
|
+
icon: localizationIcon,
|
|
211
|
+
shouldDisplayLocalizationButton,
|
|
212
|
+
}}
|
|
213
|
+
localizationSelector={{
|
|
214
|
+
title: localizationTitle,
|
|
215
|
+
languageLabel: localizationLanguageLabel,
|
|
216
|
+
currencyLabel: localizationCurrencyLabel,
|
|
217
|
+
description: localizationDescription,
|
|
218
|
+
saveLabel: localizationSaveLabel,
|
|
219
|
+
}}
|
|
175
220
|
/>
|
|
176
221
|
</Section>
|
|
177
222
|
)
|
|
@@ -1,46 +1,47 @@
|
|
|
1
|
+
@use "@faststore/ui/src/styles/base/utilities";
|
|
2
|
+
@use "sass:meta";
|
|
3
|
+
|
|
1
4
|
@layer components {
|
|
2
5
|
.section {
|
|
3
6
|
position: sticky;
|
|
4
7
|
top: 0;
|
|
5
8
|
z-index: var(--fs-z-index-high);
|
|
6
9
|
|
|
7
|
-
@
|
|
8
|
-
@
|
|
9
|
-
@
|
|
10
|
-
@
|
|
11
|
-
@
|
|
12
|
-
@
|
|
13
|
-
@
|
|
14
|
-
@
|
|
15
|
-
@
|
|
16
|
-
@
|
|
17
|
-
@
|
|
18
|
-
@
|
|
19
|
-
@
|
|
20
|
-
@
|
|
21
|
-
@
|
|
22
|
-
@
|
|
23
|
-
@
|
|
24
|
-
@
|
|
25
|
-
@
|
|
26
|
-
@
|
|
27
|
-
@
|
|
28
|
-
@
|
|
29
|
-
@
|
|
30
|
-
@
|
|
31
|
-
@
|
|
32
|
-
@
|
|
33
|
-
@
|
|
34
|
-
@
|
|
35
|
-
@
|
|
36
|
-
@
|
|
37
|
-
@import "@faststore/ui/src/components/organisms/SKUMatrix/styles.scss";
|
|
38
|
-
@import "@faststore/ui/src/components/organisms/QuickOrderDrawer/styles.scss";
|
|
10
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Badge/styles.scss");
|
|
11
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Button/styles.scss");
|
|
12
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Icon/styles.scss");
|
|
13
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Loader/styles.scss");
|
|
14
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Input/styles.scss");
|
|
15
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Link/styles.scss");
|
|
16
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/List/styles.scss");
|
|
17
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Logo/styles.scss");
|
|
18
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Overlay/styles.scss");
|
|
19
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Price/styles.scss");
|
|
20
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/InputField/styles.scss");
|
|
21
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/LinkButton/styles.scss");
|
|
22
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/QuantitySelector/styles.scss");
|
|
23
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/NavbarLinks/styles.scss");
|
|
24
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Popover/styles.scss");
|
|
25
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/ProductPrice/styles.scss");
|
|
26
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/RegionPopover/styles.scss");
|
|
27
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/SearchAutoComplete/styles.scss");
|
|
28
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/SearchDropdown/styles.scss");
|
|
29
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/SearchHistory/styles.scss");
|
|
30
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/SearchInputField/styles.scss");
|
|
31
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/SearchProducts/styles.scss");
|
|
32
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/SearchTop/styles.scss");
|
|
33
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/SkuSelector/styles.scss");
|
|
34
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Table/styles.scss");
|
|
35
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/SearchInput/styles.scss");
|
|
36
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/Navbar/styles.scss");
|
|
37
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/SlideOver/styles.scss");
|
|
38
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/SKUMatrix/styles.scss");
|
|
39
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/QuickOrderDrawer/styles.scss");
|
|
39
40
|
|
|
40
41
|
// Sets Navbar height on desktop to avoid CLS issue - Cumulative Layout Shift
|
|
41
42
|
--fs-navbar-height-desktop: 4.5rem;
|
|
42
43
|
|
|
43
|
-
@include media(">=notebook") {
|
|
44
|
+
@include utilities.media(">=notebook") {
|
|
44
45
|
height: var(--fs-navbar-height-desktop);
|
|
45
46
|
|
|
46
47
|
// Sets margin to avoid overlapping the section below
|
|
@@ -1,12 +1,14 @@
|
|
|
1
|
+
@use "sass:meta";
|
|
2
|
+
|
|
1
3
|
@layer components {
|
|
2
4
|
.section {
|
|
3
|
-
@
|
|
4
|
-
@
|
|
5
|
-
@
|
|
6
|
-
@
|
|
7
|
-
@
|
|
8
|
-
@
|
|
9
|
-
@
|
|
10
|
-
@
|
|
5
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Button/styles.scss");
|
|
6
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Icon/styles.scss");
|
|
7
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Input/styles.scss");
|
|
8
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Link/styles.scss");
|
|
9
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/List/styles.scss");
|
|
10
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/RichText/styles.scss");
|
|
11
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/InputField/styles.scss");
|
|
12
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/Newsletter/styles.scss");
|
|
11
13
|
}
|
|
12
14
|
}
|
|
@@ -6,6 +6,7 @@ import { gql } from '@generated'
|
|
|
6
6
|
import type { AnalyticsItem } from 'src/sdk/analytics/types'
|
|
7
7
|
import { useFormattedPrice } from 'src/sdk/product/useFormattedPrice'
|
|
8
8
|
import { useSession } from 'src/sdk/session'
|
|
9
|
+
import { getGlobalSettings } from 'src/utils/globalSettings'
|
|
9
10
|
|
|
10
11
|
import Section from '../Section'
|
|
11
12
|
|
|
@@ -35,6 +36,7 @@ export interface ProductDetailsProps {
|
|
|
35
36
|
showDiscountBadge: boolean
|
|
36
37
|
}
|
|
37
38
|
}
|
|
39
|
+
loadingLabel: string
|
|
38
40
|
buyButton: {
|
|
39
41
|
title: string
|
|
40
42
|
icon: {
|
|
@@ -55,12 +57,17 @@ export interface ProductDetailsProps {
|
|
|
55
57
|
title: string
|
|
56
58
|
displayDescription: boolean
|
|
57
59
|
initiallyExpanded: 'first' | 'all' | 'none'
|
|
60
|
+
accordionAriaLabel?: string
|
|
58
61
|
}
|
|
59
62
|
notAvailableButton: {
|
|
60
63
|
title: string
|
|
61
64
|
}
|
|
62
65
|
quantitySelector: {
|
|
63
66
|
useUnitMultiplier?: boolean
|
|
67
|
+
invalidQuantityToastLabels?: {
|
|
68
|
+
title?: string
|
|
69
|
+
message?: string
|
|
70
|
+
}
|
|
64
71
|
}
|
|
65
72
|
taxesConfiguration?: {
|
|
66
73
|
usePriceWithTaxes?: boolean
|
|
@@ -88,6 +95,7 @@ function ProductDetails({
|
|
|
88
95
|
refNumber: showRefNumber,
|
|
89
96
|
discountBadge: { showDiscountBadge, size: discountBadgeSize },
|
|
90
97
|
},
|
|
98
|
+
loadingLabel,
|
|
91
99
|
buyButton: { icon: buyButtonIcon, title: buyButtonTitle },
|
|
92
100
|
shippingSimulator: {
|
|
93
101
|
title: shippingSimulatorTitle,
|
|
@@ -99,6 +107,7 @@ function ProductDetails({
|
|
|
99
107
|
title: productDescriptionDetailsTitle,
|
|
100
108
|
initiallyExpanded: productDescriptionInitiallyExpanded,
|
|
101
109
|
displayDescription: shouldDisplayProductDescription,
|
|
110
|
+
accordionAriaLabel: productDescriptionAccordionAriaLabel,
|
|
102
111
|
},
|
|
103
112
|
skuMatrix,
|
|
104
113
|
notAvailableButton: { title: notAvailableButtonTitle },
|
|
@@ -121,6 +130,10 @@ function ProductDetails({
|
|
|
121
130
|
const context = usePDP()
|
|
122
131
|
const { product, isValidating } = context?.data
|
|
123
132
|
const [quantity, setQuantity] = useState(1)
|
|
133
|
+
const cmsData = getGlobalSettings()
|
|
134
|
+
const {
|
|
135
|
+
inputField: { errorMessage: inputFieldErrorMessage = '' } = {},
|
|
136
|
+
} = cmsData?.regionalization ?? {}
|
|
124
137
|
if (!product) {
|
|
125
138
|
throw new Error('NotFound')
|
|
126
139
|
}
|
|
@@ -232,7 +245,7 @@ function ProductDetails({
|
|
|
232
245
|
data-fs-product-details-settings
|
|
233
246
|
data-fs-product-details-section
|
|
234
247
|
>
|
|
235
|
-
<p>
|
|
248
|
+
<p>{loadingLabel}</p>
|
|
236
249
|
</section>
|
|
237
250
|
</section>
|
|
238
251
|
) : (
|
|
@@ -250,6 +263,7 @@ function ProductDetails({
|
|
|
250
263
|
useUnitMultiplier={
|
|
251
264
|
quantitySelector?.useUnitMultiplier ?? false
|
|
252
265
|
}
|
|
266
|
+
loadingLabel={loadingLabel}
|
|
253
267
|
{...ProductDetailsSettings.props}
|
|
254
268
|
// Dynamic props shouldn't be overridable
|
|
255
269
|
// This decision can be reviewed later if needed
|
|
@@ -258,6 +272,9 @@ function ProductDetails({
|
|
|
258
272
|
product={product}
|
|
259
273
|
isValidating={isValidating}
|
|
260
274
|
taxesConfiguration={taxesConfiguration}
|
|
275
|
+
invalidQuantityToastLabels={
|
|
276
|
+
quantitySelector?.invalidQuantityToastLabels
|
|
277
|
+
}
|
|
261
278
|
/>
|
|
262
279
|
|
|
263
280
|
{skuMatrix?.shouldDisplaySKUMatrix &&
|
|
@@ -276,6 +293,9 @@ function ProductDetails({
|
|
|
276
293
|
formatter={useFormattedPrice}
|
|
277
294
|
columns={skuMatrix.columns}
|
|
278
295
|
overlayProps={{ className: styles.section }}
|
|
296
|
+
invalidQuantityToastLabels={
|
|
297
|
+
quantitySelector?.invalidQuantityToastLabels
|
|
298
|
+
}
|
|
279
299
|
/>
|
|
280
300
|
</SKUMatrix.Component>
|
|
281
301
|
</>
|
|
@@ -313,6 +333,7 @@ function ProductDetails({
|
|
|
313
333
|
shippingSimulatorOptionsTableTitle ??
|
|
314
334
|
ShippingSimulation.props.optionsLabel
|
|
315
335
|
}
|
|
336
|
+
invalidPostalCodeErrorMessage={inputFieldErrorMessage}
|
|
316
337
|
/>
|
|
317
338
|
)}
|
|
318
339
|
</section>
|
|
@@ -324,6 +345,7 @@ function ProductDetails({
|
|
|
324
345
|
productDescriptionInitiallyExpanded ??
|
|
325
346
|
ProductDescription.props.initiallyExpanded
|
|
326
347
|
}
|
|
348
|
+
accordionAriaLabel={productDescriptionAccordionAriaLabel}
|
|
327
349
|
descriptionData={[
|
|
328
350
|
{ content: description, title: productDescriptionDetailsTitle },
|
|
329
351
|
]}
|
|
@@ -1,40 +1,42 @@
|
|
|
1
|
+
@use "sass:meta";
|
|
2
|
+
|
|
1
3
|
@layer components {
|
|
2
4
|
.section {
|
|
3
5
|
// Taxes label
|
|
4
|
-
--fs-product-details-taxes-label-color
|
|
5
|
-
--fs-product-details-taxes-text-size
|
|
6
|
-
--fs-product-details-taxes-text-weight
|
|
6
|
+
--fs-product-details-taxes-label-color: var(--fs-color-info-text);
|
|
7
|
+
--fs-product-details-taxes-text-size: var(--fs-text-size-tiny);
|
|
8
|
+
--fs-product-details-taxes-text-weight: var(--fs-text-weight-regular);
|
|
7
9
|
|
|
8
10
|
// Separator colors
|
|
9
|
-
--fs-product-details-separator-color
|
|
10
|
-
--fs-product-details-separator-color-text
|
|
11
|
+
--fs-product-details-separator-color: var(--fs-color-neutral-2);
|
|
12
|
+
--fs-product-details-separator-color-text: var(--fs-color-text-light);
|
|
11
13
|
|
|
12
14
|
margin-top: 0;
|
|
13
15
|
|
|
14
|
-
@
|
|
15
|
-
@
|
|
16
|
-
@
|
|
17
|
-
@
|
|
18
|
-
@
|
|
19
|
-
@
|
|
20
|
-
@
|
|
21
|
-
@
|
|
22
|
-
@
|
|
23
|
-
@
|
|
24
|
-
@
|
|
25
|
-
@
|
|
26
|
-
@
|
|
27
|
-
@
|
|
28
|
-
@
|
|
29
|
-
@
|
|
30
|
-
@
|
|
31
|
-
@
|
|
32
|
-
@
|
|
33
|
-
@
|
|
34
|
-
@
|
|
35
|
-
@
|
|
36
|
-
@
|
|
37
|
-
@
|
|
16
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Icon/styles.scss");
|
|
17
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Link/styles.scss");
|
|
18
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/List/styles.scss");
|
|
19
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Badge/styles.scss");
|
|
20
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Button/styles.scss");
|
|
21
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Input/styles.scss");
|
|
22
|
+
@include meta.load-css("~@faststore/ui/src/components/atoms/Price/styles.scss");
|
|
23
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Accordion/styles.scss");
|
|
24
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Breadcrumb/styles.scss");
|
|
25
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/BuyButton/styles.scss");
|
|
26
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/DiscountBadge/styles.scss");
|
|
27
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Dropdown/styles.scss");
|
|
28
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/InputField/styles.scss");
|
|
29
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/LinkButton/styles.scss");
|
|
30
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Rating/styles.scss");
|
|
31
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/ProductTitle/styles.scss");
|
|
32
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/QuantitySelector/styles.scss");
|
|
33
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/SkuSelector/styles.scss");
|
|
34
|
+
@include meta.load-css("~@faststore/ui/src/components/molecules/Table/styles.scss");
|
|
35
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/ShippingSimulation/styles.scss");
|
|
36
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/ImageGallery/styles.scss");
|
|
37
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/ProductDetails/styles.scss");
|
|
38
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/SlideOver/styles.scss");
|
|
39
|
+
@include meta.load-css("~@faststore/ui/src/components/organisms/SKUMatrix/styles.scss");
|
|
38
40
|
|
|
39
41
|
[data-fs-product-details-taxes-label] {
|
|
40
42
|
font-size: var(--fs-product-details-taxes-text-size);
|
|
@@ -67,7 +69,7 @@
|
|
|
67
69
|
}
|
|
68
70
|
|
|
69
71
|
[data-fs-sku-matrix] {
|
|
70
|
-
>
|
|
72
|
+
>[data-fs-button] {
|
|
71
73
|
width: 100%;
|
|
72
74
|
}
|
|
73
75
|
}
|
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
LinkButton as UILinkButton,
|
|
4
|
-
EmptyState as UIEmptyState,
|
|
5
|
-
} from '@faststore/ui'
|
|
1
|
+
import { Icon as UIIcon, EmptyState as UIEmptyState } from '@faststore/ui'
|
|
2
|
+
import LinkButton from 'src/components/ui/LinkButton'
|
|
6
3
|
|
|
7
4
|
export interface EmptyGalleryProps {
|
|
8
5
|
title?: string
|
|
@@ -22,17 +19,17 @@ function EmptyGallery({ title, firstButton, secondButton }: EmptyGalleryProps) {
|
|
|
22
19
|
return (
|
|
23
20
|
<UIEmptyState
|
|
24
21
|
variant="rounded"
|
|
25
|
-
title={title
|
|
22
|
+
title={title}
|
|
26
23
|
titleIcon={
|
|
27
24
|
<UIIcon name="CircleWavyWarning" width={56} height={56} weight="thin" />
|
|
28
25
|
}
|
|
29
26
|
>
|
|
30
|
-
<
|
|
31
|
-
href={firstButton?.url
|
|
27
|
+
<LinkButton
|
|
28
|
+
href={firstButton?.url}
|
|
32
29
|
variant="secondary"
|
|
33
30
|
icon={
|
|
34
31
|
<UIIcon
|
|
35
|
-
name={firstButton?.icon
|
|
32
|
+
name={firstButton?.icon}
|
|
36
33
|
width={18}
|
|
37
34
|
height={18}
|
|
38
35
|
weight="bold"
|
|
@@ -40,14 +37,14 @@ function EmptyGallery({ title, firstButton, secondButton }: EmptyGalleryProps) {
|
|
|
40
37
|
}
|
|
41
38
|
iconPosition="left"
|
|
42
39
|
>
|
|
43
|
-
{firstButton?.label
|
|
44
|
-
</
|
|
45
|
-
<
|
|
46
|
-
href={secondButton?.url
|
|
40
|
+
{firstButton?.label}
|
|
41
|
+
</LinkButton>
|
|
42
|
+
<LinkButton
|
|
43
|
+
href={secondButton?.url}
|
|
47
44
|
variant="secondary"
|
|
48
45
|
icon={
|
|
49
46
|
<UIIcon
|
|
50
|
-
name={secondButton?.icon
|
|
47
|
+
name={secondButton?.icon}
|
|
51
48
|
width={18}
|
|
52
49
|
height={18}
|
|
53
50
|
weight="bold"
|
|
@@ -55,8 +52,8 @@ function EmptyGallery({ title, firstButton, secondButton }: EmptyGalleryProps) {
|
|
|
55
52
|
}
|
|
56
53
|
iconPosition="left"
|
|
57
54
|
>
|
|
58
|
-
{secondButton?.label
|
|
59
|
-
</
|
|
55
|
+
{secondButton?.label}
|
|
56
|
+
</LinkButton>
|
|
60
57
|
</UIEmptyState>
|
|
61
58
|
)
|
|
62
59
|
}
|