@jetshop/template-trend 6.1.4 → 6.1.5
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/dist/src/client.js +6 -0
- package/dist/src/client.js.map +1 -0
- package/dist/src/components/Auth/ForgotPassword.js +30 -0
- package/dist/src/components/Auth/ForgotPassword.js.map +1 -0
- package/dist/src/components/Auth/ForgotPassword.loadable.js +7 -0
- package/dist/src/components/Auth/ForgotPassword.loadable.js.map +1 -0
- package/dist/src/components/Auth/LogInPage.js +69 -0
- package/dist/src/components/Auth/LogInPage.js.map +1 -0
- package/dist/src/components/Auth/LogInPage.loadable.js +7 -0
- package/dist/src/components/Auth/LogInPage.loadable.js.map +1 -0
- package/dist/src/components/Auth/ResetPassword.js +30 -0
- package/dist/src/components/Auth/ResetPassword.js.map +1 -0
- package/dist/src/components/Auth/ResetPassword.loadable.js +7 -0
- package/dist/src/components/Auth/ResetPassword.loadable.js.map +1 -0
- package/dist/src/components/Auth/Signup/Address.js +34 -0
- package/dist/src/components/Auth/Signup/Address.js.map +1 -0
- package/dist/src/components/Auth/Signup/CustomerType.js +30 -0
- package/dist/src/components/Auth/Signup/CustomerType.js.map +1 -0
- package/dist/src/components/Auth/Signup/LoginFields.js +31 -0
- package/dist/src/components/Auth/Signup/LoginFields.js.map +1 -0
- package/dist/src/components/Auth/Signup/PID.js +11 -0
- package/dist/src/components/Auth/Signup/PID.js.map +1 -0
- package/dist/src/components/Auth/Signup/SSN.js +29 -0
- package/dist/src/components/Auth/Signup/SSN.js.map +1 -0
- package/dist/src/components/Auth/Signup/SignUpPage.js +78 -0
- package/dist/src/components/Auth/Signup/SignUpPage.js.map +1 -0
- package/dist/src/components/Auth/Signup/SignUpPage.loadable.js +7 -0
- package/dist/src/components/Auth/Signup/SignUpPage.loadable.js.map +1 -0
- package/dist/src/components/Auth/Signup/useSignupValidation.js +29 -0
- package/dist/src/components/Auth/Signup/useSignupValidation.js.map +1 -0
- package/dist/src/components/Auth/UI/Form.js +33 -0
- package/dist/src/components/Auth/UI/Form.js.map +1 -0
- package/dist/src/components/Cart/CartButton.js +46 -0
- package/dist/src/components/Cart/CartButton.js.map +1 -0
- package/dist/src/components/Cart/CartFlyout.js +190 -0
- package/dist/src/components/Cart/CartFlyout.js.map +1 -0
- package/dist/src/components/Cart/CartItem.js +155 -0
- package/dist/src/components/Cart/CartItem.js.map +1 -0
- package/dist/src/components/Cart/FreeShipping.js +51 -0
- package/dist/src/components/Cart/FreeShipping.js.map +1 -0
- package/dist/src/components/CategoryPage/CategoryHeader.js +104 -0
- package/dist/src/components/CategoryPage/CategoryHeader.js.map +1 -0
- package/dist/src/components/CategoryPage/CategoryHeaderLoadingState.js +13 -0
- package/dist/src/components/CategoryPage/CategoryHeaderLoadingState.js.map +1 -0
- package/dist/src/components/CategoryPage/CategoryPage.js +26 -0
- package/dist/src/components/CategoryPage/CategoryPage.js.map +1 -0
- package/dist/src/components/CategoryPage/CategoryPage.loadable.js +7 -0
- package/dist/src/components/CategoryPage/CategoryPage.loadable.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/ActiveFilters.js +79 -0
- package/dist/src/components/CategoryPage/Filters/ActiveFilters.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/BooleanFilters.js +18 -0
- package/dist/src/components/CategoryPage/Filters/BooleanFilters.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/Filter.js +97 -0
- package/dist/src/components/CategoryPage/Filters/Filter.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/FilterDrawer.js +91 -0
- package/dist/src/components/CategoryPage/Filters/FilterDrawer.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/FilterDropdownMenu.js +77 -0
- package/dist/src/components/CategoryPage/Filters/FilterDropdownMenu.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/ListFilters.js +38 -0
- package/dist/src/components/CategoryPage/Filters/ListFilters.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/ActiveCarot.js +15 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/ActiveCarot.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/FilterButton.js +107 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/FilterButton.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/ListAccordion.js +44 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/ListAccordion.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/RangeAccordion.js +21 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/RangeAccordion.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/SortOrderAccordion.js +30 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/SortOrderAccordion.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/shared/styles.js +12 -0
- package/dist/src/components/CategoryPage/Filters/Mobile/shared/styles.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/MultiListFilters.js +37 -0
- package/dist/src/components/CategoryPage/Filters/MultiListFilters.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/RangeFilters.js +122 -0
- package/dist/src/components/CategoryPage/Filters/RangeFilters.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/SortOrders.js +29 -0
- package/dist/src/components/CategoryPage/Filters/SortOrders.js.map +1 -0
- package/dist/src/components/CategoryPage/Filters/index.js +2 -0
- package/dist/src/components/CategoryPage/Filters/index.js.map +1 -0
- package/dist/src/components/CategoryPage/ProductCard.js +98 -0
- package/dist/src/components/CategoryPage/ProductCard.js.map +1 -0
- package/dist/src/components/CategoryPage/ProductGrid.js +89 -0
- package/dist/src/components/CategoryPage/ProductGrid.js.map +1 -0
- package/dist/src/components/CategoryPage/ProductGridWindow.js +48 -0
- package/dist/src/components/CategoryPage/ProductGridWindow.js.map +1 -0
- package/dist/src/components/CategoryPage/StandardCategoryPage.js +51 -0
- package/dist/src/components/CategoryPage/StandardCategoryPage.js.map +1 -0
- package/dist/src/components/CategoryPage/WindowedCategoryPage.js +87 -0
- package/dist/src/components/CategoryPage/WindowedCategoryPage.js.map +1 -0
- package/dist/src/components/CategoryPage/index.js +2 -0
- package/dist/src/components/CategoryPage/index.js.map +1 -0
- package/dist/src/components/ContentPage/ContentPage.js +64 -0
- package/dist/src/components/ContentPage/ContentPage.js.map +1 -0
- package/dist/src/components/ContentPage/ContentPage.loadable.js +7 -0
- package/dist/src/components/ContentPage/ContentPage.loadable.js.map +1 -0
- package/dist/src/components/ContentPage/SubPageNavigation.js +164 -0
- package/dist/src/components/ContentPage/SubPageNavigation.js.map +1 -0
- package/dist/src/components/ContentPage/index.js +2 -0
- package/dist/src/components/ContentPage/index.js.map +1 -0
- package/dist/src/components/CookieConsent.js +84 -0
- package/dist/src/components/CookieConsent.js.map +1 -0
- package/dist/src/components/Forms/GlobalError.js +28 -0
- package/dist/src/components/Forms/GlobalError.js.map +1 -0
- package/dist/src/components/Forms/Input.js +79 -0
- package/dist/src/components/Forms/Input.js.map +1 -0
- package/dist/src/components/Forms/InputStatus.js +42 -0
- package/dist/src/components/Forms/InputStatus.js.map +1 -0
- package/dist/src/components/Forms/Success.js +25 -0
- package/dist/src/components/Forms/Success.js.map +1 -0
- package/dist/src/components/Layout/Container.js +19 -0
- package/dist/src/components/Layout/Container.js.map +1 -0
- package/dist/src/components/Layout/Content/index.js +7 -0
- package/dist/src/components/Layout/Content/index.js.map +1 -0
- package/dist/src/components/Layout/Footer/Footer.js +106 -0
- package/dist/src/components/Layout/Footer/Footer.js.map +1 -0
- package/dist/src/components/Layout/Footer/FooterLinks.js +24 -0
- package/dist/src/components/Layout/Footer/FooterLinks.js.map +1 -0
- package/dist/src/components/Layout/Footer/SocialLinks.js +62 -0
- package/dist/src/components/Layout/Footer/SocialLinks.js.map +1 -0
- package/dist/src/components/Layout/Header/Categories/Categories.js +10 -0
- package/dist/src/components/Layout/Header/Categories/Categories.js.map +1 -0
- package/dist/src/components/Layout/Header/Categories/MobileCategories.js +128 -0
- package/dist/src/components/Layout/Header/Categories/MobileCategories.js.map +1 -0
- package/dist/src/components/Layout/Header/Categories/__util__/getCategoriesByLevel.js +4 -0
- package/dist/src/components/Layout/Header/Categories/__util__/getCategoriesByLevel.js.map +1 -0
- package/dist/src/components/Layout/Header/Categories/__util__/getCategoriesUnderParent.js +4 -0
- package/dist/src/components/Layout/Header/Categories/__util__/getCategoriesUnderParent.js.map +1 -0
- package/dist/src/components/Layout/Header/Categories/__util__/hasChildCategories.js +4 -0
- package/dist/src/components/Layout/Header/Categories/__util__/hasChildCategories.js.map +1 -0
- package/dist/src/components/Layout/Header/CategoryMenu/CategoryMenu.js +21 -0
- package/dist/src/components/Layout/Header/CategoryMenu/CategoryMenu.js.map +1 -0
- package/dist/src/components/Layout/Header/CategoryMenu/CategoryMenuContainer.js +55 -0
- package/dist/src/components/Layout/Header/CategoryMenu/CategoryMenuContainer.js.map +1 -0
- package/dist/src/components/Layout/Header/CategoryMenu/SubMenuSection.js +60 -0
- package/dist/src/components/Layout/Header/CategoryMenu/SubMenuSection.js.map +1 -0
- package/dist/src/components/Layout/Header/CategoryMenu/SubMenuWrapper.js +78 -0
- package/dist/src/components/Layout/Header/CategoryMenu/SubMenuWrapper.js.map +1 -0
- package/dist/src/components/Layout/Header/ChannelSelector/ChannelSelector.js +26 -0
- package/dist/src/components/Layout/Header/ChannelSelector/ChannelSelector.js.map +1 -0
- package/dist/src/components/Layout/Header/ChannelSelector/ChannelSelectorModal.js +36 -0
- package/dist/src/components/Layout/Header/ChannelSelector/ChannelSelectorModal.js.map +1 -0
- package/dist/src/components/Layout/Header/ChannelSelector/LanguageSelector.js +12 -0
- package/dist/src/components/Layout/Header/ChannelSelector/LanguageSelector.js.map +1 -0
- package/dist/src/components/Layout/Header/ChannelSelector/Selector.js +120 -0
- package/dist/src/components/Layout/Header/ChannelSelector/Selector.js.map +1 -0
- package/dist/src/components/Layout/Header/ChannelSelector/flattenCountries.js +15 -0
- package/dist/src/components/Layout/Header/ChannelSelector/flattenCountries.js.map +1 -0
- package/dist/src/components/Layout/Header/Header.js +189 -0
- package/dist/src/components/Layout/Header/Header.js.map +1 -0
- package/dist/src/components/Layout/Header/Logo.js +40 -0
- package/dist/src/components/Layout/Header/Logo.js.map +1 -0
- package/dist/src/components/Layout/Header/LogoSearchBar.js +15 -0
- package/dist/src/components/Layout/Header/LogoSearchBar.js.map +1 -0
- package/dist/src/components/Layout/Header/MobileMenu.js +76 -0
- package/dist/src/components/Layout/Header/MobileMenu.js.map +1 -0
- package/dist/src/components/Layout/Header/RecommendedChannel/ChannelBanner.js +218 -0
- package/dist/src/components/Layout/Header/RecommendedChannel/ChannelBanner.js.map +1 -0
- package/dist/src/components/Layout/Header/RecommendedChannel/RecommendedChannelSelector.js +123 -0
- package/dist/src/components/Layout/Header/RecommendedChannel/RecommendedChannelSelector.js.map +1 -0
- package/dist/src/components/Layout/Header/SearchBar.js +79 -0
- package/dist/src/components/Layout/Header/SearchBar.js.map +1 -0
- package/dist/src/components/Layout/Header/SearchButton.js +50 -0
- package/dist/src/components/Layout/Header/SearchButton.js.map +1 -0
- package/dist/src/components/Layout/Header/SubCategoryNav.js +71 -0
- package/dist/src/components/Layout/Header/SubCategoryNav.js.map +1 -0
- package/dist/src/components/Layout/Header/TopNav.js +63 -0
- package/dist/src/components/Layout/Header/TopNav.js.map +1 -0
- package/dist/src/components/Layout/MaxWidth.js +19 -0
- package/dist/src/components/Layout/MaxWidth.js.map +1 -0
- package/dist/src/components/Layout/Notifications.js +70 -0
- package/dist/src/components/Layout/Notifications.js.map +1 -0
- package/dist/src/components/LoadingPage.js +19 -0
- package/dist/src/components/LoadingPage.js.map +1 -0
- package/dist/src/components/LogOut.loadable.js +7 -0
- package/dist/src/components/LogOut.loadable.js.map +1 -0
- package/dist/src/components/MyPages/ChangePasswordPage.js +26 -0
- package/dist/src/components/MyPages/ChangePasswordPage.js.map +1 -0
- package/dist/src/components/MyPages/CustomerNameHeader.js +28 -0
- package/dist/src/components/MyPages/CustomerNameHeader.js.map +1 -0
- package/dist/src/components/MyPages/DeleteAccount.js +47 -0
- package/dist/src/components/MyPages/DeleteAccount.js.map +1 -0
- package/dist/src/components/MyPages/MyPages.js +152 -0
- package/dist/src/components/MyPages/MyPages.js.map +1 -0
- package/dist/src/components/MyPages/MyPages.loadable.js +7 -0
- package/dist/src/components/MyPages/MyPages.loadable.js.map +1 -0
- package/dist/src/components/MyPages/MyPagesBreadcrumbs.js +18 -0
- package/dist/src/components/MyPages/MyPagesBreadcrumbs.js.map +1 -0
- package/dist/src/components/MyPages/MyPagesSidebar.js +81 -0
- package/dist/src/components/MyPages/MyPagesSidebar.js.map +1 -0
- package/dist/src/components/MyPages/MyPagesStartPage.js +99 -0
- package/dist/src/components/MyPages/MyPagesStartPage.js.map +1 -0
- package/dist/src/components/MyPages/Newsletter.js +33 -0
- package/dist/src/components/MyPages/Newsletter.js.map +1 -0
- package/dist/src/components/MyPages/Orders/ListOrder.js +159 -0
- package/dist/src/components/MyPages/Orders/ListOrder.js.map +1 -0
- package/dist/src/components/MyPages/Orders/OrderDetail/Contact.js +38 -0
- package/dist/src/components/MyPages/Orders/OrderDetail/Contact.js.map +1 -0
- package/dist/src/components/MyPages/Orders/OrderDetail/ListDetail.js +196 -0
- package/dist/src/components/MyPages/Orders/OrderDetail/ListDetail.js.map +1 -0
- package/dist/src/components/MyPages/Orders/OrderDetail/OrderTotals.js +81 -0
- package/dist/src/components/MyPages/Orders/OrderDetail/OrderTotals.js.map +1 -0
- package/dist/src/components/MyPages/Orders/OrderDetail/ShippingPayment.js +37 -0
- package/dist/src/components/MyPages/Orders/OrderDetail/ShippingPayment.js.map +1 -0
- package/dist/src/components/MyPages/Orders/OrderListPage.js +56 -0
- package/dist/src/components/MyPages/Orders/OrderListPage.js.map +1 -0
- package/dist/src/components/MyPages/ProfileDeliveryAddresses.js +93 -0
- package/dist/src/components/MyPages/ProfileDeliveryAddresses.js.map +1 -0
- package/dist/src/components/MyPages/ProfilePage.js +109 -0
- package/dist/src/components/MyPages/ProfilePage.js.map +1 -0
- package/dist/src/components/MyPages/ProfileView.js +42 -0
- package/dist/src/components/MyPages/ProfileView.js.map +1 -0
- package/dist/src/components/NavigationTree/NavTree.js +53 -0
- package/dist/src/components/NavigationTree/NavTree.js.map +1 -0
- package/dist/src/components/NavigationTree/NavTreePage.js +7 -0
- package/dist/src/components/NavigationTree/NavTreePage.js.map +1 -0
- package/dist/src/components/NavigationTree/NavTreePage.loadable.js +7 -0
- package/dist/src/components/NavigationTree/NavTreePage.loadable.js.map +1 -0
- package/dist/src/components/Newsletter/NewsletterField.js +93 -0
- package/dist/src/components/Newsletter/NewsletterField.js.map +1 -0
- package/dist/src/components/NotFoundPage.js +59 -0
- package/dist/src/components/NotFoundPage.js.map +1 -0
- package/dist/src/components/NotFoundPage.loadable.js +7 -0
- package/dist/src/components/NotFoundPage.loadable.js.map +1 -0
- package/dist/src/components/Pages/About.js +7 -0
- package/dist/src/components/Pages/About.js.map +1 -0
- package/dist/src/components/Pagination/Pagination.js +29 -0
- package/dist/src/components/Pagination/Pagination.js.map +1 -0
- package/dist/src/components/Pagination/PaginationWrapper.js +16 -0
- package/dist/src/components/Pagination/PaginationWrapper.js.map +1 -0
- package/dist/src/components/PreviewRoute.loadable.js +7 -0
- package/dist/src/components/PreviewRoute.loadable.js.map +1 -0
- package/dist/src/components/ProductList/AddToCart.js +46 -0
- package/dist/src/components/ProductList/AddToCart.js.map +1 -0
- package/dist/src/components/ProductList/Favourite.js +46 -0
- package/dist/src/components/ProductList/Favourite.js.map +1 -0
- package/dist/src/components/ProductList/FavouriteCount.js +15 -0
- package/dist/src/components/ProductList/FavouriteCount.js.map +1 -0
- package/dist/src/components/ProductList/Favourites.js +187 -0
- package/dist/src/components/ProductList/Favourites.js.map +1 -0
- package/dist/src/components/ProductList/Lister.js +22 -0
- package/dist/src/components/ProductList/Lister.js.map +1 -0
- package/dist/src/components/ProductList/Product.js +62 -0
- package/dist/src/components/ProductList/Product.js.map +1 -0
- package/dist/src/components/ProductList/SelectVariant.js +47 -0
- package/dist/src/components/ProductList/SelectVariant.js.map +1 -0
- package/dist/src/components/ProductList/productListQueries.js +15 -0
- package/dist/src/components/ProductList/productListQueries.js.map +1 -0
- package/dist/src/components/ProductPage/AddToCart/AddToCartForm.js +110 -0
- package/dist/src/components/ProductPage/AddToCart/AddToCartForm.js.map +1 -0
- package/dist/src/components/ProductPage/AddToCart/ProductToast.js +118 -0
- package/dist/src/components/ProductPage/AddToCart/ProductToast.js.map +1 -0
- package/dist/src/components/ProductPage/AddToCart/useProductToast.js +21 -0
- package/dist/src/components/ProductPage/AddToCart/useProductToast.js.map +1 -0
- package/dist/src/components/ProductPage/Campaigns.js +43 -0
- package/dist/src/components/ProductPage/Campaigns.js.map +1 -0
- package/dist/src/components/ProductPage/ConfigurationSelector.js +62 -0
- package/dist/src/components/ProductPage/ConfigurationSelector.js.map +1 -0
- package/dist/src/components/ProductPage/Images/ImageContainer.js +45 -0
- package/dist/src/components/ProductPage/Images/ImageContainer.js.map +1 -0
- package/dist/src/components/ProductPage/Images/Thumbnails.js +32 -0
- package/dist/src/components/ProductPage/Images/Thumbnails.js.map +1 -0
- package/dist/src/components/ProductPage/PackageProduct/IncludedInPackages.js +32 -0
- package/dist/src/components/ProductPage/PackageProduct/IncludedInPackages.js.map +1 -0
- package/dist/src/components/ProductPage/PackageProduct/PackageProduct.js +170 -0
- package/dist/src/components/ProductPage/PackageProduct/PackageProduct.js.map +1 -0
- package/dist/src/components/ProductPage/PackageProduct/PackageProductItem.js +92 -0
- package/dist/src/components/ProductPage/PackageProduct/PackageProductItem.js.map +1 -0
- package/dist/src/components/ProductPage/PriceHistory.js +99 -0
- package/dist/src/components/ProductPage/PriceHistory.js.map +1 -0
- package/dist/src/components/ProductPage/ProductInfo.js +55 -0
- package/dist/src/components/ProductPage/ProductInfo.js.map +1 -0
- package/dist/src/components/ProductPage/ProductInfoAccordion.js +46 -0
- package/dist/src/components/ProductPage/ProductInfoAccordion.js.map +1 -0
- package/dist/src/components/ProductPage/ProductPage.js +174 -0
- package/dist/src/components/ProductPage/ProductPage.js.map +1 -0
- package/dist/src/components/ProductPage/ProductPage.loadable.js +7 -0
- package/dist/src/components/ProductPage/ProductPage.loadable.js.map +1 -0
- package/dist/src/components/ProductPage/ProductPageLoadingState.js +55 -0
- package/dist/src/components/ProductPage/ProductPageLoadingState.js.map +1 -0
- package/dist/src/components/ProductPage/QuantityContainer.js +21 -0
- package/dist/src/components/ProductPage/QuantityContainer.js.map +1 -0
- package/dist/src/components/ProductPage/RelatedProducts.js +45 -0
- package/dist/src/components/ProductPage/RelatedProducts.js.map +1 -0
- package/dist/src/components/ProductPage/SizePicker.js +37 -0
- package/dist/src/components/ProductPage/SizePicker.js.map +1 -0
- package/dist/src/components/ProductPage/StockStatus/NotifyWhenBack.js +93 -0
- package/dist/src/components/ProductPage/StockStatus/NotifyWhenBack.js.map +1 -0
- package/dist/src/components/ProductPage/StockStatus/StockOrb.js +31 -0
- package/dist/src/components/ProductPage/StockStatus/StockOrb.js.map +1 -0
- package/dist/src/components/ProductPage/StockStatus/StockStatusIndicator.js +33 -0
- package/dist/src/components/ProductPage/StockStatus/StockStatusIndicator.js.map +1 -0
- package/dist/src/components/ProductPage/StockStatus/WarehouseStock.js +255 -0
- package/dist/src/components/ProductPage/StockStatus/WarehouseStock.js.map +1 -0
- package/dist/src/components/ProductPage/VariantSelector.js +138 -0
- package/dist/src/components/ProductPage/VariantSelector.js.map +1 -0
- package/dist/src/components/ProductPage/styledComponents.js +11 -0
- package/dist/src/components/ProductPage/styledComponents.js.map +1 -0
- package/dist/src/components/ProductPage/useProductValidationMessage.js +24 -0
- package/dist/src/components/ProductPage/useProductValidationMessage.js.map +1 -0
- package/dist/src/components/SearchPage/CategoryList.js +129 -0
- package/dist/src/components/SearchPage/CategoryList.js.map +1 -0
- package/dist/src/components/SearchPage/EmptySearchResults.js +23 -0
- package/dist/src/components/SearchPage/EmptySearchResults.js.map +1 -0
- package/dist/src/components/SearchPage/SearchMeta.js +27 -0
- package/dist/src/components/SearchPage/SearchMeta.js.map +1 -0
- package/dist/src/components/SearchPage/SearchPage.js +52 -0
- package/dist/src/components/SearchPage/SearchPage.js.map +1 -0
- package/dist/src/components/SearchPage/SearchPage.loadable.js +7 -0
- package/dist/src/components/SearchPage/SearchPage.loadable.js.map +1 -0
- package/dist/src/components/SearchPage/SearchResults.js +60 -0
- package/dist/src/components/SearchPage/SearchResults.js.map +1 -0
- package/dist/src/components/SearchPage/SearchTerm.js +11 -0
- package/dist/src/components/SearchPage/SearchTerm.js.map +1 -0
- package/dist/src/components/SearchPage/WindowedSearchResults.js +80 -0
- package/dist/src/components/SearchPage/WindowedSearchResults.js.map +1 -0
- package/dist/src/components/SearchPage/index.js +3 -0
- package/dist/src/components/SearchPage/index.js.map +1 -0
- package/dist/src/components/Shop.js +82 -0
- package/dist/src/components/Shop.js.map +1 -0
- package/dist/src/components/StartPage/Content/Row.js +40 -0
- package/dist/src/components/StartPage/Content/Row.js.map +1 -0
- package/dist/src/components/StartPage/Content/StartPageCampaign.js +112 -0
- package/dist/src/components/StartPage/Content/StartPageCampaign.js.map +1 -0
- package/dist/src/components/StartPage/Content/StartPageCategories.js +80 -0
- package/dist/src/components/StartPage/Content/StartPageCategories.js.map +1 -0
- package/dist/src/components/StartPage/Content/StartPageHTMLContent.js +74 -0
- package/dist/src/components/StartPage/Content/StartPageHTMLContent.js.map +1 -0
- package/dist/src/components/StartPage/Content/StartPageHero.js +73 -0
- package/dist/src/components/StartPage/Content/StartPageHero.js.map +1 -0
- package/dist/src/components/StartPage/Content/StartPageProductGrid.js +69 -0
- package/dist/src/components/StartPage/Content/StartPageProductGrid.js.map +1 -0
- package/dist/src/components/StartPage/StartPage.js +37 -0
- package/dist/src/components/StartPage/StartPage.js.map +1 -0
- package/dist/src/components/StartPage/StartPage.loadable.js +7 -0
- package/dist/src/components/StartPage/StartPage.loadable.js.map +1 -0
- package/dist/src/components/StartPage/index.js +3 -0
- package/dist/src/components/StartPage/index.js.map +1 -0
- package/dist/src/components/Store/Store.js +26 -0
- package/dist/src/components/Store/Store.js.map +1 -0
- package/dist/src/components/Store/Store.loadable.js +7 -0
- package/dist/src/components/Store/Store.loadable.js.map +1 -0
- package/dist/src/components/Store/StoreDetail.js +13 -0
- package/dist/src/components/Store/StoreDetail.js.map +1 -0
- package/dist/src/components/StoreLocator/StoreList.js +160 -0
- package/dist/src/components/StoreLocator/StoreList.js.map +1 -0
- package/dist/src/components/StoreLocator/StoreLocator.js +133 -0
- package/dist/src/components/StoreLocator/StoreLocator.js.map +1 -0
- package/dist/src/components/StoreLocator/StoreLocator.loadable.js +7 -0
- package/dist/src/components/StoreLocator/StoreLocator.loadable.js.map +1 -0
- package/dist/src/components/StoreLocator/StoreMap.js +116 -0
- package/dist/src/components/StoreLocator/StoreMap.js.map +1 -0
- package/dist/src/components/StoreLocator/StoreMarker.js +63 -0
- package/dist/src/components/StoreLocator/StoreMarker.js.map +1 -0
- package/dist/src/components/StoreLocator/StoreSearch.js +47 -0
- package/dist/src/components/StoreLocator/StoreSearch.js.map +1 -0
- package/dist/src/components/StoreLocator/UserLocation.js +76 -0
- package/dist/src/components/StoreLocator/UserLocation.js.map +1 -0
- package/dist/src/components/StoreLocator/useLocationState.js +14 -0
- package/dist/src/components/StoreLocator/useLocationState.js.map +1 -0
- package/dist/src/components/StoreLocator/useMapState.js +16 -0
- package/dist/src/components/StoreLocator/useMapState.js.map +1 -0
- package/dist/src/components/Theme.js +6 -0
- package/dist/src/components/Theme.js.map +1 -0
- package/dist/src/components/ui/Badge.js +33 -0
- package/dist/src/components/ui/Badge.js.map +1 -0
- package/dist/src/components/ui/Button.js +93 -0
- package/dist/src/components/ui/Button.js.map +1 -0
- package/dist/src/components/ui/CloseButton.js +18 -0
- package/dist/src/components/ui/CloseButton.js.map +1 -0
- package/dist/src/components/ui/Divider.js +11 -0
- package/dist/src/components/ui/Divider.js.map +1 -0
- package/dist/src/components/ui/Headings.js +19 -0
- package/dist/src/components/ui/Headings.js.map +1 -0
- package/dist/src/components/ui/RadioGroupWithLabels.js +16 -0
- package/dist/src/components/ui/RadioGroupWithLabels.js.map +1 -0
- package/dist/src/components/ui/Spinner.js +39 -0
- package/dist/src/components/ui/Spinner.js.map +1 -0
- package/dist/src/fonts/loadFontCss.js +51 -0
- package/dist/src/fonts/loadFontCss.js.map +1 -0
- package/dist/src/globalStyles.js +83 -0
- package/dist/src/globalStyles.js.map +1 -0
- package/dist/src/server.js +12 -0
- package/dist/src/server.js.map +1 -0
- package/dist/src/shop.config.js +68 -0
- package/dist/src/shop.config.js.map +1 -0
- package/dist/src/theme-variables.js +65 -0
- package/dist/src/theme-variables.js.map +1 -0
- package/dist/translations/cs.json +788 -0
- package/dist/translations/da.json +791 -0
- package/dist/translations/de.json +788 -0
- package/dist/translations/en.json +794 -0
- package/dist/translations/es.json +788 -0
- package/dist/translations/et.json +788 -0
- package/dist/translations/fi.json +794 -0
- package/dist/translations/fr.json +788 -0
- package/dist/translations/index.js +18 -0
- package/dist/translations/index.js.map +1 -0
- package/dist/translations/it.json +788 -0
- package/dist/translations/lv.json +788 -0
- package/dist/translations/nb.json +791 -0
- package/dist/translations/nl.json +788 -0
- package/dist/translations/pl.json +788 -0
- package/dist/translations/ru.json +788 -0
- package/dist/translations/sk.json +788 -0
- package/dist/translations/sr.json +464 -0
- package/dist/translations/sv.json +794 -0
- package/jsconfig.json +1 -0
- package/package.json +5 -5
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ReactComponent as Check } from '@jetshop/ui/svg/Check.svg';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { filterName } from './shared/styles';
|
|
4
|
+
import SortOrder from '@jetshop/ui/SortOrder/SortOrder';
|
|
5
|
+
import t from '@jetshop/intl';
|
|
6
|
+
import { filtersStyle } from './ListAccordion';
|
|
7
|
+
import { ActiveCarot } from './ActiveCarot';
|
|
8
|
+
export const SortOrderAccordion = ({ sortOrders, accordionProps, startingIdx = 0 }) => {
|
|
9
|
+
if (sortOrders.length === 0)
|
|
10
|
+
return null;
|
|
11
|
+
return (React.createElement(SortOrder, { sortOrders: sortOrders }, sortOrderOptions => (React.createElement(SortOrderComponent, { startingIdx: startingIdx, accordionProps: accordionProps, sortOrderOptions: sortOrderOptions }))));
|
|
12
|
+
};
|
|
13
|
+
function SortOrderComponent({ accordionProps, startingIdx, sortOrderOptions }) {
|
|
14
|
+
const idx = 0; // As there is only one sort order accordion, idx is 0
|
|
15
|
+
const { changeSortOrder, direction, sortOrder, mappedSortOrder } = sortOrderOptions;
|
|
16
|
+
const { AccordionContent } = accordionProps;
|
|
17
|
+
const accordionIsOpen = accordionProps.openIndexes.includes(idx + startingIdx);
|
|
18
|
+
return (React.createElement(React.Fragment, null,
|
|
19
|
+
React.createElement("div", { className: filterName, onClick: () => accordionProps.handleClick(idx + startingIdx) },
|
|
20
|
+
t('Sort by'),
|
|
21
|
+
React.createElement(ActiveCarot, { isOpen: accordionIsOpen })),
|
|
22
|
+
React.createElement(AccordionContent, { isOpen: accordionIsOpen },
|
|
23
|
+
React.createElement("ul", { className: filtersStyle }, mappedSortOrder.map(order => (React.createElement("li", { key: `${order.value}-${order.direction}` },
|
|
24
|
+
React.createElement("button", { onClick: () => {
|
|
25
|
+
changeSortOrder(order.value, order.direction);
|
|
26
|
+
} },
|
|
27
|
+
order.text,
|
|
28
|
+
direction === order.direction && sortOrder === order.value && (React.createElement(Check, null))))))))));
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=SortOrderAccordion.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SortOrderAccordion.js","sourceRoot":"","sources":["../../../../../../src/components/CategoryPage/Filters/Mobile/SortOrderAccordion.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,IAAI,KAAK,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,SAAS,MAAM,iCAAiC,CAAC;AACxD,OAAO,CAAC,MAAM,eAAe,CAAC;AAC9B,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,EACjC,UAAU,EACV,cAAc,EACd,WAAW,GAAG,CAAC,EAChB,EAAE,EAAE;IACH,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAEzC,OAAO,CACL,oBAAC,SAAS,IAAC,UAAU,EAAE,UAAU,IAC9B,gBAAgB,CAAC,EAAE,CAAC,CACnB,oBAAC,kBAAkB,IACjB,WAAW,EAAE,WAAW,EACxB,cAAc,EAAE,cAAc,EAC9B,gBAAgB,EAAE,gBAAgB,GAClC,CACH,CACS,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,SAAS,kBAAkB,CAAC,EAAE,cAAc,EAAE,WAAW,EAAE,gBAAgB,EAAE;IAC3E,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,sDAAsD;IACrE,MAAM,EACJ,eAAe,EACf,SAAS,EACT,SAAS,EACT,eAAe,EAChB,GAAG,gBAAgB,CAAC;IACrB,MAAM,EAAE,gBAAgB,EAAE,GAAG,cAAc,CAAC;IAC5C,MAAM,eAAe,GAAG,cAAc,CAAC,WAAW,CAAC,QAAQ,CACzD,GAAG,GAAG,WAAW,CAClB,CAAC;IAEF,OAAO,CACL;QACE,6BACE,SAAS,EAAE,UAAU,EACrB,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,WAAW,CAAC,GAAG,GAAG,WAAW,CAAC;YAE3D,CAAC,CAAC,SAAS,CAAC;YACb,oBAAC,WAAW,IAAC,MAAM,EAAE,eAAe,GAAI,CACpC;QACN,oBAAC,gBAAgB,IAAC,MAAM,EAAE,eAAe;YACvC,4BAAI,SAAS,EAAE,YAAY,IACxB,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAC5B,4BAAI,GAAG,EAAE,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,SAAS,EAAE;gBAC1C,gCACE,OAAO,EAAE,GAAG,EAAE;wBACZ,eAAe,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;oBAChD,CAAC;oBAEA,KAAK,CAAC,IAAI;oBACV,SAAS,KAAK,KAAK,CAAC,SAAS,IAAI,SAAS,KAAK,KAAK,CAAC,KAAK,IAAI,CAC7D,oBAAC,KAAK,OAAG,CACV,CACM,CACN,CACN,CAAC,CACC,CACY,CAClB,CACJ,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { css } from 'linaria';
|
|
2
|
+
export const filterName = css `
|
|
3
|
+
display: flex;
|
|
4
|
+
padding: 1em;
|
|
5
|
+
justify-content: space-between;
|
|
6
|
+
align-items: center;
|
|
7
|
+
border-top: 1px solid #dedede;
|
|
8
|
+
:first-of-type {
|
|
9
|
+
border-top: none;
|
|
10
|
+
}
|
|
11
|
+
`;
|
|
12
|
+
//# sourceMappingURL=styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../../../../src/components/CategoryPage/Filters/Mobile/shared/styles.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,SAAS,CAAC;AAE9B,MAAM,CAAC,MAAM,UAAU,GAAG,GAAG,CAAA;;;;;;;;;CAS5B,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { DropdownMenuButton as Button, DropdownMenuItem, DropdownMenuItems as Items } from '@jetshop/ui/DropdownMenu';
|
|
2
|
+
import ErrorBoundary from '@jetshop/ui/ErrorBoundary/Generic';
|
|
3
|
+
import PassThrough from '@jetshop/ui/ErrorBoundary/PassThrough';
|
|
4
|
+
import { ReactComponent as Carot } from '@jetshop/ui/svg/Carrot.svg';
|
|
5
|
+
import { ReactComponent as Check } from '@jetshop/ui/svg/Check.svg';
|
|
6
|
+
import React from 'react';
|
|
7
|
+
import { FilterDropdownMenu } from './FilterDropdownMenu';
|
|
8
|
+
import { useMultiFilter } from '@jetshop/core/hooks/Filters/useMultiFilter';
|
|
9
|
+
import t from '@jetshop/intl';
|
|
10
|
+
export function MultiListFilters({ filters }) {
|
|
11
|
+
const multiListFilters = filters.filter(filter => filter.__typename === 'MultiListFilter');
|
|
12
|
+
return multiListFilters.map(multiListFilter => (React.createElement(ErrorBoundary, { component: PassThrough, key: multiListFilter.id }, multiListFilter.lists.map((listFilter, index) => (React.createElement(MultiListFilter, { filter: listFilter, multiListFilter: multiListFilter, index: index, key: listFilter.id }))))));
|
|
13
|
+
}
|
|
14
|
+
function MultiListFilter({ filter, multiListFilter, index }) {
|
|
15
|
+
const { apply, clearList } = useMultiFilter({
|
|
16
|
+
filter: multiListFilter
|
|
17
|
+
});
|
|
18
|
+
return (React.createElement(FilterDropdownMenu, null,
|
|
19
|
+
React.createElement(Button, { disabled: filter.items.length === 0 },
|
|
20
|
+
React.createElement("span", null, filter.name),
|
|
21
|
+
filter.hasActiveItems ? React.createElement(Check, null) : React.createElement(Carot, { className: "carot" })),
|
|
22
|
+
React.createElement(Items, { as: "ul" },
|
|
23
|
+
filter.items.map(item => (React.createElement(DropdownMenuItem, { key: item.id, onSelect: ({ setIsOpen }) => {
|
|
24
|
+
apply({
|
|
25
|
+
value: item.value,
|
|
26
|
+
listIndex: index
|
|
27
|
+
});
|
|
28
|
+
setIsOpen(false);
|
|
29
|
+
} },
|
|
30
|
+
React.createElement("span", null, item.text),
|
|
31
|
+
item.isActive ? React.createElement(Check, null) : React.createElement("span", null, item.resultCount)))),
|
|
32
|
+
React.createElement(React.Fragment, null, filter.hasActiveItems && (React.createElement(DropdownMenuItem, { onSelect: ({ setIsOpen }) => {
|
|
33
|
+
setIsOpen(false);
|
|
34
|
+
clearList({ listIndex: index });
|
|
35
|
+
} }, t('Clear filter')))))));
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=MultiListFilters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MultiListFilters.js","sourceRoot":"","sources":["../../../../../src/components/CategoryPage/Filters/MultiListFilters.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { useRangeFilter } from '@jetshop/core/hooks/Filters/useRangeFilter';
|
|
2
|
+
import t from '@jetshop/intl';
|
|
3
|
+
import Button from '@jetshop/ui/Button';
|
|
4
|
+
import { DropdownMenuButton, DropdownMenuItems } from '@jetshop/ui/DropdownMenu';
|
|
5
|
+
import ErrorBoundary from '@jetshop/ui/ErrorBoundary/Generic';
|
|
6
|
+
import PassThrough from '@jetshop/ui/ErrorBoundary/PassThrough';
|
|
7
|
+
import { ReactComponent as Carrot } from '@jetshop/ui/svg/Carrot.svg';
|
|
8
|
+
import { ReactComponent as Check } from '@jetshop/ui/svg/Check.svg';
|
|
9
|
+
import { css } from 'linaria';
|
|
10
|
+
import React, { useState } from 'react';
|
|
11
|
+
import { styled } from 'linaria/react';
|
|
12
|
+
import ReactSlider from 'react-slider';
|
|
13
|
+
import { FilterDropdownMenu } from './FilterDropdownMenu';
|
|
14
|
+
export const RangeSliderContainer = styled('div') `
|
|
15
|
+
width: 100%;
|
|
16
|
+
padding: 1rem;
|
|
17
|
+
background: #f7f7f7;
|
|
18
|
+
z-index: 5;
|
|
19
|
+
border: 1px solid #dedede;
|
|
20
|
+
border-top: 0;
|
|
21
|
+
|
|
22
|
+
.slider {
|
|
23
|
+
height: 1rem;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
.slider.disabled {
|
|
27
|
+
opacity: 0.3;
|
|
28
|
+
pointer-events: none;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.track {
|
|
32
|
+
height: 1rem;
|
|
33
|
+
background: transparent;
|
|
34
|
+
padding-bottom: 1rem;
|
|
35
|
+
&:after {
|
|
36
|
+
height: 2px;
|
|
37
|
+
width: 100%;
|
|
38
|
+
position: absolute;
|
|
39
|
+
top: 7px;
|
|
40
|
+
background: silver;
|
|
41
|
+
content: '';
|
|
42
|
+
}
|
|
43
|
+
&-1:after {
|
|
44
|
+
/* The active bar section */
|
|
45
|
+
background: black;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
.thumb {
|
|
49
|
+
height: 1rem;
|
|
50
|
+
width: 1rem;
|
|
51
|
+
background: black;
|
|
52
|
+
}
|
|
53
|
+
`;
|
|
54
|
+
const wrapper = css `
|
|
55
|
+
.active-vals {
|
|
56
|
+
display: flex;
|
|
57
|
+
margin-bottom: 0.5rem;
|
|
58
|
+
justify-content: space-between;
|
|
59
|
+
}
|
|
60
|
+
button {
|
|
61
|
+
margin-top: 0.5rem;
|
|
62
|
+
}
|
|
63
|
+
`;
|
|
64
|
+
export function RangeFilters({ filters }) {
|
|
65
|
+
const rangeFilters = filters.filter(filter => filter.__typename === 'NumericRangeFilter');
|
|
66
|
+
if (rangeFilters.length === 0)
|
|
67
|
+
return null;
|
|
68
|
+
return rangeFilters.map(filter => (React.createElement(ErrorBoundary, { component: PassThrough, key: filter.id },
|
|
69
|
+
React.createElement(RangeFilter, { filter: filter }))));
|
|
70
|
+
}
|
|
71
|
+
function RangeFilter({ filter }) {
|
|
72
|
+
return (React.createElement(FilterDropdownMenu, null,
|
|
73
|
+
React.createElement(DropdownMenuButton, null,
|
|
74
|
+
React.createElement("span", null, filter.name),
|
|
75
|
+
filter.isActive ? React.createElement(Check, null) : React.createElement(Carrot, { className: "carot" })),
|
|
76
|
+
React.createElement(DropdownMenuItems, { as: "div" },
|
|
77
|
+
React.createElement(RangeSlider, { filter: filter }))));
|
|
78
|
+
}
|
|
79
|
+
export function RangeSlider({ filter }) {
|
|
80
|
+
const { apply, clear } = useRangeFilter({ filter });
|
|
81
|
+
// Filter.value may be null (on first render). If it is, use the filter min/max as initial value
|
|
82
|
+
const [initialMin, initialMax] = filter.value
|
|
83
|
+
? filter.value
|
|
84
|
+
: [filter.min, filter.max];
|
|
85
|
+
// // Make sure the selected min/max are never lower or higher than
|
|
86
|
+
// // the available min/max respectively.
|
|
87
|
+
const selectedVals = [
|
|
88
|
+
Math.max(initialMin, filter.min),
|
|
89
|
+
Math.min(initialMax, filter.max)
|
|
90
|
+
];
|
|
91
|
+
// draftVal will be used to track the values from the slider
|
|
92
|
+
const [draftVal, setDraftVal] = useState({
|
|
93
|
+
min: selectedVals[0],
|
|
94
|
+
max: selectedVals[1]
|
|
95
|
+
});
|
|
96
|
+
const [touched, setTouched] = useState(false);
|
|
97
|
+
const handleUpdate = ([min, max]) => {
|
|
98
|
+
setTouched(true);
|
|
99
|
+
setDraftVal({ min, max });
|
|
100
|
+
};
|
|
101
|
+
const applyFilter = () => {
|
|
102
|
+
setTouched(false);
|
|
103
|
+
apply(draftVal);
|
|
104
|
+
};
|
|
105
|
+
const reset = () => {
|
|
106
|
+
setTouched(false);
|
|
107
|
+
const minMax = { min: filter.min, max: filter.max };
|
|
108
|
+
setDraftVal(minMax);
|
|
109
|
+
clear();
|
|
110
|
+
};
|
|
111
|
+
return (React.createElement(React.Fragment, null,
|
|
112
|
+
React.createElement(RangeSliderContainer, { className: wrapper },
|
|
113
|
+
React.createElement("div", { className: "active-vals" },
|
|
114
|
+
React.createElement("span", null, draftVal.min),
|
|
115
|
+
React.createElement("span", null, draftVal.max)),
|
|
116
|
+
React.createElement(ReactSlider, { disabled: filter.min === filter.max, min: filter.min, max: filter.max, minDistance: 10, defaultValue: selectedVals, onChange: handleUpdate, value: [draftVal.min, draftVal.max], withBars: true }),
|
|
117
|
+
touched ? (React.createElement(Button, { onClick: applyFilter }, t('Apply'))) : (React.createElement(React.Fragment, null, filter.isActive ? (React.createElement(Button, { onClick: reset, className: "secondary" },
|
|
118
|
+
' ',
|
|
119
|
+
t('Reset'),
|
|
120
|
+
' ')) : (React.createElement(Button, { disabled: true }, t('Apply'))))))));
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=RangeFilters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RangeFilters.js","sourceRoot":"","sources":["../../../../../src/components/CategoryPage/Filters/RangeFilters.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import t from '@jetshop/intl';
|
|
2
|
+
import { DropdownMenuButton, DropdownMenuItem, DropdownMenuItems } from '@jetshop/ui/DropdownMenu';
|
|
3
|
+
import { FilterDropdownMenu } from './FilterDropdownMenu';
|
|
4
|
+
import { StyledCheck } from '@jetshop/ui/Select/Components';
|
|
5
|
+
import * as React from 'react';
|
|
6
|
+
import { useSortOrder } from '@jetshop/core/hooks/Filters/useSortOrder';
|
|
7
|
+
import ErrorBoundary from '@jetshop/ui/ErrorBoundary/Generic';
|
|
8
|
+
import PassThrough from '@jetshop/ui/ErrorBoundary/PassThrough';
|
|
9
|
+
import { ReactComponent as Carot } from '@jetshop/ui/svg/Carrot.svg';
|
|
10
|
+
export const SortOrders = ({ sortOrders }) => {
|
|
11
|
+
if (sortOrders.length === 0)
|
|
12
|
+
return null;
|
|
13
|
+
return (React.createElement(ErrorBoundary, { component: PassThrough },
|
|
14
|
+
React.createElement(SortOrderDropdown, { sortOrders: sortOrders })));
|
|
15
|
+
};
|
|
16
|
+
function SortOrderDropdown({ sortOrders }) {
|
|
17
|
+
const { mappedSortOrder, changeSortOrder, sortOrder, direction } = useSortOrder({ sortOrders });
|
|
18
|
+
const activeItem = mappedSortOrder.find(item => item.direction === direction && item.value === sortOrder);
|
|
19
|
+
return (React.createElement(FilterDropdownMenu, { style: { marginRight: 0 } },
|
|
20
|
+
React.createElement(DropdownMenuButton, null,
|
|
21
|
+
React.createElement("span", null, activeItem ? activeItem.text : t('Sort By')),
|
|
22
|
+
React.createElement(Carot, { className: "carot" })),
|
|
23
|
+
React.createElement(DropdownMenuItems, null, mappedSortOrder.map(sortItem => {
|
|
24
|
+
return (React.createElement(DropdownMenuItem, { onSelect: () => changeSortOrder(sortItem.value, sortItem.direction), key: `${sortItem.value}-${sortItem.direction}` },
|
|
25
|
+
sortItem.text,
|
|
26
|
+
activeItem === sortItem && React.createElement(StyledCheck, null)));
|
|
27
|
+
}))));
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=SortOrders.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SortOrders.js","sourceRoot":"","sources":["../../../../../src/components/CategoryPage/Filters/SortOrders.js"],"names":[],"mappings":"AAAA,OAAO,CAAC,MAAM,eAAe,CAAC;AAC9B,OAAO,EACL,kBAAkB,EAClB,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,YAAY,EAAE,MAAM,0CAA0C,CAAC;AAExE,OAAO,aAAa,MAAM,mCAAmC,CAAC;AAC9D,OAAO,WAAW,MAAM,uCAAuC,CAAC;AAChE,OAAO,EAAE,cAAc,IAAI,KAAK,EAAE,MAAM,4BAA4B,CAAC;AAErE,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE;IAC3C,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAEzC,OAAO,CACL,oBAAC,aAAa,IAAC,SAAS,EAAE,WAAW;QACnC,oBAAC,iBAAiB,IAAC,UAAU,EAAE,UAAU,GAAI,CAC/B,CACjB,CAAC;AACJ,CAAC,CAAC;AAEF,SAAS,iBAAiB,CAAC,EAAE,UAAU,EAAE;IACvC,MAAM,EAAE,eAAe,EAAE,eAAe,EAAE,SAAS,EAAE,SAAS,EAAE,GAC9D,YAAY,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;IAE/B,MAAM,UAAU,GAAG,eAAe,CAAC,IAAI,CACrC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,CACjE,CAAC;IAEF,OAAO,CACL,oBAAC,kBAAkB,IAAC,KAAK,EAAE,EAAE,WAAW,EAAE,CAAC,EAAE;QAC3C,oBAAC,kBAAkB;YACjB,kCAAO,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAQ;YAC1D,oBAAC,KAAK,IAAC,SAAS,EAAC,OAAO,GAAG,CACR;QACrB,oBAAC,iBAAiB,QACf,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC9B,OAAO,CACL,oBAAC,gBAAgB,IACf,QAAQ,EAAE,GAAG,EAAE,CACb,eAAe,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,EAErD,GAAG,EAAE,GAAG,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,SAAS,EAAE;gBAE7C,QAAQ,CAAC,IAAI;gBACb,UAAU,KAAK,QAAQ,IAAI,oBAAC,WAAW,OAAG,CAC1B,CACpB,CAAC;QACJ,CAAC,CAAC,CACgB,CACD,CACtB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/components/CategoryPage/Filters/index.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import t from '@jetshop/intl';
|
|
13
|
+
import Image, { transparentDataImg } from '@jetshop/ui/Image/Image';
|
|
14
|
+
import { Price } from '@jetshop/ui/Price';
|
|
15
|
+
import ProductLink from '@jetshop/ui/ProductLink';
|
|
16
|
+
import Badges from '@jetshop/ui/ProductList/Badges';
|
|
17
|
+
import { css, cx } from 'linaria';
|
|
18
|
+
import React from 'react';
|
|
19
|
+
import { theme } from '../Theme';
|
|
20
|
+
const wrapperStyling = css `
|
|
21
|
+
font-size: 1rem;
|
|
22
|
+
position: relative;
|
|
23
|
+
a {
|
|
24
|
+
text-decoration: none;
|
|
25
|
+
color: inherit;
|
|
26
|
+
display: block;
|
|
27
|
+
background: white;
|
|
28
|
+
border: 1px solid ${theme.colors.tablegrey};
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.product-card-detail {
|
|
32
|
+
background: white;
|
|
33
|
+
padding: 0.75em;
|
|
34
|
+
line-height: 1.35;
|
|
35
|
+
border-top: 1px solid ${theme.colors.tablegrey};
|
|
36
|
+
h3 {
|
|
37
|
+
font-weight: 600;
|
|
38
|
+
font-size: 1em;
|
|
39
|
+
text-overflow: ellipsis;
|
|
40
|
+
white-space: nowrap;
|
|
41
|
+
overflow: hidden;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
h4 {
|
|
45
|
+
font-weight: normal;
|
|
46
|
+
font-size: 1em;
|
|
47
|
+
color: ${theme.colors.darkerGrey};
|
|
48
|
+
text-overflow: ellipsis;
|
|
49
|
+
white-space: nowrap;
|
|
50
|
+
overflow: hidden;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
.package-badge {
|
|
54
|
+
background: black;
|
|
55
|
+
color: white;
|
|
56
|
+
font-size: 14px;
|
|
57
|
+
padding: 3px 6px;
|
|
58
|
+
}
|
|
59
|
+
.price-package-wrapper {
|
|
60
|
+
display: flex;
|
|
61
|
+
align-items: center;
|
|
62
|
+
.package-price-label {
|
|
63
|
+
font-size: 12px;
|
|
64
|
+
color: grey;
|
|
65
|
+
margin-left: 5px;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.badge-top-right {
|
|
70
|
+
top: 3em;
|
|
71
|
+
}
|
|
72
|
+
`;
|
|
73
|
+
export function ProductCard(_a) {
|
|
74
|
+
var { product, className, imageAspect = '1:1', imageSizes = [1 / 2, 1 / 2, 1 / 3, 1 / 4], forwardRef, as = 'li', children, loadImageEagerly = false } = _a, linkProps = __rest(_a, ["product", "className", "imageAspect", "imageSizes", "forwardRef", "as", "children", "loadImageEagerly"]);
|
|
75
|
+
const hasImages = product.images && product.images.length > 0;
|
|
76
|
+
const Tag = as;
|
|
77
|
+
let badges = [...(product.badges || [])];
|
|
78
|
+
product.isPackage &&
|
|
79
|
+
badges.push({
|
|
80
|
+
location: 'TOP_RIGHT',
|
|
81
|
+
name: 'Package',
|
|
82
|
+
text: t('Package'),
|
|
83
|
+
style: 'package-badge'
|
|
84
|
+
});
|
|
85
|
+
return (React.createElement(Tag, { className: cx('product-card', wrapperStyling, className), "data-testid": "product", "data-product-card": true, ref: forwardRef },
|
|
86
|
+
React.createElement(ProductLink, Object.assign({ product: product }, linkProps, { style: {
|
|
87
|
+
margin: '0 0.5em 1em'
|
|
88
|
+
} }),
|
|
89
|
+
hasImages ? (React.createElement(Image, { sizes: imageSizes, aspect: imageAspect, alt: product.images[0].alt, src: product.images[0].url, modifiedDate: product.images[0].modifiedDate, badges: React.createElement(Badges, { badges: badges }), critical: loadImageEagerly })) : (React.createElement(Image, { src: transparentDataImg })),
|
|
90
|
+
React.createElement("section", { className: "product-card-detail" },
|
|
91
|
+
React.createElement("header", null,
|
|
92
|
+
React.createElement("h3", null, product.name),
|
|
93
|
+
React.createElement("h4", { className: "sub-name" }, product.subName || '\u00A0')),
|
|
94
|
+
React.createElement("div", { className: "price-package-wrapper" },
|
|
95
|
+
React.createElement(Price, { hidePrice: product.hidePrice, price: product.price, previousPrice: product.previousPrice })))),
|
|
96
|
+
children));
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=ProductCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProductCard.js","sourceRoot":"","sources":["../../../../src/components/CategoryPage/ProductCard.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import { useTracker } from '@jetshop/core/analytics/Analytics';
|
|
13
|
+
import { trackListEvent } from '@jetshop/core/analytics/tracking';
|
|
14
|
+
import React, { useEffect } from 'react';
|
|
15
|
+
import { styled } from 'linaria/react';
|
|
16
|
+
import { css, cx } from 'linaria';
|
|
17
|
+
import { ProductCard } from './ProductCard';
|
|
18
|
+
import { theme } from '../Theme';
|
|
19
|
+
import { Favourite } from '../ProductList/Favourite';
|
|
20
|
+
export const priceStyle = css `
|
|
21
|
+
[data-flight-price] {
|
|
22
|
+
display: flex;
|
|
23
|
+
}
|
|
24
|
+
.new-price {
|
|
25
|
+
color: #eb0000;
|
|
26
|
+
margin-right: 8px;
|
|
27
|
+
text-overflow: ellipsis;
|
|
28
|
+
white-space: nowrap;
|
|
29
|
+
overflow: hidden;
|
|
30
|
+
}
|
|
31
|
+
.old-price {
|
|
32
|
+
color: ${theme.colors.darkerGrey};
|
|
33
|
+
text-overflow: ellipsis;
|
|
34
|
+
white-space: nowrap;
|
|
35
|
+
overflow: hidden;
|
|
36
|
+
}
|
|
37
|
+
`;
|
|
38
|
+
export const Wrapper = styled('ul') `
|
|
39
|
+
display: flex;
|
|
40
|
+
flex-wrap: wrap;
|
|
41
|
+
justify-content: flex-start;
|
|
42
|
+
align-items: stretch;
|
|
43
|
+
margin-right: -${theme.space[1]};
|
|
44
|
+
margin-left: -${theme.space[1]};
|
|
45
|
+
|
|
46
|
+
.product-card {
|
|
47
|
+
line-height: 19px;
|
|
48
|
+
min-width: 0;
|
|
49
|
+
|
|
50
|
+
width: 50%;
|
|
51
|
+
${theme.above.md} {
|
|
52
|
+
width: 33.333%;
|
|
53
|
+
}
|
|
54
|
+
${theme.above.lg} {
|
|
55
|
+
width: 25%;
|
|
56
|
+
}
|
|
57
|
+
a {
|
|
58
|
+
margin: 0 0.5em 2em 0.5em;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
`;
|
|
62
|
+
export function isAboveFold(index) {
|
|
63
|
+
return index < 4;
|
|
64
|
+
}
|
|
65
|
+
export function ProductGrid(_a) {
|
|
66
|
+
var { products, listName, category = '', loading, className, categoryPath } = _a, rest = __rest(_a, ["products", "listName", "category", "loading", "className", "categoryPath"]);
|
|
67
|
+
const track = useTracker();
|
|
68
|
+
useEffect(() => {
|
|
69
|
+
// Dont track anything if there are no products to render
|
|
70
|
+
if (!products || products.length === 0)
|
|
71
|
+
return;
|
|
72
|
+
// Otherwise track a list view event
|
|
73
|
+
track(trackListEvent({ listName, products, category }));
|
|
74
|
+
}, [listName, products, track, category]);
|
|
75
|
+
if (!products)
|
|
76
|
+
return null;
|
|
77
|
+
return (React.createElement(Wrapper, { "data-testid": "product-grid", className: cx('product-grid', className, priceStyle) }, products.map((product, index) => {
|
|
78
|
+
return (React.createElement(ProductCard, Object.assign({ key: index + ':' + product.articleNumber, product: product, style: { opacity: loading ? 0.5 : 1 }, list: listName, categoryPath: categoryPath, loadImageEagerly: isAboveFold(index) }, rest),
|
|
79
|
+
React.createElement(Favourite, { product: product, style: {
|
|
80
|
+
position: 'absolute',
|
|
81
|
+
padding: '0.5em',
|
|
82
|
+
fontSize: '1.5em',
|
|
83
|
+
top: 0,
|
|
84
|
+
right: '0.5em'
|
|
85
|
+
} })));
|
|
86
|
+
})));
|
|
87
|
+
}
|
|
88
|
+
export default ProductGrid;
|
|
89
|
+
//# sourceMappingURL=ProductGrid.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProductGrid.js","sourceRoot":"","sources":["../../../../src/components/CategoryPage/ProductGrid.js"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACjC,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAErD,MAAM,CAAC,MAAM,UAAU,GAAG,GAAG,CAAA;;;;;;;;;;;;aAYhB,KAAK,CAAC,MAAM,CAAC,UAAU;;;;;CAKnC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;;;;;mBAKhB,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;kBACf,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;;;;;;;MAO1B,KAAK,CAAC,KAAK,CAAC,EAAE;;;MAGd,KAAK,CAAC,KAAK,CAAC,EAAE;;;;;;;CAOnB,CAAC;AAEF,MAAM,UAAU,WAAW,CAAC,KAAK;IAC/B,OAAO,KAAK,GAAG,CAAC,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,EAQ3B;QAR2B,EAC1B,QAAQ,EACR,QAAQ,EACR,QAAQ,GAAG,EAAE,EACb,OAAO,EACP,SAAS,EACT,YAAY,OAEb,EADI,IAAI,cAPmB,4EAQ3B,CADQ;IAEP,MAAM,KAAK,GAAG,UAAU,EAAE,CAAC;IAC3B,SAAS,CAAC,GAAG,EAAE;QACb,yDAAyD;QACzD,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAE/C,oCAAoC;QACpC,KAAK,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC1D,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;IAE1C,IAAI,CAAC,QAAQ;QAAE,OAAO,IAAI,CAAC;IAE3B,OAAO,CACL,oBAAC,OAAO,mBACM,cAAc,EAC1B,SAAS,EAAE,EAAE,CAAC,cAAc,EAAE,SAAS,EAAE,UAAU,CAAC,IAEnD,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;QAC/B,OAAO,CACL,oBAAC,WAAW,kBACV,GAAG,EAAE,KAAK,GAAG,GAAG,GAAG,OAAO,CAAC,aAAa,EACxC,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EACrC,IAAI,EAAE,QAAQ,EACd,YAAY,EAAE,YAAY,EAC1B,gBAAgB,EAAE,WAAW,CAAC,KAAK,CAAC,IAChC,IAAI;YAER,oBAAC,SAAS,IACR,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE;oBACL,QAAQ,EAAE,UAAU;oBACpB,OAAO,EAAE,OAAO;oBAChB,QAAQ,EAAE,OAAO;oBACjB,GAAG,EAAE,CAAC;oBACN,KAAK,EAAE,OAAO;iBACf,GACD,CACU,CACf,CAAC;IACJ,CAAC,CAAC,CACM,CACX,CAAC;AACJ,CAAC;AAED,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import { useTracker } from '@jetshop/core/analytics/Analytics';
|
|
13
|
+
import { trackListEvent } from '@jetshop/core/analytics/tracking';
|
|
14
|
+
import React, { useEffect, useMemo } from 'react';
|
|
15
|
+
import { css, cx } from 'linaria';
|
|
16
|
+
import { ProductCard } from './ProductCard';
|
|
17
|
+
import { isAboveFold, priceStyle } from './ProductGrid';
|
|
18
|
+
import { WindowGrid } from '@jetshop/ui/WindowGrid';
|
|
19
|
+
const container = css `
|
|
20
|
+
display: flex;
|
|
21
|
+
flex-direction: row;
|
|
22
|
+
flex-wrap: wrap;
|
|
23
|
+
margin: 0 -0.5em 1em;
|
|
24
|
+
`;
|
|
25
|
+
const defaultStyle = css `
|
|
26
|
+
flex: 0 0 auto;
|
|
27
|
+
width: 25%;
|
|
28
|
+
`;
|
|
29
|
+
function ProductGridWindow(_a) {
|
|
30
|
+
var { id, products, listName, loading, className, prevOffset, itemsPerRow, categoryPath, category = '' } = _a, rest = __rest(_a, ["id", "products", "listName", "loading", "className", "prevOffset", "itemsPerRow", "categoryPath", "category"]);
|
|
31
|
+
// Track product listing
|
|
32
|
+
const track = useTracker();
|
|
33
|
+
useEffect(() => {
|
|
34
|
+
// Dont track anything if there are no products to render
|
|
35
|
+
if (!products || products.length === 0)
|
|
36
|
+
return;
|
|
37
|
+
// Otherwise track a list view event
|
|
38
|
+
track(trackListEvent({ listName, products, category }));
|
|
39
|
+
}, [listName, products, track, category]);
|
|
40
|
+
const renderProduct = useMemo(() => ({ item: product, style, innerRef }) => (React.createElement("div", { className: defaultStyle, style: style, ref: innerRef },
|
|
41
|
+
React.createElement(ProductCard, { key: product.articleNumber, product: product, as: "div", categoryPath: categoryPath, loadImageEagerly: isAboveFold(product.index) }))), [categoryPath]);
|
|
42
|
+
const items = useMemo(() => {
|
|
43
|
+
return products.map((product, index) => (Object.assign(Object.assign({}, product), { index })));
|
|
44
|
+
}, [products]);
|
|
45
|
+
return (React.createElement(WindowGrid, { id: id, itemsPerRow: [2, null, 3, 4], items: items, prevOffset: prevOffset, className: cx(container, priceStyle), component: renderProduct }));
|
|
46
|
+
}
|
|
47
|
+
export default ProductGridWindow;
|
|
48
|
+
//# sourceMappingURL=ProductGridWindow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProductGridWindow.js","sourceRoot":"","sources":["../../../../src/components/CategoryPage/ProductGridWindow.js"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAClD,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,MAAM,SAAS,GAAG,GAAG,CAAA;;;;;CAKpB,CAAC;AAEF,MAAM,YAAY,GAAG,GAAG,CAAA;;;CAGvB,CAAC;AAEF,SAAS,iBAAiB,CAAC,EAW1B;QAX0B,EACzB,EAAE,EACF,QAAQ,EACR,QAAQ,EACR,OAAO,EACP,SAAS,EACT,UAAU,EACV,WAAW,EACX,YAAY,EACZ,QAAQ,GAAG,EAAE,OAEd,EADI,IAAI,cAVkB,+GAW1B,CADQ;IAEP,wBAAwB;IACxB,MAAM,KAAK,GAAG,UAAU,EAAE,CAAC;IAC3B,SAAS,CAAC,GAAG,EAAE;QACb,yDAAyD;QACzD,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAE/C,oCAAoC;QACpC,KAAK,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC1D,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;IAE1C,MAAM,aAAa,GAAG,OAAO,CAC3B,GAAG,EAAE,CACH,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,CACrC,CACE,6BAAK,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,QAAQ;QACvD,oBAAC,WAAW,IACV,GAAG,EAAE,OAAO,CAAC,aAAa,EAC1B,OAAO,EAAE,OAAO,EAChB,EAAE,EAAC,KAAK,EACR,YAAY,EAAE,YAAY,EAC1B,gBAAgB,EAAE,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,GAC5C,CACE,CACP,EACL,CAAC,YAAY,CAAC,CACf,CAAC;IAEF,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,EAAE;QACzB,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,iCAAM,OAAO,KAAE,KAAK,IAAG,CAAC,CAAC;IACnE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEf,OAAO,CACL,oBAAC,UAAU,IACT,EAAE,EAAE,EAAE,EACN,WAAW,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAC5B,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,UAAU,EACtB,SAAS,EAAE,EAAE,CAAC,SAAS,EAAE,UAAU,CAAC,EACpC,SAAS,EAAE,aAAa,GACxB,CACH,CAAC;AACJ,CAAC;AAED,eAAe,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import PaginationContext from '@jetshop/core/components/Pagination/PaginationContext';
|
|
2
|
+
import t from '@jetshop/intl';
|
|
3
|
+
import { PaginationBehaviour } from '@jetshop/ui/Pagination';
|
|
4
|
+
import { styled } from 'linaria/react';
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import CategoryHeader from '../CategoryPage/CategoryHeader';
|
|
7
|
+
import MaxWidth from '../Layout/MaxWidth';
|
|
8
|
+
import { Pagination } from '../Pagination/Pagination';
|
|
9
|
+
import { theme } from '../Theme';
|
|
10
|
+
import CategoryHeaderLoadingState from './CategoryHeaderLoadingState';
|
|
11
|
+
import Filters from './Filters';
|
|
12
|
+
import ProductGrid from './ProductGrid';
|
|
13
|
+
const Container = styled(MaxWidth) `
|
|
14
|
+
padding-top: 2rem;
|
|
15
|
+
${theme.above.sm} {
|
|
16
|
+
padding-top: 2rem;
|
|
17
|
+
}
|
|
18
|
+
`;
|
|
19
|
+
const CategoryWrapper = styled('div') ``;
|
|
20
|
+
const ProductNumber = styled('p') `
|
|
21
|
+
text-transform: uppercase;
|
|
22
|
+
font-size: 12px;
|
|
23
|
+
color: #707070;
|
|
24
|
+
letter-spacing: 0.5px;
|
|
25
|
+
margin-top: 2rem;
|
|
26
|
+
margin-bottom: 0.5rem;
|
|
27
|
+
`;
|
|
28
|
+
const Category = ({ category, result }) => {
|
|
29
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
|
30
|
+
if (!category) {
|
|
31
|
+
return (React.createElement(CategoryWrapper, null,
|
|
32
|
+
React.createElement(CategoryHeaderLoadingState, null),
|
|
33
|
+
";"));
|
|
34
|
+
}
|
|
35
|
+
return (React.createElement(CategoryWrapper, null,
|
|
36
|
+
React.createElement(React.Fragment, null,
|
|
37
|
+
React.createElement(CategoryHeader, { category: category, parents: (_b = (_a = result === null || result === void 0 ? void 0 : result.data) === null || _a === void 0 ? void 0 : _a.route) === null || _b === void 0 ? void 0 : _b.parents, breadcrumbs: (_d = (_c = result === null || result === void 0 ? void 0 : result.data) === null || _c === void 0 ? void 0 : _c.route) === null || _d === void 0 ? void 0 : _d.breadcrumbs }),
|
|
38
|
+
React.createElement(Container, null,
|
|
39
|
+
React.createElement(Filters, { filters: ((_e = category.products) === null || _e === void 0 ? void 0 : _e.filters) || [], sortOrders: ((_f = category.products) === null || _f === void 0 ? void 0 : _f.sortOrders) || [], result: result }),
|
|
40
|
+
React.createElement("div", null,
|
|
41
|
+
React.createElement(ProductNumber, null, t('{totalProducts} Products', {
|
|
42
|
+
totalProducts: (_g = category.products) === null || _g === void 0 ? void 0 : _g.totalResults
|
|
43
|
+
})),
|
|
44
|
+
React.createElement(ProductGrid, { products: category.products.result, listName: category.name, categoryPath: category.isDynamic ? null : (_h = result === null || result === void 0 ? void 0 : result.data) === null || _h === void 0 ? void 0 : _h.route, category: ((_l = (_k = (_j = result === null || result === void 0 ? void 0 : result.data) === null || _j === void 0 ? void 0 : _j.route) === null || _k === void 0 ? void 0 : _k.breadcrumbs) === null || _l === void 0 ? void 0 : _l.join('/')) || '', loading: result.loading, imageSizes: [1 / 2, 1 / 2, 1 / 3, 1 / 4] })),
|
|
45
|
+
React.createElement(PaginationContext.Consumer, null, props => {
|
|
46
|
+
var _a;
|
|
47
|
+
return (React.createElement(PaginationBehaviour, Object.assign({}, props, { total: (_a = category.products) === null || _a === void 0 ? void 0 : _a.totalResults }), props => React.createElement(Pagination, Object.assign({}, props))));
|
|
48
|
+
})))));
|
|
49
|
+
};
|
|
50
|
+
export default Category;
|
|
51
|
+
//# sourceMappingURL=StandardCategoryPage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StandardCategoryPage.js","sourceRoot":"","sources":["../../../../src/components/CategoryPage/StandardCategoryPage.js"],"names":[],"mappings":"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"}
|