{"version":3,"sources":["webpack:///./scripts/Server/render-wrapper.js","webpack:///./scripts/Actions/Error.action.js","webpack:///./scripts/Actions/Cart.action.js","webpack:///./scripts/Services/translation.ts","webpack:///./scripts/Actions/Overlay.action.js","webpack:///./scripts/styling/mixins/breakpoints.ts","webpack:///./scripts/styling/mixins/colors.ts","webpack:///./scripts/styling/utils/flex.ts","webpack:///./scripts/Components/SideMenu/styles/SideMenu.styling.ts","webpack:///./scripts/Components/SideMenu/SideMenu.tsx","webpack:///./scripts/styling/mixins/typography.ts","webpack:///./scripts/Components/Inputs/styles/Inputs.styled.ts","webpack:///./scripts/Components/Inputs/Input.tsx","webpack:///./scripts/Components/QuantityInput/QuantityInput.tsx","webpack:///./scripts/Components/StockStatus/StockStatus.tsx","webpack:///./scripts/Components/OrderRowProductCard/OrderRowProductCard.tsx","webpack:///./scripts/Hooks/useTypedSelector.ts","webpack:///./scripts/styling/mixins/buttons.ts","webpack:///./scripts/Components/Button.tsx","webpack:///./scripts/Components/MiniCart/MiniCart.tsx","webpack:///./scripts/Components/MiniCart/MiniCartIcon.tsx","webpack:///./scripts/Components/MiniCart/MiniCartButton.tsx","webpack:///./scripts/Components/Checkout/utils/Checkout.SectionHeader.tsx","webpack:///./scripts/Components/Checkout/utils/Checkout.Section.tsx","webpack:///./scripts/Components/Checkout/utils/Checkout.SectionContent.tsx","webpack:///./scripts/Hooks/useDebouncedOnChange.js","webpack:///./scripts/Actions/Checkout.action.js","webpack:///./scripts/Components/Inputs/TextArea.tsx","webpack:///./scripts/Components/Checkout/Checkout.AdditionalOrderInfo.tsx","webpack:///./scripts/Components/Checkout/utils/Checkout.SectionFooter.tsx","webpack:///./scripts/Components/Chip.tsx","webpack:///./scripts/Components/Checkout/Checkout.Discount.tsx","webpack:///./scripts/Components/Checkout/Checkout.OrderSummary.tsx","webpack:///./scripts/styling/utils/visibility.ts","webpack:///./scripts/Components/Checkout/Checkout.Cart.tsx","webpack:///./scripts/Components/Checkout/utils/Checkout.ValidationSchema.ts","webpack:///./scripts/Components/Inputs/Checkbox.tsx","webpack:///./scripts/Components/Checkout/Checkout.ConfirmOrder.tsx","webpack:///./scripts/Components/Inputs/Radiobutton.tsx","webpack:///./scripts/Components/Checkout/utils/Checkout.Radio.tsx","webpack:///./scripts/Components/Checkout/Checkout.DeliveryMethods.tsx","webpack:///./scripts/Components/Checkout/Checkout.PaymentMethods.tsx","webpack:///./scripts/Components/Dropdown.tsx","webpack:///./scripts/styling/utils/grid.ts","webpack:///./scripts/Components/Checkout/styles/Checkout.PrivateCustomerInfo.styling.ts","webpack:///./scripts/Components/Checkout/Checkout.PrivateCustomerInfo.tsx","webpack:///./scripts/Components/Checkout/Checkout.BusinessCustomerInfo.tsx","webpack:///./scripts/Components/Checkout/Checkout.EmptyCart.tsx","webpack:///./scripts/Components/Checkout/styles/Checkout.styling.ts","webpack:///./scripts/Components/DynamicComponent.js","webpack:///./scripts/Components/Payments/PaymentWidget.js","webpack:///./scripts/Components/Checkout/Ingrid/IngridDeliveryCheckout.service.ts","webpack:///./scripts/Components/Checkout/Ingrid/IngridDeliveryCheckout.tsx","webpack:///./scripts/Components/Checkout/Checkout.Signup.tsx","webpack:///./scripts/Components/Checkout/utils/Checkout.Message.tsx","webpack:///./scripts/Components/Checkout/Checkout.tsx","webpack:///./scripts/Components/Collapsible.tsx","webpack:///./scripts/Components/ProductFiltering/FilterOptions/FilterCheckbox.tsx","webpack:///./scripts/Components/ProductFiltering/FilterOptions/FilterRangeSlider.tsx","webpack:///./scripts/Components/ProductFiltering/FilterInput.tsx","webpack:///./scripts/Components/ProductFiltering/FilterSearchInput.tsx","webpack:///./scripts/Components/ProductFiltering/FilterGroupElement.tsx","webpack:///./scripts/Components/ProductFiltering/ProductFiltering.tsx","webpack:///./scripts/Components/ProductSorting/ProductSorting.tsx","webpack:///./scripts/Services/Cart.service.js","webpack:///./icons/refresh.svg","webpack:///./scripts/Components/LoadingSpinner.tsx","webpack:///./scripts/Actions/BuyButton.action.ts","webpack:///./scripts/Actions/ProductPage.action.ts","webpack:///./scripts/Components/BuyButton/BuyButton.tsx","webpack:///./scripts/Components/FilterBar/ProductSortingRadios.tsx","webpack:///./scripts/Components/ProductListing/CategoryNavigation.tsx","webpack:///./scripts/Components/FilterBar/CategoriesMenu.tsx","webpack:///./scripts/Components/FilterBar/FilterMenu.tsx","webpack:///./scripts/Components/FilterBar/FilterBarButtons.tsx","webpack:///./scripts/Components/FilterBar/FilterBar.tsx","webpack:///./scripts/Actions/Login.action.ts","webpack:///./scripts/Components/MyPages/MyPagesMobileMenu.tsx","webpack:///./scripts/Components/MyPages/MyPagesDesktopMenu.tsx","webpack:///./scripts/Components/MyPages/styles/MyPagesForm.styling.ts","webpack:///./scripts/Actions/UserInfo.action.ts","webpack:///./scripts/Hooks/useTypedDispatch.ts","webpack:///./scripts/Components/EditorString/EditorString.tsx","webpack:///./scripts/Components/MyPages/MyPagesSettings.tsx","webpack:///./scripts/Actions/Order.action.ts","webpack:///./scripts/Components/MyPages/ui/OrderListItemMobile.tsx","webpack:///./scripts/Components/MyPages/ui/OrderListItemDesktop.tsx","webpack:///./scripts/Services/Pagination.service.ts","webpack:///./scripts/Components/Pagination.tsx","webpack:///./scripts/Components/MyPages/ui/SkeletonListItemDesktop.tsx","webpack:///./scripts/Components/MyPages/ui/SkeletonListItemMobile.tsx","webpack:///./scripts/Components/MyPages/MyPagesOrderHistory.tsx","webpack:///./scripts/Components/OrderDetail/ui/ProductCard.tsx","webpack:///./scripts/Components/OrderDetail/styles/OrderDetailStyling.ts","webpack:///./scripts/Components/ResponsiveImage/ResponsiveImage.tsx","webpack:///./scripts/Components/OrderDetail/OrderDetail.tsx","webpack:///./scripts/Components/MyPages/MyPagesOrderDetail.tsx","webpack:///./scripts/Actions/Person.action.ts","webpack:///./scripts/Components/MyPages/ui/UserListItemMobile.tsx","webpack:///./scripts/Components/MyPages/ui/UserListItemDesktop.tsx","webpack:///./scripts/Components/MyPages/MyPagesUsers.tsx","webpack:///./scripts/Components/MyPages/MyPagesAddUser.tsx","webpack:///./scripts/Components/MyPages/MyPagesEditUser.tsx","webpack:///./scripts/Actions/Address.action.js","webpack:///./scripts/Components/MyPages/ui/AddressListItemDesktop.tsx","webpack:///./scripts/Components/MyPages/ui/AddressListItemMobile.tsx","webpack:///./scripts/Components/MyPages/MyPagesAddresses.tsx","webpack:///./scripts/Components/MyPages/MyPagesAddAddress.tsx","webpack:///./scripts/Components/MyPages/MyPagesEditAddress.tsx","webpack:///./scripts/Components/MyPages/ui/ScrollToTop.tsx","webpack:///./scripts/Components/MyPages/MyPagesContainer.tsx","webpack:///./scripts/Components/TestContainerForReact.js","webpack:///./scripts/Components/MegaMenu/MegaMenu.tsx","webpack:///./scripts/Components/Navigation/NavigationLink.tsx","webpack:///./scripts/Components/Navigation/Navigation.tsx","webpack:///./scripts/Components/FullscreenImageSlider/FullscreenImageSlider.tsx","webpack:///./scripts/Components/ProductPage/Styles/ProductPage.ImageSliderStyling.ts","webpack:///./scripts/Components/ProductCards/styles/ProductCard.styling.ts","webpack:///./scripts/Components/ProductTags/ProductTag.tsx","webpack:///./scripts/styling/mixins/productTag.ts","webpack:///./scripts/Components/ProductPage/ProductPage.ImageSlider.tsx","webpack:///./scripts/Blocks/BannerBlock/Styles/Banner-item.styling.ts","webpack:///./scripts/Components/Dialog/Dialog.tsx","webpack:///./scripts/Components/NavigatorCTA/NavigatorCTADialog/NavigatorCTADialogItem.tsx","webpack:///./scripts/Components/NavigatorCTA/NavigatorCTADialog/NavigatorCTADialog.tsx","webpack:///./scripts/Components/NavigatorCTA/NavigatorCTAHeaderButton.tsx","webpack:///./scripts/Blocks/BannerBlock/_banner-item.tsx","webpack:///./scripts/Blocks/BannerBlock/Styles/Banner-Slider.styling.ts","webpack:///./scripts/Blocks/BannerBlock/Styles/Banner-block.styling.ts","webpack:///./scripts/Blocks/BannerBlock/BannerBlock.tsx","webpack:///./scripts/Blocks/BannerBlock/BannerSliderBlock.tsx","webpack:///./scripts/Components/ProductCards/ProductCardBuyButton.tsx","webpack:///./scripts/Components/Lipscore/ProductCard.LipscoreStars.tsx","webpack:///./scripts/Components/ProductCards/ProductCard.tsx","webpack:///./scripts/Blocks/ProductBlockNoSlider.tsx","webpack:///./scripts/Blocks/ProductSlider.tsx","webpack:///./scripts/Components/ProductList.HeaderText.tsx","webpack:///./scripts/Components/ActiveFilterChips/FilterGroupChips.tsx","webpack:///./scripts/Components/ActiveFilterChips/ActiveFilterChips.tsx","webpack:///./scripts/Components/QuickSearch/QuickSearch.NoHit.tsx","webpack:///./scripts/Components/ProductCards/ProductCardQuickSearch.tsx","webpack:///./scripts/Components/QuickSearch/QuickSearch.LinkItem.tsx","webpack:///./scripts/Components/QuickSearch/QuickSearchResultTab.tsx","webpack:///./scripts/Actions/QuickSearch.action.js","webpack:///./scripts/Components/QuickSearch/utils/QuickSearchResult.TabItem.tsx","webpack:///./scripts/Components/QuickSearch/QuickSearchResult.tsx","webpack:///./scripts/Components/QuickSearch/QuickSearch.InitialTab.tsx","webpack:///./scripts/Components/QuickSearch/styles/QuickSearch.styling.ts","webpack:///./scripts/Components/QuickSearch/QuickSearch.tsx","webpack:///./scripts/Components/ProgressBar/ProgressBar.tsx","webpack:///./scripts/Components/LoadMoreButton/LoadMoreButton.tsx","webpack:///./scripts/styling/variables/breakpoints.ts","webpack:///./scripts/Hooks/useBreakpoint.ts","webpack:///./scripts/Hooks/useWindowSize.js","webpack:///./scripts/Components/ProductListing/ProductListingResizeObserver.js","webpack:///./scripts/Components/ProductCards/ProductCardPlaceholder.tsx","webpack:///./scripts/Components/ProductCards/styles/ProductCardLandscape.styling.ts","webpack:///./scripts/Components/ProductCards/ProductCardLandscape.tsx","webpack:///./scripts/Components/ProductCards/ProductCardLandscapePlaceholder.tsx","webpack:///./scripts/Components/ProductListing/ProductListing.tsx","webpack:///./scripts/Components/SearchResult/SearchResultLinkTab.tsx","webpack:///./scripts/Components/SearchResult/SearchResult.tsx","webpack:///./scripts/Actions/Search.action.js","webpack:///./scripts/Components/SearchResult/SearchNavigationItem.tsx","webpack:///./scripts/Components/SearchResult/SearchNavigation.tsx","webpack:///./scripts/Actions/Navigation.action.js","webpack:///./scripts/Components/Navigation/NavigationMobileTrigger.tsx","webpack:///./scripts/Components/Navigation/ui/MobileNavigationItem.tsx","webpack:///./scripts/Components/FloorHeatingGuide/FHGuideNavigationCard.tsx","webpack:///./scripts/Components/Navigation/styles/MobileMenu.styling.ts","webpack:///./scripts/Components/Navigation/ui/LanguageMenu.tsx","webpack:///./scripts/Components/Navigation/NavigationMobile.tsx","webpack:///./scripts/Components/Overlay.tsx","webpack:///./scripts/Components/VariantPicker/VariantMultiPicker.Dropdown.tsx","webpack:///./scripts/Components/VariantPicker/VariantPicker.Buttons.tsx","webpack:///./scripts/Components/Login/styles/LoginForm.styles.ts","webpack:///./scripts/Components/Login/ui/LoginChangePassword.tsx","webpack:///./scripts/Components/Login/ui/LoginForgotPassword.tsx","webpack:///./scripts/Components/Login/ui/LoginForm.tsx","webpack:///./scripts/Components/Login/ui/LoginSelectOrganization.tsx","webpack:///./scripts/Components/Login/LoginContainer.tsx","webpack:///./scripts/Components/Login/LoginModal.tsx","webpack:///./scripts/Components/Login/LoginPage.tsx","webpack:///./scripts/Components/Login/LoginModalTrigger.tsx","webpack:///./scripts/Components/Test.tsx","webpack:///./scripts/Actions/PriceHistory.actions.ts","webpack:///./scripts/Components/ProductPage/PriceHistoryModalTrigger.tsx","webpack:///./scripts/Blocks/LinkBlock/LinkBlock.tsx","webpack:///./scripts/Blocks/LinkCardBlock/LinkCardBlock.tsx","webpack:///./scripts/Components/OrderConfirmation/OrderConfirmation.tsx","webpack:///./scripts/Blocks/BrandsBlock.tsx","webpack:///./scripts/Components/TopMessage/TopMessage.tsx","webpack:///./scripts/Blocks/FaqAccordion.tsx","webpack:///./scripts/Components/FloorHeatingGuide/FHGuideCard.tsx","webpack:///./scripts/Blocks/UspBlock.tsx","webpack:///./scripts/Components/ProductListing/CategoryDescription.tsx","webpack:///./scripts/Components/FHGuide/_fhGuideContainerModuleItem.tsx","webpack:///./scripts/Components/FHGuide/_fhGuideContainerModule.tsx","webpack:///./scripts/Components/FHGuide/styles/FHGuideContainer.styling.ts","webpack:///./scripts/Components/FHGuide/FHGuideContainer.tsx","webpack:///./scripts/Components/ProductPage/ProductPage.VariantList.tsx","webpack:///./scripts/Components/ScrollToElementButton/ScrollToElementButton.tsx","webpack:///./scripts/Components/SubNavigationContainer/SubNavigationCollapsible.tsx","webpack:///./scripts/Components/SubNavigationContainer/SubNavigation.tsx","webpack:///./scripts/Components/SubNavigationContainer/SubNavigationContainer.tsx","webpack:///./scripts/Blocks/ProductsAndBannerBlock.tsx","webpack:///./scripts/Components/MaterialCalculator/MaterialCalculator.Advanced.tsx","webpack:///./scripts/Components/MaterialCalculator/MaterialCalculator.MoreInfo.tsx","webpack:///./scripts/Components/MaterialCalculator/MaterialCalculator.RoomItem.tsx","webpack:///./scripts/Components/MaterialCalculator/MaterialCalculator.FloorItemWrapper.tsx","webpack:///./scripts/Components/MaterialCalculator/utils/styles/ProductCardLandscape.styling.ts","webpack:///./scripts/Components/MaterialCalculator/utils/_materialCalculatorProductCard.tsx","webpack:///./scripts/Components/MaterialCalculator/utils/_materialCalculatorDisclaimerItem.tsx","webpack:///./scripts/Components/MaterialCalculator/MaterialCalculator.Disclaimer.tsx","webpack:///./scripts/Components/MaterialCalculator/MaterialCalculator.ProductListing.tsx","webpack:///./scripts/Services/MaterialCalculator.service.ts","webpack:///./scripts/Components/MaterialCalculator/utils/_materialCalculatorToggle.tsx","webpack:///./scripts/Components/MaterialCalculator/MaterialCalculator.Container.tsx","webpack:///./scripts/Components/QuotationRequest/ui/RoomContainer.tsx","webpack:///./scripts/Components/QuotationRequest/ui/FloorContainer.tsx","webpack:///./scripts/Components/QuotationRequest/ui/StatusMessage.tsx","webpack:///./scripts/Components/QuotationRequest/QuotationRequest.tsx","webpack:///./scripts/Components/ProductPage/ProductPageTechnicalTable.tsx","webpack:///./scripts/Components/ProductPage/ProductPageArticleNumber.tsx","webpack:///./scripts/Components/ProductPage/ProductPagePrice.tsx","webpack:///./scripts/Components/ProductPage/ProductPageStockStatus.tsx","webpack:///./scripts/Components/ProductPage/ProductPageBuyButton.tsx","webpack:///./scripts/Components/VariantPicker/Variant.Dropdown.tsx","webpack:///./scripts/Components/NewsLetter/NewsLetter.tsx","webpack:///./scripts/Components/ProductPage/PriceHistoryModal.tsx","webpack:///./scripts/Blocks/MegaMenuCardBlock/MegaMenuCardBlock.tsx","webpack:///./scripts/Components/ProductPage/ProductPageBrandImage.tsx","webpack:///./scripts/Blocks/SimilarProductsSlider.tsx","webpack:///./scripts/styling/razor/components/header.ts","webpack:///./scripts/styling/razor/components/top-menu.ts","webpack:///./scripts/styling/razor/components/breadcrumbs.ts","webpack:///./scripts/styling/razor/components/brands-list.ts","webpack:///./icons/check.svg","webpack:///./scripts/styling/razor/pages/product-page.tsx","webpack:///./scripts/styling/razor/pages/error-page.ts","webpack:///./scripts/styling/razor/pages/product-list.ts","webpack:///./scripts/styling/razor/block/link-block.ts","webpack:///./scripts/styling/razor/block/lipscoreservicereviews-block.ts","webpack:///./scripts/styling/razor/pages/checkout-page.ts","webpack:///./scripts/styling/razor/components/footer.ts","webpack:///./scripts/styling/razor/components/quicksearch.ts","webpack:///./scripts/styling/globals/blocks.ts","webpack:///./scripts/styling/globals/collapsible.ts","webpack:///./scripts/styling/globals/layout-two-columns.ts","webpack:///./scripts/styling/globals/normalize.ts","webpack:///./scripts/styling/globals/overlay.ts","webpack:///./scripts/styling/globals/skeleton.ts","webpack:///./scripts/styling/globals/index.ts","webpack:///./scripts/styling/utils/icons.ts","webpack:///./scripts/styling/utils/margins.ts","webpack:///./scripts/styling/utils/paddings.ts","webpack:///./scripts/styling/utils/misc.ts","webpack:///./scripts/styling/utils/text.ts","webpack:///./scripts/styling/global.styled.tsx","webpack:///./scripts/styling/razor/block/brands-block.ts","webpack:///./scripts/styling/razor/pages/article-page.ts","webpack:///./scripts/styling/razor/components/file-list.ts","webpack:///./scripts/styling/razor/components/link-list.ts","webpack:///./scripts/styling/razor/pages/news-list.ts","webpack:///./scripts/styling/razor/components/pagination.ts","webpack:///./scripts/styling/razor/pages/search-no-result-page.tsx","webpack:///./scripts/styling/razor/pages/content-page.ts","webpack:///./scripts/styling/razor/block/product-block.ts","webpack:///./scripts/styling/razor/pages/material-calculator.ts","webpack:///./scripts/Server/expose-styling.tsx","webpack:///./scripts/Components/NavigatorCTA/NavigatorCTAContainer.tsx","webpack:///./scripts/Server/expose-components.tsx"],"names":["Component","props","global","window","theme","Themes","ThemeName","store","LitiumReduxStore","catchError","ex","onError","dispatch","response","json","then","error","load","getState","get","cart","receive","catch","loadError","type","CART_LOAD_ERROR","payload","quantity","triggerAddToCartAnimation","CART_RECEIVE","setShowMiniCart","showMiniCart","CART_SHOW_MINI_CART","update","articleNumber","abortController","put","addToCartAnimationTimeoutId","addToCartAnimating","clearTimeout","setAddToCartAnimating","setTimeout","CART_ADD_TO_CART_ANIMATION","translate","key","addOverlay","componentName","onOverlayClick","OVERLAY_ADD_OVERLAY","removeOverlay","OVERLAY_REMOVE_OVERLAY","breakpoint","breakpointDirection","undefined","css","p","breakpoints","grid","breakpointValue","breakpointKeys","Object","keys","nextBreakpointIndex","indexOf","nextBreakpoint","length","nextBreakpointValue","breakpointValues","getMediaQuery","getColor","level","getColorFromVar","displayFlex","flexColumn","spaceBetween","justifyCenter","alignCenter","flex1","StyledSideMenu","styled","$from","$open","StyledSideMenuHeader","StyledSideMenuFooter","StyledSideMenuCloseButton","Icon","StyledSideMenuContent","forwardRef","id","duration","from","className","open","onClosed","showCloseButton","children","title","disableClosing","closeButton","components","ref","ready","setReady","useState","slideIn","setSlideIn","renderSideMenu","setRenderSideMenu","timeoutId","setTimeoutId","useDispatch","Error","useEffect","close","useCallback","OVERLAY_UPDATE_OVERLAY","newTimeoutId","parseFloat","CloseIcon","name","onClick","ReactDOM","trim","style","transitionDuration","Header","cloneElement","Content","Footer","document","body","text","size","typography","fontFamily","fontSizeText","fontWeights","lineHeights","header","fontFamilyHeader","fontSizeHeader","mobile","desktop","displayHeader","fontFamilyDisplayHeader","fontSizeDisplayHeader","getColorByState","inputState","StyledInputWrapper","$hasIcon","$inputState","StyledInput","inputs","borderColors","default","backgroundColor","paddings","$inputSize","rightPaddings","StyledIcon","iconSize","iconRightDistance","StyledTextArea","textareaSize","StyledTextAreaIcon","StyledCheckboxWrapper","StyledRadioButton","checkboxSizes","$checked","StyledInputIconWrapper","inputSize","icon","wrapperClassName","label","helperText","message","showMessageIcon","messageIcon","useMemo","htmlFor","required","StyledQuantityInput","StyledQuantityInputIcon","$disabled","onChange","showButtons","min","max","step","disabled","internalValue","setInternalValue","debounceTimer","setDebounceTimer","onInputChanged","value","parsedValue","e","target","role","inStock","description","stockType","iconName","iconColor","StyledOrderRowProductCard","StyledImageBackground","row","onRemoveClick","setAbortController","AbortController","onQuantityChange","image","href","url","src","brand","extraInfo","items","map","item","stockStatus","isFreeGift","totalCampaignPrice","totalPrice","useTypedSelector","useSelector","btnType","display","alignItems","justifyContent","buttons","backgroundColors","color","fontColors","border","borderWidth","borderRadius","hoverBackgroundColors","borderColor","hoverBorderColors","focusBackgroundColors","focusBorderColors","btnSize","padding","fontSize","fontSizes","lineHeight","btn","StyledButton","$btnType","$btnSize","$fullwidth","fontWeight","textTransform","fullwidth","as","useTheme","types","includes","console","warn","join","sizeClasses","StyledMiniCartSideMenu","SideMenu","StyledMiniCartHeader","StyledMiniCartFooter","StyledEmptyCart","StyledMiniCartContent","$empty","GlobalMiniCartStyling","createGlobalStyle","orderRows","emptyCartLink","orderTotal","checkoutUrl","state","hasOrderRows","reduce","prev","current","closeMiniCart","removeRow","rowSystemId","StyledMiniCartIcon","StyledQuantity","Math","StyledMiniCartButton","StyledCheckoutSectionHeader","StyledCheckoutSection","titleRight","headerClassName","initialValue","action","wait","setSignUp","signUp","CHECKOUT_SET_SIGN_UP","setCheckoutIsSubmitting","checkoutIsSubmitting","CHECKOUT_SET_IS_SUBMITTING","setDelivery","method","CHECKOUT_SET_DELIVERY","selectedDeliveryMethod","checkout","result","loadCart","paymentWidget","setPaymentWidget","submitError","setPayment","CHECKOUT_SET_PAYMENT","selectedPaymentMethod","modelState","payment","CHECKOUT_SET_PAYMENT_WIDGET","setDiscountCode","discountCode","CHECKOUT_SET_DISCOUNT_CODE","setUsedDiscountCodes","usedDiscountCodes","CHECKOUT_SET_USED_DISCOUNT_CODE","_submit","model","post","submitDone","redirectUrl","location","CHECKOUT_SUBMIT","CHECKOUT_SUBMIT_ERROR","setValidationErrors","validationErrors","CHECKOUT_SET_VALIDATION_ERRORS","setStatusSubmitButton","CHECKOUT_SET_STATUS_SUBMIT_BUTTON","enableConfirmButton","CheckoutSection","customerServiceMessage","comments","setOrderNote","useDebouncedOnChange","orderNote","CHECKOUT_SET_ORDER_NOTE","dangerouslySetInnerHTML","__html","placeholder","StyledChip","showDelete","chipProps","onDeleteClick","trimEnd","cursor","StyledDiscountWrapper","errors","inputDiscountCode","setInputDiscountCode","showDiscountInput","setShowDiscountInput","isLoading","setIsLoading","submitDiscount","async","code","onBlur","onKeyDown","remove","StyledPriceRow","StyledDiscountRow","StyledGrandTotal","StyledOrderSummary","StyledHeader","discount","deliveryCost","paymentCost","grandTotal","vat","hideFor","breakpointKey","only","showFor","getValues","lowerBound","nextBreakpointKeyIndex","nextBreakpointKey","upperBound","log","getValue","small","medium","large","xlarge","StyledSection","StyledContent","CheckoutSectionContent","StyledFooter","CheckoutSectionFooter","values","requiredTranslation","alwaysRequiredSchema","object","shape","acceptTermsOfCondition","boolean","oneOf","privateCustomerAddressSchema","lastName","string","nullable","firstName","address","zipCode","city","country","mixed","notOneOf","phoneNumber","email","privateCustomerAlternativeAddressSchema","businessCustomerDetailsSchema","selectedDeliveryAddressId","selectedBillingAddressId","checked","setChecked","sizeClass","stateClass","clsx","StyledCheckoutSectionFooter","customerDetails","alternativeAddress","showAlternativeAddress","isBusinessCustomer","onSubmit","placeOrder","notCustomerDetailFields","validate","abortEarly","stateKey","inner","err","path","newValidationErrors","onValidationFailed","acceptTermsError","CHECKOUT_ACCEPT_TERMS_OF_CONDITION","setAcceptTermsOfCondition","termsUrl","StyledCheckoutRadioWrapper","cost","logo","deliveryMethods","formattedPrice","imageUrl","alt","StyledMailIcon","paymentMethods","DesktopDropdownWrapper","$placeholderVisible","MobileDropdownWrapper","MobileSelectWrapper","StyledLabel","StyledSelect","$size","$showMobileLegend","StyledDesktopOption","$selected","StyledSelectIcon","StyledSelectIconMobile","options","selectedValue","initialSelectedValue","setSelectedValue","dropdownOpen","setDropdownOpen","selectedOption","find","o","_selectedValue","onOptionSelected","legendLabel","option","index","tabIndex","gridRowGutter","cells","fraction","fractions","generateGridTemplateColumns","span","section","rowMaxWidth","StyledPrivateCustomerWrapper","StyledLoginLink","CustomerInfoInput","validationSchema","onCustomerDetailsChange","errorMessage","validateOnBlur","schema","errorKey","validateAt","validationErrorsCopy","toLowerCase","event","showSignUp","authenticated","loginUrl","propName","CHECKOUT_SET_CUSTOMER_INFO","data","setCustomerDetails","setAlternativeAddress","autoComplete","countries","sectionFooter","CHECKOUT_SET_SHOW_ALTERNATIVE_ADDRESS","setShowAlternativeAddress","StyledCheckoutSectionContent","StyledCheckoutInfoWrapper","StyledCheckoutInfoContainer","StyledInfoIcon","StyledCheckoutDropdown","Dropdown","addressList","companyAddresses","filter","addressType","billingList","selectedDeliveryAddress","a","systemId","selectedBillingAddress","companyName","CHECKOUT_SET_SELECTED_DELIVERY_ADDRESS","setSelectedBillingAddress","CHECKOUT_SET_SELECTED_BILLING_ADDRESS","emptyCartMessage","StyledCheckout","loader","loading","lazy","Suspense","fallback","scriptPattern","scriptFilePattern","extractScripts","domString","matches","html","scripts","scriptFiles","exec","replace","push","executeScript","domId","scriptContent","script","createElement","appendChild","createTextNode","getElementById","includeScript","srciptUrl","React","responseString","paymentSession","CheckoutWidget","DynamicComponent","args","renderWidget","replaceScriptNode","node","onLoad","tagName","isScriptNode","isExternalScript","parentNode","replaceChild","innerHTML","i","attributes","setAttribute","addEventListener","cloneScriptNode","childNodes","ingridDeliveryMethodId","uniqueContainerId","updateDependencies","selectedDeliveryMethodId","onShippingOptionChanged","htmlSnippet","setHtmlSnippet","ingridWidgetLoaded","setIngridWidgetLoaded","previousUpdateDeps","setPreviousUpdateDeps","wrapperRef","useRef","anyDepsHasChanged","some","idx","isEqual","updateIngridSession","initIngrid","handleApiError","onShippingMethodChanged","_sw","api","suspend","ok","resume","querySelector","on","meta","price_changed","shipping_method_changed","pickup_location_changed","external_method_id_changed","search_address_changed","category_name_changed","delivery_type_changed","session","getSession","debounce","ingridSession","status","updateSession","SignUp","sign","StyledMessage","numProducts","paymentWidgetVisibility","setPaymentWidgetVisibility","paymentOptionVisibility","setPaymentOptionVisibility","customerDetailsVisibility","setCustomerDetailsVisibility","deliveryWidgetVisibility","setDeliveryWidgetVisibility","confirmOrderVisibility","setConfirmOrderVisibility","signUpCheckboxVisibility","setSignUpCheckboxVisibility","shippingOptionVisibility","setShippingOptionVisibility","checkIntegrationTypeExist","integrationTypeCheck","integrationType","DeliveryMethods","resetVisibilityValues","PaymentIntegrationType","ShippingIntegrationType","updateKey","_force_update","labelClassName","contentClassName","onStateChange","externalStateChange","isOpen","externalIsOpen","hideBorder","setIsOpen","Collapse","isOpened","singleSelect","selectedOptions","setValues","parseInt","minValue","maxValue","onChangeTimer","setOnChangeTimer","Range","renderThumb","isDragged","renderTrack","onMouseDown","onTouchStart","background","getTrackBackground","colors","onSearch","setValue","matchingOptions","opt","showAll","showAllButtonVisible","onShowHideAllClick","onOptionChanged","filterId","optionId","onOptionChangedAction","queryProductFiltering","onRangeChanged","onRangeChangedAction","renderFilterOptions","filterGroupType","FilterGroupType","productFiltering","filters","showAllForFilters","setShowMoreForFilters","filterSearchResults","setFilterSearchResults","listCopy","splice","shouldShowAllFilters","filterSearchResultsCopy","hasOwnProperty","getFilterOptions","getFilterGroupLabel","Collapsible","slice","sortCriteria","selectedSortItem","sortItems","s","selected","query","onSortItemSelected","addToDataLayer","products","responseProducts","call","findIndex","gtmEcommerceItem","gtmEcommerceItems","dataLayerAddToCart","_path","assign","bind","arguments","source","prototype","apply","this","width","height","viewBox","xmlns","d","fill","setBuyButtonArticleNumber","BUY_BUTTON_SET_ARTICLE_NUMBER","setProductPageSelectedVariant","selectedVariant","PRODUCT_PAGE_SET_SELECTED_VARIANT","setProductPageSelectedVariantQuery","URLSearchParams","search","set","delete","toString","history","pushState","localArticleNumber","showQuantityInput","customOnClick","initialQuantity","disabledProp","variants","reducerArticleNumber","buyButton","setQuantity","showLoadingSpinner","setShowLoadingSpinner","BUY_BUTTON_SET_LOADING","setBuyButtonLoading","v","loadingSpinnerTimeout","isNaN","addToCart","receiveCart","alert","LoadingComponent","_label","StyledProductSortingList","StyledSortingItem","RadioButton","StyledCategoryNavigation","StyledCategoryLinks","StyledCategoryLink","isSelected","subNavigation","previousCategory","foundCategory","currentCategory","subCategories","links","l","sort","b","localeCompare","link","StyledCategoriesMenu","StyledFilterMenu","StyledProductFiltering","StyledProductFilteringFooter","GlobalFilterMenuStyling","currentMenu","setCurrentMenu","totalProductsCount","productListing","hasAnyOptionSelected","f","clearAllFilters","StyledFilterBarButtonWrapper","StyledFilterButton","Button","StyledFilterBar","$productListingType","ProductListingType","productListingType","setProductListingType","sortItem","setUsername","username","LOGIN_SET_USERNAME_PASSWORD","setLoginModalOpen","modalOpen","LOGIN_SET_MODAL_OPEN","setLoginMode","loginMode","LOGIN_SET_LOGIN_MODE","signOut","setMagicLinkModel","magicLinkModel","LOGIN_SET_MAGIC_LINK_MODEL","handleErrorResponse","setLoginFormLoading","LOGIN_ERROR","LOGIN_SET_IS_LOADING","handleLoginResponse","organizations","success","requestToken","localStorage","setItem","setRedirectUrl","mustChangePassword","LoginMode","LOGIN_SET_ORGANIZATIONS","onSuccessfulLogin","LOGIN_SET_REDIRECT_URL","reload","StyledMobileMenu","navigation","navigate","useNavigate","pathname","useLocation","userInfo","currentOrganizationName","defaultValue","StyledDesktopMenu","StyledMenuItem","StyledMenuAnchor","NavLink","StyledSignOut","to","end","StyledFormWrapper","StyledFormDropdown","BASE_ROUTE","res","isJson","headers","general","userInfoActions","useTypedDispatch","StyledEditorString","StyledGeneralMessage","StyledSuccessMessage","StyledZipCityWrapper","successMessage","setAddress","userInfoForm","setUserInfoForm","password","setPassword","confirmPassword","setConfirmPassword","confirmPasswordError","setConfirmPasswordError","setUserInfoValue","userInfoCopy","setAddressValue","_address","hasErrors","getErrorMessages","scrollTo","top","behavior","phone","preventDefault","saveUserInfo","finally","address1","careOf","saveAddress","mayEditLogin","saveUsername","savePassword","rootRoute","ORDER_SET_IS_LOADING","list","totalCount","currentPage","showOnlyMyOrders","mode","ViewMode","ORDER_RECEIVE","setError","ORDER_ERROR","setOrder","order","ORDER_SET_ORDER","StyledOrderMobileItem","externalOrderID","orderGrandTotal","orderDate","StyledOrderDesktopItem","getInterval","pageCount","currentPageIndex","displayedEntries","internalPageIndex","half","ceil","upperLimit","StyledPagination","StyledPaginationLink","$current","StyledPaginationIcon","PaginationItem","RenderFirstHalfItems","intervalStart","edgeEntries","renderItems","publicPageIndex","RenderMiddleItems","intervalEnd","RenderSecondHalfItems","StyledSkeletonWrapper","$cells","Array","StyledOrderHistory","orders","myPage","orderList","pager","setPager","setCurrentPageIndex","setShowOnlyMyOrders","generalError","pageIndex","pageSize","PaginationOptions","orderId","showOrderDetail","queryOrders","interval","calculatePager","onOrderClick","StyledProductCard","product","quantityString","StyledOrderDetail","sizeDefinitions","lazyLoad","imageClassName","smallestImage","orderedSizeDefinitions","fromWidth","img","srcSet","media","OrderDetailAddress","deliveryMethod","pickupLocation","address_lines","postal_code","organizationName","address2","isConfirmation","confirmationTitle","confirmationText","confirmationExtraText","confirmationReviewItems","deliveryAddress","deliveries","reviewItem","rel","responsiveImage","deliveryId","orderTotalDiscountAmount","orderTotalDeliveryCost","orderTotalFee","orderTotalVat","billingAddress","paymentMethod","StyledMyPagesOrderDetail","useParams","reorder","personSystemId","httpRemove","PERSON_RECEIVE","PERSON_ERROR","StyledUserMobileItem","person","removeUser","StyledUserDesktopItem","StyledMyPagesUsers","persons","personsList","queryPersons","setFirstName","setLastName","setEmail","setPhone","setRole","submitForm","setPerson","fetchUser","setPersonValue","personCopy","editPerson","addressSystemId","ADDRESS_RECEIVE","ADDRESS_ERROR","StyledAddressDesktopItem","removeAddress","StyledAddressMobileItem","StyledMyPagesAddresses","addresses","queryAddresses","countriesList","globalThis","LitiumConstants","setZipCode","setCity","setCountry","setPhoneNumber","addAddress","fetchAddress","addressCopy","editAddress","ScrollToTop","StyledMyPagesContainer","isB2bOnly","addAddressDescription","addUserDescription","addressDescription","editAddressDescription","editUserDescription","orderDescription","settingsDescription","userDescription","filteredNav","element","MyPagesAddresses","useStyles","createUseStyles","testKlass","primary","classes","onMegaMenuClose","onMouseOverMegaMenu","onMouseLeaveMegaMenu","blocks","blockContainerRef","uniqueId","blocksLoaded","setBlocksLoaded","hasRendered","setHasRendered","block","onMouseLeave","onMouseOver","subLink","subSubLink","isActive","onLinkHover","onMouseLeaveLink","right","contentLinks","rightContentLinks","activeMegaMenuLink","setActiveMegaMenuLink","megaMenuTimer","setMegaMenuTimer","blockElements","setBlockElements","getBlocks","blockSystemIds","dataset","blockElementsContainer","StyledSwiper","Swiper","StyledImageSliderWrapper","StyledCloseButton","StyledZoomInfo","$zoomInfoVisible","GlobalImageSliderStyling","images","initialSlide","contentRef","createRef","setOpen","isZoomed","setIsZoomed","zoomInfoVisible","setZoomInfoVisible","hasLoadedOriginalImage","setHasLoadedOriginalImage","imageCount","removeEventListener","onMouseOut","loop","slidesPerView","zoom","toggle","modules","Pagination","Thumbs","FreeMode","Zoom","onZoomChange","swiper","scale","slideIndex","onZoom","realIndex","pagination","dynamicBullets","dynamicMainBullets","hdSrc","originalSrc","MainSwiperMixin","StyledProductTagWrapper","StockStatus","StyledProductTag","tagStyle","productTags","borderStyle","textColor","tagSize","$tagSize","$tagId","tags","thumbsSwiper","setThumbsSwiper","fullscreenOpen","setFullscreenOpen","activeSlideIndex","setActiveSlideIndex","rendered","setRendered","productPage","sliderImages","margin","tag","thumbs","Navigation","onSlideChange","onSwiper","watchSlidesProgress","slidesPerGroup","thumbnailSrc","DialogContent","removePaddingTop","displayName","DialogHeader","headerContent","onClose","closeButtonAriaLabel","hideHeader","disableCloseOnOutsideClick","dialogRef","dialog","focusableElements","querySelectorAll","firstFocusableElement","lastFocusableElement","showModal","classList","add","lockFocusToModal","shiftKey","activeElement","focus","handleEscKeyPress","handleOutsideClick","contains","linkUrl","modalHeader","setItems","hasError","setHasError","fetchItems","btnSizeLarge","buttonText","headerText","isDesktop","isDialogOpen","setIsDialogOpen","mobileImageUrl","linkText","actionText","overlay","bodyText","triggerCTAModal","lazyLoadImage","hasLinkButton","StyledBannerSliderSection","swiperCss","swiperPagination","swiperNavigation","StyledBannerSection","banners","numPerRow","cellsClass","banner","StyledSwiperPlaceholder","slides","slide","isVariantListing","useLipscoreState","create","ratings","addRating","rating","Star","starState","fillRule","transform","productId","ratingValue","lipscore","round","lipscoreApiKey","Promise","_","reject","lipscoreLocale","fetch","fetchRating","getStarState","diff","buildUrl","brandLogoUrl","showRating","baseProductId","descriptionShort","fromPrice","useFromPrice","price","formattedCampaignPrice","StyledNoSliderProductBlock","variantOptions","StyledNoSwiperWrapper","StyledProductSwiper","renderSlider","setRenderSlider","clickable","StyledShowButton","StyledHidden","StyledFull","showMore","setShowMore","wordLength","resultSubstr","substring","lastIndexOf","filterGroup","chipText","clearFilterGroup","StyledActiveFilterChip","g","QuickSearchNoHitWrapper","StyledQuickSearchCard","StyledBrandImage","hasImage","imageSource","brandImageUrl","StyledLinkItem","QuickSearchResultItem","modelKey","QuickSearchTab","results","searchError","QUICK_SEARCH_ERROR","toggleInputActive","active","clear","quickSearch","QUICK_SEARCH_INPUT_ACTIVE","inputActive","QUICK_SEARCH_RECEIVE","showResult","activeTab","selectItem","selectedItem","QUICK_SEARCH_SELECT_ITEM","StyledNavigationItem","resultKey","translation","QUICK_SEARCH_ACTIVE_TAB","Wrapper","searchUrl","noHitHeader","noHitDescription","totalNumResults","total","curr","QuickSearchInitWrapper","sectionList","listItem","sectionTitle","sectionLinkList","subListItem","QuickSearchWrapper","QuickSearchInput","$inputActive","QuickSearchIcon","debouncedQuery","q","abort","searchContainer","searchInput","decodeURIComponent","encodeURIComponent","QUICK_SEARCH_QUERY","setSearchQuery","clip","keyCode","selectedObject","handleKeyDown","progress","maxProgress","showLabel","progressPercent","LoadMoreButton","count","productsPerLoad","canLoadMore","crawlerCount","setCrawlerCount","windowWidth","initialWidth","innerWidth","initialHeight","innerHeight","setSize","updateSize","useWindowSize","currentBreakpoint","setCurrentBreakpoint","setBreakpointValues","setBreakpoints","_breakpoints","breakpointVars","obj","sortedValues","keyArray","sortedValue","nextValue","useBreakpoint","isMedium","getProductsPerRowForBreakpoint","setProductsPerRow","StyledLandscapeProductCard","StyledProductTagWrapperLandscape","StyledBrandLogo","cache","CellMeasurerCache","defaultWidth","minWidth","defaultHeight","fixedWidth","fixedHeight","oneColRowClass","isLoadingMore","isLoadingReverse","productsPerRow","gtmViewModel","rowCount","listRef","RowComponent","ProductComponent","ProductPlaceholderComponent","ProductCard","ProductCardPlaceholder","ProductCardLandscape","LandscapeProductCardPlaceholder","clearAll","recomputeRowHeights","pushEcommerce","isRowLoaded","loadMoreRows","startIndex","stopIndex","resolve","endIndex","setIsLoadingReverse","fetchProducts","rowRenderer","parent","productsForRow","rowIndex","columnIndex","isScrolling","onChildScroll","scrollTop","disableHeight","minimumBatchSize","threshold","onRowsRendered","registerChild","autoHeight","onScroll","rowHeight","addPlaceholderProducts","setIsLoadingMore","StyledResultLinkWrapper","StyledColumnWrapper","brandListing","pagesListing","categoryListing","setActiveTab","SEARCH_ACTIVE_TAB","StyledSearchNavigation","productListingHits","categoryListingHits","pagesListingHits","brandListingHits","setActiveTabAction","totalHits","setMobileMenuOpen","mobileMenuOpen","NAVIGATION_RECEIVE","StyledNavMobileTrigger","StyledIconWrapper","onLinkClick","StyledFloorNavigationCard","StyledMenuIcon","StyledCloseIcon","StyledHeaderImg","StyledLinks","StyledSocialWrapper","StyledFHGuideNavigationCard","GlobalNavigationMobileStyling","StyledLanguageMenu","currentCountry","setCurrentCountry","currentLanguage","setCurrentLanguage","logoUrl","fhGuide","navigatorCTAHeaderButtonText","navigationCTAModalHeader","socialMediaLinks","currentLink","setCurrentLink","previousLink","setPreviousLink","languageMenuOpen","setLanguageMenuOpen","onBackClick","mobileLinks","rightAligned","FHGuideNavigationCard","social","OVERLAY_CLASS","StyledOverlay","activeOverlays","disableOverlayClick","overlayClasses","c","classesToRemove","startsWith","component","removeOverlayAction","FIRST_VARIANT_VALUE","SECOND_VARIANT_VALUE","StyledVariantWrapper","$dropDownSize","variantPickerOptions","hasSelectedVariant","productItem","GetUniqueRows","Map","x","isAnyEnabled","variantId","firstVariantValue","firstVariantLabel","GetUniqueColumns","secondVariantValue","secondVariantLabel","rowOptions","setRowOptions","columnOptions","setColumnOptions","hasVariant","setHasVariant","setSelectedVariant","selectedRow","setSelectedRow","selectedColumn","setSelectedColumn","updateRowOptions","updateColumnOptions","selectVariant","_selectedVariant","selectedVariantObj","setSelectedArticleNumber","uniqueColumnOptions","uniqueAvailableColumnOptions","y","compare","getVariantValue","number","dropDownSize","firstVariant","secondVariant","StyledVariantButton","StyledLogin","StyledChangePasswordForm","login","newPassword","setNewPassword","passwordConfirmation","setPasswordConfirmation","oldPassword","submitChangePassword","StyledForgotPasswordForm","isSuccessful","setIsSuccessful","submitMagicLink","submitForgotPassword","StyledLoginForm","performLoginAction","StyledOrganizationForm","selectedOrganizationId","setSelectedOrganizationId","org","selectOrganization","StyledLoginError","StyledLoginModal","GlobalLoginModalStyling","StyledLoginContainer","StyledLoginWrapper","StyledLoginIcon","StyledSpan","showSearch","setPriceHistoryModalOpen","previouslyLowestPrice","numberOfDays","PRICE_HISTORY_SET_MODAL_OPEN","StyledPriceHistoryIcon","productPriceHistory","StyledLinkBlock","StyledWrapper","StyledLink","$allowThumbnails","allowThumbnails","Link","thumbnailUrl","StyledLinkCard","StyledOrderConfirmationWrapper","GlobalOrderConfirmationStyling","extraText","reviewItems","StyledBlockHeader","StyledBrandsList","$brandsCount","StyledBrandItem","brands","StyledTopMessageWrapper","bgColor","StyledTopMessage","setCookie","useCookies","StyledFaqWrapper","StyledCollapsible","faqList","faqItems","faq","StyledFloorGuideCard","$backgroundUrl","StyledGuideCardImg","StyledGuideCardDescription","StyledGuideCardIcon","backgroundUrl","GlobalUspStyling","StyledUspWrapper","StyledUspList","StyledUspItem","StyledCategoryDescription","$showMore","StyledExpandButton","GlobalCategoryDescriptionStyling","descriptionLength","setInputValue","val","handleInputChange","module","helpText","handleIsSelected","setSelected","itemIndex","Title","StyledFHContainer","StyledNoResults","showResults","setShowResults","setResults","btnDisabled","setBtnDisabled","guideModules","setGuideModules","HelpText","Type","SelectedChoiceIndex","Items","mapVal","objectIndex","selectionIndex","tempGuideModule","m2","Number","filterItem","Effect","CableLength","Area","Wetroom","FloorType","StyledProductPageVariantList","selector","iconBefore","iconAfter","IconElement","elementTopPosition","getBoundingClientRect","headerHeight","StyledCollapsibleIcon","$isOpen","$transitionDuration","StyledSecondLevelNavigationList","StyledNavigationList","SubNavigationCollapsible","secondLevelLink","StyledMobileCollapsible","StyledProductsWrapper","$numPerRow","StyledTitleWrapper","LeftBannerItemWrapper","$showBannerToRight","RightBannerItemWrapper","productsBlock","bannersBlock","showBannerToTheRight","bannerBlockItem","firstTwoProducts","remainingProducts","installationData","installationType","floorIndex","roomIndex","installationTypes","defaultDistanceToDistributor","materialCalculator","distanceToDistributor","setDistanceToDistributor","materialCalculatorActions","showCCInput","availableCCs","cc","showMillCheckbox","millSelfChecked","showTurnZoneInput","inputMode","turnZone","valueAsNumber","StyledMoreInfo","moreInfoTitle","moreInfoDescription","StyledFloorItem","floor","room","DisplayMoreInfo","calculateTurnZone","area","sqrt","toFixed","moreInfoOpen","setMoreInfoOpen","roomNo","JSON","stringify","parse","StyledMCFloorWrapper","floorNumber","rooms","floorId","marginRight","materialCalculatorFormulas","coilQuantity","coilLength","StyledDisclaimer","floors","shunt","disclaimerDescription","rotate","keyframes","StyledProductListing","gtmProducts","prod","gtmProduct","ecommerce","currencyCode","currency","addMultiple","StyledMcWrapperContainer","$error","productsLoading","materialCalculatorState","getProducts","ROOM_TYPES","ROOM_FLOORING","ROOM_MATERIAL","removeRoom","updateRoom","roomSpecs","setRoomSpecs","updatedRoomSpecs","yta","roomType","rum","flooring","typ","material","ERROR_CLASSES","updateFloor","onInvalid","setRooms","r","plan","setPlan","floorIdx","updatedRooms","roomIdx","addRoom","newRoom","v4","onRadioClick","removeErrorClasses","input","getElementsByName","forEach","radioButton","setStatus","QUOTATION_TYPE","termsAndConditionsLink","currentError","setCurrentError","generalInfo","setGeneralInfo","befintliga_vattenradiatorer","setFloors","setUserInfo","namn","adress","postnummer","ort","telefonnummer","fastighetsbeteckning","information","files","updatedFloors","updateUserInfo","updatedInfo","handleInvalidInput","updateGeneralInfo","onInputChange","scrollIntoView","inline","formData","FormData","append","objKey","j","roomKey","num","newFloor","changeFloorAmount","StyledTechnicalTable","StyledTableRow","StyledPlaceholderRow","variantSpecs","setVariantSpecs","dimension","effect","weight","spec","priceFrom","itemProp","content","campaignPrice","StyledStockStatusPlaceholder","isDisabled","setIsDisabled","variant","filteredVariant","StyledNewsLetterContainer","StyledNewsLetterForm","StyledNewsLetterText","newsLetterText","isSubmitting","setIsSubmitting","emailInputValue","setEmaiInputValue","request","test","submitNewsLetterSignUp","customModalStyles","zIndex","StyledModalContent","priceHistory","ariaHideApp","preventScroll","onRequestClose","shouldCloseOnOverlayClick","amountOfLinks","relationProducts","productList","setProductList","headerMainContentHeightMobile","headerQuickSearchHeightMobile","svgTest","ReactDOMServer","checkAsBase64","base64","collapsible","normalize","skeleton","layoutTwoColumns","fontRegular","fontBold","fontItalic","GlobalStyle","misc","visibility","icons","margins","globals","Global","ProductListing","renderWrapper","MiniCart","MiniCartButton","ProductFiltering","ProductSorting","MyPagesContainer","Checkout","BuyButton","FilterBar","QuickSearch","SearchResult","SearchNavigation","ProductBlockNoSlider","ProductListHeaderText","Navbar","TestContainerForReact","ProductPageImageSlider","BannerSliderBlock","BannerBlock","ProductSlider","ActiveFilterChips","NavigationMobileTrigger","NavigationMobile","Overlay","VariantMultiPickerDropdown","VariantPickerButtons","LoginModal","LoginPage","LoginModalTrigger","TopMessage","OrderConfirmation","ProductsAndBannerBlock","Test","LinkBlock","LinkCardBlock","BrandsBlock","EditorString","FaqAccordion","FloorHeatingNavigationCard","NavigatorCTAHeaderButton","UspBlock","ResponsiveImage","FHGuideContainer","NavigatorCTAContainer","FHGuideCard","CategoryDescription","ProductPageVariantList","ScrollToElementButton","MCContainer","QuotationRequest","SubNavigationContainer","ProductPageTechnicalTable","ProductPageArticleNumber","ProductPagePrice","VariantDropdown","NewsLetter","PriceHistoryModalTrigger","PriceHistoryModal","CategoryNavigation","MegaMenuCardBlock","ProductPageStockStatus","ProductPageBuyButton","ProductPageBrandImage","SimilarProductsSlider"],"mappings":"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","file":"654.cb8d101349938cdbbb1c.js","sourcesContent":["import React from 'react';\nimport { ThemeProvider } from 'styled-components';\nimport { Provider } from 'react-redux';\nimport store from '../store';\n\nconst renderWrapper = (Component, props = {}) =>\n global.window ? (\n \n \n \n \n \n ) : (\n \n \n \n );\n\nexport default renderWrapper;\n","export const catchError = (ex, onError) => (dispatch) => {\n if (ex.response) {\n ex.response.json().then((error) => dispatch(onError(error)));\n } else {\n dispatch(onError(ex));\n }\n};\n","import { get, put } from '../Services/http';\nimport { catchError } from './Error.action';\nimport {\n CART_LOAD_ERROR,\n CART_RECEIVE,\n CART_SHOW_MINI_CART,\n CART_ADD_TO_CART_ANIMATION,\n} from '../constants';\n\nexport const load = () => (dispatch, getState) => {\n return get('/api/cart')\n .then((response) => response.json())\n .then((cart) => {\n dispatch(receive(cart));\n })\n .catch((ex) => dispatch(catchError(ex, (error) => loadError(error))));\n};\n\nexport const loadError = (error) => ({\n type: CART_LOAD_ERROR,\n payload: {\n error,\n },\n});\n\nexport const receive = (cart) => (dispatch, getState) => {\n if (getState().cart.quantity != cart.quantity) {\n dispatch(triggerAddToCartAnimation());\n }\n\n return dispatch({\n type: CART_RECEIVE,\n payload: cart,\n });\n};\n\nexport const toggle = () => (dispatch, getState) => {\n dispatch(show(!getState().cart.showMiniCart));\n};\n\nexport const setShowMiniCart = (showMiniCart) => ({\n type: CART_SHOW_MINI_CART,\n payload: {\n showMiniCart,\n },\n});\n\nexport const update = (articleNumber, quantity, abortController = null) => (\n dispatch\n) => {\n return put(`/api/cart/update`, { articleNumber, quantity }, abortController)\n .then((response) => response.json())\n .then((cart) => dispatch(receive(cart)))\n .catch((ex) => dispatch(catchError(ex, (error) => loadError(error))));\n};\n\nlet addToCartAnimationTimeoutId;\nexport const triggerAddToCartAnimation = () => (dispatch, getState) => {\n const addToCartAnimating = getState().cart.addToCartAnimating;\n if (!addToCartAnimating) {\n if (addToCartAnimationTimeoutId) {\n clearTimeout(addToCartAnimationTimeoutId);\n }\n\n dispatch(setAddToCartAnimating(true));\n addToCartAnimationTimeoutId = setTimeout(\n () => dispatch(setAddToCartAnimating(false)),\n 500\n );\n }\n};\n\nconst setAddToCartAnimating = (addToCartAnimating) => ({\n type: CART_ADD_TO_CART_ANIMATION,\n payload: {\n addToCartAnimating,\n },\n});\n","export const translate = (key: string) =>\n (global['LitiumTexts'] && global['LitiumTexts'][key]) || key;\n","import {\n OVERLAY_ADD_OVERLAY,\n OVERLAY_CLOSE_OVERLAY,\n OVERLAY_REMOVE_OVERLAY,\n OVERLAY_UPDATE_OVERLAY,\n} from '../constants';\n\nexport const addOverlay = (componentName, onOverlayClick) => ({\n type: OVERLAY_ADD_OVERLAY,\n payload: {\n componentName,\n onOverlayClick,\n },\n});\n\nexport const updateOverlay = (componentName, onOverlayClick) => ({\n type: OVERLAY_UPDATE_OVERLAY,\n payload: {\n componentName,\n onOverlayClick,\n },\n});\n\nexport const removeOverlay = (componentName) => ({\n type: OVERLAY_REMOVE_OVERLAY,\n payload: {\n componentName,\n },\n});\n\nexport const closeOverlay = () => ({\n type: OVERLAY_CLOSE_OVERLAY,\n payload: {\n activeOverlays: [],\n },\n});\n","import { css, DefaultTheme } from 'styled-components';\n\nexport type BreakpointDirection = 'up' | 'down' | 'only' | undefined;\n\nexport const getMediaQuery = (\n theme: DefaultTheme,\n breakpoint: string,\n breakpointDirection: BreakpointDirection = undefined\n) => {\n const breakpoints = theme.grid.breakpoints;\n const breakpointValue: string = breakpoints[breakpoint];\n\n if (!breakpointDirection || breakpointDirection == 'up') {\n return `@media screen and (min-width: ${breakpointValue})`;\n }\n\n const breakpointKeys = Object.keys(breakpoints);\n\n const nextBreakpointIndex = breakpointKeys.indexOf(breakpoint) + 1;\n const nextBreakpoint =\n nextBreakpointIndex < breakpointKeys.length\n ? breakpointKeys[nextBreakpointIndex]\n : null;\n const nextBreakpointValue: number | undefined = nextBreakpoint\n ? theme.grid.breakpointValues[nextBreakpoint]\n : null;\n\n switch (breakpointDirection) {\n default:\n return `@media screen and (min-width: ${breakpointValue})`;\n\n case 'down':\n if (nextBreakpointValue) {\n return `@media screen and (max-width: ${nextBreakpointValue - 1}px)`;\n }\n return `@media screen and (min-width: 0px)`;\n\n case 'only':\n if (nextBreakpointValue) {\n return `@media screen and (min-width: ${breakpointValue}) and (max-width: ${\n nextBreakpointValue - 1\n }px)`;\n }\n return `@media screen and (min-width: ${breakpointValue})`;\n }\n};\n\nexport const breakpoint = (\n breakpoint: string,\n breakpointDirection: BreakpointDirection = undefined\n) => css`\n ${(p) => getMediaQuery(p.theme, breakpoint, breakpointDirection)}\n`;\n","import { css } from 'styled-components';\nimport { getColorFromVar } from '../variables/colors';\n\nexport const getColor = (key: string, level?: number) =>\n css`\n ${(p) => getColorFromVar(p.theme, key, level)}\n `;\n","import { css } from 'styled-components';\n\nexport const displayFlex = css`\n display: flex;\n`;\nexport const flexRow = css`\n flex-direction: row;\n`;\nexport const flexColumn = css`\n flex-direction: column;\n`;\nexport const spaceBetween = css`\n justify-content: space-between;\n`;\nexport const justifyCenter = css`\n justify-content: center;\n`;\nexport const alignCenter = css`\n align-items: center;\n`;\nexport const alignEnd = css`\n align-items: flex-end;\n`;\nexport const alignStart = css`\n align-items: flex-start;\n`;\nexport const flexGrow = css`\n flex-grow: 1;\n`;\nexport const flex1 = css`\n flex: 1;\n`;\n","import { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport {\n alignCenter,\n displayFlex,\n flexColumn,\n justifyCenter,\n} from '../../../styling/utils/flex';\nimport Icon from '../../Icon';\n\ninterface StyledSideMenuProps {\n $from: string;\n $open: boolean;\n}\n\nexport const StyledSideMenu = styled.div`\n ${displayFlex}\n ${flexColumn}\n position: fixed;\n z-index: 50;\n top: 0;\n height: 100%;\n width: 100%;\n background-color: ${getColor('white')};\n transition: all ease-in-out 0.4s;\n max-width: 640px;\n\n ${breakpoint('medium')} {\n width: 640px;\n }\n\n left: ${(p) => (p.$from == 'left' ? '-100%' : 'unset')};\n right: ${(p) => (p.$from == 'right' ? '-100%' : 'unset')};\n\n &.open {\n left: ${(p) => (p.$from == 'left' && p.$open ? '0' : 'unset')};\n right: ${(p) => (p.$from == 'right' && p.$open ? '0' : 'unset')};\n }\n\n &.closing {\n left: ${(p) => (p.$from == 'left' ? '-100' : 'unset')};\n right: ${(p) => (p.$from == 'right' ? '-100' : 'unset')};\n }\n`;\n\nexport const StyledSideMenuHeader = styled.div`\n ${displayFlex}\n ${alignCenter}\n text-transform: capitalize;\n position: relative;\n border-bottom: 1px solid ${getColor('grey', 300)};\n max-height: 56px;\n padding: 1.6rem;\n`;\n\nexport const StyledSideMenuFooter = styled.div`\n ${displayFlex}\n ${justifyCenter}\n border-top: 1px solid ${getColor('grey', 300)};\n padding: 1.6rem;\n`;\n\nexport const StyledSideMenuCloseButton = styled(Icon)`\n position: absolute;\n top: 1.6rem;\n right: 1.6rem;\n cursor: pointer;\n font-size: 2.4rem;\n\n ${breakpoint('small', 'only')} {\n font-size: 2rem;\n }\n`;\n\nexport const StyledSideMenuContent = styled.div`\n padding-left: 1.6rem;\n padding-right: 1.6rem;\n gap: 1.6rem;\n`;\n","import React, {\n cloneElement,\n forwardRef,\n useCallback,\n useEffect,\n useState,\n} from 'react';\nimport ReactDOM from 'react-dom';\nimport { useDispatch } from 'react-redux';\nimport {\n addOverlay,\n removeOverlay,\n updateOverlay,\n} from '../../Actions/Overlay.action';\nimport {\n StyledSideMenu,\n StyledSideMenuCloseButton,\n StyledSideMenuContent,\n StyledSideMenuFooter,\n StyledSideMenuHeader,\n} from './styles/SideMenu.styling';\n\ninterface SideMenuProps {\n id: string;\n duration?: string;\n from?: string;\n className?: string;\n open?: boolean;\n onClosed: () => void;\n showCloseButton?: boolean;\n children?: React.ReactNode;\n title?: string;\n disableClosing?: boolean;\n closeButton?: any;\n components?: {\n Header?: React.FC;\n Footer?: React.FC;\n Content?: React.FC;\n };\n}\n\nexport default forwardRef(\n (\n {\n id,\n duration = '0.2s',\n from = 'right',\n className,\n open = false,\n onClosed,\n showCloseButton = true,\n children,\n title,\n disableClosing = false,\n closeButton = null,\n components = {},\n },\n ref\n ) => {\n const [ready, setReady] = useState(false);\n const [slideIn, setSlideIn] = useState(open);\n const [renderSideMenu, setRenderSideMenu] = useState(open);\n const [timeoutId, setTimeoutId] = useState();\n const dispatch = useDispatch();\n\n if (!id || id == '') {\n throw new Error(\n 'A unique side-menu \"id\" must be passed to side menu component'\n );\n }\n\n useEffect(() => {\n setReady(true);\n }, []);\n\n const close = useCallback(() => {\n if (!disableClosing) {\n // Just sets \"slideIn\" to false, which triggers the animation to close it\n setSlideIn(false);\n return true;\n }\n\n // False disables overlay click\n return false;\n }, [disableClosing]);\n\n useEffect(() => {\n dispatch(updateOverlay(id, close));\n }, [dispatch, close, id]);\n\n useEffect(() => {\n if (!ready) return;\n if (!slideIn && ready) {\n // If not slide in, slide out :^)\n if (timeoutId) {\n // Clear previous timeout to avoid animation delay bug\n clearTimeout(timeoutId);\n }\n\n var newTimeoutId = setTimeout(() => {\n setTimeoutId(undefined);\n onClosed && onClosed();\n setRenderSideMenu(false);\n }, parseFloat(duration) * 1000);\n\n setTimeoutId(newTimeoutId);\n dispatch(removeOverlay(id));\n }\n }, [slideIn]);\n\n useEffect(() => {\n if (!ready) return;\n\n // Triggered every time \"open\" is changed, initially as well\n // Timeout to not trigger on the same frame as the render, to enable the slide-in\n setTimeout(() => setSlideIn(open), 1);\n\n if (open) {\n setRenderSideMenu(true);\n dispatch(addOverlay(id, close));\n }\n }, [open, close]);\n\n const CloseIcon = () => (\n \n );\n\n return renderSideMenu\n ? ReactDOM.createPortal(\n \n {components.Header && (\n \n {showCloseButton &&\n !disableClosing &&\n (!closeButton ? (\n \n ) : (\n cloneElement(closeButton, {\n onClick: close,\n })\n ))}\n \n \n )}\n {!components.Header &&\n showCloseButton &&\n !disableClosing &&\n (!closeButton ? (\n \n ) : (\n cloneElement(closeButton, {\n onClick: close,\n })\n ))}\n {title &&

{title}

}\n {components?.Content && (\n {children}\n )}\n {!components?.Content && (\n {children}\n )}\n {components.Footer != null && (\n \n \n \n )}\n ,\n document.body\n )\n : null;\n }\n);\n","import { css } from 'styled-components';\nimport { breakpoint } from './breakpoints';\n\nexport const text = (size: string) => css`\n font-family: ${(p) => p.theme.typography.fontFamily};\n font-size: ${(p) => p.theme.typography.fontSizeText[size]};\n font-weight: ${(p) => p.theme.typography.fontWeights.text};\n line-height: ${(p) => p.theme.typography.lineHeights.text};\n`;\n\nexport const header = (size: string) => css`\n font-family: ${(p) => p.theme.typography.fontFamilyHeader};\n font-size: ${(p) => p.theme.typography.fontSizeHeader.mobile[size]};\n font-weight: ${(p) => p.theme.typography.fontWeights.header};\n line-height: ${(p) => p.theme.typography.lineHeights.header};\n margin-block-start: 0;\n margin-block-end: 0;\n margin-inline-start: 0;\n margin-inline-end: 0;\n\n ${breakpoint('medium')} {\n font-size: ${(p) => p.theme.typography.fontSizeHeader.desktop[size]};\n }\n`;\n\nexport const displayHeader = (size: string) => css`\n font-family: ${(p) => p.theme.typography.fontFamilyDisplayHeader};\n font-size: ${(p) => p.theme.typography.fontSizeDisplayHeader.mobile[size]};\n font-weight: ${(p) => p.theme.typography.fontWeights.displayHeader};\n line-height: ${(p) => p.theme.typography.lineHeights.displayHeader};\n\n ${breakpoint('medium')} {\n font-size: ${(p) => p.theme.typography.fontSizeDisplayHeader.desktop[size]};\n }\n`;\n","import styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport { alignCenter, flexColumn } from '../../../styling/utils/flex';\nimport Icon from '../../Icon';\nimport {\n InputSize,\n InputState,\n StyledCheckboxProps,\n} from '../types/Input.types';\n\ninterface StyledInputWrapperProps {\n $inputState: InputState;\n $hasIcon: boolean;\n}\n\ninterface StyledInputProps {\n $inputSize: InputSize;\n $inputState: InputState;\n $hasIcon: boolean;\n}\n\nconst getColorByState = (inputState: InputState) => {\n switch (inputState) {\n case 'default':\n default:\n return null;\n case 'success':\n return getColor('success');\n case 'error':\n return getColor('alert');\n case 'warning':\n return getColor('warning');\n }\n};\n\nexport const StyledInputWrapper = styled.div`\n display: flex;\n ${flexColumn}\n width: 100%;\n position: ${(p) => (p.$hasIcon ? 'relative' : null)};\n\n label {\n ${text('large')}\n color: ${getColor('grey', 900)};\n font-weight: 700;\n margin-bottom: 0.8rem;\n }\n\n .helper-text {\n ${text('small')}\n margin-top: 0.8rem;\n color: ${getColor('grey', 600)};\n }\n\n .message {\n ${text('small')}\n display: flex;\n ${alignCenter}\n margin-top: 0.4rem;\n color: ${(p) => getColorByState(p.$inputState)};\n span {\n margin-left: 0.4rem;\n }\n }\n`;\n\nexport const StyledInput = styled.input`\n ${text('large')}\n border: 1px solid ${(p) => p.theme.inputs.borderColors.default};\n border-color: ${(p) => getColorByState(p.$inputState)};\n color: ${(p) => getColorByState(p.$inputState)};\n background-color: ${(p) => p.theme.inputs.backgroundColor};\n padding: ${(p) => p.theme.inputs.paddings[p.$inputSize]};\n width: 100%;\n resize: none;\n -webkit-appearance: textfield;\n -moz-appearance: textfield;\n padding-right: ${(p) =>\n p.$hasIcon ? p.theme.inputs.rightPaddings[p.$inputSize] : null};\n\n &::placeholder {\n color: ${(p) => getColorByState(p.$inputState)};\n }\n\n &:hover,\n &:active,\n &:focus {\n &::placeholder {\n color: ${(p) => getColorByState(p.$inputState)};\n }\n }\n &:disabled {\n border-color: ${getColor('grey', 300)};\n background-color: ${getColor('grey', 200)};\n cursor: not-allowed;\n\n &::placeholder {\n color: ${getColor('grey', 400)};\n }\n\n &:hover {\n border-color: ${getColor('grey', 300)};\n }\n }\n &::-webkit-outer-spin-button,\n &::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n`;\n\nexport const StyledIcon = styled(Icon)<{ $inputSize: InputSize }>`\n position: absolute;\n color: ${getColor('grey', 500)};\n font-size: ${(p) => p.theme.inputs.iconSize[p.$inputSize]};\n right: ${(p) => p.theme.inputs.iconRightDistance[p.$inputSize]};\n top: 50%;\n transform: translateY(-50%);\n`;\n\nexport const StyledTextArea = styled(StyledInput)`\n ${text('large')}\n width: 100%;\n height: ${(p) => p.theme.inputs.textareaSize[p.$inputSize]};\n`;\n\nexport const StyledTextAreaIcon = styled(StyledIcon)`\n top: ${(p) => p.theme.inputs.iconRightDistance[p.$inputSize]};\n transform: unset;\n`;\n\nexport const StyledCheckboxWrapper = styled.div`\n display: inline-flex;\n ${flexColumn}\n cursor: pointer;\n ${text('medium')}\n line-height: 1.2;\n color: ${getColor('grey', 600)};\n white-space: pre-wrap;\n\n label {\n display: flex;\n ${alignCenter}\n\n span {\n margin-left: 1.2rem;\n color: ${getColor('grey', 900)};\n cursor: pointer;\n }\n }\n\n .helper-text {\n ${text('small')}\n margin-top: 0.8rem;\n color: ${getColor('grey', 600)};\n }\n\n .message {\n ${text('small')}\n display: flex;\n ${alignCenter}\n margin-top: 0.4rem;\n color: ${(p) => getColorByState(p.$inputState)};\n span {\n margin-left: 0.4rem;\n }\n }\n`;\n\nexport const CheckboxIconWrapper = styled.div`\n position: relative;\n`;\n\nexport const StyledCheckbox = styled.input`\n display: flex;\n cursor: pointer;\n position: relative;\n appearance: none;\n border-radius: 2px;\n width: ${(p) => p.theme.inputs.checkboxSizes[p.$inputSize]};\n height: ${(p) => p.theme.inputs.checkboxSizes[p.$inputSize]};\n box-sizing: border-box;\n outline: none;\n transition: all linear 0.125s;\n margin: 0;\n border: 1px solid ${getColor('grey', 400)};\n background-color: ${getColor('white')};\n\n &:hover,\n &:focus {\n border-color: ${getColor('primary')};\n }\n &:disabled {\n border-color: ${getColor('primary')};\n background-color: ${getColor('grey', 200)};\n\n &:checked {\n border-color: ${getColor('grey', 300)};\n background-color: ${getColor('grey', 200)};\n\n &:after {\n border: solid ${getColor('grey', 300)};\n border-width: 0 2px 2px 0;\n }\n }\n }\n &:checked {\n background-color: ${getColor('primary')};\n border-color: ${getColor('primary')};\n }\n`;\n\nexport const StyledCheckboxIcon = styled(Icon)<{ $checked: boolean }>`\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n color: ${getColor('white')};\n pointer-events: none;\n width: 100% !important;\n height: 100% !important;\n opacity: ${(p) => (p.$checked ? '1' : '0')};\n transition: opacity linear 0.125s;\n`;\n\nexport const StyledRadioButton = styled.input`\n cursor: pointer;\n display: inline-flex;\n ${alignCenter}\n appearance: none;\n border-radius: 50%;\n width: ${(p) => p.theme.inputs.checkboxSizes[p.$inputSize]};\n height: ${(p) => p.theme.inputs.checkboxSizes[p.$inputSize]};\n box-shadow: 0 0 0 1px ${getColor('grey', 400)};\n background-color: ${getColor('white')};\n transition: all linear 0.125s;\n\n &:hover,\n &:focus {\n box-shadow: 0 0 0 1px ${getColor('primary')};\n }\n\n &:disabled {\n background: ${getColor('grey', 200)};\n border: 4px solid ${getColor('grey', 200)};\n box-shadow: 0 0 0 1px ${getColor('grey', 300)};\n }\n\n &:checked {\n background: ${getColor('primary')};\n border: 4px solid ${getColor('white')};\n box-shadow: 0 0 0 1px ${getColor('primary')};\n\n &:disabled {\n background: ${getColor('grey', 400)};\n border: 4px solid ${getColor('grey', 200)};\n box-shadow: 0 0 0 1px ${getColor('grey', 300)};\n }\n }\n`;\n\nexport const StyledInputIconWrapper = styled.div`\n position: relative;\n display: flex;\n`;\n","import React from 'react';\nimport { useMemo } from 'react';\nimport Icon from '../Icon';\nimport {\n StyledIcon,\n StyledInput,\n StyledInputIconWrapper,\n StyledInputWrapper,\n} from './styles/Inputs.styled';\nimport { InputProps } from './types/Input.types';\n\nconst Input: React.FC<\n InputProps & React.InputHTMLAttributes\n> = ({\n inputSize = 'medium',\n inputState = 'default',\n icon,\n wrapperClassName,\n label,\n helperText,\n message,\n showMessageIcon = true,\n ...props\n}) => {\n const messageIcon = useMemo(() => {\n switch (inputState) {\n case 'default':\n default:\n return null;\n\n case 'success':\n return ;\n\n case 'error':\n case 'warning':\n return ;\n }\n }, [inputState]);\n\n return (\n \n {label && (\n \n )}\n \n \n {typeof icon == 'string' && (\n \n )}\n {typeof icon == 'object' && icon}\n \n {helperText && {helperText}}\n {message && (\n \n {showMessageIcon && messageIcon}\n {message}\n \n )}\n \n );\n};\n\nexport default Input;\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport Icon from '../Icon';\nimport Input from '../Inputs/Input';\n\ninterface QuantityInputAttributes {\n className?: string;\n wrapperClassName?: string;\n onChange?: (quantity: number) => void;\n quantity?: number;\n showButtons?: boolean;\n min?: number;\n max?: number;\n step?: number;\n disabled?: boolean;\n}\n\ninterface StyledIconProps {\n $disabled?: boolean;\n}\n\nconst StyledQuantityInput = styled.div`\n position: relative;\n display: flex;\n flex-direction: column;\n\n & div {\n flex: 1;\n }\n\n input {\n text-align: center;\n }\n`;\n\nconst StyledQuantityInputIcon = styled(Icon)`\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n cursor: pointer;\n width: 16px;\n height: 16px;\n color: ${getColor('grey', 900)};\n\n &.minus-icon {\n left: 12px;\n opacity: ${(p) => (p.$disabled ? 0.24 : 1)};\n cursor: ${(p) => (p.$disabled ? 'not-allowed' : 'pointer')};\n }\n\n &.plus-icon {\n right: 12px;\n }\n`;\n\nconst QuantityInput = (props: QuantityInputAttributes) => {\n const {\n className = '',\n wrapperClassName = '',\n onChange,\n quantity,\n showButtons = false,\n min,\n max,\n step,\n disabled = false,\n } = props;\n\n const [internalValue, setInternalValue] = useState(quantity ?? 1);\n const [debounceTimer, setDebounceTimer] = useState();\n\n const onInputChanged = (value) => {\n let parsedValue: number | undefined = parseFloat(value);\n if (!parsedValue) {\n parsedValue = 0;\n }\n if (parsedValue <= 0) return;\n setInternalValue(parsedValue);\n\n if (onChange) {\n if (debounceTimer) {\n clearTimeout(debounceTimer);\n }\n\n // Debounce onChange\n setDebounceTimer(\n setTimeout(() => {\n onChange(value);\n }, 350)\n );\n }\n };\n\n return (\n \n onInputChanged(e.target.value)}\n min={min}\n max={max}\n step={step}\n disabled={disabled}\n />\n {showButtons && (\n <>\n onInputChanged(internalValue - 1)}\n $disabled={internalValue <= 1 || disabled}\n />\n onInputChanged(internalValue + 1)}\n $disabled={disabled}\n />\n \n )}\n \n );\n};\n\nexport default QuantityInput;\n","import React, { useMemo } from 'react';\nimport Icon from '../Icon';\nimport { StockType } from '../../Types/StockStatus';\n\ninterface StockStatusProps {\n inStock: boolean;\n description: string;\n stockType: StockType;\n}\n\nconst StockStatus: React.FC<\n StockStatusProps & React.HTMLAttributes\n> = ({ inStock, description, stockType, ...props }) => {\n\n const iconName = useMemo(() => {\n switch (stockType) {\n case 'Default':\n return inStock ? 'check-circle' : 'cross-circle';\n case 'External':\n return inStock ? 'check-circle' : 'cross-circle';\n default:\n return 'info';\n }\n }, [inStock, stockType]);\n\n const iconColor = useMemo(() => {\n switch (stockType) {\n case 'Default':\n case 'External':\n return inStock ? 'text-success-500' : 'text-error-500';\n default:\n return inStock ? 'text-success-500' : 'text-error-500';\n case 'OrderItem':\n return 'text-orange-500';\n case 'TemporarySoldOut':\n return 'text-yellow-500';\n }\n }, [inStock, stockType]);\n\n return (\n
\n \n {description}\n
\n );\n};\nexport default StockStatus;\n","import React, { useCallback, useEffect, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport { update } from '../../Actions/Cart.action';\nimport { translate } from '../../Services/translation';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport { OrderRow } from '../../Types/OrderRow';\nimport QuantityInput from '../QuantityInput/QuantityInput';\nimport StockStatus from '../StockStatus/StockStatus';\n\ninterface OrderRowProductCardProps {\n row: OrderRow;\n onRemoveClick?: (row: OrderRow) => void;\n className?: string;\n}\n\nconst StyledOrderRowProductCard = styled.div`\n display: flex;\n gap: 0 1.6rem;\n background-color: ${getColor('grey', 100)};\n padding: 1.6rem;\n\n .image-wrapper {\n background-color: ${getColor('grey', 200)};\n width: 64px;\n height: 64px;\n }\n\n .image {\n width: 100%;\n aspect-ratio: 1/1;\n object-fit: cover;\n }\n\n .content {\n display: flex;\n flex-direction: column;\n flex: 1;\n }\n\n .overline {\n ${text('medium')}\n color: ${getColor('grey', 500)};\n margin-bottom: 0.2rem;\n }\n\n .name {\n ${text('medium')}\n font-weight: bold;\n margin-bottom: 0.4rem;\n }\n\n .extra-row {\n ${text('medium')}\n color: ${getColor('grey', 500)}\n }\n\n .quantity-input {\n max-width: 112px;\n }\n\n .stock-status {\n margin-top: 0.8rem;\n margin-bottom: 1.6rem;\n }\n\n .right-col {\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n align-items: flex-end;\n ${text('large')}\n font-weight: bold;\n }\n\n .price {\n ${text('small')}\n text-decoration: line-through;\n ${getColor('grey', 500)}\n }\n\n .btn--remove {\n ${text('medium')}\n color: ${getColor('grey', 500)};\n text-decoration: underline;\n cursor: pointer;\n margin-left: 1.6rem;\n }\n\n .footer {\n display: flex;\n align-items: center;\n\n input {\n background-color: ${getColor('white')};\n padding: 0.4rem 0.8rem;\n }\n }\n`;\n\nconst StyledImageBackground = styled.div`\n position: relative;\n background: ${getColor('white')};\n\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0, 0, 0, 0.04);\n pointer-events: none;\n z-index: 2;\n }\n`;\n\nconst OrderRowProductCard = ({\n row,\n onRemoveClick,\n className = '',\n}: OrderRowProductCardProps) => {\n const dispatch = useDispatch();\n\n const [abortController, setAbortController] = useState<\n AbortController | undefined\n >();\n\n useEffect(() => setAbortController(new AbortController()), []);\n\n const onQuantityChange = useCallback(\n (row, quantity) => {\n dispatch(update(row.articleNumber, quantity, abortController));\n },\n [abortController, dispatch]\n );\n\n return (\n \n
\n \n {row.image && (\n \n \n \n )}\n \n
\n
\n
{row.brand}
\n \n {row.extraInfo && (\n
\n {row.extraInfo.items.map((item) => (\n
\n {item.key}: {item.value}\n
\n ))}\n
\n )}\n \n
\n onQuantityChange(row, quantity)}\n />\n
\n
\n
\n {row.totalCampaignPrice != '' ? row.totalCampaignPrice : row.totalPrice}\n {row.totalCampaignPrice != '' && (\n
{row.totalPrice}
\n )}\n {onRemoveClick && !row.isFreeGift && (\n onRemoveClick && onRemoveClick(row)}\n >\n {translate('general.remove')}\n
\n )}\n \n
\n );\n};\n\nexport default OrderRowProductCard;\n","import { TypedUseSelectorHook, useSelector } from 'react-redux';\nimport { RootState } from '../reducers';\n\nexport const useTypedSelector: TypedUseSelectorHook = useSelector;\n","import { css, DefaultTheme } from 'styled-components';\n\nexport const btnType = (theme: DefaultTheme, style: string) => ({\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: theme.buttons.backgroundColors[style],\n color: theme.buttons.fontColors[style],\n border: `${theme.buttons.borderWidth} solid ${theme.buttons.borderColors[style]}`,\n borderRadius: theme.buttons.borderRadius,\n '&:not(:disabled):hover': {\n backgroundColor: theme.buttons.hoverBackgroundColors[style],\n borderColor: theme.buttons.hoverBorderColors[style],\n },\n '&:not(:disabled):active': {\n backgroundColor: theme.buttons.focusBackgroundColors[style],\n borderColor: theme.buttons.focusBorderColors[style],\n },\n});\n\nexport const btnSize = (theme: DefaultTheme, size: string) => ({\n padding: theme.buttons.paddings[size],\n fontSize: theme.buttons.fontSizes[size],\n lineHeight: theme.buttons.lineHeights[size],\n});\n\nexport const btn = (type: string, size: string = 'medium') => css`\n ${(p) => btnType(p.theme, type)}\n ${(p) => btnSize(p.theme, size)}\n`;\n","import React, { useEffect } from 'react';\nimport styled, { useTheme } from 'styled-components';\nimport { btnSize, btnType } from '../styling/mixins/buttons';\n\ninterface ButtonProps {\n btnType: string;\n btnSize?: string;\n fullwidth?: boolean;\n as?: any;\n href?: string;\n}\n\ninterface StyledButtonProps {\n $btnType: string;\n $btnSize: string;\n $fullwidth: boolean;\n}\n\nconst StyledButton = styled.button`\n ${(p) => btnType(p.theme, p.$btnType)}\n ${(p) => btnSize(p.theme, p.$btnSize)}\n width: ${(p) => (p.$fullwidth ? '100%' : null)};\n opacity: ${(p) => (p.disabled ? '0.5' : '1')};\n cursor: ${(p) => (p.disabled ? 'default' : 'pointer')};\n pointer-events: ${(p) => (p.disabled ? 'none' : 'default')};\n font-weight: ${(p) => p.theme.buttons.fontWeight};\n text-transform: ${(p) => p.theme.buttons.textTransform};\n\n .icon + span,\n span + .icon {\n margin-left: 1.6rem;\n }\n\n .icon {\n font-size: 2.4rem;\n }\n`;\n\nconst Button: React.FC<\n ButtonProps & React.ButtonHTMLAttributes\n> = ({\n btnType,\n btnSize = 'medium',\n fullwidth = false,\n as,\n href,\n ...props\n}) => {\n const theme = useTheme();\n\n useEffect(() => {\n if (!theme.buttons.types.includes(btnType)) {\n console.warn(\n `The specified btnType \"${btnType}\" was not found for the current theme. Available types: [${theme.buttons.types.join(\n ', '\n )}]`\n );\n }\n }, [theme.buttons.types, btnType]);\n\n useEffect(() => {\n if (!theme.buttons.sizeClasses.includes(btnSize)) {\n console.warn(\n `The specified btnSize \"${btnSize}\" was not found for the current theme. Available sizes: [${theme.buttons.sizeClasses.join(\n ', '\n )}]`\n );\n }\n }, [theme.buttons.sizeClasses, btnSize]);\n\n return (\n \n );\n};\n\nexport default Button;\n","import React from 'react';\nimport { useMemo } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setShowMiniCart, update } from '../../Actions/Cart.action';\nimport { translate } from '../../Services/translation';\nimport SideMenu from '../SideMenu/SideMenu';\nimport OrderRowProductCard from '../OrderRowProductCard/OrderRowProductCard';\nimport Icon from '../Icon';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport {\n alignCenter,\n displayFlex,\n flex1,\n spaceBetween,\n} from '../../styling/utils/flex';\nimport { StyledSideMenuContent } from '../SideMenu/styles/SideMenu.styling';\nimport Button from '../Button';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { getColor } from '../../styling/mixins/colors';\n\ninterface StyledMiniCartSideMenuProps {\n $empty: boolean;\n}\n\nconst StyledMiniCartSideMenu = styled(SideMenu)`\n z-index: 60;\n overflow-y: auto;\n -ms-overflow-style: none;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n\n ${breakpoint('small')} {\n border-left: 1px solid ${getColor('grey', 300)};\n }\n`;\n\nconst StyledMiniCartHeader = styled.div`\n ${displayFlex}\n ${spaceBetween}\n ${alignCenter}\n ${flex1}\n \n & h4 {\n text-transform: none;\n }\n\n .close {\n cursor: pointer;\n }\n`;\n\nconst StyledMiniCartFooter = styled.div`\n ${flex1}\n .rows {\n ${displayFlex}\n ${spaceBetween}\n ${alignCenter}\n margin-bottom: 1.6rem;\n }\n\n .checkout-button {\n font-weight: bold;\n text-transform: uppercase;\n }\n`;\n\nconst StyledEmptyCart = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n margin: auto;\n\n .title {\n margin: 1.6rem 0;\n }\n\n .cart-icon {\n font-size: 7.2rem;\n }\n\n .shopping-button {\n font-weight: bold;\n text-transform: uppercase;\n }\n`;\n\nconst StyledMiniCartContent = styled(\n StyledSideMenuContent\n)`\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n flex: 1;\n margin: ${(p) => (p.$empty ? 'auto' : null)};\n padding: 1.6rem;\n overflow-y: auto;\n`;\n\nconst GlobalMiniCartStyling = createGlobalStyle`\n body #overlay-container .overlay--mini-cart {\n z-index: 55;\n }\n`;\n\nconst MiniCart = () => {\n const dispatch = useDispatch();\n const {\n showMiniCart,\n orderRows,\n emptyCartLink,\n orderTotal,\n checkoutUrl,\n } = useTypedSelector((state) => state.cart);\n const hasOrderRows = useMemo(() => orderRows?.length > 0, [orderRows]);\n\n const quantity = useMemo(\n () => orderRows.reduce((prev, current) => prev + current.quantity, 0),\n [orderRows]\n );\n\n const closeMiniCart = () => dispatch(setShowMiniCart(false));\n\n const Header = () => (\n \n

\n {translate('general.cart')} {quantity > 0 ? `(${quantity})` : ''}\n

\n \n
\n );\n\n const Footer = hasOrderRows\n ? () => (\n \n
\n

{translate('general.total')}

\n

{orderTotal}

\n
\n \n \n {translate('cart.to-checkout')}\n \n \n
\n )\n : undefined;\n\n const Content = () => (\n \n {hasOrderRows ? (\n orderRows.map((row) => (\n \n ))\n ) : (\n \n \n

{translate('cart.empty')}

\n {emptyCartLink && (\n \n \n {translate('cart.empty-cart-link')}\n \n \n )}\n
\n )}\n
\n );\n\n const removeRow = (row) => {\n dispatch(update(row.articleNumber, 0));\n };\n\n return (\n <>\n \n \n \n );\n};\n\nexport default MiniCart;\n","import React from 'react';\nimport { useMemo } from 'react';\nimport Icon from '../Icon';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\n\ninterface StyledMiniCartIconProps {\n addToCartAnimating: boolean;\n}\n\nconst StyledMiniCartIcon = styled.div`\n position: relative;\n color: ${getColor('grey', 900)};\n`;\n\nconst StyledQuantity = styled.div`\n display: flex;\n align-items: center;\n justify-content: center;\n ${text('small')};\n color: ${getColor('grey', 900)};\n text-align: center;\n position: absolute;\n top: -10px;\n right: -8px;\n width: 16px;\n height: 16px;\n transition: 0.125s ease-in-out;\n -moz-transition: 0.125s ease-in-out;\n -webkit-transition: 0.125 ease-in-out;\n border-radius: 100%;\n line-height: 1.3;\n transform: ${(props) => (props.addToCartAnimating ? 'scale(1.5)' : null)};\n background-color: ${(props) =>\n props.addToCartAnimating\n ? getColor('primary', 300)\n : getColor('primary', 500)};\n`;\n\nconst MiniCartIcon = () => {\n const { orderRows, addToCartAnimating = false } = useTypedSelector(\n (state) => state.cart\n );\n\n const quantity = useMemo(\n () =>\n Math.min(\n orderRows.reduce((prev, current) => prev + current.quantity, 0),\n 99\n ),\n [orderRows]\n );\n\n return (\n \n \n {quantity > 0 ? (\n \n {quantity}\n \n ) : null}\n \n );\n};\n\nexport default MiniCartIcon;\n","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setShowMiniCart } from '../../Actions/Cart.action';\nimport MiniCartIcon from './MiniCartIcon';\nimport styled from 'styled-components';\n\nconst StyledMiniCartButton = styled.div`\n cursor: pointer;\n`;\n\nconst MiniCartButton = () => {\n const dispatch = useDispatch();\n return (\n dispatch(setShowMiniCart(true))}\n role=\"button\"\n >\n \n \n );\n};\n\nexport default MiniCartButton;\n","import React from 'react';\nimport styled from 'styled-components';\n\nconst StyledCheckoutSectionHeader = styled.div`\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-bottom: 1.6rem;\n`;\n\nconst CheckoutSectionHeader = ({ children, className = '' }) => {\n return (\n \n {children}\n \n );\n};\n\nexport default CheckoutSectionHeader;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\nimport CheckoutSectionHeader from './Checkout.SectionHeader';\n\ninterface CheckoutSectionProps {\n children?: any;\n className?: string;\n headerClassName?: string;\n title?: string;\n titleRight?: JSX.Element | string;\n}\n\nconst StyledCheckoutSection = styled.div`\n background-color: ${getColor('white')};\n padding: 2.4rem 1.6rem;\n\n ${breakpoint('large')} {\n padding: 2.4rem;\n }\n`;\n\nconst CheckoutSection = ({\n children,\n className = '',\n title,\n titleRight,\n headerClassName,\n}: CheckoutSectionProps) => {\n return (\n \n {title && (\n \n

{title}

\n {titleRight}\n
\n )}\n {children}\n
\n );\n};\n\nexport default CheckoutSection;\n","import React from 'react';\n\ninterface CheckoutSectionContentProps {\n children?: any;\n className?: string;\n}\n\nconst CheckoutSectionContent = ({\n children,\n className,\n}: CheckoutSectionContentProps) =>
{children}
;\n\nexport default CheckoutSectionContent;\n","import React, { useEffect, useState } from 'react';\n\nconst useDebouncedOnChange = (initialValue, action, wait = 300) => {\n const [internalValue, setInternalValue] = useState(initialValue);\n const [timeoutId, setTimeoutId] = useState(-1);\n\n useEffect(() => {\n if (timeoutId !== -1) {\n setTimeoutId(clearTimeout(timeoutId));\n }\n\n setTimeoutId(setTimeout(action, wait));\n }, [internalValue]);\n\n return [internalValue, setInternalValue];\n};\n\nexport default useDebouncedOnChange;\n","import { post, put, remove } from '../Services/http';\nimport { load as loadCart } from './Cart.action';\nimport { catchError } from './Error.action';\n\nimport {\n CHECKOUT_SET_SELECTED_COMPANY_ADDRESS,\n CHECKOUT_SET_SELECTED_BILLING_ADDRESS,\n CHECKOUT_SET_SELECTED_DELIVERY_ADDRESS,\n CHECKOUT_SET_PRIVATE_CUSTOMER,\n CHECKOUT_SET_SIGN_UP,\n CHECKOUT_SET_DELIVERY,\n CHECKOUT_SET_COUNTRY,\n CHECKOUT_SET_PAYMENT,\n CHECKOUT_SET_DISCOUNT_CODE,\n CHECKOUT_SET_ORDER_NOTE,\n CHECKOUT_ACCEPT_TERMS_OF_CONDITION,\n CHECKOUT_SUBMIT,\n CHECKOUT_SUBMIT_ERROR,\n CHECKOUT_SET_PAYMENT_WIDGET,\n CHECKOUT_SET_USED_DISCOUNT_CODE,\n CHECKOUT_UPDATE_CUSTOMER_INFO,\n CHECKOUT_SET_SHOW_ALTERNATIVE_ADDRESS,\n CLEAR_ERROR,\n CHECKOUT_SET_STATUS_SUBMIT_BUTTON,\n CHECKOUT_VALIDATE_ADDRESS,\n CHECKOUT_SET_CUSTOMER_INFO,\n CHECKOUT_SET_VALIDATION_ERRORS,\n CHECKOUT_SET_IS_SUBMITTING,\n} from '../constants';\n\nexport const setBusinessCustomer = (isBusinessCustomer) => ({\n type: CHECKOUT_SET_PRIVATE_CUSTOMER,\n payload: {\n isBusinessCustomer,\n },\n});\n\nexport const setSignUp = (signUp) => ({\n type: CHECKOUT_SET_SIGN_UP,\n payload: {\n signUp,\n },\n});\n\nexport const submitSignup = () => (dispatch, getState) => {\n const { payload } = getState().checkout;\n\n return put('/api/checkout/setSignup', payload)\n .then((response) => response.json())\n .catch((ex) => {\n if (ex.response) {\n ex.response.json().then((error) => {\n dispatch(submitError(error));\n });\n } else {\n dispatch(submitError(ex));\n }\n throw ex;\n });\n};\n\nexport const updateCustomerDetails = (key, data) => ({\n type: CHECKOUT_UPDATE_CUSTOMER_INFO,\n payload: {\n key,\n data,\n },\n});\n\nexport const setSelectedBillingAddress = (selectedBillingAddressId) => ({\n type: CHECKOUT_SET_SELECTED_BILLING_ADDRESS,\n payload: {\n selectedBillingAddressId,\n },\n});\n\nexport const setSelectedDeliveryAddress = (selectedDeliveryAddressId) => ({\n type: CHECKOUT_SET_SELECTED_DELIVERY_ADDRESS,\n payload: {\n selectedDeliveryAddressId,\n },\n});\n\nexport const setCheckoutIsSubmitting = (checkoutIsSubmitting) => ({\n type: CHECKOUT_SET_IS_SUBMITTING,\n payload: {\n checkoutIsSubmitting,\n },\n});\n\nexport const setDelivery = (method) => (dispatch, getState) => {\n dispatch({\n type: CHECKOUT_SET_DELIVERY,\n payload: {\n selectedDeliveryMethod: method,\n },\n });\n const { payload } = getState().checkout;\n return put('/api/checkout/setDeliveryProvider', payload)\n .then((response) => response.json())\n .then((result) => {\n dispatch(loadCart());\n if (result !== null && result.paymentWidget) {\n dispatch(setPaymentWidget(result.paymentWidget));\n }\n })\n .catch((ex) => dispatch(catchError(ex, (error) => submitError(error))));\n};\n\nexport const setCountry = (systemId) => (dispatch, getState) => {\n dispatch({\n type: CHECKOUT_SET_COUNTRY,\n payload: {\n selectedCountry: systemId,\n },\n });\n const { payload } = getState().checkout;\n\n // reset paymentWidget to null to avoid sending unnecessary request to payment provider\n dispatch(setPaymentWidget(null));\n\n return put('/api/checkout/setCountry', payload)\n .then((response) => response.json())\n .then((result) => {\n dispatch(loadCart());\n dispatch(setPaymentWidget(result.paymentWidget));\n dispatch({\n type: CHECKOUT_SET_DELIVERY,\n payload: {\n deliveryMethods: result.deliveryMethods,\n selectedDeliveryMethod: result.selectedDeliveryMethod,\n },\n });\n dispatch({\n type: CHECKOUT_SET_PAYMENT,\n payload: {\n paymentMethods: result.paymentMethods,\n selectedPaymentMethod: result.selectedPaymentMethod,\n },\n });\n })\n .catch((ex) => dispatch(catchError(ex, (error) => submitError(error))));\n};\n\nexport const setPayment = (method) => (dispatch, getState) => {\n dispatch({\n type: CHECKOUT_SET_PAYMENT,\n payload: {\n selectedPaymentMethod: method,\n },\n });\n\n const { payload } = getState().checkout;\n // reset paymentWidget to null to avoid sending unnecessary request to payment provider\n dispatch(setPaymentWidget(null));\n // reset payment error on the checkout\n dispatch(\n submitError({\n modelState: {\n payment: [],\n },\n })\n );\n\n return put('/api/checkout/setPaymentProvider', payload)\n .then((response) => response.json())\n .then((result) => {\n dispatch(loadCart());\n dispatch(setPaymentWidget(result.paymentWidget));\n })\n .catch((ex) => dispatch(catchError(ex, (error) => submitError(error))));\n};\n\nexport const reloadPayment = () => (dispatch, getState) => {\n const { payload } = getState().checkout;\n return put('/api/checkout/reloadPaymentWidget', payload)\n .then((response) => response.json())\n .then((result) => {\n dispatch(loadCart());\n if (result && result.paymentWidget) {\n dispatch(setPaymentWidget(result.paymentWidget));\n }\n })\n .catch((ex) => dispatch(catchError(ex, (error) => submitError(error))));\n};\n\nconst setPaymentWidget = (paymentWidget) => ({\n type: CHECKOUT_SET_PAYMENT_WIDGET,\n payload: {\n paymentWidget,\n },\n});\n\nexport const setOrderNote = (orderNote) => ({\n type: CHECKOUT_SET_ORDER_NOTE,\n payload: {\n orderNote,\n },\n});\n\nexport const acceptTermsOfCondition = (acceptTermsOfCondition) => ({\n type: CHECKOUT_ACCEPT_TERMS_OF_CONDITION,\n payload: {\n acceptTermsOfCondition,\n },\n});\n\nexport const setDiscountCode = (discountCode) => ({\n type: CHECKOUT_SET_DISCOUNT_CODE,\n payload: {\n discountCode,\n },\n});\n\nexport const submitDiscountCode = () => (dispatch, getState) => {\n const { payload } = getState().checkout;\n return put('/api/checkout/setDiscountCode', payload)\n .then((response) => response.json())\n .then((result) => {\n dispatch(setUsedDiscountCodes(result.usedDiscountCodes));\n dispatch(loadCart());\n dispatch(setPaymentWidget(result.paymentWidget));\n // reset error of campaign code\n dispatch(\n submitError({\n modelState: {\n discountCode: [],\n },\n })\n );\n })\n .catch((ex) => {\n dispatch(catchError(ex, (error) => submitError(error)));\n // restore the initial cart\n dispatch(loadCart());\n });\n};\n\nexport const deleteDiscountCode = (discountCode) => (dispatch, getState) => {\n const { payload } = getState().checkout;\n payload.discountCode = discountCode;\n return remove('/api/checkout/deleteDiscountCode', payload)\n .then((response) => response.json())\n .then((result) => {\n dispatch(setUsedDiscountCodes(result.usedDiscountCodes));\n dispatch(loadCart());\n dispatch(setPaymentWidget(result.paymentWidget));\n dispatch(setDiscountCode(''));\n // reset error of campaign code\n dispatch(\n submitError({\n modelState: {\n discountCode: [],\n },\n })\n );\n })\n .catch((ex) => {\n dispatch(catchError(ex, (error) => submitError(error)));\n // restore the initial cart\n dispatch(loadCart());\n });\n};\n\nconst setUsedDiscountCodes = (usedDiscountCodes) => ({\n type: CHECKOUT_SET_USED_DISCOUNT_CODE,\n payload: {\n usedDiscountCodes,\n },\n});\n\nexport const setAlternativeAddress = (propName, value) => ({\n type: CHECKOUT_SET_CUSTOMER_INFO,\n payload: {\n key: 'alternativeAddress',\n data: {\n [propName]: value,\n },\n },\n});\n\nexport const setCustomerDetails = (propName, value) => ({\n type: CHECKOUT_SET_CUSTOMER_INFO,\n payload: {\n key: 'customerDetails',\n data: {\n [propName]: value,\n },\n },\n});\n\nexport const submit = () => (dispatch, getState) => {\n const { payload } = getState().checkout;\n return _submit('/api/checkout', payload, dispatch);\n};\n\nconst _submit = (url, model, dispatch) => {\n return post(url, model)\n .then((response) => response.json())\n .then((result) => {\n dispatch(submitDone(result));\n if (result.redirectUrl) {\n location.href = result.redirectUrl;\n } else {\n dispatch(setCheckoutIsSubmitting(false));\n }\n })\n .catch((ex) => {\n dispatch(setCheckoutIsSubmitting(false));\n if (ex.response) {\n ex.response.json().then((error) => {\n dispatch(submitError(error));\n dispatch(submitDone(null));\n // reload the cart, it might be changed after validation\n dispatch(loadCart());\n });\n } else {\n dispatch(submitError(ex));\n }\n });\n};\n\nexport const saveCustomerDetail = () => (dispatch, getState) => {\n const { payload } = getState().checkout;\n return put('/api/checkout/setCustomerDetail', payload)\n .then((response) => response.json())\n .catch((ex) => {\n if (ex.response) {\n ex.response.json().then((error) => {\n dispatch(submitError(error));\n });\n } else {\n dispatch(submitError(ex));\n }\n throw ex;\n });\n};\n\nexport const clearError = () => ({\n type: CLEAR_ERROR,\n payload: {\n errors: [],\n },\n});\n\nexport const submitDone = (result) => ({\n type: CHECKOUT_SUBMIT,\n payload: {\n result,\n },\n});\n\nexport const submitError = (error) => ({\n type: CHECKOUT_SUBMIT_ERROR,\n payload: {\n error,\n },\n});\n\nexport const setValidationErrors = (validationErrors) => ({\n type: CHECKOUT_SET_VALIDATION_ERRORS,\n payload: {\n validationErrors,\n },\n});\n\nexport const setStatusSubmitButton = (value) => ({\n type: CHECKOUT_SET_STATUS_SUBMIT_BUTTON,\n payload: {\n enableConfirmButton: value,\n },\n});\n\nexport const setShowAlternativeAddress = (showAlternativeAddress) => ({\n type: CHECKOUT_SET_SHOW_ALTERNATIVE_ADDRESS,\n payload: {\n showAlternativeAddress,\n },\n});\nexport const setValidateStatus = (isValidating) => ({\n type: CHECKOUT_VALIDATE_ADDRESS,\n payload: {\n isValidating,\n },\n});\n","import React from 'react';\nimport { useMemo } from 'react';\nimport Icon from '../Icon';\nimport {\n StyledInputIconWrapper,\n StyledInputWrapper,\n StyledTextArea,\n StyledTextAreaIcon,\n} from './styles/Inputs.styled';\nimport { InputProps } from './types/Input.types';\n\nconst TextArea: React.FC<\n InputProps & React.InputHTMLAttributes\n> = ({\n inputSize = 'medium',\n inputState = 'default',\n icon,\n wrapperClassName,\n label,\n helperText,\n message,\n showMessageIcon = true,\n ...props\n}) => {\n const messageIcon = useMemo(() => {\n switch (inputState) {\n case 'default':\n default:\n return null;\n\n case 'success':\n return ;\n\n case 'error':\n case 'warning':\n return ;\n }\n }, [inputState]);\n\n return (\n \n {label && }\n \n \n {typeof icon == 'string' && (\n \n )}\n {typeof icon == 'object' && icon}\n \n {helperText && {helperText}}\n {message && (\n \n {showMessageIcon && messageIcon}\n {message}\n \n )}\n \n );\n};\n\nexport default TextArea;\n","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport CheckoutSection from './utils/Checkout.Section';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport { translate } from '../../Services/translation';\nimport useDebouncedOnChange from '../../Hooks/useDebouncedOnChange';\nimport { setOrderNote as setOrderNoteAction } from '../../Actions/Checkout.action';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport TextArea from '../Inputs/TextArea';\n\nconst StyledCheckoutSection = styled(CheckoutSection)`\n .description {\n ${text('large')}\n margin-bottom: 1.6rem;\n }\n`;\n\nconst AdditionalOrderInfo = () => {\n const dispatch = useDispatch();\n const checkout = useTypedSelector((state) => state.checkout);\n const { customerServiceMessage } = checkout.payload;\n const [comments, setOrderNote] = useDebouncedOnChange('', () =>\n dispatch(setOrderNoteAction(comments))\n );\n\n return (\n \n \n {customerServiceMessage && (\n \n )}\n setOrderNote(e.target.value)}\n />\n \n \n );\n};\n\nexport default AdditionalOrderInfo;\n","import React from 'react';\n\ninterface CheckoutSectionFooterProps {\n children?: any;\n className?: string;\n}\n\nconst CheckoutSectionFooter = ({\n children,\n className,\n}: CheckoutSectionFooterProps) =>
{children}
;\n\nexport default CheckoutSectionFooter;\n","import React, { HTMLAttributes } from 'react';\nimport Icon from './Icon';\nimport styled from 'styled-components';\nimport { getColor } from '../styling/mixins/colors';\nimport { text } from '../styling/mixins/typography';\n\ninterface ChipAttributes {\n children?: any;\n showDelete?: boolean;\n onDeleteClick?: Function;\n chipProps?: HTMLAttributes;\n}\n\nconst StyledChip = styled.div`\n ${text('small')}\n display: flex;\n align-items: center;\n text-align: center;\n justify-content: center;\n padding: 0.6rem 1.2rem;\n background-color: ${getColor('white')};\n border: 1px solid ${getColor('grey', 400)};\n gap: 0.8rem;\n\n .delete-icon {\n width: 1.6rem;\n height: 1.6rem;\n }\n`;\n\nconst Chip = (props: ChipAttributes) => {\n const { children, showDelete = true, chipProps = {}, onDeleteClick } = props;\n\n return (\n \n {children}\n {showDelete && (\n onDeleteClick && onDeleteClick()}\n />\n )}\n \n );\n};\n\nexport default Chip;\n","import React, { useEffect, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { translate } from '../../Services/translation';\nimport {\n submitDiscountCode,\n deleteDiscountCode,\n setDiscountCode,\n submitError,\n} from '../../Actions/Checkout.action';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport Chip from '../Chip';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport Input from '../Inputs/Input';\nimport Button from '../Button';\n\nconst StyledDiscountWrapper = styled.div`\n display: flex;\n flex-direction: column;\n gap: 1.6rem;\n\n .title {\n cursor: pointer;\n text-align: right;\n flex: 1;\n color: ${getColor('grey', 600)};\n text-decoration: underline;\n }\n\n .label-wrapper {\n display: flex;\n gap: 1.2rem;\n flex: 1;\n }\n\n .input-wrapper {\n flex: 1;\n }\n\n .input {\n padding: 1.2rem;\n border: 1px solid ${getColor('grey', 200)};\n }\n\n .checkout__used-discount-codes {\n display: flex;\n gap: 0.8rem;\n }\n\n button {\n min-width: 25%;\n max-height: 50px;\n }\n`;\n\nconst Discount = () => {\n const dispatch = useDispatch();\n const { payload, errors = {} } = useTypedSelector((state) => state.checkout);\n const { usedDiscountCodes } = payload;\n const [inputDiscountCode, setInputDiscountCode] = useState('');\n const [showDiscountInput, setShowDiscountInput] = useState(false);\n const [isLoading, setIsLoading] = useState(false);\n\n useEffect(() => {\n if (errors && !errors['discountCode']?.length) {\n setInputDiscountCode('');\n }\n }, [errors]);\n\n const submitDiscount = async (code) => {\n setIsLoading(true);\n await dispatch(setDiscountCode(code));\n await dispatch(submitDiscountCode());\n setIsLoading(false);\n };\n\n const onChange = (code) => {\n setInputDiscountCode(code);\n if (errors['discountCode']?.length > 0 && !code.length) {\n dispatch(\n submitError({\n modelState: {\n discountCode: [],\n },\n })\n );\n }\n };\n\n return (\n \n {!showDiscountInput && (\n setShowDiscountInput(true)}>\n {translate('checkout.campaign-code')}\n \n )}\n {showDiscountInput && (\n
\n \n submitDiscount(inputDiscountCode)}\n disabled={!inputDiscountCode || isLoading}\n >\n {translate('general.use')}\n \n
\n )}\n {usedDiscountCodes.length > 0 && (\n
\n {usedDiscountCodes.map((code) => (\n dispatch(deleteDiscountCode(code))}\n >\n {code}\n \n ))}\n
\n )}\n
\n );\n};\n\nexport default Discount;\n","import { translate } from '../../Services/translation';\nimport React from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport styled from 'styled-components';\nimport { flex1 } from '../../styling/utils/flex';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\nimport Discount from './Checkout.Discount';\nimport { showFor } from '../../styling/utils/visibility';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\n\nconst StyledPriceRow = styled.div`\n display: flex;\n ${flex1}\n justify-content: space-between;\n ${text('large')}\n margin-bottom: 0.4rem;\n &:last-child {\n margin-bottom: unset;\n }\n`;\n\nconst StyledDiscountRow = styled.div`\n display: flex;\n ${flex1}\n justify-content: space-between;\n ${text('large')}\n margin-bottom: 0.4rem;\n color: ${getColor('alert')};\n &:last-child {\n margin-bottom: unset;\n }\n`;\n\nconst StyledGrandTotal = styled.div`\n ${text('large')}\n font-weight: bold;\n display: flex;\n ${flex1}\n justify-content: space-between;\n margin-bottom: 0.4rem;\n &:last-child {\n margin-bottom: unset;\n }\n`;\n\nconst StyledOrderSummary = styled.div`\n display: flex;\n flex-direction: column;\n gap: 1.6rem;\n height: fit-content;\n\n ${breakpoint('large')} {\n background-color: ${getColor('white')};\n padding: 2.4rem;\n }\n`;\n\nconst StyledHeader = styled.h4`\n display: none;\n ${breakpoint('large')} {\n display: flex;\n }\n`;\n\nconst CheckoutOrderSummary = () => {\n const cart = useTypedSelector((state) => state.cart);\n\n return (\n \n {translate('checkout.summary')}\n
\n \n {translate('checkout.order.sum')}\n {cart.orderTotal}\n \n {cart.discount && (\n \n {translate('checkout.order.saved')}\n {cart.discount}\n \n )}\n {cart.deliveryCost && (\n \n {translate('checkout.order.shipping')}\n {cart.deliveryCost}\n \n )}\n {cart.paymentCost && (\n \n {translate('checkout.order.fee')}\n {cart.paymentCost}\n \n )}\n\n \n {translate('checkout.order.grandTotal')}\n {cart.grandTotal}\n \n \n {translate('checkout.order.vat')}\n {cart.vat}\n \n
\n \n
\n );\n};\n\nexport default CheckoutOrderSummary;\n","import { breakpoint } from '../mixins/breakpoints';\nimport { css, DefaultTheme } from 'styled-components';\n\nexport const hideFor = (breakpointKey: string, only: boolean = false) => {\n return css`\n ${breakpoint(breakpointKey, only ? 'only' : undefined)} {\n display: none !important;\n }\n `;\n};\n\nexport const showFor = (breakpointKey: string, only: boolean = false) => {\n if (only) {\n const getValues = (theme: DefaultTheme) => {\n const breakpointKeys = Object.keys(theme.grid.breakpoints);\n const lowerBound = theme.grid.breakpointValues[breakpointKey] - 1;\n const nextBreakpointKeyIndex = breakpointKeys.indexOf(breakpointKey) + 1;\n const nextBreakpointKey =\n nextBreakpointKeyIndex != 0\n ? breakpointKeys[nextBreakpointKeyIndex]\n : undefined;\n const upperBound = nextBreakpointKey\n ? theme.grid.breakpoints[nextBreakpointKey]\n : undefined;\n return {\n lowerBound,\n upperBound,\n nextBreakpointKey,\n };\n };\n\n return css`\n ${(p) => {\n const { lowerBound, upperBound, nextBreakpointKey } = getValues(\n p.theme\n );\n\n console.log(p);\n \n if (!upperBound && nextBreakpointKey) {\n return css`\n ${breakpoint(nextBreakpointKey, 'down')} {\n display: none !important;\n }\n `;\n } else {\n return css`\n @media screen and (max-width: ${lowerBound}px),\n screen and (min-width: ${upperBound}) {\n display: none !important;\n }\n `;\n }\n }}\n `;\n } else {\n const getValue = (theme: DefaultTheme) =>\n theme.grid.breakpointValues[breakpointKey] - 0.00125;\n\n return css`\n @media screen and (max-width: ${(p) => getValue(p.theme) - 0.00125}px) {\n display: none !important;\n }\n `;\n }\n};\n\nexport default css`\n .hide-for-small {\n @media screen and (min-width: ${(p) => p.theme.grid.breakpoints.small}) {\n display: none !important;\n }\n }\n .hide-for-medium {\n @media screen and (min-width: ${(p) => p.theme.grid.breakpoints.medium}) {\n display: none !important;\n }\n }\n .hide-for-large {\n @media screen and (min-width: ${(p) => p.theme.grid.breakpoints.large}) {\n display: none !important;\n }\n }\n .hide-for-xlarge {\n @media screen and (min-width: ${(p) => p.theme.grid.breakpoints.xlarge}) {\n display: none !important;\n }\n }\n .show-for-small {\n @media screen and (max-width: ${(p) =>\n p.theme.grid.breakpointValues.small - 0.00125}px) {\n display: none !important;\n }\n }\n .show-for-medium {\n @media screen and (max-width: ${(p) =>\n p.theme.grid.breakpointValues.medium - 0.00125}px) {\n display: none !important;\n }\n }\n .show-for-large {\n @media screen and (max-width: ${(p) =>\n p.theme.grid.breakpointValues.large - 0.00125}px) {\n display: none !important;\n }\n }\n .show-for-xlarge {\n @media screen and (max-width: ${(p) =>\n p.theme.grid.breakpointValues.large - 0.00125}px) {\n display: none !important;\n }\n }\n`;\n","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport OrderRowProductCard from '../OrderRowProductCard/OrderRowProductCard';\nimport CheckoutSection from './utils/Checkout.Section';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport CheckoutSectionFooter from './utils/Checkout.SectionFooter';\nimport { translate } from '../../Services/translation';\nimport CheckoutOrderSummary from './Checkout.OrderSummary';\nimport { update } from '../../Actions/Cart.action';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport styled from 'styled-components';\nimport { hideFor } from '../../styling/utils/visibility';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\n\nconst StyledSection = styled(CheckoutSection)`\n display: flex;\n flex-direction: column;\n gap: 2.4rem;\n\n ${breakpoint('large')} {\n gap: 1.6rem;\n }\n\n .cart__header {\n margin-bottom: 0;\n }\n`;\n\nconst StyledContent = styled(CheckoutSectionContent)`\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n`;\n\nconst StyledFooter = styled(CheckoutSectionFooter)`\n ${hideFor('large')}\n`;\n\nconst Cart = () => {\n const dispatch = useDispatch();\n const cart = useTypedSelector((state) => state.cart);\n const hasOrderRows = cart.orderRows && Object.keys(cart.orderRows).length > 0;\n const removeRow = (row) => {\n dispatch(update(row.articleNumber, 0));\n };\n\n return (\n \n \n {hasOrderRows &&\n Object.values(cart.orderRows).map((row: any) => (\n removeRow(row)}\n />\n ))}\n \n \n \n \n \n );\n};\n\nexport default Cart;\n","import { translate } from '../../../Services/translation';\nimport { string, object, boolean, mixed } from 'yup';\n\nconst requiredTranslation = translate('validation.required');\n\nexport const alwaysRequiredSchema = object().shape({\n acceptTermsOfCondition: boolean()\n .required(translate('validation.checkrequired'))\n .oneOf([true]),\n selectedDeliveryMethod: object().required(requiredTranslation),\n selectedPaymentMethod: object().required(requiredTranslation),\n});\n\nexport const privateCustomerAddressSchema = object().shape({\n lastName: string().nullable().required(requiredTranslation),\n firstName: string().nullable().required(requiredTranslation),\n address: string().nullable().required(requiredTranslation),\n zipCode: string().nullable().required(requiredTranslation),\n city: string().nullable().required(requiredTranslation),\n country: mixed()\n .nullable()\n .required(requiredTranslation)\n .notOneOf([''], requiredTranslation),\n phoneNumber: string().nullable().required(requiredTranslation),\n email: string()\n .nullable()\n .required(requiredTranslation)\n .email(translate(`validation.email`)),\n});\n\nexport const privateCustomerAlternativeAddressSchema = object().shape({\n city: string().nullable().required(requiredTranslation),\n zipCode: string().nullable().required(requiredTranslation),\n address: string().nullable().required(requiredTranslation),\n lastName: string().nullable().required(requiredTranslation),\n firstName: string().nullable().required(requiredTranslation),\n});\n\nexport const businessCustomerDetailsSchema = object().shape({\n email: string()\n .required(requiredTranslation)\n .nullable()\n .email(translate('validation.email')),\n phoneNumber: string().nullable().required(requiredTranslation),\n lastName: string().nullable().required(requiredTranslation),\n firstName: string().nullable().required(requiredTranslation),\n selectedDeliveryAddressId: string().nullable().required(requiredTranslation),\n selectedBillingAddressId: string().nullable().required(requiredTranslation),\n});\n","import React, { useState, useMemo, useEffect } from 'react';\nimport Icon from '../Icon';\nimport { InputProps } from './types/Input.types';\nimport clsx from 'clsx';\n\nconst Checkbox: React.FC<\n InputProps & React.InputHTMLAttributes\n> = ({\n inputSize = 'medium',\n inputState = 'default',\n wrapperClassName,\n label,\n message,\n helperText,\n showMessageIcon = true,\n ...props\n}) => {\n const [checked, setChecked] = useState(\n props.checked ?? props.value == 'on'\n );\n const onChange = (\n e: React.ChangeEvent\n ) => {\n props.onChange && props.onChange(e);\n setChecked(e.target.checked);\n };\n\n useEffect(() => {\n setChecked(props.checked ?? false);\n }, [props.checked])\n\n const messageIcon = useMemo(() => {\n switch (inputState) {\n case 'default':\n default:\n return null;\n\n case 'success':\n return ;\n\n case 'error':\n case 'warning':\n return ;\n }\n }, [inputState]);\n\n const sizeClass = useMemo(() => {\n switch (inputSize) {\n case 'small':\n case 'xsmall':\n return 'checkbox-wrapper--sm';\n case 'large':\n return 'checkbox-wrapper--lg';\n case 'xlarge':\n return 'checkbox-wrapper--xl';\n case 'medium':\n default:\n return 'checkbox-wrapper--md';\n }\n }, [inputSize]);\n\n const stateClass = useMemo(() => {\n switch (inputState) {\n case 'error':\n return 'checkbox-wrapper--error';\n case 'warning':\n return 'checkbox-wrapper--warning';\n case 'success':\n return 'checkbox-wrapper--success';\n default:\n return undefined;\n }\n }, [inputState]);\n\n return (\n \n \n {helperText && (\n {helperText}\n )}\n {message && (\n
\n {showMessageIcon && messageIcon}\n {message}\n
\n )}\n \n );\n};\n\nexport default Checkbox;\n","import React, { useCallback, useMemo } from 'react';\nimport { useDispatch } from 'react-redux';\nimport CheckoutSection from './utils/Checkout.Section';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport CheckoutSectionFooter from './utils/Checkout.SectionFooter';\nimport {\n acceptTermsOfCondition as setAcceptTermsOfCondition,\n setStatusSubmitButton,\n setValidationErrors,\n submit,\n submitDone,\n setCheckoutIsSubmitting,\n saveCustomerDetail,\n} from '../../Actions/Checkout.action';\nimport {\n alwaysRequiredSchema,\n businessCustomerDetailsSchema,\n privateCustomerAddressSchema,\n privateCustomerAlternativeAddressSchema,\n} from './utils/Checkout.ValidationSchema';\nimport { translate } from '../../Services/translation';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport Checkbox from '../Inputs/Checkbox';\nimport styled from 'styled-components';\nimport Button from '../Button';\n\nconst StyledCheckoutSectionFooter = styled(CheckoutSectionFooter)`\n display: flex;\n margin-top: 2.4rem;\n\n button {\n flex: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n`;\n\nconst ConfirmOrder = () => {\n const dispatch = useDispatch();\n const checkout = useTypedSelector((state) => state.checkout);\n const { payload, validationErrors = {}, checkoutIsSubmitting } = checkout;\n const {\n customerDetails,\n alternativeAddress,\n selectedDeliveryAddressId,\n selectedBillingAddressId,\n selectedDeliveryMethod,\n selectedPaymentMethod,\n showAlternativeAddress,\n isBusinessCustomer,\n acceptTermsOfCondition,\n } = payload;\n\n const onSubmit = useCallback(() => dispatch(submit()), [dispatch]);\n\n const placeOrder = useCallback(async () => {\n dispatch(setCheckoutIsSubmitting(true));\n const notCustomerDetailFields = [\n 'selectedDeliveryAddressId',\n 'selectedBillingAddressId',\n 'selectedPaymentMethod',\n 'selectedDeliveryMethod',\n 'acceptTermsOfCondition',\n ];\n\n const onValidationFailed = (stateKey: string, errors: any[]) => {\n const key = (err: any) =>\n stateKey && !notCustomerDetailFields.includes(err.path)\n ? `${stateKey}-${err.path}`\n : err.path;\n\n const newValidationErrors = errors.reduce(\n (prev, err) => ({\n ...prev,\n [key(err)]: err.errors,\n }),\n {}\n );\n dispatch(\n setValidationErrors({ ...validationErrors, ...newValidationErrors })\n );\n dispatch(setStatusSubmitButton(true));\n dispatch(submitDone(null));\n };\n\n dispatch(setStatusSubmitButton(false));\n\n // Validate, then submit. Not proud of this validation, but better than Litium default\n try {\n if (isBusinessCustomer) {\n // Business customer\n try {\n await businessCustomerDetailsSchema.validate(\n {\n ...customerDetails,\n selectedDeliveryAddressId,\n selectedBillingAddressId,\n },\n { abortEarly: false }\n );\n } catch (ex) {\n // re-throw the error with the scheme's state key\n throw { stateKey: 'customerDetails', error: ex.inner };\n }\n } else {\n // Private customer\n try {\n await privateCustomerAddressSchema.validate(\n {\n ...customerDetails,\n },\n { abortEarly: false }\n );\n } catch (ex) {\n // re-throw the error with the scheme's state key\n throw { stateKey: 'customerDetails', error: ex.inner };\n }\n\n // Alternative address\n if (showAlternativeAddress) {\n try {\n await privateCustomerAlternativeAddressSchema.validate(\n {\n ...alternativeAddress,\n },\n { abortEarly: false }\n );\n } catch (ex) {\n // re-throw the error with the scheme's state key\n throw { stateKey: 'alternativeAddress', error: ex.inner };\n }\n }\n }\n\n // Always required\n try {\n await alwaysRequiredSchema.validate(\n {\n acceptTermsOfCondition,\n selectedPaymentMethod,\n selectedDeliveryMethod,\n },\n { abortEarly: false }\n );\n } catch (ex) {\n // re-throw the error with the scheme's state key\n throw { stateKey: null, error: ex.inner };\n }\n\n // Will not be reached if any validation failed\n dispatch(saveCustomerDetail()).then(() => onSubmit());\n } catch (err) {\n dispatch(setCheckoutIsSubmitting(false));\n onValidationFailed(err.stateKey, err.error);\n }\n }, [\n dispatch,\n validationErrors,\n isBusinessCustomer,\n customerDetails,\n selectedDeliveryAddressId,\n selectedBillingAddressId,\n showAlternativeAddress,\n alternativeAddress,\n acceptTermsOfCondition,\n selectedPaymentMethod,\n selectedDeliveryMethod,\n onSubmit,\n ]);\n\n const acceptTermsError = useMemo(\n () =>\n validationErrors['acceptTermsOfCondition']\n ? validationErrors['acceptTermsOfCondition'][0]\n : null,\n [validationErrors]\n );\n\n return (\n \n \n \n dispatch(setAcceptTermsOfCondition(e.target.checked))\n }\n inputState={acceptTermsError ? 'error' : 'default'}\n label={\n <>\n {translate(`checkout.terms.acceptterms`)}{' '}\n \n {translate(`checkout.terms.link`)}\n \n \n }\n message={acceptTermsError}\n />\n \n \n placeOrder()}\n type=\"submit\"\n >\n {!checkoutIsSubmitting && translate('checkout.placeorder')}\n {\n checkoutIsSubmitting && (\n <>{translate('general.loading')}...\n ) /* TODO Loading spinner or similar */\n }\n \n \n \n );\n};\n\nexport default ConfirmOrder;\n","import React, { useCallback, useState } from 'react';\nimport {\n StyledCheckboxWrapper,\n StyledRadioButton,\n} from './styles/Inputs.styled';\nimport { InputProps } from './types/Input.types';\n\nconst RadioButton: React.FC<\n InputProps & React.InputHTMLAttributes\n> = ({\n inputSize = 'medium',\n inputState = 'default',\n wrapperClassName,\n label,\n ...props\n}) => {\n const [checked, setChecked] = useState(\n props.checked ?? props.value == 'on'\n );\n const onChange = useCallback(\n (e: React.ChangeEvent) => {\n props.onChange && props.onChange(e);\n setChecked(e.target.checked);\n },\n [props]\n );\n\n return (\n \n \n \n );\n};\n\nexport default RadioButton;\n","import React from 'react';\nimport { createUseStyles } from 'react-jss';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { Theme } from '../../../styling/variables';\nimport RadioButton from '../../Inputs/Radiobutton';\n\ninterface CheckoutRadioProps {\n className?: string;\n title?: string;\n description?: string;\n cost?: string;\n logo?: JSX.Element | string;\n stateKey?: string;\n id?: string;\n onChange?: React.ChangeEventHandler;\n checked?: boolean;\n}\n\nconst StyledCheckoutRadioWrapper = styled.label`\n display: flex;\n flex: 1;\n cursor: pointer;\n padding: 1.2rem 1.6rem;\n border: 1px solid ${getColor('grey', 200)};\n margin-bottom: 1.6rem;\n align-items: center;\n &:last-child {\n margin-bottom: unset;\n }\n\n .text-wrapper {\n display: flex;\n flex: 1;\n flex-direction: column;\n margin-left: 1.6rem;\n gap: 0.8rem;\n }\n\n .title {\n font-weight: bold;\n }\n .description {\n line-height: 150%;\n }\n .end {\n display: flex;\n align-items: center;\n justify-content: center;\n }\n .logo {\n display: flex;\n align-items: center;\n margin-left: 1.6rem;\n }\n .button-wrapper {\n //radiobutton\n }\n`;\n\nconst CheckoutRadio = ({\n className,\n title,\n description,\n cost,\n logo,\n stateKey,\n id,\n onChange,\n checked = false,\n}: CheckoutRadioProps) => {\n return (\n \n \n
\n {title}\n {description && {description}}\n
\n
\n {cost}\n {logo && {logo}}\n
\n \n );\n};\n\nexport default CheckoutRadio;\n","import React, { useEffect } from 'react';\nimport { useDispatch } from 'react-redux';\nimport CheckoutSection from './utils/Checkout.Section';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport Radio from './utils/Checkout.Radio';\nimport { setDelivery } from '../../Actions/Checkout.action';\nimport { translate } from '../../Services/translation';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\n\nconst DeliveryMethods = () => {\n const dispatch = useDispatch();\n const checkout = useTypedSelector((state) => state.checkout);\n const { deliveryMethods, selectedDeliveryMethod } = checkout.payload;\n\n useEffect(() => {\n if (!selectedDeliveryMethod) return;\n\n dispatch(setDelivery(selectedDeliveryMethod));\n }, []);\n\n return (\n \n \n {deliveryMethods &&\n deliveryMethods.map((method) => (\n \n )\n }\n stateKey={'delivery-method'}\n id={method.id}\n checked={method.id === selectedDeliveryMethod?.id}\n onChange={() => dispatch(setDelivery(method))}\n />\n ))}\n \n \n );\n};\n\nexport default DeliveryMethods;\n","import React, { useEffect } from 'react';\nimport { useDispatch } from 'react-redux';\nimport CheckoutSection from './utils/Checkout.Section';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport { setPayment } from '../../Actions/Checkout.action';\nimport Radio from './utils/Checkout.Radio';\nimport { translate } from '../../Services/translation';\nimport Icon from '../Icon';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport styled from 'styled-components';\n\nconst StyledMailIcon = styled(Icon)`\n font-size: 2.4rem;\n`;\n\nconst PaymentMethods = () => {\n const dispatch = useDispatch();\n const checkout = useTypedSelector((state) => state.checkout);\n const { paymentMethods, selectedPaymentMethod } = checkout.payload;\n\n useEffect(() => {\n if (!selectedPaymentMethod) return;\n\n dispatch(setPayment(selectedPaymentMethod));\n }, []);\n\n return paymentMethods.length > 1 ? (\n \n \n {paymentMethods &&\n paymentMethods.map((method) => (\n \n ) : (\n \n )\n }\n stateKey={'payment-method'}\n id={method.id}\n onChange={() => dispatch(setPayment(method))}\n checked={method.id === selectedPaymentMethod?.id}\n />\n ))}\n \n \n ) : null;\n};\n\nexport default PaymentMethods;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport styled from 'styled-components';\nimport { getColor } from '../styling/mixins/colors';\nimport { text } from '../styling/mixins/typography';\nimport { alignCenter } from '../styling/utils/flex';\nimport { hideFor, showFor } from '../styling/utils/visibility';\nimport Icon from './Icon';\nimport { breakpoint } from '../styling/mixins/breakpoints';\n\nexport interface DropdownOption {\n value: any;\n label?: string;\n disabled?: boolean;\n legendLabel?: string;\n}\n\ninterface DropdownAttributes {\n options: DropdownOption[];\n onChange?: (option: DropdownOption) => void;\n selectedValue?: any;\n className?: string;\n size?: 'small' | 'large';\n placeholder?: string;\n disabled?: boolean;\n label?: string;\n}\n\ninterface DesktopDropdownWrapperProps {\n $disabled: boolean;\n $placeholderVisible: boolean;\n}\n\nconst DesktopDropdownWrapper = styled.div`\n ${showFor('large')}\n\n width: 100%;\n position: relative;\n color: ${getColor('grey', 900)};\n pointer-events: ${(p) => (p.$disabled ? 'none' : null)};\n\n .options-list {\n position: absolute;\n top: 100%;\n margin-top: 0.4rem;\n width: 100%;\n border: 1px solid ${getColor('grey', 400)};\n background-color: ${getColor('grey', 100)};\n z-index: 10;\n }\n\n .dropdown-label {\n flex: 1;\n color: ${(p) => (p.$placeholderVisible ? getColor('grey', 400) : null)};\n display: flex;\n flex-direction: column;\n\n .legend-label{\n top: 9px;\n font-size: 12px;\n font-weight: 400;\n line-height: 10px;\n }\n }\n`;\n\nconst MobileDropdownWrapper = styled.div`\n ${hideFor('large')}\n\n .mobile-legend{\n position: absolute;\n z-index: 100;\n margin-left: 1.85rem;\n margin-top: 10px;\n font-size: 12px;\n font-weight: 400;\n }\n`;\n\nconst MobileSelectWrapper = styled.div`\n position: relative;\n`;\n\nconst StyledLabel = styled.div`\n ${text('large')}\n font-weight: bold;\n margin-bottom: 0.8rem;\n`;\n\nconst StyledSelect = styled.select<{ $size: string, $showMobileLegend: boolean | undefined, }>`\n ${text('large')}\n ${alignCenter}\n display: flex;\n padding: ${(p) => (p.$size == 'large' ? '1.6rem' : '0.8rem 1.2rem')};\n border: 1px solid ${getColor('grey', 400)};\n background-color: ${getColor('grey', 100)};\n max-height: 60px;\n ${breakpoint('large')} {\n max-height: 56px;\n }\n cursor: pointer;\n -webkit-appearance: none;\n -moz-appearance: none;\n width: 100%;\n line-height: ${(p) => (p.$showMobileLegend && '2')};\n &:focus {\n outline: none;\n }\n\n option {\n ${text('medium')}\n }\n`;\n\ninterface DesktopOptionProps {\n $selected: boolean;\n $disabled: boolean;\n}\n\nconst StyledDesktopOption = styled.li`\n ${text('medium')}\n color: ${(p) => getColor('grey', p.$disabled ? 400 : 900)};\n padding: 1rem 1.2rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n cursor: pointer;\n font-weight: ${(p) => (p.$selected ? '700' : null)};\n pointer-events: ${(p) => (p.$selected || p.$disabled ? 'none' : null)};\n\n &:last-child {\n border-bottom: none;\n }\n`;\n\nconst StyledSelectIcon = styled(Icon)<{ $open: boolean }>`\n font-size: 2rem;\n transition: rotate 300ms;\n rotate: ${(p) => (p.$open ? '180deg' : null)};\n`;\n\nconst StyledSelectIconMobile = styled(StyledSelectIcon)`\n position: absolute;\n right: 12px;\n top: 50%;\n transform: translateY(-50%);\n transform-origin: 50% 0;\n`;\n\nconst Dropdown = ({\n options,\n selectedValue: initialSelectedValue,\n onChange,\n className = '',\n size = 'large',\n placeholder,\n disabled = false,\n label,\n}: DropdownAttributes) => {\n const [selectedValue, setSelectedValue] = useState(\n initialSelectedValue ?? placeholder\n );\n const [dropdownOpen, setDropdownOpen] = useState(false);\n\n const selectedOption = useMemo(\n () => options?.find((o) => o.value == selectedValue),\n [selectedValue, options]\n );\n\n useEffect(() => {\n let _selectedValue = options?.find((o) => o.value == selectedValue && (o.disabled == false || o.disabled == undefined));\n if (!_selectedValue) {\n setSelectedValue(undefined);\n }\n }, [options])\n\n const onOptionSelected = (value: string | undefined) => {\n setSelectedValue(value);\n const selectedOption = options?.find((o) => o.value == value);\n if (onChange) {\n onChange(selectedOption);\n }\n setDropdownOpen(false);\n };\n\n return (\n <>\n \n {label ? {label} : null}\n {selectedOption?.legendLabel && \n {selectedOption?.legendLabel}\n }\n \n onOptionSelected(e.target.value)}\n onClick={() => setDropdownOpen(!dropdownOpen)}\n onBlur={() => setDropdownOpen(false)}\n disabled={disabled}\n className=\"dropdown-select\"\n >\n {placeholder && (\n \n )}\n {options.map((option, index) => (\n \n {option.label ?? option.value}\n \n ))}\n \n \n \n \n setDropdownOpen(false)}\n tabIndex={1}\n >\n {label ? {label} : null}\n setDropdownOpen(!dropdownOpen)}\n className=\"dropdown-select\"\n >\n
\n {selectedOption?.legendLabel ?\n <>\n \n {selectedOption?.legendLabel} \n \n \n {selectedOption?.label ?? selectedOption?.value ?? placeholder}\n \n \n : selectedOption?.label ?? selectedOption?.value ?? placeholder\n }\n
\n \n \n {dropdownOpen && (\n
    \n {options.map((option, index) => (\n {\n onOptionSelected(option.value);\n setDropdownOpen(false);\n }}\n key={option.value + index + 'desktop'}\n >\n {option.label ?? option.value}\n \n ))}\n
\n )}\n \n \n );\n};\n\nexport default Dropdown;\n","import { css } from 'styled-components';\nimport { breakpoint } from '../mixins/breakpoints';\n\nexport const grid = css`\n display: grid;\n\n // Generate gap different breakpoints\n ${(p) =>\n Object.keys(p.theme.grid.gridRowGutter).map(\n (key) => css`\n ${breakpoint(key)} {\n gap: ${(p) => p.theme.grid.gridRowGutter[key]};\n }\n `\n )}\n`;\n\nconst generateGridTemplateColumns = (\n cells: number,\n fractions: string = '1fr'\n) => {\n switch (cells) {\n case 1:\n case undefined:\n return css`\n grid-template-columns: ${fractions};\n `;\n default:\n return css`\n grid-template-columns: repeat(${cells}, ${fractions});\n `;\n }\n};\n\nexport const cells = (cells: number, fraction?: string) => css`\n ${generateGridTemplateColumns(cells, fraction)}\n`;\n\nexport const span = (span: number) => css`\n grid-column: span ${span};\n`;\n\nexport const section = css`\n max-width: ${(p) => p.theme.grid.rowMaxWidth};\n margin-left: auto;\n margin-right: auto;\n\n // Generate section paddings for different breakpoints\n ${(p) =>\n Object.keys(p.theme.grid.gridRowGutter).map(\n (key) => css`\n ${breakpoint(key)} {\n padding-left: ${(p) => p.theme.grid.gridRowGutter[key]};\n padding-right: ${(p) => p.theme.grid.gridRowGutter[key]};\n }\n `\n )}\n`;\n\nexport default css`\n .section {\n ${section}\n\n &--fullwidth {\n max-width: none;\n }\n }\n\n .grid {\n ${grid}\n }\n\n .grid-auto-rows {\n grid-auto-rows: 1fr;\n }\n`;\n","import styled from 'styled-components';\nimport { cells, span } from '../../../styling/utils/grid';\nimport CheckoutSection from '../utils/Checkout.Section';\n\nexport const StyledPrivateCustomerWrapper = styled(CheckoutSection)`\n .section-content {\n display: grid;\n gap: 2.4rem;\n ${cells(2)}\n }\n .checkout__input-oneCol {\n ${span(1)}\n }\n .checkout__input-fullCol {\n ${span(2)}\n }\n\n .checkout__checkbox {\n display: flex;\n flex: 1;\n margin-top: 2.4rem;\n :not(:first-child) {\n margin-bottom: 2.4rem;\n }\n }\n`;\n","import React, { useCallback, useMemo } from 'react';\nimport { useDispatch } from 'react-redux';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport CheckoutSectionFooter from './utils/Checkout.SectionFooter';\nimport { translate } from '../../Services/translation';\nimport {\n setCustomerDetails,\n setAlternativeAddress,\n setShowAlternativeAddress,\n setSignUp,\n setValidationErrors,\n} from '../../Actions/Checkout.action';\nimport { privateCustomerAddressSchema } from './utils/Checkout.ValidationSchema';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport Dropdown from '../Dropdown';\nimport styled from 'styled-components';\nimport Checkbox from '../Inputs/Checkbox';\nimport Input from '../Inputs/Input';\nimport { InputProps } from '../Inputs/types/Input.types';\nimport { StyledPrivateCustomerWrapper } from './styles/Checkout.PrivateCustomerInfo.styling';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\n\ninterface CustomerInfoInputProps {\n validationSchema: any;\n stateKey: string;\n id: string;\n onCustomerDetailsChange?: (\n stateKey: string,\n id: string,\n value: string\n ) => void;\n}\n\nconst StyledLoginLink = styled.div`\n ${text('medium')}\n\n a {\n color: ${getColor('grey', 900)};\n text-decoration: underline;\n }\n`;\n\nconst CustomerInfoInput: React.FC<\n CustomerInfoInputProps &\n InputProps &\n React.InputHTMLAttributes\n> = ({\n validationSchema,\n stateKey,\n onCustomerDetailsChange,\n id,\n wrapperClassName,\n ...props\n}) => {\n const dispatch = useDispatch();\n const { validationErrors = {}, payload } = useTypedSelector(\n (state) => state.checkout\n );\n\n const errorMessage = useMemo(\n () =>\n validationErrors[`${stateKey}-${id}`]\n ? validationErrors[`${stateKey}-${id}`][0]\n : null,\n [id, stateKey, validationErrors]\n );\n\n const validateOnBlur = useCallback(\n async (schema, stateKey, id, value) => {\n const errorKey = `${stateKey}-${id}`;\n try {\n await schema.validateAt(id, { [id]: value });\n const validationErrorsCopy = { ...validationErrors };\n delete validationErrorsCopy[errorKey];\n dispatch(setValidationErrors(validationErrorsCopy));\n } catch (err) {\n dispatch(\n setValidationErrors({\n ...validationErrors,\n [errorKey]: err.errors,\n })\n );\n }\n },\n [dispatch, validationErrors]\n );\n\n return (\n \n onCustomerDetailsChange &&\n onCustomerDetailsChange(stateKey, id, event.target.value)\n }\n onBlur={(e) =>\n validateOnBlur(validationSchema, stateKey, id, e.target.value)\n }\n inputSize=\"large\"\n value={(payload[stateKey] && payload[stateKey][id]) ?? ''}\n />\n );\n};\n\nconst PrivateCustomerInfo = ({ showSignUp }) => {\n const dispatch = useDispatch();\n const { payload } = useTypedSelector((state) => state.checkout);\n const {\n authenticated,\n customerDetails = {},\n signUp,\n loginUrl,\n showAlternativeAddress,\n } = payload;\n const classes: any = {};\n\n const onCustomerDetailsChange = useCallback(\n (stateKey, id, value) => {\n switch (stateKey) {\n case 'customerDetails':\n dispatch(setCustomerDetails(id, value));\n break;\n case 'alternativeAddress':\n dispatch(setAlternativeAddress(id, value));\n break;\n }\n },\n [dispatch]\n );\n\n const titleRight = useMemo(\n () =>\n !authenticated ? (\n \n {translate('checkout.customerinfo.existingcustomer')}{' '}\n {translate('checkout.customerinfo.login')}\n \n ) : undefined,\n [authenticated, loginUrl]\n );\n\n return (\n \n \n
\n \n \n \n \n \n \n
\n ({ label: text, value }))}\n onChange={(value) => {\n onCustomerDetailsChange('alternativeAddress', 'country', value);\n onCustomerDetailsChange('customerDetails', 'country', value);\n }}\n />\n
\n \n \n \n
\n \n {showSignUp && (\n dispatch(setSignUp(e.target.checked))}\n />\n )}\n \n dispatch(setShowAlternativeAddress(e.target.checked))\n }\n />\n \n {showAlternativeAddress && (\n \n
\n \n \n \n \n \n \n \n
\n )}\n \n );\n};\n\nexport default PrivateCustomerInfo;\n","import React, { useMemo } from 'react';\nimport CheckoutSection from './utils/Checkout.Section';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport { translate } from '../../Services/translation';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { cells } from '../../styling/utils/grid';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport Icon from '../Icon';\nimport Dropdown from '../Dropdown';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { useDispatch } from 'react-redux';\nimport {\n setSelectedDeliveryAddress,\n setSelectedBillingAddress,\n} from '../../Actions/Checkout.action';\n\nconst StyledCheckoutSectionContent = styled(CheckoutSectionContent)`\n display: grid;\n gap: 1.6rem;\n\n ${breakpoint('medium')} {\n ${cells(2)}\n }\n`;\n\nconst StyledCheckoutInfoWrapper = styled.div`\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n\n .wrapper-title {\n ${text('large')}\n font-weight: bold;\n }\n`;\n\nconst StyledCheckoutInfoContainer = styled.div`\n border: 1px solid ${getColor('grey', 900)};\n background-color: ${getColor('grey', 100)};\n padding: 1.6rem;\n display: flex;\n gap: 0.8rem;\n flex: 1;\n\n .container-text {\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n }\n\n .container-title {\n font-weight: bold;\n }\n`;\n\nconst StyledInfoIcon = styled(Icon)`\n font-size: 2.4rem;\n`;\n\nconst StyledCheckoutDropdown = styled(Dropdown)`\n margin-bottom: 0.8rem;\n\n .dropdown-select {\n background-color: ${getColor('grey', 100)};\n }\n`;\n\nconst BusinessCustomerInfo = () => {\n const dispatch = useDispatch();\n const { payload } = useTypedSelector((state) => state.checkout);\n const addressList = useMemo(\n () =>\n payload.companyAddresses.filter((type) => type.addressType !== 'Billing'),\n [payload.companyAddresses]\n );\n const billingList = useMemo(\n () =>\n payload.companyAddresses.filter((type) => type.addressType == 'Billing'),\n [payload.companyAddresses]\n );\n const selectedDeliveryAddress = useMemo(\n () =>\n addressList.find((a) => a.systemId == payload.selectedDeliveryAddressId),\n [addressList, payload.selectedDeliveryAddressId]\n );\n const selectedBillingAddress = useMemo(\n () =>\n billingList.find((a) => a.systemId == payload.selectedBillingAddressId),\n [billingList, payload.selectedBillingAddressId]\n );\n\n return (\n \n \n \n
\n {translate('checkout.selectdelivery')}\n
\n ({\n value: address.systemId,\n label: `${payload.companyName}, ${address.address}, ${address.city}, ${address.zipCode}, ${address.country}`,\n }))}\n onChange={({ value }) => {\n dispatch(setSelectedDeliveryAddress(value));\n }}\n disabled={addressList.length <= 1}\n />\n
\n {translate('checkout.order.delivery')}\n
\n \n \n
\n {payload.companyName}\n \n {selectedDeliveryAddress?.address}\n \n \n {selectedDeliveryAddress?.zipCode}{' '}\n {selectedDeliveryAddress?.city}\n \n \n {selectedDeliveryAddress?.country}\n \n
\n
\n
\n \n
\n {translate('checkout.selectbilling')}\n
\n ({\n value: address.systemId,\n label: `${payload.companyName}, ${address.address}, ${address.city}, ${address.zipCode}, ${address.country}`,\n }))}\n onChange={({ value }) => setSelectedBillingAddress(value)}\n disabled={billingList.length <= 1}\n />\n
\n {translate('checkout.order.billing')}\n
\n \n \n
\n {payload.companyName}\n \n {selectedBillingAddress?.address}\n \n \n {selectedBillingAddress?.zipCode} {selectedBillingAddress?.city}\n \n \n {selectedBillingAddress?.country}\n \n
\n
\n
\n
\n
\n );\n};\n\nexport default BusinessCustomerInfo;\n","import Icon from '../Icon';\nimport React from 'react';\nimport { translate } from '../../Services/translation';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport Button from '../Button';\nimport { section } from '../../styling/utils/grid';\n\nconst StyledEmptyCart = styled.div`\n ${section}\n display: flex;\n justify-content: center;\n align-items: center;\n\n .empty-cart-content {\n display: flex;\n align-items: center;\n flex-direction: column;\n max-width: 768px;\n width: 100%;\n padding: 80px 0;\n\n ${breakpoint('large')} {\n padding: 240px 0;\n }\n }\n\n .icon {\n font-size: 7.2rem;\n margin-bottom: 0.8rem;\n }\n\n h1 {\n margin-bottom: 0.8rem;\n text-align: center;\n }\n\n .para {\n ${text('large')}\n text-align: center;\n margin-bottom: 2.4rem;\n }\n\n button {\n font-weight: bold;\n text-transform: uppercase;\n }\n`;\n\nconst EmptyCart = () => {\n const checkout = useTypedSelector((state) => state.checkout);\n const { emptyCartMessage, emptyCartLink } = checkout.payload;\n\n return (\n \n
\n \n

{translate('checkout.empty.title')}

\n {emptyCartMessage && (\n \n )}\n {emptyCartLink && (\n \n \n \n )}\n
\n
\n );\n};\n\nexport default EmptyCart;\n","import { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { cells, section, span } from '../../../styling/utils/grid';\nimport { hideFor, showFor } from '../../../styling/utils/visibility';\n\nexport const StyledCheckout = styled.div`\n padding: 2.4rem 0;\n background-color: ${getColor('grey', 100)};\n\n ${breakpoint('medium')} {\n padding: 3.2rem 0;\n }\n ${breakpoint('large')} {\n padding: 4rem 0;\n }\n\n .checkout-content {\n padding: 0;\n ${breakpoint('large')} {\n ${section}\n }\n }\n\n .checkout__wrapper {\n gap: 0;\n ${cells(1)}\n ${breakpoint('large')} {\n gap: 2.4rem;\n ${cells(3)}\n }\n ${breakpoint('xlarge')} {\n gap: 4.8rem;\n }\n }\n\n .checkout__title {\n line-height: 120%;\n margin-bottom: 1.6rem;\n padding: 0 1.6rem;\n\n ${breakpoint('large')} {\n padding: unset;\n }\n }\n\n .checkout__sections-wrapper {\n display: flex;\n flex-direction: column;\n gap: 1.6rem;\n ${span(1)}\n ${breakpoint('small')} {\n ${span(2)}\n gap: 2.4rem;\n }\n }\n\n .checkout-order-summary {\n display: none;\n ${breakpoint('large')} {\n display: flex;\n }\n }\n\n .payment-widget__section {\n padding-top: 0;\n padding-bottom: 0;\n }\n\n .cart__section-wrapper {\n ${span(1)}\n }\n .cart__mobilesection-wrapper {\n display: flex;\n flex-direction: column;\n gap: 2.4rem;\n ${hideFor('large')}\n ${span(1)}\n }\n .cart__desktopsection-wrapper {\n ${breakpoint('large')} {\n ${span(1)}\n height: max-content;\n }\n }\n`;\n","import React, { lazy, Suspense } from 'react';\n\nconst DynamicComponent = ({ loader, loading =
}) => {\n const Component = lazy(loader);\n return (props) => (\n \n \n \n );\n};\n\nexport default DynamicComponent;\n","import React from 'react';\nimport DynamicComponent from '../DynamicComponent';\nimport CheckoutSection from '../Checkout/utils/Checkout.Section';\nimport CheckoutSectionContent from '../Checkout/utils/Checkout.SectionContent';\nimport { translate } from '../../Services/translation';\n\nconst scriptPattern = /]*>([\\s\\S]*?)<\\/script>/gi;\nconst scriptFilePattern = / {\n let matches,\n html = domString;\n const scripts = [],\n scriptFiles = [];\n while ((matches = scriptPattern.exec(domString)) !== null) {\n html = html.replace(matches[0], '');\n matches[1] && matches[1].trim() !== '' && scripts.push(matches[1]);\n }\n while ((matches = scriptFilePattern.exec(domString)) !== null) {\n matches[1] && matches[1].trim() !== '' && scriptFiles.push(matches[1]);\n }\n\n return {\n html,\n scripts,\n scriptFiles,\n };\n};\n\nconst executeScript = (domId, scriptContent) => {\n const script = document.createElement('script');\n script.type = 'text/javascript';\n try {\n script.appendChild(document.createTextNode(scriptContent));\n } catch (e) {\n // to support IE\n script.text = scriptContent;\n }\n document.getElementById(domId).appendChild(script);\n};\n\nconst includeScript = (domId, srciptUrl) => {\n const script = document.createElement('script');\n script.type = 'text/javascript';\n script.src = srciptUrl;\n document.getElementById(domId).appendChild(script);\n};\n\nconst PaymentWidget = React.memo(function PaymentWidget({ responseString }) {\n const renderWidget = (paymentSession) => {\n const CheckoutWidget = DynamicComponent({\n loader: () => import('./CheckoutWidget'),\n });\n const args = {\n paymentSession,\n extractScripts,\n executeScript,\n includeScript,\n };\n return ;\n };\n\n return (\n \n \n {renderWidget(responseString)}\n \n \n );\n});\n\nexport default PaymentWidget;\n","import { get, post } from '../../../Services/http';\nimport { IngridSession } from './Types/IngridSession';\n\nexport const getSession: () => Promise = async () => {\n const response = await get('/api/ingrid');\n return response.json();\n};\n\nexport const updateSession: () => Promise<\n IngridSession | undefined\n> = async () => {\n const response = await post('/api/ingrid', {});\n return response.status == 200 ? response.json() : undefined;\n};\n\nfunction isScriptNode(node) {\n return node.tagName === 'SCRIPT';\n}\n\nfunction isExternalScript(node) {\n return !!node.src && node.src !== '';\n}\n\nfunction cloneScriptNode(node, onLoad) {\n var script = document.createElement('script');\n script.text = node.innerHTML;\n for (var i = node.attributes.length - 1; i >= 0; i--) {\n script.setAttribute(node.attributes[i].name, node.attributes[i].value);\n if (onLoad) {\n script.addEventListener('load', onLoad);\n }\n }\n return script;\n}\n\nexport function replaceScriptNode(node, onLoad: any = undefined) {\n if (isScriptNode(node) && !isExternalScript(node)) {\n node.parentNode.replaceChild(cloneScriptNode(node, onLoad), node);\n } else {\n var i = 0,\n children = node.childNodes;\n while (i < children.length) {\n replaceScriptNode(children[i++], onLoad);\n }\n }\n return node;\n}\n","import { debounce } from 'lodash-es';\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { post } from '../../../Services/http';\nimport isEqual from 'deep-equal';\nimport { IngridDeliveryCheckoutProps } from './Types/IngridDeliveryCheckoutProps';\nimport { ShippingOptionChangedData } from './Types/ShippingOptionChangedData';\nimport {\n getSession,\n replaceScriptNode,\n updateSession,\n} from './IngridDeliveryCheckout.service';\n\n// To use window._sw in TypeScript\ndeclare global {\n interface Window {\n _sw: any;\n }\n}\n\nconst IngridDeliveryCheckout = ({\n className,\n ingridDeliveryMethodId,\n uniqueContainerId = 'shipwallet-container',\n updateDependencies,\n selectedDeliveryMethodId,\n onShippingOptionChanged,\n onError,\n}: IngridDeliveryCheckoutProps) => {\n const [htmlSnippet, setHtmlSnippet] = useState('');\n const [ingridWidgetLoaded, setIngridWidgetLoaded] = useState(false);\n const [previousUpdateDeps, setPreviousUpdateDeps] =\n useState(updateDependencies);\n const wrapperRef = useRef(null);\n\n useEffect(() => {\n const anyDepsHasChanged = updateDependencies.some(\n (current, idx) =>\n !isEqual(\n current,\n previousUpdateDeps.length > idx\n ? previousUpdateDeps[idx]\n : undefined\n )\n );\n\n if (\n ingridWidgetLoaded &&\n updateDependencies.length > 0 &&\n anyDepsHasChanged\n ) {\n setPreviousUpdateDeps(updateDependencies);\n updateIngridSession();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [updateDependencies]);\n\n // Load ingrid if selected delivery method is ingrid\n useEffect(() => {\n selectedDeliveryMethodId == ingridDeliveryMethodId\n ? initIngrid()\n : setHtmlSnippet('');\n }, [selectedDeliveryMethodId, ingridDeliveryMethodId]);\n\n const handleApiError = useCallback(\n async (err) => {\n let errorMessage;\n if (err.response) {\n const data = await err.response.json();\n errorMessage = data.error;\n } else {\n errorMessage = err;\n }\n\n if (typeof onError === 'function') {\n onError(errorMessage);\n } else {\n console.error(errorMessage);\n }\n },\n [onError]\n );\n\n const onShippingMethodChanged = useCallback(\n async (data) => {\n try {\n if (typeof window._sw === 'function') {\n window._sw((api) => api.suspend());\n const response = await post('/api/ingrid/shippingoption', data);\n if (response.ok && typeof onShippingOptionChanged === 'function') {\n onShippingOptionChanged(data as ShippingOptionChangedData);\n }\n\n window._sw((api) => api.resume());\n }\n } catch (err) {\n await handleApiError(err);\n }\n },\n [handleApiError, onShippingOptionChanged]\n );\n\n const registerIngridEvents = () => {\n \n window._sw((api) => {\n api.on('loaded', () => setIngridWidgetLoaded(true));\n api.on('data_changed', async (data, meta) => {\n if (\n meta.price_changed ||\n meta.shipping_method_changed ||\n meta.pickup_location_changed ||\n meta.external_method_id_changed ||\n meta.search_address_changed ||\n meta.category_name_changed ||\n meta.delivery_type_changed\n ) {\n await onShippingMethodChanged(data);\n }\n });\n });\n };\n\n // Initialize ingrid scripts after setting html snippet\n useEffect(() => {\n if (wrapperRef?.current && !!htmlSnippet && !ingridWidgetLoaded) {\n replaceScriptNode(\n wrapperRef.current.querySelector(`#${uniqueContainerId}`)\n );\n registerIngridEvents();\n }\n }, [htmlSnippet]); // eslint-disable-line react-hooks/exhaustive-deps\n\n const initIngrid = async () => {\n try {\n const session = await getSession();\n if (session) {\n setHtmlSnippet(session.htmlSnippet);\n }\n } catch (err) {\n await handleApiError(err);\n }\n };\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const updateIngridSession = useCallback(\n debounce(async () => {\n try {\n\n if (typeof window._sw === 'function') {\n window._sw((api) => api.suspend());\n }\n const ingridSession = await updateSession();\n if (ingridSession?.htmlSnippet) {\n setHtmlSnippet(ingridSession.htmlSnippet);\n }\n } catch (err) {\n await handleApiError(err);\n } finally {\n if (typeof window._sw === 'function') {\n window._sw((api) => api.resume());\n }\n }\n }, 500),\n []\n );\n\n return (\n \n );\n};\n\nexport default IngridDeliveryCheckout;\n","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport CheckoutSection from './utils/Checkout.Section';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport { translate } from '../../Services/translation';\nimport { setSignUp, submitSignup } from '../../Actions/Checkout.action';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport Checkbox from '../Inputs/Checkbox';\n\nconst StyledCheckoutSection = styled(CheckoutSection)`\n .description {\n ${text('large')}\n margin-bottom: 1.6rem;\n }\n`;\n\nconst SignUp = () => {\n const dispatch = useDispatch();\n const checkout = useTypedSelector((state) => state.checkout);\n const { signUp } = checkout.payload;\n\n const SignUp = async (sign) => {\n await dispatch(setSignUp(sign));\n await dispatch(submitSignup());\n };\n\n return (\n \n
\n {translate('checkout.signup.description')}\n
\n \n dispatch(SignUp(e.target.checked))}\n />\n \n
\n );\n};\n\nexport default SignUp;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\nimport Icon from '../../Icon';\n\nconst StyledMessage = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 1.2rem;\n background-color: ${getColor('primary', 100)};\n border: 1px solid ${getColor('primary', 800)};\n margin: 0 1.6rem 2.4rem 1.6rem;\n font-size: 1.6rem;\n ${breakpoint('large')} {\n margin: 0 0 2.4rem 0;\n }\n`;\n\nconst StyledIcon = styled(Icon)`\n font-size: 2.4rem;\n margin-right: 0.8rem;\n`;\n\nconst CheckoutMessage = ({ message }) => {\n return (\n \n \n {message}\n \n );\n};\n\nexport default CheckoutMessage;\n","import React, { useCallback, useState, useEffect } from 'react';\nimport { translate } from '../../Services/translation';\nimport Icon from '../Icon';\nimport AdditionalOrderInfo from './Checkout.AdditionalOrderInfo';\nimport Cart from './Checkout.Cart';\nimport ConfirmOrder from './Checkout.ConfirmOrder';\nimport DeliveryMethods from './Checkout.DeliveryMethods';\nimport PaymentMethods from './Checkout.PaymentMethods';\nimport PrivateCustomerInfo from './Checkout.PrivateCustomerInfo';\nimport BusinessCustomerInfo from './Checkout.BusinessCustomerInfo';\nimport EmptyCart from './Checkout.EmptyCart';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { StyledCheckout } from './styles/Checkout.styling';\nimport PaymentWidget from '../Payments/PaymentWidget';\nimport {\n PaymentIntegrationType,\n ShippingIntegrationType,\n} from '../../constants';\nimport { load as loadCart } from '../../Actions/Cart.action';\nimport IngridDeliveryCheckout from './Ingrid/IngridDeliveryCheckout';\nimport { useDispatch } from 'react-redux';\nimport SignUp from './Checkout.Signup';\nimport CheckoutOrderSummary from './Checkout.OrderSummary';\nimport CheckoutMessage from './utils/Checkout.Message';\nimport CheckoutSection from './utils/Checkout.Section';\nimport CheckoutSectionContent from './utils/Checkout.SectionContent';\nimport { setPayment, setDelivery } from '../../Actions/Checkout.action';\n\nconst Checkout = () => {\n const dispatch = useDispatch();\n const { payload } = useTypedSelector((state) => state.checkout);\n const cart = useTypedSelector((state) => state.cart);\n const [orderRows] = useState(cart?.orderRows);\n const hasOrderRows = orderRows && Object.keys(orderRows).length > 0;\n const numProducts = hasOrderRows ? Object.values(cart.orderRows).length : 0;\n const {\n message,\n isBusinessCustomer,\n paymentWidget,\n deliveryMethods,\n selectedDeliveryMethod,\n selectedPaymentMethod,\n paymentMethods,\n authenticated,\n } = payload;\n\n const [paymentWidgetVisibility, setPaymentWidgetVisibility] = useState(true);\n const [paymentOptionVisibility, setPaymentOptionVisibility] = useState(true);\n const [customerDetailsVisibility, setCustomerDetailsVisibility] = useState(\n true\n );\n const [deliveryWidgetVisibility, setDeliveryWidgetVisibility] = useState(\n true\n );\n const [confirmOrderVisibility, setConfirmOrderVisibility] = useState(true);\n const [signUpCheckboxVisibility, setSignUpCheckboxVisibility] = useState(\n true\n );\n const [shippingOptionVisibility, setShippingOptionVisibility] = useState(\n true\n );\n\n const checkIntegrationTypeExist = useCallback(\n (integrationTypeCheck) => {\n return deliveryMethods.find(\n (method) => method.integrationType === integrationTypeCheck\n );\n },\n [DeliveryMethods]\n );\n\n const resetVisibilityValues = useCallback(() => {\n setShippingOptionVisibility(true);\n setPaymentOptionVisibility(true);\n setCustomerDetailsVisibility(true);\n setDeliveryWidgetVisibility(true);\n setPaymentWidgetVisibility(true);\n setConfirmOrderVisibility(true);\n setSignUpCheckboxVisibility(true);\n }, []);\n\n // Show or hide different sections depending on payment and delivery methods.\n useEffect(() => {\n resetVisibilityValues();\n switch (selectedPaymentMethod?.integrationType) {\n case PaymentIntegrationType.IframeCheckout:\n setCustomerDetailsVisibility(false);\n setConfirmOrderVisibility(false);\n setSignUpCheckboxVisibility(true);\n break;\n case PaymentIntegrationType.PaymentWidgets:\n setConfirmOrderVisibility(false);\n setSignUpCheckboxVisibility(true);\n break;\n case PaymentIntegrationType.DirectPayment:\n setPaymentWidgetVisibility(false);\n break;\n }\n if (checkIntegrationTypeExist(ShippingIntegrationType.DeliveryCheckout)) {\n return setShippingOptionVisibility(false);\n }\n if (checkIntegrationTypeExist(ShippingIntegrationType.PaymentCheckout)) {\n setShippingOptionVisibility(false);\n setDeliveryWidgetVisibility(false);\n return;\n }\n if (\n selectedDeliveryMethod?.integrationType === ShippingIntegrationType.Inline\n ) {\n setDeliveryWidgetVisibility(false);\n }\n }, [\n selectedDeliveryMethod,\n selectedPaymentMethod,\n deliveryMethods,\n paymentMethods,\n resetVisibilityValues,\n checkIntegrationTypeExist,\n ]);\n\n console.log(selectedDeliveryMethod?.integrationType);\n\n const responseString = paymentWidget ? paymentWidget.responseString : null;\n const updateKey = paymentWidget ? paymentWidget._force_update : null;\n\n useEffect(() => {\n if (!selectedDeliveryMethod) return;\n\n dispatch(setDelivery(selectedDeliveryMethod));\n }, []);\n\n const onShippingOptionChanged = () => {\n dispatch(loadCart());\n dispatch(setPayment(selectedPaymentMethod));\n };\n\n if (numProducts <= 0) {\n return (\n \n \n \n );\n }\n return (\n \n
\n

{translate('checkout.title')}

\n {message && }\n
\n
\n \n {!isBusinessCustomer && customerDetailsVisibility && (\n \n )}\n {isBusinessCustomer && customerDetailsVisibility && (\n \n )}\n \n \n \n \n \n {paymentOptionVisibility && }\n {!authenticated && }\n {!paymentWidget && !paymentWidgetVisibility && (\n \n )}\n {confirmOrderVisibility && }\n {paymentWidget && paymentWidgetVisibility && (\n \n )}\n
\n
\n \n
\n
\n
\n
\n );\n};\nexport default Checkout;\n","import React, { useEffect, useState } from 'react';\nimport { Collapse } from 'react-collapse';\nimport Icon from './Icon';\nimport clsx from 'clsx';\n\ninterface CollapsibleAttributes {\n label?: string | JSX.Element;\n labelClassName?: string;\n contentClassName?: string;\n className?: string;\n transitionDuration?: string;\n onStateChange?: Function;\n isOpen?: boolean;\n hideBorder?: boolean;\n children?: any;\n}\n\nexport default ({\n children,\n label,\n labelClassName = '',\n contentClassName = '',\n className = '',\n onStateChange: externalStateChange,\n isOpen: externalIsOpen,\n hideBorder,\n}: CollapsibleAttributes) => {\n const [isOpen, setIsOpen] = useState(externalIsOpen ?? false);\n\n const onStateChange = (open: boolean) => {\n externalStateChange && externalStateChange(open);\n setIsOpen(open);\n };\n\n useEffect(() => {\n setIsOpen(externalIsOpen ?? false);\n }, [externalIsOpen]);\n\n return (\n \n \n
\n {children}\n
\n \n );\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport Checkbox from '../../Inputs/Checkbox';\nimport RadioButton from '../../Inputs/Radiobutton';\nimport { FilterElementAttributes } from '../types/FilterElementAttributes';\n\n\nconst FilterCheckbox = ({\n filter,\n option,\n onChange,\n}: FilterElementAttributes) => {\n return option ? (\n \n ) : null;\n};\n\nexport default FilterCheckbox;\n","import React, { useState, useMemo, useEffect } from 'react';\nimport { FilterElementAttributes } from '../types/FilterElementAttributes';\nimport { Range, getTrackBackground } from 'react-range';\nimport {\n IRenderThumbParams,\n IRenderTrackParams,\n} from 'react-range/lib/types';\n\nconst FilterRangeSlider = ({\n filter,\n onChange,\n}: FilterElementAttributes) => {\n const [values, setValues] = useState([\n parseInt(\n (filter.options.length == 4\n ? filter.options[2]?.id\n : filter.options[0]?.id) ?? '0'\n ),\n parseInt(\n (filter.options.length == 4\n ? filter.options[3]?.id\n : filter.options[1]?.id) ?? '0'\n ),\n ]);\n\n useEffect(() => {\n setValues([\n parseInt(\n filter.options.length == 4 ? filter.options[2].id : filter.options[0].id\n ),\n parseInt(\n filter.options.length == 4 ? filter.options[3].id : filter.options[1].id\n ),\n ]);\n }, [filter.options]);\n // Store the initial min and max value\n const minValue = useMemo(\n () => parseInt(filter.options[0]?.id ?? '0'),\n []\n );\n const maxValue = useMemo(\n () => parseInt(filter.options[1]?.id ?? '0'),\n []\n );\n\n const [onChangeTimer, setOnChangeTimer] = useState();\n const onRangeChanged = (values: number[]) => {\n setValues(values);\n\n if (onChange) {\n if (onChangeTimer) {\n clearTimeout(onChangeTimer);\n }\n // Debounce onChange\n setOnChangeTimer(\n setTimeout(() => {\n onChange(filter.id, values);\n }, 350)\n );\n }\n };\n\n const renderThumb = ({\n props,\n isDragged,\n value,\n }: IRenderThumbParams) => (\n \n {value}\n \n );\n\n const renderTrack = ({ props, children }: IRenderTrackParams) => (\n \n \n {children}\n \n \n );\n\n return (\n \n );\n};\n\nexport default FilterRangeSlider;\n","import React from 'react';\nimport { useMemo } from 'react';\nimport Icon from '../Icon';\nimport { InputProps } from './types/Input.types';\nimport clsx from 'clsx';\n\nconst Input: React.FC<\n InputProps & React.InputHTMLAttributes\n> = ({\n inputSize = 'medium',\n inputState = 'default',\n icon,\n className,\n wrapperClassName,\n label,\n helperText,\n message,\n showMessageIcon = true,\n ...props\n}) => {\n const messageIcon = useMemo(() => {\n switch (inputState) {\n case 'default':\n default:\n return null;\n\n case 'success':\n return ;\n\n case 'error':\n case 'warning':\n return ;\n }\n }, [inputState]);\n\n const sizeClass = useMemo(() => {\n switch (inputSize) {\n case 'small':\n case 'xsmall':\n return 'input-wrapper--sm';\n case 'large':\n return 'input-wrapper--lg';\n case 'xlarge':\n return 'input-wrapper--xl';\n case 'medium':\n default:\n return 'input-wrapper--md';\n }\n }, [inputSize]);\n\n const stateClass = useMemo(() => {\n switch (inputState) {\n case 'error':\n return 'input-wrapper--error';\n case 'warning':\n return 'input-wrapper--warning';\n case 'success':\n return 'input-wrapper--success';\n default:\n return undefined;\n }\n }, [inputState]);\n\n return (\n \n {label && (\n \n )}\n
\n \n {typeof icon == 'string' && }\n {typeof icon == 'object' && icon}\n
\n {helperText && {helperText}}\n {message && (\n \n {showMessageIcon && messageIcon}\n {message}\n \n )}\n \n );\n};\n\nexport default Input;\n","import React from 'react';\nimport { useEffect } from 'react';\nimport { useState } from 'react';\nimport { useMemo } from 'react';\nimport { translate } from '../../Services/translation';\nimport Input from './FilterInput';\nimport { FilterGroup } from './types/FilterGroup';\n\ninterface FilterSearchInputAttributes {\n filter: FilterGroup;\n onSearch?: Function;\n}\n\nconst FilterSearchInput = ({\n filter,\n onSearch,\n}: FilterSearchInputAttributes) => {\n const [value, setValue] = useState('');\n\n const matchingOptions = useMemo(\n () =>\n value != ''\n ? filter.options.filter(\n (opt) =>\n filter.selectedOptions.includes(opt.id) ||\n opt.label.toLowerCase().includes(value.toLowerCase())\n )\n : null,\n [value, filter]\n );\n\n useEffect(() => {\n onSearch && onSearch(filter, matchingOptions);\n }, [filter, onSearch, matchingOptions]);\n\n return (\n
\n setValue(e.target.value)}\n placeholder={translate('general.search')}\n />\n
\n );\n};\n\nexport default FilterSearchInput;\n","import React from 'react';\nimport { useCallback } from 'react';\nimport { useDispatch } from 'react-redux';\nimport {\n onOptionChanged as onOptionChangedAction,\n onRangeChanged as onRangeChangedAction,\n queryProductFiltering,\n} from '../../Actions/ProductFiltering.action';\nimport { translate } from '../../Services/translation';\nimport Button from '../Button';\nimport FilterCheckbox from './FilterOptions/FilterCheckbox';\nimport FilterRangeSlider from './FilterOptions/FilterRangeSlider';\nimport FilterSearchInput from './FilterSearchInput';\nimport { FilterGroup } from './types/FilterGroup';\nimport { FilterGroupOption } from './types/FilterGroupOption';\nimport { FilterGroupType } from './types/FilterGroupType';\n\ninterface FilterGroupFactoryAttributes {\n filter: FilterGroup;\n options: FilterGroupOption[];\n showAll?: boolean;\n showAllButtonVisible?: boolean;\n onShowHideAllClick?: Function;\n onSearch?: Function;\n onChange?: Function;\n}\n\nconst FilterGroupElement = ({\n filter,\n options,\n showAll,\n showAllButtonVisible,\n onShowHideAllClick,\n onSearch,\n}: FilterGroupFactoryAttributes) => {\n const dispatch = useDispatch();\n\n // When a filter checkbox/radiobutton is changed, this is called, which triggers a filter query\n const onOptionChanged = useCallback(\n async (filterId: string, optionId: string) => {\n dispatch(onOptionChangedAction(filterId, optionId));\n dispatch(queryProductFiltering());\n },\n [dispatch]\n );\n\n // When a filter range is changed, this is called, which triggers a filter query\n const onRangeChanged = useCallback(\n async (filterId: string, values: number[]) => {\n dispatch(onRangeChangedAction(filterId, values));\n dispatch(queryProductFiltering());\n },\n [dispatch]\n );\n\n // Renders each filter group depending on the filter group type\n const renderFilterOptions = useCallback(\n (filter: FilterGroup) => {\n switch (filter.filterGroupType) {\n case FilterGroupType.Checkbox:\n return (\n <>\n \n {options.map((opt) => (\n \n ))}\n \n );\n case FilterGroupType.Range:\n return (\n \n );\n default:\n return null;\n }\n },\n [onRangeChanged, onOptionChanged, options, onSearch]\n );\n\n return (\n <>\n {renderFilterOptions(filter)}\n {onShowHideAllClick && showAllButtonVisible == true && (\n \n onShowHideAllClick && onShowHideAllClick(filter.id)\n }\n >\n {showAll\n ? translate('general.show-less')\n : translate('general.show-more')}\n \n )}\n \n );\n};\n\nexport default FilterGroupElement;\n","import React, { useState, useCallback, useEffect } from 'react';\nimport Collapsible from '../Collapsible';\nimport { FilterGroup } from './types/FilterGroup';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { FilterGroupType } from './types/FilterGroupType';\nimport { FilterGroupOption } from './types/FilterGroupOption';\nimport FilterGroupElement from './FilterGroupElement';\nimport { useDispatch } from 'react-redux';\nimport { queryProductFiltering } from '../../Actions/ProductFiltering.action';\n\nconst MAX_FILTERS_BEFORE_SHOW_MORE = 5;\n\nconst ProductFiltering = () => {\n const productFiltering = useTypedSelector((state) => state.productFiltering);\n const { filters } = productFiltering;\n const dispatch = useDispatch();\n\n const [showAllForFilters, setShowMoreForFilters] = useState([]);\n const [filterSearchResults, setFilterSearchResults] = useState<{\n [filterId: string]: FilterGroupOption[];\n }>({});\n\n useEffect(() => {\n if (filters?.length > 0) return;\n\n dispatch(queryProductFiltering(null, true));\n }, [dispatch]);\n\n const onShowHideAllClick = (filterId: string) => {\n const listCopy = [...showAllForFilters];\n const index = listCopy.indexOf(filterId);\n if (index == -1) {\n listCopy.push(filterId);\n } else {\n listCopy.splice(index, 1);\n }\n setShowMoreForFilters(listCopy);\n };\n\n // Returns true if the filter has \"show all\" selected\n const shouldShowAllFilters = useCallback(\n (filterId: string) => showAllForFilters.indexOf(filterId) != -1,\n [showAllForFilters]\n );\n\n // Called when the search input was changed for the specified filter\n const onSearch = useCallback(\n (filter: FilterGroup, options: FilterGroupOption[]) => {\n setFilterSearchResults((current) => {\n const filterSearchResultsCopy = { ...current };\n if (!options) {\n if (filterSearchResultsCopy.hasOwnProperty(filter.id)) {\n delete filterSearchResultsCopy[filter.id];\n }\n } else {\n filterSearchResultsCopy[filter.id] = options;\n }\n return filterSearchResultsCopy ?? {};\n });\n },\n []\n );\n\n // Get options from the specified filter, with regard to the search value for the filter\n const getFilterOptions = useCallback(\n (filter: FilterGroup) =>\n filterSearchResults.hasOwnProperty(filter.id) &&\n filterSearchResults[filter.id] != undefined\n ? filterSearchResults[filter.id] ?? filter.options\n : filter.options,\n [filterSearchResults]\n );\n\n const getFilterGroupLabel = useCallback(\n (filter: FilterGroup) =>\n `${\n filter.filterGroupType != FilterGroupType.Range &&\n filter.selectedOptions.length > 0\n ? `(${filter.selectedOptions.length})`\n : ''\n } ${filter.label}`.trim(),\n []\n );\n\n return (\n <>\n {filters?.length > 0\n ? filters.map((filter) => (\n \n MAX_FILTERS_BEFORE_SHOW_MORE\n }\n />\n \n ))\n : null}\n \n );\n};\n\nexport default ProductFiltering;\n","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport { onSortItemSelected } from '../../Actions/ProductFiltering.action';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\n\nconst ProductSorting = () => {\n const dispatch = useDispatch();\n const { sortCriteria } =\n useTypedSelector((state) => state.productFiltering) ?? {};\n\n const selectedSortItem = sortCriteria?.sortItems.find((s) => s.selected);\n\n return sortCriteria ? (\n \n dispatch(\n onSortItemSelected(\n sortCriteria?.sortItems.find((s) => s.query == e.target.value)\n )\n )\n }\n >\n {sortCriteria.sortItems.map((item) => (\n \n ))}\n \n ) : null;\n};\n\nexport default ProductSorting;\n","import { post } from './http';\nimport { dataLayerAddToCart } from '../Services/Gtm.service';\n\nexport const add = async ({ articleNumber, quantity = 1 }) => {\n if (!quantity || isNaN(quantity) || parseFloat(quantity) <= 0) {\n throw 'Invalid quantity';\n }\n\n const response = await post('/api/cart/add', {\n articleNumber,\n quantity: parseFloat(quantity),\n });\n\n var result = await response.json();\n\n try {\n addToDataLayer([{ articleNumber, quantity }], result.orderRows);\n } catch (err) {\n console.log(err);\n }\n\n return result;\n};\n\nexport const reorder = async (orderId) => {\n const response = await post('/api/cart/reorder', { orderId });\n return response.json();\n};\n\nconst addToDataLayer = (products, orderRows) => {\n let responseProducts = [];\n orderRows.map((row) => {\n for (const i in products) {\n if (Object.hasOwnProperty.call(products, i)) {\n if (products[i].articleNumber === row.articleNumber) {\n const index = responseProducts.findIndex(\n (e) => e.articleNumber === row.articleNumber\n );\n if (index === -1) {\n row.gtmEcommerceItem.quantity = products[i].quantity;\n row.gtmEcommerceItem.index = responseProducts.length;\n responseProducts.push(row);\n }\n }\n }\n }\n });\n\n const gtmEcommerceItems = responseProducts.map((p) => p.gtmEcommerceItem);\n if (gtmEcommerceItems) {\n dataLayerAddToCart(gtmEcommerceItems);\n }\n};\n","var _path;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nconst SvgRefresh = props => /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: \"1em\",\n height: \"1em\",\n viewBox: \"0 0 24 24\",\n xmlns: \"http://www.w3.org/2000/svg\"\n}, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 20c-2.233 0-4.125-.775-5.675-2.325C4.775 16.125 4 14.233 4 12c0-2.233.775-4.125 2.325-5.675C7.875 4.775 9.767 4 12 4c1.15 0 2.25.238 3.3.713A7.617 7.617 0 0 1 18 6.75V4h2v7h-7V9h4.2a5.837 5.837 0 0 0-2.187-2.2A5.93 5.93 0 0 0 12 6c-1.667 0-3.083.583-4.25 1.75C6.583 8.917 6 10.333 6 12c0 1.667.583 3.083 1.75 4.25C8.917 17.417 10.333 18 12 18a5.863 5.863 0 0 0 3.475-1.1A5.81 5.81 0 0 0 17.65 14h2.1c-.467 1.767-1.417 3.208-2.85 4.325S13.833 20 12 20Z\"\n})));\nexport default SvgRefresh;","import React from 'react';\nimport Refresh from '../../icons/refresh.svg';\n\ninterface LoadingSpinnerAttributes {\n className?: string;\n}\n\nconst LoadingSpinner = (props: LoadingSpinnerAttributes) => {\n const { className = '' } = props;\n return (\n \n );\n};\n\nexport default LoadingSpinner;\n","import {\n BUY_BUTTON_SET_ARTICLE_NUMBER,\n BUY_BUTTON_SET_LOADING,\n} from '../constants';\n\nexport const setBuyButtonArticleNumber = (articleNumber: string) => ({\n type: BUY_BUTTON_SET_ARTICLE_NUMBER,\n payload: {\n articleNumber,\n },\n});\n\nexport const setBuyButtonLoading = (isLoading: boolean) => ({\n type: BUY_BUTTON_SET_LOADING,\n payload: {\n isLoading,\n },\n});\n","import { PRODUCT_PAGE_SET_SELECTED_VARIANT } from '../constants';\nimport Product from '../Types/Product';\n\nexport const setProductPageSelectedVariant = (selectedVariant: Product) => ({\n type: PRODUCT_PAGE_SET_SELECTED_VARIANT,\n payload: {\n selectedVariant,\n },\n});\n\nexport const setProductPageSelectedVariantQuery = (\n selectedVariant: Product\n) => {\n const query = new URLSearchParams(window.location.search);\n if (selectedVariant != null) {\n query.set('v', selectedVariant?.id!);\n } else {\n query.delete('v');\n }\n const url =\n window.location.href.replace(window.location.search, '') +\n `?${query.toString()}`;\n window.history.pushState('setSelectedVariant', null, url);\n};\n","import React, { useState, useMemo, useEffect } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { add as addToCart } from '../../Services/Cart.service';\nimport {\n receive as receiveCart,\n triggerAddToCartAnimation,\n} from '../../Actions/Cart.action';\nimport { translate } from '../../Services/translation';\nimport QuantityInput from '../QuantityInput/QuantityInput';\nimport LoadingSpinner from '../LoadingSpinner';\nimport { useCallback } from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { setBuyButtonLoading } from '../../Actions/BuyButton.action';\nimport { setShowMiniCart } from '../../Actions/Cart.action';\nimport Product from '../../Types/Product';\nimport {\n setProductPageSelectedVariant,\n setProductPageSelectedVariantQuery,\n} from '../../Actions/ProductPage.action';\n\n\n\n\nexport interface BuyButtonAttributes {\n articleNumber?: string;\n disabled?: boolean;\n showQuantityInput?: boolean;\n onClick?: Function;\n className?: string;\n label?: string;\n quantity?: number;\n href?: string;\n variants?: Product[];\n}\n\nconst BuyButton = (props: BuyButtonAttributes) => {\n const {\n articleNumber: localArticleNumber,\n showQuantityInput = true,\n className = '',\n onClick: customOnClick,\n label,\n quantity: initialQuantity,\n href,\n disabled: disabledProp,\n variants,\n } = props;\n const {\n articleNumber: reducerArticleNumber,\n disabled = false,\n isLoading = false,\n } = useTypedSelector((state) => state.buyButton);\n const dispatch = useDispatch();\n const [quantity, setQuantity] = useState(\n initialQuantity ?? 1\n );\n\n const [showLoadingSpinner, setShowLoadingSpinner] = useState(false);\n const articleNumber = useMemo(\n () => localArticleNumber ?? reducerArticleNumber,\n [localArticleNumber, reducerArticleNumber]\n );\n const setIsLoading = (isLoading: boolean) => {\n dispatch(setBuyButtonLoading(isLoading));\n };\n\n useEffect(() => {\n if (variants) {\n const selectedVariant = variants.find((v) => v.id == articleNumber);\n dispatch(setProductPageSelectedVariant(selectedVariant!));\n setProductPageSelectedVariantQuery(selectedVariant!);\n }\n });\n\n const onClick = async () => {\n if (customOnClick) {\n customOnClick(articleNumber, quantity);\n } else if (!href) {\n setIsLoading(true);\n const loadingSpinnerTimeout = setTimeout(\n () => setShowLoadingSpinner(true),\n 150\n );\n\n try {\n const cart = await addToCart({ articleNumber, quantity });\n dispatch(receiveCart(cart));\n dispatch(triggerAddToCartAnimation());\n dispatch(setShowMiniCart(true));\n } catch (err) {\n // TODO Error handling\n alert('Kunde inte lägga i varukorgen');\n console.log(err);\n } finally {\n clearTimeout(loadingSpinnerTimeout);\n setShowLoadingSpinner(false);\n setIsLoading(false);\n }\n }\n };\n\n const LoadingComponent = useCallback(\n () => (\n \n ),\n []\n );\n\n const _label = useMemo(\n () =>\n label ??\n (href ? translate('general.show') : translate('general.add-to-cart')),\n [href, label]\n );\n\n return (\n
\n {showQuantityInput && (\n setQuantity(value)}\n className=\"flex-1\"\n />\n )}\n {href && (\n \n {showLoadingSpinner && }\n {!showLoadingSpinner && _label}\n \n )}\n {!href && (\n \n {showLoadingSpinner ? : _label}\n \n )}\n
\n );\n};\n\nexport default BuyButton;\n","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport { onSortItemSelected } from '../../Actions/ProductFiltering.action';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport RadioButton from '../Inputs/Radiobutton';\n\nconst StyledProductSortingList = styled.ul`\n padding: 2.4rem 1.6rem;\n`;\n\nconst StyledSortingItem = styled.li`\n ${text('large')}\n display: flex;\n justify-content: space-between;\n cursor: pointer;\n\n & div {\n margin: 0;\n }\n\n &:not(:last-child) {\n margin-bottom: 1.6rem;\n }\n\n &:hover .sort-radio-button {\n box-shadow: 0 0 0 1px ${getColor('primary')};\n }\n`;\n\nconst StyledRadioButton = styled(RadioButton)`\n margin-right: 0;\n`;\n\nconst ProductSortingRadios = () => {\n const dispatch = useDispatch();\n const { sortCriteria } =\n useTypedSelector((state) => state.productFiltering) ?? {};\n const selectedSortItem = sortCriteria?.sortItems.find((s) => s.selected);\n\n return (\n \n {sortCriteria?.sortItems.map((item) => (\n {\n dispatch(\n onSortItemSelected(\n sortCriteria?.sortItems.find((s) => s.query == item.query)\n )\n );\n }}\n >\n {item.name}{' '}\n \n \n ))}\n \n );\n};\n\nexport default ProductSortingRadios;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport { showFor } from '../../styling/utils/visibility';\nimport Icon from '../Icon';\n\nconst StyledCategoryNavigation = styled.div`\n ${showFor('large')}\n ${text('medium')}\n display: flex;\n flex-direction: column;\n\n .current-category {\n padding: 1.2rem 0;\n font-weight: bold;\n }\n\n .previous-category {\n ${text('large')}\n display: flex;\n align-items: center;\n max-width: fit-content;\n margin-bottom: 0.4rem;\n\n & > * {\n color: ${getColor('grey', 500)};\n }\n\n &:hover > * {\n color: ${getColor('grey', 900)};\n }\n }\n`;\n\nconst StyledCategoryLinks = styled.ul`\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n padding-bottom: 1.6rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n`;\n\nconst StyledCategoryLink = styled.li<{ isSelected: boolean }>`\n display: flex;\n font-weight: ${(p) => (p.isSelected ? 'bold' : null)};\n pointer-events: ${(p) => (p.isSelected ? 'none' : null)};\n\n a {\n flex: 1;\n }\n`;\n\nconst CategoryNavigation = () => {\n const { subNavigation } = useTypedSelector((state) => state.productFiltering);\n\n let currentCategory = subNavigation;\n let subCategories = subNavigation.links;\n let previousCategory;\n let foundCategory;\n\n while (currentCategory.links.length > 0) {\n subCategories = currentCategory.links;\n foundCategory = currentCategory.links.find((l) => l.isSelected == true);\n if (foundCategory && foundCategory.links.length > 0) {\n previousCategory = currentCategory;\n }\n if (!foundCategory || foundCategory.links.length === 0) {\n break;\n } else {\n currentCategory = foundCategory;\n }\n }\n\n return (\n \n {previousCategory && previousCategory.url && (\n \n )}\n
\n {foundCategory ? (\n {currentCategory.name}\n ) : (\n currentCategory.name\n )}\n
\n \n {subCategories\n .sort((a, b) => a.name.localeCompare(b.name))\n .map((link, idx) => (\n \n {link.name}{' '}\n \n ))}\n \n
\n );\n};\n\nexport default CategoryNavigation;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport CategoryNavigation from '../ProductListing/CategoryNavigation';\n\nconst StyledCategoriesMenu = styled.div`\n padding: 2.4rem 1.6rem;\n\n & .category__navigation-container {\n ${text('large')}\n display: flex !important;\n\n & .current-category {\n ${text('xlarge')}\n font-weight: bold;\n padding-top: 0;\n }\n\n & ul {\n border-bottom: none;\n padding-bottom: 0;\n gap: 1.6rem;\n }\n }\n`;\n\nconst CategoriesMenu = () => {\n return (\n \n \n \n );\n};\n\nexport default CategoriesMenu;\n","import React, { useMemo } from 'react';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { getColor } from '../../styling/mixins/colors';\nimport ProductFiltering from '../ProductFiltering/ProductFiltering';\nimport SideMenu from '../SideMenu/SideMenu';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport { translate } from '../../Services/translation';\nimport ProductSortingRadios from './ProductSortingRadios';\nimport { text } from '../../styling/mixins/typography';\nimport Button from '../Button';\nimport { clearAllFilters } from '../../Actions/ProductFiltering.action';\nimport { useDispatch } from 'react-redux';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport CategoriesMenu from './CategoriesMenu';\n\nconst StyledFilterMenu = styled(SideMenu)`\n && {\n z-index: 60;\n overflow-y: auto;\n -ms-overflow-style: none;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n\n ${breakpoint('small')} {\n max-width: 360px;\n border-left: 1px solid ${getColor('grey', 300)};\n }\n }\n`;\n\nconst StyledProductFiltering = styled.div`\n & .collapsible {\n border-top: none;\n border-bottom: 1px solid ${getColor('grey', 300)};\n\n &:last-child {\n border: none;\n }\n\n & label {\n ${text('large')}\n font-weight: bold;\n padding: 1.6rem;\n }\n }\n\n & .ReactCollapse--collapse[aria-hidden='false'] .ReactCollapse--content {\n padding-left: 1.6rem;\n padding-right: 1.6rem;\n\n & label {\n padding: 0.8rem 0;\n }\n & button {\n margin-top: 1.6rem;\n }\n }\n`;\n\nconst StyledProductFilteringFooter = styled.div`\n display: flex;\n flex: 1;\n gap: 0.8rem;\n\n button {\n text-transform: uppercase;\n font-weight: bold;\n }\n`;\n\nconst GlobalFilterMenuStyling = createGlobalStyle`\n body #overlay-container .overlay--filter-menu {\n z-index: 50;\n }\n`;\n\nconst FilterMenu = ({ currentMenu, setCurrentMenu }) => {\n const dispatch = useDispatch();\n const { totalProductsCount } = useTypedSelector(\n (state) => state.productListing\n );\n const filters = useTypedSelector((state) => state.productFiltering.filters);\n const hasAnyOptionSelected = useMemo(\n () => filters?.findIndex((f) => f.selectedOptions.length > 0) > 0,\n [filters]\n );\n\n const Header = () => (\n <>\n {currentMenu == 'categories' ? (\n

{translate('filter.categories')}

\n ) : null}\n {currentMenu == 'filters' ?

{translate('filter.filter')}

: null}\n {currentMenu == 'sorting' ?

{translate('filter.sort')}

: null}\n \n );\n\n const Content = () => (\n <>\n {currentMenu == 'categories' ? : null}\n {currentMenu == 'filters' ? (\n \n \n \n ) : null}\n {currentMenu == 'sorting' ? : null}\n \n );\n\n const Footer = () => (\n <>\n {currentMenu == 'filters' ? (\n \n dispatch(clearAllFilters())}\n >\n {translate('filter.clear')}\n \n setCurrentMenu(undefined)}\n >\n {translate('filter.view')} ( {totalProductsCount} )\n \n \n ) : null}\n \n );\n\n return (\n <>\n setCurrentMenu(undefined)}\n components={{ Header, Content, Footer }}\n >\n \n \n );\n};\n\nexport default FilterMenu;\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { hideFor } from '../../styling/utils/visibility';\nimport Button from '../Button';\nimport { translate } from '../../Services/translation';\nimport { getColor } from '../../styling/mixins/colors';\nimport FilterMenu from './FilterMenu';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\n\ntype CurrentMenuType = 'categories' | 'filters' | 'sorting';\n\nconst StyledFilterBarButtonWrapper = styled.div`\n ${hideFor('large')}\n display: flex;\n gap: 1.6rem;\n padding: 1.6rem 0 1.6rem 0;\n\n ${breakpoint('medium')} {\n padding: 2.4rem 0 1.6rem 0;\n }\n`;\n\nconst StyledFilterButton = styled(Button)`\n flex: 1;\n border-color: ${getColor('grey', 400)};\n color: ${getColor('grey', 900)};\n`;\n\nconst FilterBarButtons = () => {\n const [currentMenu, setCurrentMenu] = useState();\n return (\n <>\n \n setCurrentMenu('categories')}\n >\n {translate('filter.categories')}\n \n setCurrentMenu('filters')}\n >\n {translate('filter.filter')}\n \n setCurrentMenu('sorting')}\n >\n {translate('filter.sort')}\n \n \n\n \n \n );\n};\n\nexport default FilterBarButtons;\n","import React, { useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { translate } from '../../Services/translation';\nimport Dropdown, { DropdownOption } from '../Dropdown';\nimport { onSortItemSelected } from '../../Actions/ProductFiltering.action';\nimport { setProductListingType } from '../../Actions/ProductListing.action';\nimport Icon from '../Icon';\nimport { ProductListingType } from '../../Reducers/ProductListing.reducer';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { alignCenter, spaceBetween } from '../../styling/utils/flex';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\nimport { hideFor, showFor } from '../../styling/utils/visibility';\nimport FilterBarButtons from './FilterBarButtons';\n\ninterface StyledFilterBarProps {\n $productListingType: ProductListingType;\n}\n\nconst StyledFilterBar = styled.div`\n display: flex;\n ${alignCenter}\n ${spaceBetween}\n margin-bottom: 1.6rem;\n ${breakpoint('large')} {\n margin-bottom: 2.4rem;\n }\n\n .products-count {\n display: flex;\n flex: 1;\n ${text('medium')}\n color: ${getColor('grey', 500)};\n }\n\n .listing-toggle {\n display: flex;\n gap: 1.6rem;\n\n .icon {\n font-size: 2.4rem;\n cursor: pointer;\n }\n }\n\n .grid-icon {\n color: ${(p) =>\n p.$productListingType == ProductListingType.Grid\n ? getColor('black')\n : getColor('grey', 500)};\n }\n\n .list-icon {\n ${showFor('medium')}\n color: ${(p) =>\n p.$productListingType == ProductListingType.List\n ? getColor('black')\n : getColor('grey', 500)};\n }\n\n .single-card-icon {\n ${hideFor('medium')}\n color: ${(p) =>\n p.$productListingType == ProductListingType.SingleCard\n ? getColor('black')\n : getColor('grey', 500)};\n }\n\n .sort-items-wrapper {\n ${showFor('large')}\n width: 200px;\n }\n\n .right {\n display: flex;\n ${alignCenter}\n gap: 1.6rem;\n }\n`;\nconst FilterBar = () => {\n const dispatch = useDispatch();\n const { totalProductsCount, productListingType } = useTypedSelector(\n (state) => state.productListing\n );\n const sortItems = useTypedSelector(\n (state) => state.productFiltering.sortCriteria?.sortItems\n );\n\n const onSortingChanged = (selectedOption: DropdownOption) => {\n const sortItem = sortItems?.find((s) => s.query == selectedOption.value);\n if (!sortItem) return;\n\n dispatch(onSortItemSelected(sortItem));\n };\n\n return (\n <>\n \n \n
\n {totalProductsCount} {translate('general.products').toLowerCase()}\n
\n
\n
\n \n dispatch(setProductListingType(ProductListingType.Grid))\n }\n />\n \n dispatch(setProductListingType(ProductListingType.List))\n }\n />\n \n dispatch(setProductListingType(ProductListingType.SingleCard))\n }\n />\n
\n {sortItems && (\n
\n ({\n value: item.query,\n label: item.name,\n }))}\n selectedValue={sortItems.find((s) => s.selected)?.query}\n onChange={onSortingChanged}\n size=\"small\"\n />\n
\n )}\n
\n
\n \n );\n};\n\nexport default FilterBar;\n","import {\n LOGIN_SET_IS_LOADING,\n LOGIN_SET_ORGANIZATIONS,\n LOGIN_SET_USERNAME_PASSWORD,\n LOGIN_SET_MODAL_OPEN,\n LOGIN_SET_LOGIN_MODE,\n LOGIN_ERROR,\n LOGIN_SET_REDIRECT_URL,\n LOGIN_SET_MAGIC_LINK_MODEL,\n} from '../constants';\nimport { RootState } from '../reducers';\nimport { post } from '../Services/http';\nimport { translate } from '../Services/translation';\nimport LoginMode from '../Types/LoginMode';\nimport LoginOrganization from '../Types/LoginOrganization';\nimport LoginResponse from '../Types/LoginResponse';\nimport { MagicLinkModel } from '../Types/MagicLinkModel';\n\nexport const performLogin = (username: string, password: string) => (\n dispatch\n) => {\n dispatch(setLoginFormLoading(true));\n const redirectUrl = new URLSearchParams(location.search.toLowerCase()).get(\n 'redirecturl'\n );\n\n post(`/api/login${redirectUrl ? `?redirectUrl=${redirectUrl}` : ''}`, {\n username,\n password,\n redirectUrl,\n })\n .then((res) => res.json())\n .then((response: LoginResponse) => dispatch(handleLoginResponse(response)))\n .catch((err) => dispatch(handleErrorResponse(err)));\n};\n\nexport const selectOrganization = (selectedOrganizationId: string) => (\n dispatch,\n getState: () => RootState\n) => {\n dispatch(setLoginFormLoading(true));\n const redirectUrl = getState().login.redirectUrl;\n post(\n `/api/login/organizations/${selectedOrganizationId}${\n redirectUrl ? `?redirectUrl=${redirectUrl}` : ''\n }`,\n {}\n )\n .then((res) => res.json())\n .then((response: LoginResponse) => {\n dispatch(onError(response.error));\n if (response.success) {\n onSuccessfulLogin(response);\n } else {\n dispatch(setLoginFormLoading(false));\n }\n })\n .catch((err) => dispatch(handleErrorResponse(err)));\n};\n\nexport const submitChangePassword = (\n username,\n oldPassword,\n newPassword,\n passwordConfirmation\n) => (dispatch, getState: () => RootState) => {\n if (newPassword !== passwordConfirmation) {\n dispatch(onError(translate('login.password-mismatch')));\n return;\n }\n\n const { redirectUrl, magicLinkModel } = getState().login;\n dispatch(setLoginFormLoading(true));\n post(\n `/api/login/changepassword${\n redirectUrl ? `?redirectUrl=${redirectUrl}` : ''\n }`,\n {\n username,\n oldPassword,\n newPassword,\n magicLinkModel,\n }\n )\n .then((res) => res.json())\n .then((response: LoginResponse) => {\n if (response.success) {\n dispatch(handleLoginResponse(response));\n } else {\n dispatch(onError(response.error));\n dispatch(setLoginFormLoading(false));\n }\n })\n .catch((err) => dispatch(handleErrorResponse(err)));\n};\n\nexport const submitForgotPassword = (username: string): any => (\n dispatch\n): Promise => {\n return post('/api/login/forgotpassword', { username })\n .then((res) => res.json())\n .then((response: ForgotPasswordResponse) => {\n dispatch(onError(response.error));\n return response.success;\n })\n .catch((err) => dispatch(handleErrorResponse(err)))\n .finally(() => dispatch(setLoginFormLoading(false)));\n};\n\nexport const setOrganizations = (organizations: LoginOrganization[]) => ({\n type: LOGIN_SET_ORGANIZATIONS,\n payload: {\n organizations,\n },\n});\n\nexport const setUsername = (username: string) => ({\n type: LOGIN_SET_USERNAME_PASSWORD,\n payload: {\n username,\n },\n});\n\nexport const setPassword = (password: string) => ({\n type: LOGIN_SET_USERNAME_PASSWORD,\n payload: {\n password,\n },\n});\n\nexport const setLoginModalOpen = (modalOpen: boolean) => ({\n type: LOGIN_SET_MODAL_OPEN,\n payload: {\n modalOpen,\n },\n});\n\nexport const setLoginMode = (loginMode: LoginMode) => ({\n type: LOGIN_SET_LOGIN_MODE,\n payload: {\n loginMode,\n },\n});\n\nexport const signOut = () => {\n post('/api/mypages/logout', null).then(() => (location.href = '/'));\n};\n\nexport const submitMagicLink = (magicLinkModel: MagicLinkModel) => (\n dispatch\n) => {\n dispatch(setLoginFormLoading(true));\n return post('/api/login/magiclink', magicLinkModel)\n .then((res) => res.json())\n .then((response: LoginResponse) => {\n dispatch(handleLoginResponse(response));\n })\n .catch((err) => {\n dispatch(setLoginMode(LoginMode.Login));\n dispatch(setMagicLinkModel(undefined));\n return dispatch(handleErrorResponse(err));\n })\n .finally(() => dispatch(setLoginFormLoading(false)));\n};\n\nconst setMagicLinkModel = (magicLinkModel?: MagicLinkModel) => ({\n type: LOGIN_SET_MAGIC_LINK_MODEL,\n payload: {\n magicLinkModel,\n },\n});\n\nconst handleErrorResponse = (err) => (dispatch) => {\n err.response.json().then((data) => dispatch(onError(data.error)));\n dispatch(setLoginFormLoading(false));\n};\n\nconst onError = (error?: string) => ({\n type: LOGIN_ERROR,\n payload: {\n error,\n },\n});\n\nconst setLoginFormLoading = (isLoading: boolean) => ({\n type: LOGIN_SET_IS_LOADING,\n payload: {\n isLoading,\n },\n});\n\nconst handleLoginResponse = (response: LoginResponse) => (dispatch) => {\n dispatch(onError(response.error));\n\n if (response.success) {\n if (response.requestToken) {\n localStorage.setItem('requestVerificationToken', response.requestToken);\n }\n\n dispatch(setRedirectUrl(response.redirectUrl));\n\n if (response.mustChangePassword) {\n dispatch(setLoginMode(LoginMode.ChangePassword));\n } else if (!response.organizations && !response.mustChangePassword) {\n onSuccessfulLogin(response);\n } else if (response.organizations) {\n dispatch(setOrganizations(response.organizations));\n dispatch(setLoginMode(LoginMode.SelectOrganization));\n dispatch(setLoginFormLoading(false));\n }\n } else {\n dispatch(setLoginFormLoading(false));\n }\n};\n\nconst setRedirectUrl = (redirectUrl?: string) => ({\n type: LOGIN_SET_REDIRECT_URL,\n payload: {\n redirectUrl,\n },\n});\n\nconst onSuccessfulLogin = (response: LoginResponse) => {\n if (response.redirectUrl) {\n location.href = response.redirectUrl;\n } else {\n location.reload();\n }\n};\n\ninterface ForgotPasswordResponse {\n success: boolean;\n error?: string;\n}\n","import React, { useMemo } from 'react';\nimport { useNavigate, useLocation } from 'react-router-dom';\nimport Icon from '../Icon';\nimport { signOut } from '../../Actions/Login.action';\nimport { translate } from '../../Services/translation';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport { hideFor } from '../../styling/utils/visibility';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\n\nconst StyledMobileMenu = styled.div`\n ${hideFor('large')}\n position: relative;\n overflow: hidden;\n height: 56px;\n border: 1px solid ${getColor('grey', 300)};\n margin-bottom: 1.6rem;\n\n select {\n width: 100%;\n height: 100%;\n color: transparent;\n margin-bottom: 1.6rem;\n border: none;\n\n &:focus {\n outline: none;\n }\n\n & option {\n ${text('medium')}\n color: ${getColor('grey', 900)};\n }\n }\n\n label {\n display: flex;\n align-items: center;\n justify-content: space-between;\n position: absolute;\n width: 100%;\n height: 100%;\n padding: 0 1.6rem;\n pointer-events: none;\n text-transform: capitalize;\n\n .info-wrapper {\n display: flex;\n flex-direction: column;\n justify-content: center;\n }\n\n .overline {\n ${text('medium')}\n color: ${getColor('grey', 600)};\n }\n }\n\n .caret-icon {\n color: ${getColor('grey', 900)};\n font-size: 2.4rem;\n }\n`;\n\nconst MyPagesMobileMenu = ({ navigation }) => {\n const navigate = useNavigate();\n const { pathname } = useLocation();\n const { current: userInfo } = useTypedSelector((state) => state.userInfo);\n\n return (\n \n \n {\n e.target.value == 'log-out' ? signOut() : navigate(e.target.value);\n }}\n >\n {navigation.map((option) => (\n \n ))}\n \n \n \n );\n};\n\nexport default MyPagesMobileMenu;\n","import React from 'react';\nimport { NavLink } from 'react-router-dom';\nimport Icon from '../Icon';\nimport { signOut } from '../../Actions/Login.action';\nimport { translate } from '../../Services/translation';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { showFor } from '../../styling/utils/visibility';\n\nconst StyledDesktopMenu = styled.div`\n ${showFor('large')}\n\n .top {\n display: flex;\n flex-direction: column;\n margin-bottom: 1.2rem;\n text-transform: capitalize;\n }\n\n .overline {\n ${text('medium')}\n color: ${getColor('grey', 600)};\n }\n\n .item__wrapper {\n border: 1px solid ${getColor('grey', 300)};\n border-radius: 4px;\n overflow: hidden;\n }\n\n .sign-out {\n display: flex;\n align-items: center;\n\n &__icon {\n color: ${getColor('alert')};\n font-size: 2rem;\n margin-right: 0.8rem;\n }\n }\n`;\n\nconst StyledMenuItem = styled.li`\n display: flex;\n border-bottom: 1px solid ${getColor('grey', 300)};\n`;\n\nconst StyledMenuAnchor = styled(NavLink)`\n ${text('medium')}\n padding: 1rem 1.2rem;\n flex: 1;\n\n &.active {\n background-color: ${getColor('grey', 100)};\n font-weight: bold;\n }\n\n &:last-child {\n border-bottom: none;\n }\n\n &:hover {\n background-color: ${getColor('grey', 100)};\n }\n`;\n\nconst StyledSignOut = styled.li`\n display: flex;\n align-items: center;\n ${text('medium')}\n padding: 1rem 1.2rem;\n flex: 1;\n cursor: pointer;\n\n &:hover {\n background-color: ${getColor('grey', 100)};\n }\n`;\n\nconst MyPagesDesktopMenu = ({ navigation }) => {\n const { current: userInfo } = useTypedSelector((state) => state.userInfo);\n\n return (\n \n
\n \n {userInfo?.currentOrganizationName ?? translate('mypage.site.title')}\n \n
\n {userInfo?.firstName} {userInfo?.lastName}\n
\n
\n
    \n {navigation.map((option) => (\n \n \n {option.name}\n \n \n ))}\n \n \n {translate('general.sign-out')}\n \n
\n
\n );\n};\n\nexport default MyPagesDesktopMenu;\n","import { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { text } from '../../../styling/mixins/typography';\nimport Dropdown from '../../Dropdown';\n\nexport const StyledFormWrapper = styled.div`\n grid-column: span 2;\n\n .title {\n margin-bottom: 0.8rem;\n }\n\n .description {\n ${text('large')}\n max-width: 768px;\n margin-bottom: 1.6rem;\n\n ${breakpoint('large')} {\n margin-bottom: 2.4rem;\n }\n }\n\n .form {\n display: flex;\n flex-direction: column;\n\n &--settings:not(:last-child) {\n margin-bottom: 3.2rem;\n }\n }\n\n .input__wrapper {\n margin-bottom: 1.6rem;\n }\n\n .label {\n ${text('large')}\n font-weight: bold;\n margin-bottom: 0.8rem;\n }\n\n .input {\n ${text('large')}\n }\n\n .radio__wrapper {\n display: flex;\n flex-direction: column;\n padding-top: 0.8rem;\n padding-bottom: 2.4rem;\n\n ${breakpoint('large')} {\n padding-top: 1.6rem;\n padding-bottom: 3.2rem;\n }\n }\n\n .radio {\n ${text('large')}\n display: flex;\n gap: 0.8rem;\n\n &:not(:last-child) {\n margin-bottom: 1.6rem;\n }\n }\n\n .btn__wrapper {\n display: flex;\n gap: 0.8rem;\n }\n\n .btn--settings {\n margin-top: 0.8rem;\n width: 100%;\n font-weight: bold;\n text-transform: uppercase;\n\n ${breakpoint('large')} {\n margin-top: 1.6rem;\n }\n }\n`;\n\nexport const StyledFormDropdown = styled(Dropdown)`\n .dropdown-select {\n padding: 1.2rem;\n }\n`;\n","import { USER_INFO_UPDATE, USER_INFO_SET_ERRORS } from '../constants';\nimport { userInfoActions } from '../Reducers/UserInfo.reducer';\nimport { post } from '../Services/http';\nimport { translate } from '../Services/translation';\nimport Address from '../Types/Address';\nimport { UserInfoModel } from '../Types/UserInfoModel';\n\nconst BASE_ROUTE = '/api/userinfo';\n\ninterface ResponseError extends Error {\n response?: Response;\n}\n\nconst handleErrorResponse = (error: ResponseError) => async (dispatch) => {\n if (error.response) {\n const res = error.response;\n const isJson = res.headers\n .get('content-type')\n ?.includes('application/json');\n const data = isJson ? await res.json() : { general: await res.text() };\n\n dispatch(userInfoActions.setErrors(data));\n dispatch(userInfoActions.setSuccessMessage(undefined));\n }\n};\n\nexport const setUserInfoErrors = (errors: { [key: string]: string[] }) => ({\n type: USER_INFO_SET_ERRORS,\n payload: {\n errors,\n },\n});\n\nexport const saveUserInfo = (userInfo: UserInfoModel): any => (dispatch) => {\n return post(`${BASE_ROUTE}/details`, userInfo)\n .then(() => {\n dispatch(userInfoActions.updateUserInfo(userInfo));\n dispatch(userInfoActions.resetErrors());\n dispatch(\n userInfoActions.setSuccessMessage(translate('general.changes-saved'))\n );\n })\n .catch((err) => dispatch(handleErrorResponse(err)));\n};\n\nexport const saveUsername = (username: string): any => (dispatch) => {\n return post(`${BASE_ROUTE}/username`, { username })\n .then(() => {\n dispatch(userInfoActions.updateUsername(username));\n dispatch(userInfoActions.resetErrors());\n dispatch(\n userInfoActions.setSuccessMessage(translate('general.changes-saved'))\n );\n })\n .catch((err) => dispatch(handleErrorResponse(err)));\n};\n\nexport const savePassword = (password: string): any => (dispatch) => {\n return post(`${BASE_ROUTE}/password`, { password })\n .then(() => {\n dispatch(userInfoActions.resetErrors());\n dispatch(\n userInfoActions.setSuccessMessage(translate('general.changes-saved'))\n );\n })\n .catch((err) => dispatch(handleErrorResponse(err)));\n};\n\nexport const saveAddress = (address: Address): any => (dispatch) => {\n return post(`${BASE_ROUTE}/address`, address)\n .then(() => {\n dispatch(userInfoActions.updateAddress(address));\n dispatch(userInfoActions.resetErrors());\n dispatch(\n userInfoActions.setSuccessMessage(translate('general.changes-saved'))\n );\n })\n .catch((err) => dispatch(handleErrorResponse(err)));\n};\n\nexport const setUserInfo = (userInfo: UserInfoModel) => ({\n type: USER_INFO_UPDATE,\n payload: userInfo,\n});\n","import { useDispatch } from 'react-redux';\nimport { AppDispatch } from '../store';\n\nexport const useTypedDispatch: () => AppDispatch = useDispatch;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { EditorStringModel } from '../../Types/EditorStringModel';\nconst StyledEditorString = styled.div`\n p {\n line-height: 1.5;\n & + p {\n margin-top: 1.2rem;\n }\n }\n\n h1,\n h2,\n h3,\n h4,\n h5,\n h6 {\n margin-bottom: 1.2rem;\n\n &:last-child {\n margin-bottom: 0;\n }\n }\n\n p + h1,\n p + h1,\n p + h2,\n p + h3,\n p + h4,\n p + h5,\n p + h6 {\n margin-top: 2.4rem;\n }\n\n ul,\n ol {\n list-style-type: initial;\n padding-left: 2rem;\n margin: 1.2rem 0;\n line-height: 1.5;\n }\n`;\n\nconst EditorString = ({ value, wrapperClassName }: EditorStringModel) => {\n return value ? (\n \n ) : null;\n};\n\nexport default EditorString;\n","import React, { useCallback, useEffect, useState } from 'react';\nimport { translate } from '../../Services/translation';\nimport Button from '../Button';\nimport Input from '../Inputs/Input';\nimport { StyledFormWrapper } from './styles/MyPagesForm.styling';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport {\n saveAddress,\n savePassword,\n saveUserInfo,\n saveUsername,\n} from '../../Actions/UserInfo.action';\nimport { useTypedDispatch } from '../../Hooks/useTypedDispatch';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport Icon from '../Icon';\nimport { text } from '../../styling/mixins/typography';\nimport { cells, grid } from '../../styling/utils/grid';\nimport Address from '../../Types/Address';\nimport EditorString from '../EditorString/EditorString';\n\nconst StyledGeneralMessage = styled.div`\n display: flex;\n align-items: center;\n color: ${getColor('alert')};\n margin-bottom: 1.6rem;\n ${text('medium')}\n\n span {\n margin-left: 0.4rem;\n }\n`;\n\nconst StyledSuccessMessage = styled(StyledGeneralMessage)`\n color: ${getColor('success')};\n font-weight: 700;\n`;\n\nconst StyledZipCityWrapper = styled.div`\n ${grid}\n ${cells(2)}\n`;\n\nconst MyPagesSettings = ({ description }) => {\n const { current: userInfo, errors = {}, successMessage } = useTypedSelector(\n (state) => state.userInfo\n );\n const [address, setAddress] = useState(userInfo?.address);\n const [isLoading, setIsLoading] = useState(false);\n const [userInfoForm, setUserInfoForm] = useState(userInfo);\n const [username, setUsername] = useState(userInfo?.username);\n const [password, setPassword] = useState('');\n const [confirmPassword, setConfirmPassword] = useState('');\n const [confirmPasswordError, setConfirmPasswordError] = useState();\n const dispatch = useTypedDispatch();\n\n const setUserInfoValue = (key: string, value: any) => {\n if (!userInfoForm) return;\n\n const userInfoCopy = Object.assign({}, userInfoForm);\n userInfoCopy[key] = value;\n setUserInfoForm(userInfoCopy);\n };\n\n const setAddressValue = (key: string, value: string) => {\n if (!userInfo) return;\n const _address = { ...(address ?? userInfo.address) };\n _address[key] = value;\n setAddress(_address);\n };\n\n const submitUserInfo = (e: any) => {\n e.preventDefault();\n if (userInfoForm) {\n setIsLoading(true);\n dispatch(saveUserInfo(userInfoForm)).finally(() => setIsLoading(false));\n }\n };\n\n const submitUsername = (e: any) => {\n e.preventDefault();\n if (username) {\n setIsLoading(true);\n dispatch(saveUsername(username)).finally(() => setIsLoading(false));\n }\n };\n\n const submitChangePassword = (e: any) => {\n e.preventDefault();\n if (!password || !confirmPassword) {\n return;\n }\n\n if (password !== confirmPassword) {\n setConfirmPasswordError(translate('login.confirm-password.must-match'));\n return;\n } else {\n setConfirmPasswordError(undefined);\n }\n\n setIsLoading(true);\n dispatch(savePassword(password)).finally(() => setIsLoading(false));\n };\n\n const submitAddress = (e: any) => {\n e.preventDefault();\n if (address) {\n setIsLoading(true);\n dispatch(saveAddress(address)).finally(() => setIsLoading(false));\n }\n };\n\n const hasErrors = useCallback(\n (key: string) => errors[key] && errors[key]?.length,\n [errors]\n );\n const getErrorMessages = useCallback(\n (key: string) =>\n errors[key]?.map((err, idx) =>

{err}

),\n [errors]\n );\n\n useEffect(() => {\n if (errors['general']?.length || !!successMessage) {\n window.scrollTo({ top: 0, behavior: 'smooth' });\n }\n }, [errors, successMessage]);\n\n return (\n \n

{translate('mypage.info.title')}

\n {description?.value && (\n \n )}\n {hasErrors('general') ? (\n \n \n {errors['general'] && errors['general'][0]}\n \n ) : null}\n {successMessage ? (\n \n \n {successMessage}\n \n ) : null}\n
\n setUserInfoValue('firstName', e.target.value)}\n type=\"text\"\n id=\"fname\"\n value={userInfoForm?.firstName ?? ''}\n disabled={isLoading}\n inputState={hasErrors('FirstName') ? 'error' : 'default'}\n message={getErrorMessages('FirstName')}\n required\n />\n setUserInfoValue('lastName', e.target.value)}\n type=\"text\"\n id=\"lname\"\n value={userInfoForm?.lastName ?? ''}\n disabled={isLoading}\n required\n />\n setUserInfoValue('email', e.target.value)}\n type=\"email\"\n id=\"email\"\n value={userInfoForm?.email ?? ''}\n disabled={isLoading}\n inputState={hasErrors('Email') ? 'error' : 'default'}\n message={getErrorMessages('Email')}\n />\n setUserInfoValue('phone', e.target.value)}\n type=\"tel\"\n id=\"tel\"\n value={userInfoForm?.phone ?? ''}\n disabled={isLoading}\n inputState={hasErrors('Phone') ? 'error' : 'default'}\n message={getErrorMessages('Phone')}\n />\n \n {translate('form.save-changes')}\n \n \n\n {!userInfo?.isBusinessCustomer && (\n
\n setAddressValue('address1', e.target.value)}\n inputState={hasErrors('address') ? 'error' : 'default'}\n message={getErrorMessages('address')}\n required\n />\n setAddressValue('careOf', e.target.value)}\n inputState={hasErrors('CareOf') ? 'error' : 'default'}\n message={getErrorMessages('CareOf')}\n required\n />\n \n setAddressValue('zipCode', e.target.value)}\n inputState={hasErrors('ZipCode') ? 'error' : 'default'}\n message={getErrorMessages('ZipCode')}\n required\n />\n setAddressValue('city', e.target.value)}\n inputState={hasErrors('City') ? 'error' : 'default'}\n message={getErrorMessages('City')}\n required\n />\n \n \n {translate('mypage.address.save')}\n \n \n )}\n {userInfo?.mayEditLogin && (\n <>\n
\n setUsername(e.target.value)}\n inputState={hasErrors('username') ? 'error' : 'default'}\n message={getErrorMessages('username')}\n required\n />\n \n {translate('form.update-user')}\n \n \n
\n setPassword(e.target.value)}\n inputState={hasErrors('password') ? 'error' : 'default'}\n message={getErrorMessages('password')}\n required\n />\n setConfirmPassword(e.target.value)}\n inputState={confirmPasswordError ? 'error' : 'default'}\n message={confirmPasswordError}\n required\n />\n \n {translate('form.update-password')}\n \n \n \n )}\n
\n );\n};\n\nexport default MyPagesSettings;\n","import { ViewMode, PaginationOptions } from '../constants';\nimport { get, post } from '../Services/http';\nimport { catchError } from './Error.action';\n\nimport {\n ORDER_RECEIVE,\n ORDER_ERROR,\n ORDER_CHANGE_MODE,\n ORDER_CHANGE_CURRENTPAGE,\n ORDER_SET_ORDER,\n ORDER_SET_IS_LOADING,\n} from '../constants';\n\nconst rootRoute = '/api/order';\n\nexport const changeMode = (mode) => ({\n type: ORDER_CHANGE_MODE,\n payload: {\n mode,\n },\n});\n\nconst setIsLoading = (isLoading) => ({\n type: ORDER_SET_IS_LOADING,\n payload: {\n isLoading,\n },\n});\n\nexport const query = (\n pageIndex = 1,\n showOnlyMyOrders = false,\n pageSize = PaginationOptions.PageSize,\n orderId = null,\n showOrderDetail = false\n) => (dispatch) => {\n dispatch(setIsLoading(true));\n return get(\n `${rootRoute}?pageIndex=${pageIndex}&showMyOrders=${showOnlyMyOrders}&pageSize=${pageSize}`\n )\n .then((response) => response.json())\n .then((result) => {\n dispatch(\n receive(\n result.orders,\n result.totalCount,\n pageIndex,\n showOnlyMyOrders,\n showOrderDetail ? ViewMode.Detail : ViewMode.List\n )\n );\n if (orderId && showOrderDetail) {\n const order = result.orders.find((order) => order.orderId === orderId);\n dispatch(setOrder(order || {}));\n }\n })\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))))\n .finally(() => dispatch(setIsLoading(false)));\n};\n\nexport const approveOrder = (orderId, callback) => (dispatch) => {\n return post(`${rootRoute}/approveOrder`, {\n id: orderId,\n })\n .then((response) => response.json())\n .then((result) => {\n callback && callback(result);\n })\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))));\n};\n\nexport const getOrder = (orderId) => (dispatch) => {\n return get(`${rootRoute}/${orderId}`)\n .then((response) => response.json())\n .then((result) => {\n dispatch(setOrder(result));\n })\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))));\n};\n\nconst receive = (\n list,\n totalCount,\n currentPage,\n showOnlyMyOrders,\n mode = ViewMode.List\n) => ({\n type: ORDER_RECEIVE,\n payload: {\n list,\n mode,\n totalCount,\n currentPage,\n showOnlyMyOrders,\n },\n});\n\nexport const changeCurrentPage = (currentPage) => ({\n type: ORDER_CHANGE_CURRENTPAGE,\n payload: {\n currentPage,\n },\n});\n\nexport const setError = (error) => ({\n type: ORDER_ERROR,\n payload: {\n error,\n },\n});\n\nexport const setOrder = (order) => ({\n type: ORDER_SET_ORDER,\n payload: {\n order,\n },\n});\n","import React from 'react';\nimport { useNavigate } from 'react-router-dom';\nimport { translate } from '../../../Services/translation';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport { cells, grid } from '../../../styling/utils/grid';\nimport Button from '../../Button';\n\nconst StyledOrderMobileItem = styled.li`\n padding: 1.6rem;\n border: 1px solid ${getColor('grey', 300)};\n margin-bottom: 1.6rem;\n\n .title {\n ${text('large')}\n font-weight: bold;\n margin-bottom: 1.2rem;\n }\n\n .sub-title {\n ${text('small')}\n text-transform: uppercase;\n color: ${getColor('grey', 600)};\n }\n\n .span {\n ${text('medium')}\n }\n\n .content {\n ${grid}\n ${cells(2)}\n ${breakpoint('medium')} {\n ${cells(5)}\n }\n }\n\n .content__cell {\n display: flex;\n flex-direction: column;\n }\n\n .btn--read-more {\n grid-column: span 2;\n margin-top: 1.2rem;\n font-weight: bold;\n\n ${breakpoint('medium')} {\n grid-column: unset;\n margin-top: 0;\n }\n }\n`;\n\nconst OrderListItemMobile = ({ order, onClick }) => {\n return (\n \n

\n {translate('general.ordernumber')}: {order.externalOrderID}\n

\n
\n
\n

{translate('general.quantity')}

\n

{order.orderRows.length}

\n
\n
\n

\n {translate('orderlist.column.grandtotal')}\n

\n

{order.orderGrandTotal}

\n
\n
\n

{translate('orderlist.column.orderdate')}

\n

{order.orderDate}

\n
\n
\n

{translate('orderlist.column.status')}

\n

{order.status}

\n
\n onClick && onClick(order)}\n className=\"btn--read-more\"\n >\n {translate('general.show-more')}\n \n
\n
\n );\n};\n\nexport default OrderListItemMobile;\n","import React from 'react';\nimport { useNavigate } from 'react-router-dom';\nimport { translate } from '../../../Services/translation';\nimport styled from 'styled-components';\nimport { grid, cells } from '../../../styling/utils/grid';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\n\nconst StyledOrderDesktopItem = styled.li`\n ${grid}\n ${cells(6)}\n padding: 0.8rem;\n gap: 1.6rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n\n &:nth-child(even) {\n background-color: ${getColor('grey', 100)};\n }\n\n &:last-child {\n border-bottom: none;\n }\n\n span {\n ${text('large')}\n }\n\n a {\n ${text('large')}\n color: ${getColor('primary')};\n cursor: pointer;\n text-decoration: underline;\n text-align: right;\n }\n`;\n\nconst OrderListItemDesktop = ({ order, onClick }) => {\n const navigate = useNavigate();\n\n return (\n \n {order.externalOrderID}\n {order.orderRows.length}\n {order.orderGrandTotal}\n {order.orderDate}\n {order.status}\n onClick && onClick(order)}>\n {translate('general.show-more')}\n \n \n );\n};\n\nexport default OrderListItemDesktop;\n","import { PaginationOptions } from '../constants';\n\nexport interface Pager {\n pageSize?: number;\n displayedEntries?: number;\n edgeEntries?: number;\n}\n\nexport const calculatePager = (\n totalCount = 0,\n currentPage = 1,\n options: Pager = {}\n) => {\n const {\n pageSize = PaginationOptions.PageSize,\n displayedEntries = PaginationOptions.DisplayedEntries,\n edgeEntries = PaginationOptions.EdgeEntries,\n } = options;\n\n const pageCount =\n pageSize && pageSize > 0 ? Math.ceil(totalCount / pageSize) : 0;\n const interval = getInterval(pageCount, currentPage, displayedEntries);\n\n return {\n totalCount,\n pageSize,\n currentPageIndex: currentPage,\n pageCount,\n edgeEntries,\n intervalStart: interval[0],\n intervalEnd: interval[1],\n };\n};\n\nconst getInterval = (\n pageCount: number,\n currentPageIndex: number,\n displayedEntries: number\n) => {\n const internalPageIndex = currentPageIndex - 1;\n const half = Math.ceil(displayedEntries / 2);\n const upperLimit = pageCount - displayedEntries;\n const start =\n internalPageIndex > half\n ? Math.max(Math.min(internalPageIndex - half, upperLimit), 0)\n : 0;\n const end =\n internalPageIndex > half\n ? Math.min(internalPageIndex + half, pageCount)\n : Math.min(displayedEntries, pageCount);\n\n return [start, end];\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport { text } from '../styling/mixins/typography';\nimport { getColor } from '../styling/mixins/colors';\nimport Icon from './Icon';\n\ninterface StyledPaginationLinkProps {\n $current: boolean;\n $disabled: boolean;\n}\n\nconst StyledPagination = styled.ul`\n display: flex;\n justify-content: center;\n\n .pagination__link {\n ${text('medium')}\n font-weight: bold;\n width: 40px;\n height: 40px;\n display: flex;\n justify-content: center;\n align-items: center;\n border-radius: 4px;\n\n &--current {\n background-color: ${getColor('grey', 100)};\n }\n }\n`;\n\nconst StyledPaginationLink = styled.a`\n ${text('medium')}\n font-weight: bold;\n width: 40px;\n height: 40px;\n display: flex;\n justify-content: center;\n align-items: center;\n border-radius: 4px;\n background-color: ${(p) => (p.$current ? getColor('grey', 100) : 'none')};\n cursor: ${(p) => (p.$current ? 'default' : 'pointer')};\n pointer-events: ${(p) => (p.$disabled ? 'none' : 'auto')};\n`;\n\nconst StyledPaginationIcon = styled(Icon)`\n font-size: 2rem;\n`;\n\ninterface PaginationItemProps {\n name?: string | number;\n icon?: string;\n current?: boolean;\n disabled?: boolean;\n onChange?: () => void;\n}\n\nconst PaginationItem = ({\n name = '',\n icon = '',\n current = false,\n disabled = false,\n onChange,\n}: PaginationItemProps) => {\n return (\n
  • \n onChange && onChange()}\n >\n {name ? name : null}\n {icon ? : null}\n \n
  • \n );\n};\n\nconst RenderFirstHalfItems = ({\n intervalStart,\n edgeEntries,\n currentPageIndex,\n onChange,\n}) => {\n const renderItems: JSX.Element[] = [];\n const end = Math.min(edgeEntries, intervalStart);\n for (let i = 0; i < end; i++) {\n const publicPageIndex = i + 1;\n renderItems.push(\n onChange(publicPageIndex)}\n />\n );\n }\n if (edgeEntries < intervalStart) {\n renderItems.push(\n \n );\n }\n return <>{renderItems};\n};\n\nconst RenderMiddleItems = ({\n intervalStart,\n intervalEnd,\n currentPageIndex,\n onChange,\n}) => {\n const renderItems: JSX.Element[] = [];\n for (let i = intervalStart; i < intervalEnd; i++) {\n const publicPageIndex = i + 1;\n renderItems.push(\n onChange(publicPageIndex)}\n />\n );\n }\n return <>{renderItems};\n};\n\nconst RenderSecondHalfItems = ({\n intervalEnd,\n edgeEntries,\n pageCount,\n currentPageIndex,\n onChange,\n}) => {\n const renderItems: JSX.Element[] = [];\n if (pageCount - edgeEntries > intervalEnd) {\n renderItems.push(\n \n );\n }\n const begin = Math.max(pageCount - edgeEntries, intervalEnd);\n for (let i = begin; i < pageCount; i++) {\n const publicPageIndex = i + 1;\n renderItems.push(\n onChange(publicPageIndex)}\n />\n );\n }\n return <>{renderItems};\n};\n\nconst Pagination = ({ model, onChange }) => {\n const {\n currentPageIndex,\n pageCount,\n intervalStart,\n intervalEnd,\n edgeEntries,\n } = model;\n\n return (\n <>\n {pageCount > 1 && (\n \n {currentPageIndex > 1 && (\n onChange(currentPageIndex - 1)}\n />\n )}\n {intervalStart > 0 && edgeEntries > 0 && (\n \n )}\n \n {intervalEnd < pageCount && edgeEntries > 0 && (\n \n )}\n {currentPageIndex < pageCount && (\n onChange(currentPageIndex + 1)}\n />\n )}\n \n )}\n \n );\n};\n\nexport default Pagination;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { cells, grid } from '../../../styling/utils/grid';\n\ninterface SkeletonProps {\n $cells: number;\n}\n\nconst StyledSkeletonWrapper = styled.li`\n ${grid}\n ${(p) => cells(p.$cells)}\n padding: 1.2rem 0.8rem;\n gap: 1.6rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n\n &:nth-child(even) {\n background-color: ${getColor('grey', 100)};\n }\n\n &:last-child {\n border-bottom: none;\n }\n\n .skeleton__text {\n max-width: 100px;\n }\n`;\n\nconst SkeletonListItemDesktop = ({ items, cells, loading }) => {\n return (\n <>\n {loading &&\n [...Array(items)].map((e, index) => (\n \n {[...Array(cells - 1)].map((e, index) => (\n \n  \n \n ))}\n \n ))}\n \n );\n};\n\nexport default SkeletonListItemDesktop;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { cells, grid } from '../../../styling/utils/grid';\n\ninterface SkeletonProps {\n $cells: number;\n}\n\nconst StyledSkeletonWrapper = styled.li`\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n padding: 1.6rem;\n border: 1px solid ${getColor('grey', 300)};\n border-radius: 4px;\n margin-bottom: 1.6rem;\n\n .title {\n max-width: 40%;\n }\n\n .content {\n ${grid}\n ${(p) => cells(p.$cells - 3)}\n ${breakpoint('medium')} {\n ${(p) => cells(p.$cells)}\n }\n\n &-cell {\n display: flex;\n flex-direction: column;\n gap: 0.2rem;\n max-width: 40%;\n }\n }\n`;\n\nconst SkeletonListItemMobile = ({ items, cells, loading }) => {\n return (\n <>\n {loading &&\n [...Array(items)].map((e, index) => (\n \n \n  \n \n
    \n {[...Array(cells - 1)].map((e, index) => (\n
    \n  \n  \n
    \n ))}\n
    \n
    \n ))}\n \n );\n};\n\nexport default SkeletonListItemMobile;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport { translate } from '../../Services/translation';\nimport { query as queryOrders } from '../../Actions/Order.action';\nimport { useDispatch } from 'react-redux';\nimport OrderListItemMobile from './ui/OrderListItemMobile';\nimport OrderListItemDesktop from './ui/OrderListItemDesktop';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\nimport { cells, grid } from '../../styling/utils/grid';\nimport { hideFor, showFor } from '../../styling/utils/visibility';\nimport { btn } from '../../styling/mixins/buttons';\nimport { calculatePager, Pager } from '../../Services/Pagination.service';\nimport Pagination from '../Pagination';\nimport { setOrder } from '../../Actions/Order.action';\nimport { Order } from '../../Types/Order';\nimport { useNavigate } from 'react-router-dom';\nimport SkeletonListItemDesktop from './ui/SkeletonListItemDesktop';\nimport SkeletonListItemMobile from './ui/SkeletonListItemMobile';\nimport EditorString from '../EditorString/EditorString';\n\nconst StyledOrderHistory = styled.div`\n grid-column: span 3;\n\n .title {\n margin-bottom: 0.8rem;\n }\n\n .description {\n ${text('large')}\n max-width: 768px;\n margin-bottom: 1.6rem;\n\n ${breakpoint('large')} {\n margin-bottom: 2.4rem;\n }\n }\n\n .list-mobile {\n ${hideFor('large')}\n }\n\n .list-desktop {\n ${showFor('large')}\n border: 1px solid ${getColor('grey', 300)};\n }\n\n .desktop-header {\n ${grid}\n ${cells(6)}\n padding: 0.8rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n gap: 1.6rem;\n\n &__item {\n ${text('large')}\n font-weight: bold;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n }\n }\n\n .show-my-orders-btn {\n ${btn('outlined', 'medium')}\n margin-bottom: 1.6rem;\n }\n\n .pagination-wrapper {\n margin-top: 1.6rem;\n }\n\n .error {\n ${text('medium')}\n color: ${getColor('alert')};\n }\n`;\n\nconst MyPagesOrderHistory = ({ description }) => {\n const dispatch = useDispatch();\n const navigate = useNavigate();\n const orders = useTypedSelector((state) => state.myPage.orders);\n const { list: orderList, totalCount, errors } = orders;\n const [pager, setPager] = useState({});\n const [currentPageIndex, setCurrentPageIndex] = useState(1);\n const [showOnlyMyOrders, setShowOnlyMyOrders] = useState(false);\n const generalError = useMemo(\n () => (errors && errors['general']?.length ? errors['general'][0] : null),\n [errors]\n );\n\n useEffect(() => setCurrentPageIndex(1), [showOnlyMyOrders]);\n\n useEffect(() => {\n dispatch(queryOrders(currentPageIndex, showOnlyMyOrders));\n }, [dispatch, currentPageIndex, showOnlyMyOrders]);\n\n useEffect(() => {\n setPager(calculatePager(totalCount, currentPageIndex));\n }, [totalCount, currentPageIndex]);\n\n const onOrderClick = (order: Order) => {\n dispatch(setOrder(order));\n navigate(order.orderId);\n };\n\n return (\n \n

    {translate('mypage.order.title')}

    \n {description?.value && (\n \n )}\n {generalError &&

    {generalError}

    }\n setShowOnlyMyOrders(!showOnlyMyOrders)}\n >\n {!showOnlyMyOrders\n ? translate('mypage.order.show-only-my-orders')\n : translate('mypage.order.show-organization-orders')}\n \n {(!orderList || orderList.length == 0) && (\n

    {translate('mypage.order.no-orders')}

    \n )}\n
      \n \n {orderList &&\n orderList.map((order) => (\n \n ))}\n
    \n
      \n
      \n

      \n {translate('general.ordernumber')}\n

      \n

      \n {translate('general.quantity')}\n

      \n

      \n {translate('orderdetail.grandtotal')}\n

      \n

      \n {translate('orderdetail.orderdate')}\n

      \n

      \n {translate('orderdetail.orderstatus')}\n

      \n
      \n \n {orderList &&\n orderList.map((order) => (\n \n ))}\n
    \n
    \n \n index !== currentPageIndex && setCurrentPageIndex(index)\n }\n />\n
    \n
    \n );\n};\n\nexport default MyPagesOrderHistory;\n","import React from 'react';\nimport { translate } from '../../../Services/translation';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { text } from '../../../styling/mixins/typography';\nimport { getColor } from '../../../styling/mixins/colors';\n\nconst StyledProductCard = styled.div`\n display: flex;\n ${text('medium')}\n gap: 1.6rem;\n border-bottom: 2px solid ${getColor('grey', 100)};\n padding: 1.6rem;\n\n ${breakpoint('large')} {\n padding: 2.4rem;\n }\n\n .image {\n width: 64px;\n height: 64px;\n object-fit: cover;\n }\n\n .desc {\n display: flex;\n flex-direction: column;\n flex: 1;\n ${text('large')}\n }\n\n .title {\n ${text('large')}\n font-weight: bold;\n }\n\n span:not(:last-child) {\n margin-bottom: 0.4rem;\n }\n\n .total {\n font-weight: bold;\n }\n`;\n\nconst ProductCard = ({ product }) => {\n return (\n \n \n \n \n
    \n \n {product.name}\n \n \n {translate('product.articleno')}: {product.articleNumber}\n \n {product.extraInfo &&\n product.extraInfo.items.map((item) => (\n \n {item.key}: {item.value}\n \n ))}\n \n {translate('product.quantity')}: {product.quantityString}\n \n \n {translate('product.unitprice')}: {product.totalPrice}\n \n \n {translate('product.total')}: {product.totalPrice}\n \n
    \n
    \n );\n};\n\nexport default ProductCard;\n","import { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport { grid, cells, section } from '../../../styling/utils/grid';\n\nexport const StyledOrderDetail = styled.div`\n ${section}\n display: flex;\n flex-direction: column;\n background-color: ${getColor('grey', 100)};\n padding-bottom: 2.4rem;\n gap: 1.6rem;\n\n &.confirmation-detail {\n ${breakpoint('large')} {\n padding-top: 4rem;\n padding-bottom: 4rem;\n align-items: center;\n }\n }\n\n &.my-pages-detail {\n padding-top: 2.4rem;\n margin: 0 -0.8rem;\n margin-bottom: -2.4rem;\n\n ${breakpoint('medium')} {\n margin: 0 -1.2rem;\n margin-bottom: -2.4rem;\n }\n\n ${breakpoint('large')} {\n align-items: center;\n margin: unset;\n padding-top: 4rem;\n padding-bottom: 4rem;\n }\n }\n\n .title {\n margin-bottom: 0.8rem;\n text-align: center;\n }\n\n .msg-title {\n font-weight: bold;\n }\n\n .top-wrapper {\n display: flex;\n flex-direction: column;\n ${text('large')}\n gap: 0.8rem;\n text-align: center;\n\n ${breakpoint('large')} {\n gap: 2.4rem;\n flex-direction: row;\n justify-content: center;\n }\n }\n\n .top-span {\n font-weight: bold;\n }\n\n .top-msg {\n ${text('large')}\n text-align: center;\n }\n\n .review-items {\n margin-top: 2.4rem;\n display: flex;\n align-items: center;\n justify-content: center;\n flex-direction: column;\n gap: 1.6rem;\n\n ${breakpoint('medium')} {\n flex-direction: row;\n }\n\n .review-item {\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 2.4rem 1.6rem;\n width: 200px;\n height: 64px;\n border-radius: 8px;\n overflow: hidden;\n background-color: ${getColor('grey', 100)};\n\n img {\n pointer-events: none;\n mix-blend-mode: multiply;\n }\n }\n }\n\n .block {\n background: ${getColor('white')};\n padding: 1.6rem;\n\n ${breakpoint('large')} {\n width: 100%;\n max-width: 660px;\n padding: 2.4rem;\n }\n }\n\n .main-block {\n display: flex;\n flex-direction: column;\n padding: 0;\n }\n\n .msg-block {\n ${text('large')}\n }\n\n .bottom-block {\n ${grid}\n gap: 2.4rem;\n flex-wrap: wrap;\n\n ${breakpoint('large')} {\n ${cells(2)}\n }\n }\n\n .price-wrapper {\n ${text('large')}\n padding: 1.6rem;\n\n ${breakpoint('large')} {\n padding: 2.4rem;\n }\n\n & div:not(:last-child) {\n margin-bottom: 0.8rem;\n }\n }\n\n .price {\n display: flex;\n justify-content: space-between;\n }\n\n .saved-price {\n color: ${getColor('alert')};\n }\n\n .total-price {\n font-weight: bold;\n }\n\n .bottom-cell {\n ${text('large')}\n display: flex;\n flex-direction: column;\n text-transform: capitalize;\n }\n\n .bottom-span {\n font-weight: bold;\n }\n`;\n","import React, { useMemo } from 'react';\nimport { ResponsiveImageModel } from '../../Types/ResponsiveImageModel';\n\nconst ResponsiveImage = ({\n sizeDefinitions,\n alt,\n lazyLoad = false,\n imageClassName,\n}: ResponsiveImageModel) => {\n const smallestImage = useMemo(\n () => sizeDefinitions?.slice().sort((a, b) => a.width - b.width)[0],\n [sizeDefinitions]\n );\n\n const orderedSizeDefinitions = useMemo(\n () =>\n sizeDefinitions?.slice().sort((a, b) => b.fromWidth - a.fromWidth),\n [sizeDefinitions]\n );\n\n return (\n \n {orderedSizeDefinitions &&\n orderedSizeDefinitions.length > 1 &&\n orderedSizeDefinitions.map((img, idx) => (\n \n ))}\n \n \n );\n};\n\nexport default ResponsiveImage;\n","import React, { useMemo } from 'react';\nimport { translate } from '../../Services/translation';\nimport ProductCard from './ui/ProductCard';\nimport { Order } from '../../Types/Order';\nimport { StyledOrderDetail } from './styles/OrderDetailStyling';\nimport { ConfirmationReviewItem } from '../OrderConfirmation/OrderConfirmation';\nimport EditorString from '../EditorString/EditorString';\nimport ResponsiveImage from '../ResponsiveImage/ResponsiveImage';\nimport SalesAddress from '../../Types/OrderDetailAddress';\nimport { IngridPickupLocation } from '../../Types/Ingrid';\nimport { EditorStringModel } from '../../Types/EditorStringModel';\n\ninterface OrderDetailProps {\n order: Order;\n isConfirmation: boolean;\n confirmationTitle?: string;\n confirmationText?: EditorStringModel;\n confirmationExtraText?: EditorStringModel;\n confirmationReviewItems?: ConfirmationReviewItem[];\n}\n\nconst OrderDetailAddress = ({\n deliveryMethod,\n address,\n pickupLocation,\n}: {\n deliveryMethod: Order;\n address: SalesAddress;\n pickupLocation?: IngridPickupLocation;\n}) => {\n \n return (\n <>\n {pickupLocation && (\n <>\n {deliveryMethod}\n {pickupLocation.name}\n {pickupLocation.address?.address_lines?.[0]}\n {pickupLocation.address?.city}\n {pickupLocation.address?.country}\n {pickupLocation.address?.postal_code}\n \n )}\n {!pickupLocation && (\n <>\n {address.organizationName && (\n {address.organizationName}\n )}\n \n {address.firstName} {address.lastName}\n \n {address.address1}\n {address.address2 && {address.address2}}\n {address.careOf && C/O: {address.careOf}}\n {address.city}\n {address.country}\n {address.zipCode}\n \n )}\n \n );\n};\n\nconst OrderDetail = ({\n order,\n isConfirmation,\n confirmationTitle,\n confirmationText,\n confirmationExtraText,\n confirmationReviewItems,\n}: OrderDetailProps) => {\n const deliveryAddress = useMemo(\n () =>\n order.deliveries?.length ? order.deliveries[0].address : undefined,\n [order.deliveries]\n );\n\n return (\n \n {isConfirmation ? (\n <>\n
    \n

    {confirmationTitle}

    \n
    \n \n {translate('general.ordernumber')}:\n {order.externalOrderID}\n \n \n {translate('orderdetail.orderdate')}:\n {order.orderDate}\n \n
    \n
    \n {confirmationText?.value && (\n
    \n \n {confirmationReviewItems && (\n
    \n {confirmationReviewItems.map((reviewItem, index) => (\n \n \n \n ))}\n
    \n )}\n
    \n )}\n \n ) : (\n
    \n

    \n {translate('general.ordernumber')}: {order.externalOrderID}\n

    \n
    \n \n {translate('orderdetail.orderdate')}:\n {order.orderDate}\n \n \n {translate('orderdetail.orderstatus')}:\n {order.status}\n \n
    \n
    \n )}\n
    \n {order.orderRows.map((product) => (\n \n ))}\n
    \n
    \n {translate('checkout.order.sum')}\n {order.orderTotal}\n
    \n {order.orderTotalDiscountAmount && (\n
    \n {translate('checkout.order.saved')}\n {order.orderTotalDiscountAmount}\n
    \n )}\n
    \n {translate('checkout.order.shipping')}\n {order.orderTotalDeliveryCost}\n
    \n {order.orderTotalFee && (\n
    \n {translate('checkout.order.fee')}\n {order.orderTotalFee}\n
    \n )}\n
    \n {translate('orderdetail.grandtotal')}\n {order.orderGrandTotal}\n
    \n
    \n {translate('checkout.order.vat')}\n {order.orderTotalVat}\n
    \n
    \n
    \n {isConfirmation && confirmationExtraText?.value && (\n \n )}\n
    \n {(deliveryAddress || order.pickupLocation) && (\n
    \n \n {translate('orderdetail.deliveryaddress')}\n \n \n
    \n )}\n {order.billingAddress && (\n
    \n \n {translate('orderdetail.billingaddress')}\n \n \n
    \n )}\n
    \n \n {translate('orderdetail.paymentmethod')}\n \n {order.paymentMethod}\n
    \n
    \n \n {translate('orderdetail.deliverymethod')}\n \n {order.deliveryMethod}\n
    \n
    \n \n );\n};\n\nexport default OrderDetail;\n","import React, { useEffect, useMemo } from 'react';\nimport { translate } from '../../Services/translation';\nimport { useNavigate, useParams } from 'react-router-dom';\nimport { useDispatch } from 'react-redux';\nimport { getOrder } from '../../Actions/Order.action';\nimport Icon from '../Icon';\nimport OrderDetail from '../OrderDetail/OrderDetail';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport Button from '../Button';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { reorder } from '../../Services/Cart.service';\nimport { receive, loadError } from '../../Actions/Cart.action';\nimport { catchError } from '../../Actions/Error.action';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\nimport { setError } from '../../Actions/Order.action';\n\nconst StyledMyPagesOrderDetail = styled.div`\n grid-column: span 3;\n\n .menu {\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n margin-bottom: 1.6rem;\n\n ${breakpoint('medium')} {\n gap: unset;\n flex-direction: row;\n justify-content: space-between;\n }\n\n ${breakpoint('xlarge')} {\n margin-bottom: 2.4rem;\n }\n }\n\n .btn--back {\n align-items: center;\n justify-content: center;\n display: flex;\n width: 100%;\n font-weight: bold;\n\n ${breakpoint('medium')} {\n width: unset;\n }\n }\n\n .btn__wrapper {\n display: flex;\n gap: 0.8rem;\n\n ${breakpoint('medium')} {\n gap: 2.4rem;\n }\n\n button {\n align-items: center;\n justify-content: center;\n display: flex;\n width: 50%;\n font-weight: bold;\n\n ${breakpoint('medium')} {\n width: unset;\n }\n }\n }\n\n .order-icon {\n width: 16px;\n height: 16px;\n margin-right: 0.8rem;\n }\n\n .error {\n ${text('medium')};\n color: ${getColor('alert')};\n }\n`;\n\nconst MyPagesOrderDetail = () => {\n const navigate = useNavigate();\n const { id } = useParams();\n const dispatch = useDispatch();\n const { order, errors = {} } = useTypedSelector(\n (state) => state.myPage.orders\n );\n const generalError = useMemo(\n () => (errors && errors['general']?.length ? errors['general'][0] : null),\n [errors]\n );\n\n useEffect(() => {\n if (!order) {\n dispatch(getOrder(id));\n }\n }, []);\n\n const addOrderToCart = async () => {\n try {\n const cart = await reorder(id);\n dispatch(receive(cart));\n return true;\n } catch (ex) {\n dispatch(catchError(ex, (error) => loadError(error)));\n return false;\n }\n };\n\n return (\n \n
    \n {\n dispatch(setError({ general: [] }));\n navigate(-1);\n }}\n >\n \n {translate('mypage.order.allorders')}\n \n
    \n \n \n
    \n
    \n {generalError &&

    {generalError}

    }\n {order ? : null}\n
    \n );\n};\n\nexport default MyPagesOrderDetail;\n","import { ViewMode } from '../constants';\nimport { get, post, put, remove as httpRemove } from '../Services/http';\nimport { catchError } from './Error.action';\nimport { PERSON_RECEIVE, PERSON_ERROR, PERSON_CHANGE_MODE } from '../constants';\n\nconst rootRoute = '/api/mypageperson';\n\nexport const changeMode = (mode) => ({\n type: PERSON_CHANGE_MODE,\n payload: {\n mode,\n },\n});\n\nexport const query = (mode = ViewMode.List) => (dispatch) => {\n return get(rootRoute)\n .then((response) => response.json())\n .then((result) => {\n dispatch(receive(result, mode));\n })\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))));\n};\n\nexport const remove = (personSystemId) => (dispatch) =>\n httpRemove(rootRoute, personSystemId)\n .then(() => dispatch(query()))\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))));\n\nexport const add = (person) => (dispatch) =>\n post(rootRoute, person)\n .then(() => dispatch(query()))\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))));\n\nexport const edit = (person) => (dispatch) =>\n put(rootRoute, person)\n .then(() => dispatch(query()))\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))));\n\nexport const getPerson = (systemId) => {\n return get(`${rootRoute}/${systemId}`).then((response) => response.json());\n};\n\nconst receive = (list, mode) => ({\n type: PERSON_RECEIVE,\n payload: {\n list,\n mode,\n },\n});\n\nexport const setError = (error) => ({\n type: PERSON_ERROR,\n payload: {\n error,\n },\n});\n","import React from 'react';\nimport { translate } from '../../../Services/translation';\nimport Icon from '../../Icon';\nimport { useNavigate } from 'react-router-dom';\nimport { remove as removeUser } from '../../../Actions/Person.action';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport { cells, grid } from '../../../styling/utils/grid';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport Button from '../../Button';\n\nconst StyledUserMobileItem = styled.li`\n padding: 1.6rem;\n border: 1px solid ${getColor('grey', 300)};\n margin-bottom: 1.6rem;\n\n .title {\n ${text('large')}\n font-weight: bold;\n text-transform: capitalize;\n margin-bottom: 1.2rem;\n }\n\n .desc {\n ${grid}\n ${cells(2)}\n ${breakpoint('medium')} {\n ${cells(4)}\n }\n }\n\n .desc-cell {\n display: flex;\n flex-direction: column;\n }\n\n .sub-title {\n ${text('small')}\n color: ${getColor('grey', 600)};\n text-transform: uppercase;\n }\n\n .person-info {\n ${text('medium')}\n }\n\n .btn__wrapper {\n grid-column: span 2;\n display: flex;\n gap: 1.2rem;\n align-items: center;\n\n ${breakpoint('medium')} {\n grid-column: unset;\n justify-content: flex-end;\n }\n\n button {\n display: flex;\n align-items: center;\n width: 32px;\n height: 32px;\n\n &#edit {\n border-color: ${getColor('secondary')};\n color: ${getColor('secondary')};\n }\n\n &#delete {\n border-color: ${getColor('alert')};\n color: ${getColor('alert')};\n }\n }\n }\n`;\n\nconst UserListItemMobile = ({ person }) => {\n const navigate = useNavigate();\n const dispatch = useDispatch();\n\n return (\n \n

    \n {person.firstName} {person.lastName}\n

    \n
    \n
    \n

    {translate('mypage.person.email')}:

    \n

    {person.email}

    \n
    \n
    \n

    {translate('mypage.person.phone')}:

    \n

    {person.phone}

    \n
    \n
    \n

    {translate('mypage.person.role')}:

    \n

    {person.role}

    \n
    \n {person.role !== 'Admin' && (\n
    \n navigate(`edit/${person.systemId}`)}\n >\n \n \n {\n dispatch(removeUser(person.systemId));\n }}\n >\n \n \n
    \n )}\n
    \n
    \n );\n};\n\nexport default UserListItemMobile;\n","import React from 'react';\nimport Icon from '../../Icon';\nimport { useNavigate } from 'react-router-dom';\nimport { remove as removeUser } from '../../../Actions/Person.action';\nimport { useDispatch } from 'react-redux';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { cells } from '../../../styling/utils/grid';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport Button from '../../Button';\n\nconst StyledUserDesktopItem = styled.li`\n ${cells(5)}\n align-items: center;\n padding: 0 0.8rem;\n gap: 1.6rem;\n\n &:nth-child(even) {\n background-color: ${getColor('grey', 100)};\n }\n\n &:not(:last-child) {\n border-bottom: 1px solid ${getColor('grey', 300)};\n }\n\n .span {\n ${text('large')}\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n }\n\n .btn__wrapper {\n display: flex;\n justify-content: flex-end;\n\n ${breakpoint('large')} {\n gap: 0.8rem;\n }\n\n #edit {\n color: ${getColor('primary')};\n }\n\n #delete {\n color: ${getColor('alert')};\n }\n }\n`;\n\nconst UserListItemDesktop = ({ person }) => {\n const navigate = useNavigate();\n const dispatch = useDispatch();\n\n return (\n \n

    \n {person.firstName} {person.lastName}\n

    \n

    {person.email}

    \n

    {person.phone}

    \n

    {person.role}

    \n {person.role !== 'Admin' && (\n
    \n navigate(`edit/${person.systemId}`)}\n >\n \n \n {\n dispatch(removeUser(person.systemId));\n }}\n >\n \n \n
    \n )}\n
    \n );\n};\n\nexport default UserListItemDesktop;\n","import React, { useEffect } from 'react';\nimport { translate } from '../../Services/translation';\nimport { query as queryPersons } from '../../Actions/Person.action';\nimport { useDispatch } from 'react-redux';\nimport { useNavigate } from 'react-router-dom';\nimport UserListItemMobile from './ui/UserListItemMobile';\nimport UserListItemDesktop from './ui/UserListItemDesktop';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\nimport { grid, cells } from '../../styling/utils/grid';\nimport Button from '../Button';\nimport { hideFor, showFor } from '../../styling/utils/visibility';\nimport SkeletonListItemDesktop from './ui/SkeletonListItemDesktop';\nimport SkeletonListItemMobile from './ui/SkeletonListItemMobile';\nimport EditorString from '../EditorString/EditorString';\n\nconst StyledMyPagesUsers = styled.div`\n grid-column: span 3;\n\n .title {\n margin-bottom: 0.8rem;\n }\n\n .description {\n ${text('large')}\n max-width: 768px;\n margin-bottom: 1.6rem;\n\n ${breakpoint('large')} {\n margin-bottom: 2.4rem;\n }\n }\n\n .list-mobile {\n ${hideFor('large')}\n margin-bottom: 0.8rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 1.6rem;\n }\n }\n\n .list-desktop {\n ${showFor('large')}\n border: 1px solid ${getColor('grey', 300)};\n margin-bottom: 4rem;\n }\n\n .header {\n ${grid}\n ${cells(5)}\n padding: 0.8rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n gap: 1.6rem;\n\n &__span {\n ${text('large')}\n font-weight: bold;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n }\n }\n`;\n\nconst MyPagesUsers = ({ description }) => {\n const dispatch = useDispatch();\n const navigate = useNavigate();\n const { persons } = useTypedSelector((state) => state.myPage);\n const personsList = persons.list;\n\n useEffect(() => {\n dispatch(queryPersons());\n }, []);\n\n return (\n \n

    {translate('mypage.person.title')}

    \n {description?.value && (\n \n )}\n
      \n \n {personsList &&\n personsList.map((person) => (\n \n ))}\n
    \n
      \n
      \n

      {translate('mypage.person.name')}

      \n

      {translate('mypage.person.email')}

      \n

      {translate('mypage.person.phone')}

      \n

      {translate('mypage.person.role')}

      \n
      \n \n {personsList &&\n personsList.map((person) => (\n \n ))}\n
    \n \n
    \n );\n};\n\nexport default MyPagesUsers;\n","import React, { useState } from 'react';\nimport { translate } from '../../Services/translation';\nimport { add as addPerson } from '../../Actions/Person.action';\nimport { useDispatch } from 'react-redux';\nimport { useNavigate } from 'react-router-dom';\nimport { StyledFormWrapper } from './styles/MyPagesForm.styling';\nimport Button from '../Button';\nimport Input from '../Inputs/Input';\nimport RadioButton from '../Inputs/Radiobutton';\nimport EditorString from '../EditorString/EditorString';\n\nconst MyPagesAddUser = ({ description }) => {\n const navigate = useNavigate();\n const dispatch = useDispatch();\n\n // FORM-VALUES\n const [firstName, setFirstName] = useState('');\n const [lastName, setLastName] = useState('');\n const [email, setEmail] = useState('');\n const [phone, setPhone] = useState('');\n const [role, setRole] = useState('');\n\n const submitForm = () => {\n dispatch(\n addPerson({\n firstName,\n lastName,\n email,\n phone,\n role,\n })\n );\n navigate(-1);\n };\n\n return (\n \n

    {translate('mypage.person.adduser')}

    \n {description?.value && (\n \n )}\n
    \n setFirstName(e.target.value)}\n placeholder={translate('general.placeholder.firstname')}\n type=\"text\"\n id=\"fname\"\n />\n setLastName(e.target.value)}\n placeholder={translate('general.placeholder.lastname')}\n type=\"text\"\n id=\"lname\"\n />\n setEmail(e.target.value)}\n placeholder={translate('general.placeholder.email')}\n type=\"email\"\n id=\"email\"\n />\n setPhone(e.target.value)}\n placeholder={translate('general.placeholder.phone')}\n type=\"tel\"\n id=\"tel\"\n />\n
    \n setRole(e.target.value)}\n wrapperClassName=\"radio\"\n />\n setRole(e.target.value)}\n wrapperClassName=\"radio\"\n />\n setRole(e.target.value)}\n wrapperClassName=\"radio\"\n />\n
    \n \n
    \n \n \n
    \n
    \n );\n};\n\nexport default MyPagesAddUser;\n","import React, { useEffect, useState } from 'react';\nimport { translate } from '../../Services/translation';\nimport { getPerson, edit as editPerson } from '../../Actions/Person.action';\nimport { useDispatch } from 'react-redux';\nimport { useParams, useNavigate } from 'react-router-dom';\nimport { StyledFormWrapper } from './styles/MyPagesForm.styling';\nimport Person from '../../Types/Person';\nimport Button from '../Button';\nimport Input from '../Inputs/Input';\nimport RadioButton from '../Inputs/Radiobutton';\nimport EditorString from '../EditorString/EditorString';\n\nconst MyPagesEditUser = ({ description }) => {\n const { id } = useParams();\n const navigate = useNavigate();\n const dispatch = useDispatch();\n const [isLoading, setIsLoading] = useState(true);\n const [person, setPerson] = useState();\n\n const fetchUser = async () => {\n const person = await getPerson(id);\n setPerson(person);\n setIsLoading(!isLoading);\n };\n\n const setPersonValue = (key, value) => {\n const personCopy = Object.assign({}, person);\n personCopy[key] = value;\n setPerson(personCopy);\n console.log(personCopy);\n };\n\n const submitForm = () => {\n dispatch(editPerson(person));\n navigate(-1);\n };\n\n useEffect(() => {\n fetchUser();\n }, []);\n\n return (\n \n

    {translate('mypage.person.edituser')}

    \n {description?.value && (\n \n )}\n
    \n setPersonValue('firstName', e.target.value)}\n placeholder={translate('general.placeholder.firstname')}\n type=\"text\"\n id=\"fname\"\n disabled={isLoading}\n />\n setPersonValue('lastName', e.target.value)}\n value={person?.lastName}\n placeholder={translate('general.placeholder.lastname')}\n type=\"text\"\n id=\"lname\"\n disabled={isLoading}\n />\n setPersonValue('email', e.target.value)}\n value={person?.email}\n placeholder={translate('general.placeholder.email')}\n type=\"email\"\n id=\"email\"\n disabled={isLoading}\n />\n setPersonValue('phone', e.target.value)}\n placeholder={translate('general.placeholder.phone')}\n type=\"tel\"\n value={person?.phone}\n id=\"tel\"\n disabled={isLoading}\n />\n
    \n setPersonValue('role', e.target.value)}\n checked={person?.role === 'Admin'}\n wrapperClassName=\"radio\"\n disabled={isLoading}\n />\n setPersonValue('role', e.target.value)}\n wrapperClassName=\"radio\"\n disabled={isLoading}\n />\n setPersonValue('role', e.target.value)}\n wrapperClassName=\"radio\"\n disabled={isLoading}\n />\n
    \n \n
    \n submitForm()}\n disabled={isLoading}\n >\n {translate('general.save')}\n \n \n
    \n
    \n );\n};\n\nexport default MyPagesEditUser;\n","import { ViewMode } from '../constants';\nimport { get, post, put, remove as httpRemove } from '../Services/http';\nimport { catchError } from './Error.action';\nimport {\n ADDRESS_CHANGE_MODE,\n ADDRESS_RECEIVE,\n ADDRESS_ERROR,\n} from '../constants';\nconst rootRoute = '/api/mypageaddress';\n\nexport const changeMode = (mode) => ({\n type: ADDRESS_CHANGE_MODE,\n payload: {\n mode,\n },\n});\n\nexport const query = (mode = ViewMode.List) => (dispatch) => {\n return get(rootRoute)\n .then((response) => response.json())\n .then((result) => {\n dispatch(receive(result, mode));\n })\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))));\n};\n\nexport const remove = (addressSystemId) => (dispatch) =>\n httpRemove(rootRoute, addressSystemId)\n .then(() => dispatch(query()))\n .catch((ex) => dispatch(catchError(ex, (error) => setError(error))));\n\nexport const add = (address) => (dispatch) =>\n post(rootRoute, address)\n .then(() => dispatch(query()))\n .catch((ex) => {\n dispatch(catchError(ex, (error) => setError(error)));\n throw ex;\n });\n\nexport const edit = (address) => (dispatch) =>\n put(rootRoute, address)\n .then(() => dispatch(query()))\n .catch((ex) => {\n dispatch(catchError(ex, (error) => setError(error)));\n throw ex;\n });\n\nexport const getAddress = (systemId) => {\n return get(`${rootRoute}/${systemId}`).then((response) => response.json());\n};\n\nconst receive = (list, mode) => ({\n type: ADDRESS_RECEIVE,\n payload: {\n list,\n mode,\n },\n});\n\nexport const setError = (error) => ({\n type: ADDRESS_ERROR,\n payload: {\n error,\n },\n});\n","import React from 'react';\nimport Icon from '../../Icon';\nimport { useNavigate } from 'react-router-dom';\nimport { remove as removeAddress } from '../../../Actions/Address.action';\nimport { useDispatch } from 'react-redux';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { cells, grid } from '../../../styling/utils/grid';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport Button from '../../Button';\n\nconst StyledAddressDesktopItem = styled.li`\n ${grid}\n ${cells(5)}\n align-items: center;\n padding: 0 0.8rem;\n gap: 1.6rem;\n\n &:nth-child(even) {\n background-color: ${getColor('grey', 100)};\n }\n &:not(:last-child) {\n border-bottom: 1px solid ${getColor('grey', 300)};\n }\n\n .item-span {\n ${text('large')}\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n }\n\n .btn-wrapper {\n display: flex;\n justify-content: flex-end;\n ${breakpoint('large')} {\n gap: 0.8rem;\n }\n\n #delete {\n color: ${getColor('alert')};\n }\n }\n`;\n\nconst AddressListItemDesktop = ({ address }) => {\n const navigate = useNavigate();\n const dispatch = useDispatch();\n return (\n \n

    {address.address}

    \n

    {address.zipCode}

    \n

    {address.city}

    \n

    {address.country}

    \n
    \n navigate(`edit/${address.systemId}`)}\n >\n \n \n {\n dispatch(removeAddress(address.systemId));\n }}\n >\n \n \n
    \n
    \n );\n};\nexport default AddressListItemDesktop;\n","import React from 'react';\nimport Icon from '../../Icon';\nimport { useNavigate } from 'react-router-dom';\nimport { remove as removeAddress } from '../../../Actions/Address.action';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport Button from '../../Button';\n\nconst StyledAddressMobileItem = styled.li`\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 1.6rem;\n border: 1px solid ${getColor('grey', 300)};\n margin-bottom: 1.6rem;\n\n .span-wrapper {\n display: flex;\n flex-direction: column;\n }\n .item-span {\n ${text('medium')}\n text-transform: capitalize;\n }\n\n .primary-item-span {\n ${text('large')}\n font-weight: bold;\n }\n\n .btn-wrapper {\n display: flex;\n gap: 0.8rem;\n\n #edit {\n border-color: ${getColor('secondary')};\n }\n\n #delete {\n border-color: ${getColor('alert')};\n color: ${getColor('alert')};\n }\n }\n`;\n\nconst AddressListItemMobile = ({ address }) => {\n const navigate = useNavigate();\n const dispatch = useDispatch();\n return (\n \n
    \n

    {address.address}

    \n

    \n {address.zipCode} {address.city}\n

    \n

    {address.country}

    \n
    \n
    \n navigate(`edit/${address.systemId}`)}\n >\n \n \n {\n dispatch(removeAddress(address.systemId));\n }}\n >\n \n \n
    \n
    \n );\n};\nexport default AddressListItemMobile;\n","import React, { useEffect } from 'react';\nimport { translate } from '../../Services/translation';\nimport { query as queryAddresses } from '../../Actions/Address.action';\nimport { useDispatch } from 'react-redux';\nimport { useNavigate } from 'react-router-dom';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport AddressListItemDesktop from './ui/AddressListItemDesktop';\nimport AddressListItemMobile from './ui/AddressListItemMobile';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport { hideFor, showFor } from '../../styling/utils/visibility';\nimport { getColor } from '../../styling/mixins/colors';\nimport { cells, grid } from '../../styling/utils/grid';\nimport Button from '../Button';\nimport SkeletonListItemDesktop from './ui/SkeletonListItemDesktop';\nimport SkeletonListItemMobile from './ui/SkeletonListItemMobile';\nimport EditorString from '../EditorString/EditorString';\n\nconst StyledMyPagesAddresses = styled.div`\n grid-column: span 3;\n\n .title {\n margin-bottom: 0.8rem;\n }\n\n .description {\n ${text('large')}\n max-width: 768px;\n margin-bottom: 1.6rem;\n\n ${breakpoint('large')} {\n margin-bottom: 2.4rem;\n }\n }\n\n .list-mobile {\n ${hideFor('large')}\n margin-bottom: 0.8rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 1.6rem;\n }\n }\n\n .list-desktop {\n ${showFor('large')}\n border: 1px solid ${getColor('grey', 300)};\n margin-bottom: 4rem;\n }\n\n .header {\n ${grid}\n ${cells(5)}\n padding: 0.8rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n gap: 1.6rem;\n\n &__span {\n ${text('large')}\n font-weight: bold;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n }\n }\n`;\n\nconst MyPagesUsers = ({ description }) => {\n const dispatch = useDispatch();\n const navigate = useNavigate();\n const { addresses } = useTypedSelector((state) => state.myPage);\n const addressList = addresses.list;\n useEffect(() => {\n dispatch(queryAddresses());\n }, []);\n return (\n \n

    {translate('mypage.address.title')}

    \n {description?.value && (\n \n )}\n
      \n \n {addressList &&\n addressList.map((address) => (\n \n ))}\n
    \n
      \n
      \n

      {translate('mypage.address.address')}

      \n

      {translate('mypage.address.zipcode')}

      \n

      {translate('mypage.address.city')}

      \n

      {translate('mypage.address.country')}

      \n
      \n \n {addressList &&\n addressList.map((address) => (\n \n ))}\n
    \n \n
    \n );\n};\nexport default MyPagesUsers;\n","import React, { useState } from 'react';\nimport { translate } from '../../Services/translation';\nimport { add as addAddress } from '../../Actions/Address.action';\nimport { useDispatch } from 'react-redux';\nimport { useNavigate } from 'react-router-dom';\nimport {\n StyledFormWrapper,\n StyledFormDropdown,\n} from './styles/MyPagesForm.styling';\nimport Input from '../Inputs/Input';\nimport Button from '../Button';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport EditorString from '../EditorString/EditorString';\n\nconst MyPagesAddAddress = ({ description }) => {\n const navigate = useNavigate();\n const dispatch = useDispatch();\n const countriesList = globalThis.LitiumConstants.countries;\n const { errors = {} } = useTypedSelector((state) => state.myPage.addresses);\n\n // FORM-VALUES\n const [address, setAddress] = useState('');\n const [zipCode, setZipCode] = useState('');\n const [city, setCity] = useState('');\n const [country, setCountry] = useState(countriesList[0].value);\n const [phoneNumber, setPhoneNumber] = useState('');\n\n const submitForm = (e) => {\n e.preventDefault();\n dispatch(\n addAddress({\n address,\n zipCode,\n city,\n country,\n phoneNumber,\n })\n )\n .then(() => navigate(-1))\n .catch(() => {}); // must catch error\n };\n\n return (\n \n

    {translate('mypage.address.addaddress')}

    \n {description?.value && (\n \n )}\n
    \n setAddress(e.target.value)}\n placeholder={translate('general.placeholder.address')}\n type=\"text\"\n id=\"address\"\n required={true}\n inputState={errors['address']?.length ? 'error' : 'default'}\n message={errors['address']?.length ? errors['address']['0'] : null}\n />\n setZipCode(e.target.value)}\n placeholder={translate('general.placeholder.zipcode')}\n type=\"text\"\n id=\"zip\"\n required={true}\n inputState={errors['zipCode']?.length ? 'error' : 'default'}\n message={errors['zipCode']?.length ? errors['zipCode']['0'] : null}\n />\n setCity(e.target.value)}\n placeholder={translate('general.placeholder.city')}\n type=\"text\"\n id=\"city\"\n required={true}\n inputState={errors['city']?.length ? 'error' : 'default'}\n message={errors['city']?.length ? errors['city']['0'] : null}\n />\n \n ({\n value: country.value,\n label: country.text,\n }))}\n size=\"large\"\n placeholder={translate('general.placeholder.country')}\n onChange={({ value }) => setCountry(value)}\n selectedValue={country}\n />\n setPhoneNumber(e.target.value)}\n placeholder={translate('general.placeholder.phone')}\n type=\"tel\"\n id=\"tel\"\n required={true}\n inputState={errors['phoneNumber']?.length ? 'error' : 'default'}\n message={\n errors['phoneNumber']?.length ? errors['phoneNumber']['0'] : null\n }\n />\n
    \n \n {\n e.preventDefault();\n navigate(-1);\n }}\n >\n {translate('general.cancel')}\n \n
    \n \n
    \n );\n};\nexport default MyPagesAddAddress;\n","import React, { useEffect, useState } from 'react';\nimport { translate } from '../../Services/translation';\nimport { getAddress, edit as editAddress } from '../../Actions/Address.action';\nimport { useDispatch } from 'react-redux';\nimport { useParams, useNavigate } from 'react-router-dom';\nimport {\n StyledFormWrapper,\n StyledFormDropdown,\n} from './styles/MyPagesForm.styling';\nimport Address from '../../Types/Address';\nimport Input from '../Inputs/Input';\nimport Button from '../Button';\nimport AddressViewModel from '../../Types/AddressViewModel';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport EditorString from '../EditorString/EditorString';\n\nconst MyPagesEditAddress = ({ description }) => {\n const [isLoading, setIsLoading] = useState(true);\n const [address, setAddress] = useState();\n const { id } = useParams();\n const { errors = {} } = useTypedSelector((state) => state.myPage.addresses);\n const navigate = useNavigate();\n const dispatch = useDispatch();\n const countriesList = globalThis.LitiumConstants.countries;\n\n const fetchAddress = async () => {\n const address = await getAddress(id);\n setAddress(address);\n setIsLoading(!isLoading);\n };\n\n const setAddressValue = (key, value) => {\n const addressCopy = Object.assign({}, address);\n addressCopy[key] = value;\n setAddress(addressCopy);\n };\n\n const submitForm = (e) => {\n e.preventDefault();\n dispatch(editAddress(address))\n .then(() => navigate(-1))\n .catch(() => {}); // must catch error;\n };\n\n useEffect(() => {\n fetchAddress();\n }, []);\n\n return (\n \n

    {translate('mypage.address.editaddress')}

    \n {description?.value && (\n \n )}\n
    \n setAddressValue('address', e.target.value)}\n placeholder={translate('general.placeholder.address')}\n type=\"text\"\n id=\"address\"\n disabled={isLoading}\n required={true}\n inputState={errors['address']?.length ? 'error' : 'default'}\n message={errors['address']?.length ? errors['address']['0'] : null}\n />\n setAddressValue('zipCode', e.target.value)}\n placeholder={translate('general.placeholder.zipcode')}\n type=\"text\"\n id=\"zip\"\n disabled={isLoading}\n required={true}\n inputState={errors['zipCode']?.length ? 'error' : 'default'}\n message={errors['zipCode']?.length ? errors['zipCode']['0'] : null}\n />\n setAddressValue('city', e.target.value)}\n value={address?.city}\n placeholder={translate('general.placeholder.city')}\n type=\"text\"\n id=\"city\"\n disabled={isLoading}\n required={true}\n inputState={errors['city']?.length ? 'error' : 'default'}\n message={errors['city']?.length ? errors['city']['0'] : null}\n />\n \n ({\n value: country.value,\n label: country.text,\n }))}\n size=\"large\"\n placeholder={translate('general.placeholder.country')}\n onChange={({ value }) => setAddressValue('country', value)}\n disabled={isLoading}\n />\n setAddressValue('phoneNumber', e.target.value)}\n placeholder={translate('general.placeholder.phone')}\n type=\"tel\"\n id=\"tel\"\n disabled={isLoading}\n required={true}\n inputState={errors['address']?.length ? 'error' : 'default'}\n message={errors['address']?.length ? errors['address']['0'] : null}\n />\n
    \n \n {\n e.preventDefault();\n navigate(-1);\n }}\n >\n {translate('general.cancel')}\n \n
    \n \n
    \n );\n};\nexport default MyPagesEditAddress;\n","import { useEffect } from 'react';\nimport { useLocation } from 'react-router-dom';\n\nexport default function ScrollToTop() {\n const { pathname } = useLocation();\n\n useEffect(() => {\n window.scrollTo({ top: 0, behavior: 'smooth' });\n }, [pathname]);\n\n return null;\n}\n","import React, { useMemo } from 'react';\nimport { HashRouter, Navigate, Route, Routes } from 'react-router-dom';\nimport MyPagesMobileMenu from './MyPagesMobileMenu';\nimport MyPagesDesktopMenu from './MyPagesDesktopMenu';\nimport MyPagesSettings from './MyPagesSettings';\nimport MyPagesOrderHistory from './MyPagesOrderHistory';\nimport MyPagesOrderDetail from './MyPagesOrderDetail';\nimport MyPagesUsers from './MyPagesUsers';\nimport MyPagesAddUser from './MyPagesAddUser';\nimport MyPagesEditUser from './MyPagesEditUser';\nimport MyPagesAddresses from './MyPagesAddresses';\nimport MyPagesAddAddress from './MyPagesAddAddress';\nimport MyPagesEditAddress from './MyPagesEditAddress';\nimport { translate } from '../../Services/translation';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { cells, section } from '../../styling/utils/grid';\nimport ScrollToTop from './ui/ScrollToTop';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\n\nconst StyledMyPagesContainer = styled.section`\n ${section}\n padding-top: 1.6rem;\n padding-bottom: 2.4rem;\n color: ${getColor('grey', 900)};\n min-height: 72vh;\n\n ${breakpoint('large')} {\n display: grid;\n ${cells(4)}\n padding-top: 4rem;\n padding-bottom: 4.8rem;\n gap: 4.8rem;\n }\n`;\n\nconst navigation = [\n { name: translate('mypage.info.title'), url: '/', isB2bOnly: false },\n {\n name: translate('mypage.order.title'),\n url: '/orders',\n isB2bOnly: false,\n },\n {\n name: translate('mypage.person.title'),\n url: '/users',\n isB2bOnly: true,\n },\n {\n name: translate('mypage.address.addresses'),\n url: '/addresses',\n isB2bOnly: true,\n },\n];\n\nconst MyPagesContainer = ({\n addAddressDescription,\n addUserDescription,\n addressDescription,\n editAddressDescription,\n editUserDescription,\n orderDescription,\n settingsDescription,\n userDescription,\n}) => {\n const { current: userInfo } = useTypedSelector((state) => state.userInfo);\n const filteredNav = useMemo(\n () =>\n navigation.filter((option) =>\n !userInfo?.isBusinessCustomer ? !option.isB2bOnly : true\n ),\n [userInfo?.isBusinessCustomer]\n );\n\n return (\n \n \n \n \n \n \n }\n />\n }\n />\n } />\n\n {userInfo?.isBusinessCustomer && (\n <>\n }\n />\n }\n />\n }\n />\n }\n />\n \n }\n />\n \n }\n />\n \n )}\n \n \n \n );\n};\n\nexport default MyPagesContainer;\n","import React from 'react';\nimport Dropdown from './Dropdown';\nimport { createUseStyles } from 'react-jss';\n\nconst useStyles = createUseStyles((theme) => ({\n testKlass: {\n backgroundColor: theme.colors?.primary,\n },\n}));\n\nconst TestContainerForReact = (props) => {\n const classes = useStyles();\n return (\n
    \n
    \n \n
    \n
    \n );\n};\n\nexport default TestContainerForReact;\n","import { uniqueId } from 'lodash';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { addOverlay, removeOverlay } from '../../Actions/Overlay.action';\nimport clsx from 'clsx';\n\nconst MegaMenu = ({\n open,\n onMegaMenuClose,\n onMouseOverMegaMenu,\n onMouseLeaveMegaMenu,\n link,\n blocks,\n}) => {\n const dispatch = useDispatch();\n const blockContainerRef = useRef(null);\n const [id] = useState(uniqueId());\n const [blocksLoaded, setBlocksLoaded] = useState(false);\n const [hasRendered, setHasRendered] = useState(false);\n\n useEffect(() => {\n if(blocksLoaded){\n return;\n }\n setBlocksLoaded(blocks.length > 0);\n }, [blocks]);\n\n useEffect(() => {\n if (blocksLoaded && !hasRendered && blockContainerRef.current)\n {\n if(!blockContainerRef.current) return;\n blockContainerRef.current.innerHTML = '';\n for (let block of blocks) {\n blockContainerRef.current.appendChild(block);\n }\n setHasRendered(true);\n }\n }, [blocks]);\n\n useEffect(() => {\n if (open) {\n dispatch(addOverlay('MegaMenu-' + id, onMegaMenuClose));\n } else {\n dispatch(removeOverlay('MegaMenu-' + id));\n }\n }, [open]);\n\n return (\n \n
    0 ? 'pr-0' : null,\n )}>\n
    \n {link.links?.length > 0 &&\n link.links.map((subLink, idx) => (\n
    0 ? 'flex-1' : null,\n )}\n >\n \n
    {subLink.name ?? <> }
    \n
    \n {subLink.links?.length > 0 &&\n subLink.links.map((subSubLink) => (\n \n {subSubLink.name}\n \n ))}\n
    \n ))}\n
    \n {blocks.length > 0 && (\n
    \n )}\n
    \n \n );\n};\n\nexport default MegaMenu;\n","import React, { useCallback, useEffect, useState } from 'react';\nimport MegaMenu from '../MegaMenu/MegaMenu';\nimport clsx from 'clsx';\n\nconst NavigationLink = ({\n link,\n isActive,\n onLinkHover,\n onMouseLeaveLink,\n onMegaMenuClose,\n blocks,\n right = false,\n}) => {\n return (\n <>\n \n {link.name}\n \n {link.links?.length > 0 && (\n onLinkHover(link)}\n link={link}\n open={isActive}\n blocks={blocks}\n />\n )}\n \n );\n};\n\nexport default NavigationLink;\n","import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport NavigationLink from './NavigationLink';\n\nconst Navigation = () => {\n const { contentLinks, rightContentLinks } = useTypedSelector(\n (state) => state.navigation\n ); // TODO interface\n\n const [activeMegaMenuLink, setActiveMegaMenuLink] = useState();\n const [megaMenuTimer, setMegaMenuTimer] = useState();\n const [blockElements, setBlockElements] = useState([]);\n\n const onLinkHover = (link) => {\n clearTimeout(megaMenuTimer);\n setMegaMenuTimer(\n setTimeout(() => {\n setActiveMegaMenuLink(link);\n setMegaMenuTimer(null);\n }, 100)\n );\n };\n\n const onMouseLeaveLink = () => {\n clearTimeout(megaMenuTimer);\n setMegaMenuTimer(\n setTimeout(() => {\n setActiveMegaMenuLink(null);\n setMegaMenuTimer(null);\n }, 100)\n );\n };\n\n const getBlocks = useCallback(\n (blocks, link) => {\n return blocks?.filter(\n (b) =>\n link.blockSystemIds.indexOf(b.dataset['litiumBlockId']) != -1\n );\n },\n [blockElements]\n );\n\n const onMegaMenuClose = () => setActiveMegaMenuLink(null);\n\n useEffect(() => {\n const blockElementsContainer = document.getElementById(\n 'mega-menu-blocks'\n );\n const blockElements = blockElementsContainer\n ? Array.from(blockElementsContainer.children)\n : [];\n setBlockElements(blockElements);\n if (blockElementsContainer) blockElementsContainer.remove();\n }, []);\n\n return contentLinks?.length > 0 || rightContentLinks?.length > 0 ? (\n \n ) : null;\n};\n\nexport default Navigation;\n","import React, { createRef, useEffect, useMemo, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { addOverlay, removeOverlay } from '../../Actions/Overlay.action';\nimport { Swiper, SwiperSlide } from 'swiper/react';\nimport { Pagination, Thumbs, FreeMode, Zoom } from 'swiper';\nimport 'swiper/css/bundle';\nimport 'swiper/css/zoom';\nimport Icon from '../Icon';\nimport { translate } from '../../Services/translation';\nimport { text } from '../../styling/mixins/typography';\nimport SliderImage from '../../Types/SliderImage';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { showFor } from '../../styling/utils/visibility';\n\ninterface FullscreenImageSliderProps {\n showCloseButton?: boolean;\n images: SliderImage[];\n initialSlide?: number;\n onClosed?: () => void;\n}\n\ninterface ZoomInfoProps {\n $zoomInfoVisible: boolean;\n}\n\nconst StyledSwiper = styled(Swiper)`\n height: 100%;\n\n & .swiper-pagination {\n bottom: 3.2rem !important;\n }\n`;\n\nconst StyledImageSliderWrapper = styled.div`\n z-index: 55;\n position: fixed;\n inset: 0;\n width: 100%;\n height: 100vh;\n background-color: ${getColor('white')};\n\n .content {\n height: 100%;\n }\n\n img {\n height: 100%;\n }\n`;\n\nconst StyledCloseButton = styled(Icon)`\n position: absolute;\n top: 1.6rem;\n right: 1.6rem;\n cursor: pointer;\n z-index: 55;\n font-size: 2rem;\n`;\n\nconst StyledZoomInfo = styled.div`\n ${showFor('large')}\n ${text('small')}\n display: flex;\n align-items: center;\n position: absolute;\n top: 1.6rem;\n left: 1.6rem;\n background-color: rgba(0, 0, 0, 0.5);\n color: ${getColor('white')};\n border-radius: 1.6rem;\n padding: 0.4rem 0.8rem;\n z-index: 60;\n pointer-events: ${(p) => (p.$zoomInfoVisible ? '1' : 'none')};\n opacity: ${(p) => (p.$zoomInfoVisible ? '1' : '0')};\n transition: opacity 0.125s ease-in-out;\n\n & svg {\n margin-right: 0.4rem;\n }\n`;\n\nconst GlobalImageSliderStyling = createGlobalStyle`\nbody #overlay-container .overlay--FullscreenImageSlider {\n z-index: 50;\n}\n`;\n\nconst FullscreenImageSlider = ({\n showCloseButton = true,\n images,\n initialSlide = 0,\n onClosed,\n}: FullscreenImageSliderProps) => {\n const dispatch = useDispatch();\n const contentRef = createRef();\n\n const [open, setOpen] = useState(true);\n const [isZoomed, setIsZoomed] = useState(false);\n const [zoomInfoVisible, setZoomInfoVisible] = useState(true);\n const [hasLoadedOriginalImage, setHasLoadedOriginalImage] = useState<\n number[]\n >([]);\n const imageCount = useMemo(() => images.length, [images]);\n\n const onKeyDown = (e) => {\n if (e.key == 'Escape') {\n setOpen(false);\n }\n };\n\n useEffect(() => {\n dispatch(\n addOverlay('FullscreenImageSlider', () => {\n setOpen(false);\n })\n );\n document.addEventListener('keydown', onKeyDown, false);\n\n return () => {\n document.removeEventListener('keydown', onKeyDown, false);\n };\n }, [dispatch]);\n\n useEffect(() => {\n if (!open) {\n dispatch(removeOverlay('FullscreenImageSlider'));\n onClosed && onClosed();\n }\n }, [dispatch, open, onClosed]);\n\n useEffect(() => {\n setTimeout(() => setZoomInfoVisible(false), 5000);\n }, []);\n\n const onZoom = (slideIndex: number, scale: number) => {\n setIsZoomed(scale > 1);\n if (!hasLoadedOriginalImage.includes(slideIndex)) {\n setHasLoadedOriginalImage((hasLoadedOriginalImage) => [\n ...hasLoadedOriginalImage,\n slideIndex,\n ]);\n }\n };\n\n return open ? (\n \n setZoomInfoVisible(false)}\n $zoomInfoVisible={zoomInfoVisible}\n >\n \n {translate('fullscreen-image-slider.double-click-to-zoom')}\n \n
    \n {showCloseButton && (\n setOpen(false)} />\n )}\n\n onZoom(swiper.realIndex, scale)}\n pagination={{\n dynamicBullets: imageCount > 8 ? true : false,\n dynamicMainBullets: 3,\n }}\n >\n {images.map((img, idx) => (\n \n \n \n ))}\n \n {/* {showThumbnails && (\n \n )} */}\n
    \n \n
    \n ) : null;\n};\n\nexport default FullscreenImageSlider;\n","import styled, { css } from 'styled-components';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { showFor } from '../../../styling/utils/visibility';\n\nconst MainSwiperMixin = css`\n width: 100%;\n height: auto;\n max-height: 640px;\n aspect-ratio: 1/1;\n position: unset;\n & div.swiper-pagination {\n bottom: -3.2rem;\n ${breakpoint('medium')} {\n display: none;\n }\n }\n`;\n\nexport const StyledSwiper = styled.div`\n position: relative;\n\n .mainSwiper {\n ${MainSwiperMixin}\n }\n .mainSwiper-Placeholder {\n ${MainSwiperMixin}\n }\n .image {\n width: 100%;\n height: 100%;\n aspect-ratio: 1/1;\n object-fit: contain;\n }\n\n .thumbnail-swiper {\n display: none;\n margin: 0.8rem 0 0 0;\n max-width: 328px;\n max-height: 328px;\n ${breakpoint('medium')} {\n display: block;\n max-width: 348px;\n }\n ${breakpoint('large')} {\n max-width: 468px;\n }\n ${breakpoint('xlarge')} {\n max-width: 660px;\n }\n ${breakpoint('xxlarge')} {\n max-width: 768px;\n }\n }\n .thumbnail-slide {\n aspect-ratio: 1/1;\n box-sizing: border-box;\n object-fit: contain;\n ${breakpoint('medium')} {\n max-width: 36.5px;\n max-height: 36.5px;\n }\n ${breakpoint('large')} {\n max-width: 51.5px;\n max-height: 51.5px;\n }\n ${breakpoint('xlarge')} {\n max-width: 75.5px;\n max-height: 75.5px;\n }\n ${breakpoint('xxlarge')} {\n max-width: 89px;\n max-height: 89px;\n }\n }\n .thumbnail-image {\n width: 100%;\n height: 100%;\n aspect-ratio: 1/1;\n object-fit: cover;\n cursor: pointer;\n }\n\n & .swiper-pagination-bullet {\n &-active {\n background-color: ${getColor('primary')};\n }\n }\n\n & .swiper-button-prev,\n .swiper-button-next {\n ${showFor('medium')}\n color: ${getColor('black')};\n\n &::after {\n font-size: 1.2rem;\n font-weight: bold;\n }\n }\n`;\n","import styled from 'styled-components';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport { flexColumn } from '../../../styling/utils/flex';\nimport StockStatus from '../../StockStatus/StockStatus';\n\nexport const StyledProductCard = styled.div`\n position: relative;\n display: flex;\n ${flexColumn}\n background-color: ${getColor('grey', 100)};\n height: 100%;\n max-width: 100%;\n min-width: 0;\n`;\n\nexport const ProductCardBuyButtonWrapper = styled.div`\n margin: 0.8rem 0;\n\n`;\n\nexport const StyledProductCardImgWrapper = styled.a`\n display: flex;\n background-color: ${getColor('white')};\n border-top-left-radius: 4px;\n border-top-right-radius: 4px;\n aspect-ratio: 1/1;\n position: relative;\n overflow: hidden;\n\n img {\n aspect-ratio: 1/1;\n object-fit: contain;\n padding: 0.8rem;\n height: 100%;\n width: 100%;\n }\n\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0, 0, 0, 0.04);\n pointer-events: none;\n z-index: 3;\n }\n`;\n\nexport const StyledStockStatus = styled(StockStatus)`\n margin-bottom: 0.8rem;\n`;\n\nexport const StyledBrandLogo = styled.img`\n height: 20px;\n width: auto;\n position: absolute;\n left: 0.8rem;\n top: 0.8rem;\n z-index: 2;\n`;\n\nexport const StyledProductCardContent = styled.div`\n ${flexColumn}\n display: flex;\n padding: 1.6rem;\n flex: 1;\n\n ${breakpoint('large')} {\n padding: 1.6rem;\n }\n\n .information {\n flex: 1;\n margin-bottom: 1.2rem;\n }\n\n .overline {\n ${text('medium')}\n color: ${getColor('grey', 500)};\n margin-bottom: 0.2rem;\n }\n\n .name {\n ${text('large')}\n font-weight: bold;\n line-height: 1.2;\n display: block;\n margin-bottom: 0.8rem;\n }\n\n .description {\n ${text('medium')}\n }\n\n .price {\n font-weight: bold;\n margin-bottom: 0.8rem;\n }\n\n .campaign-price {\n color: ${getColor('red')};\n }\n\n .original-price {\n ${text('small')}\n text-decoration: line-through;\n font-weight: 400;\n margin-left: 0.8rem;\n color: ${getColor('grey', 500)};\n }\n\n .bottom {\n ${flexColumn}\n display: flex;\n }\n`;\n\nexport const StyledProductTagWrapper = styled.div`\n position: absolute;\n top: 0.8rem;\n right: 0.8rem;\n display: flex;\n flex-wrap: wrap;\n gap: 0.8rem;\n z-index: 3;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { tagStyle, tagSize } from '../../styling/mixins/productTag';\n\ninterface TagProps {\n tagSize?: string;\n}\n\ninterface StyledTagProps {\n $tagSize: string;\n $tagId: string;\n}\n\nconst StyledProductTag = styled.div`\n ${(p) => tagStyle(p.theme)}\n ${(p) => tagSize(p.theme, p.$tagSize)}\n`;\n\nconst ProductTag: React.FC<\n TagProps & React.HTMLAttributes & ProductTagModel\n> = ({ tagSize = 'small', id, ...props }) => {\n return ;\n};\n\nexport default ProductTag;\n","import { DefaultTheme } from 'styled-components';\n\nexport const tagStyle = (theme: DefaultTheme) => ({\n fontWeight: theme.productTags.fontWeight,\n borderStyle: 'solid',\n borderWidth: theme.productTags.borderWidth,\n borderRadius: theme.productTags.borderRadius,\n color: theme.productTags.textColor,\n borderColor: theme.productTags.borderColor,\n backgroundColor: theme.productTags.backgroundColor,\n});\n\nexport const tagSize = (theme: DefaultTheme, size: string) => ({\n padding: theme.productTags.paddings[size],\n fontSize: theme.productTags.fontSizes[size],\n});\n","import React, { useEffect, useState } from 'react';\nimport { Swiper, SwiperSlide } from 'swiper/react';\nimport {\n Pagination,\n Thumbs,\n FreeMode,\n Swiper as SwiperClass,\n Navigation,\n} from 'swiper';\nimport 'swiper/css/bundle';\nimport FullscreenImageSlider from '../FullscreenImageSlider/FullscreenImageSlider';\nimport { useMemo } from 'react';\nimport SliderImage from '../../Types/SliderImage';\nimport { StyledSwiper } from './Styles/ProductPage.ImageSliderStyling';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { StyledProductTagWrapper } from '../ProductCards/styles/ProductCard.styling';\nimport ProductTag from '../ProductTags/ProductTag';\nimport { ProductTagModel } from '../../Types/ProductTagModel';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\n\ninterface ProductPageImageSliderProps {\n images: SliderImage[];\n tags: ProductTagModel[];\n}\n\nconst THUMBNAILS_PER_VIEW = 8;\n\nconst StyledImageBackground = styled.div`\n position: relative;\n background: ${getColor('white')};\n\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0, 0, 0, 0.04);\n pointer-events: none;\n z-index: 2;\n }\n`;\n\nconst ProductPageImageSlider = ({\n images,\n tags,\n}: ProductPageImageSliderProps) => {\n const [thumbsSwiper, setThumbsSwiper] = useState();\n const [fullscreenOpen, setFullscreenOpen] = useState(false);\n const [activeSlideIndex, setActiveSlideIndex] = useState(0);\n const [rendered, setRendered] = useState(false);\n const { selectedVariant } = useTypedSelector((state) => state.productPage);\n\n images = selectedVariant?.sliderImages ?? images;\n\n const imageCount = useMemo(() => images.length, [images]);\n useEffect(() => setRendered(true), []);\n\n return (\n \n {!rendered && images?.length > 0 && (\n
    \n \n
    \n )}\n {rendered && (\n <>\n \n {tags?.length ? (\n \n {tags.map((tag) => (\n \n {tag.name}\n \n ))}\n \n ) : null}\n 8 ? true : false,\n dynamicMainBullets: 3,\n }}\n thumbs={{ swiper: thumbsSwiper }}\n modules={[FreeMode, Pagination, Thumbs, Navigation]}\n lazy={true}\n loop={images.length > 1}\n slidesPerView={1}\n className=\"mainSwiper\"\n onSlideChange={(swiper) => setActiveSlideIndex(swiper.realIndex)}\n navigation={true}\n >\n {images.map((image, index) => (\n setFullscreenOpen(true)}\n >\n {image.alt}\n \n ))}\n \n \n {images?.length > 1 && (\n THUMBNAILS_PER_VIEW\n ? THUMBNAILS_PER_VIEW\n : imageCount\n }\n slidesPerGroup={\n imageCount > THUMBNAILS_PER_VIEW\n ? THUMBNAILS_PER_VIEW\n : imageCount\n }\n modules={[FreeMode, Thumbs]}\n className=\"thumbnail-swiper\"\n >\n {images.map((image, index) => (\n \n \n \n \n \n ))}\n \n )}\n \n )}\n {fullscreenOpen && (\n setFullscreenOpen(false)}\n initialSlide={activeSlideIndex}\n />\n )}\n
    \n );\n};\n\nexport default ProductPageImageSlider;\n","import styled from 'styled-components';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { displayHeader } from '../../../styling/mixins/typography';\n\nconst StyledBannerItem = styled.div`\n color: ${getColor('white')};\n overflow: hidden;\n transition: 0.3s;\n\n .banner-item__image {\n grid-column-start: 1;\n grid-row-start: 1;\n width: 100%;\n aspect-ratio: 2/1;\n object-fit: cover;\n max-height: 720px;\n display: none;\n ${breakpoint('small', 'up')} {\n display: initial;\n }\n &-mobile {\n display: unset;\n grid-column-start: 1;\n grid-row-start: 1;\n width: 100%;\n aspect-ratio: 2/1;\n object-fit: cover;\n max-height: 320px;\n ${breakpoint('small', 'up')} {\n display: none;\n }\n }\n }\n\n .banner-item__title {\n margin-bottom: 2.4rem;\n ${breakpoint('medium')} {\n ${displayHeader('small')}\n }\n }\n .banner-item__content {\n width: 100%;\n height: 100%;\n grid-column-start: 1;\n grid-row-start: 1;\n z-index: 3;\n display: flex;\n justify-content: center;\n flex-direction: column;\n max-width: 728px;\n padding: 0 1.6rem 0 1.6rem;\n box-sizing: border-box;\n ${breakpoint('large')} {\n padding: 0 6.4rem 0 6.4rem;\n }\n }\n\n .banner-item__arrow {\n display: none;\n }\n\n .banner-item__body-text {\n margin-bottom: 1.6rem;\n }\n .banner-item__overlay {\n grid-column-start: 1;\n grid-row-start: 1;\n width: 100%;\n height: 100%;\n z-index: 2;\n background: linear-gradient(\n 180deg,\n rgba(0, 0, 0, 0) 30.73%,\n rgba(0, 0, 0, 0.9) 100%\n );\n pointer-events: none;\n }\n .banner-slider-item__overlay {\n grid-column-start: 1;\n grid-row-start: 1;\n width: 100%;\n height: 100%;\n z-index: 2;\n background: linear-gradient(\n 90deg,\n rgba(0, 0, 0, 0.75) 0%,\n rgba(0, 0, 0, 0) 50%\n );\n pointer-events: none;\n }\n`;\n\nexport default StyledBannerItem;\n","// Component from Motillo Storybook. Some styling differences on \nimport clsx from 'clsx';\nimport React, { useRef, useEffect, FC, ReactNode } from 'react';\nimport Icon from '../Icon';\ninterface DialogProps {\n isOpen: boolean;\n onClose?: () => void;\n children: ReactNode;\n headerContent?: ReactNode;\n hideHeader?: boolean;\n closeButtonAriaLabel: string;\n disableCloseOnOutsideClick?: boolean;\n}\ninterface DialogHeaderProps {\n onClose?: () => void;\n headerContent?: ReactNode;\n closeButtonAriaLabel: string;\n}\ninterface DialogContentProps {\n children: ReactNode;\n removePaddingTop?: boolean;\n}\nconst Dialog = ({\n isOpen,\n onClose,\n children,\n headerContent,\n hideHeader,\n closeButtonAriaLabel,\n disableCloseOnOutsideClick,\n}: DialogProps) => {\n const dialogRef = useRef(null);\n const contentRef = useRef(null);\n useEffect(() => {\n const dialog = dialogRef.current;\n if (dialog === null) return;\n const focusableElements = dialog.querySelectorAll(\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n );\n const firstFocusableElement = focusableElements[0] as HTMLElement;\n const lastFocusableElement = focusableElements[\n focusableElements.length - 1\n ] as HTMLElement;\n if (isOpen) {\n dialog.showModal();\n document.body.classList.add('overflow-hidden');\n } else {\n dialog.close();\n document.body.classList.remove('overflow-hidden');\n }\n const lockFocusToModal = (event: KeyboardEvent) => {\n if (firstFocusableElement === null || lastFocusableElement === null)\n return;\n if (event.key === 'Tab') {\n if (event.shiftKey) {\n if (document.activeElement === firstFocusableElement) {\n lastFocusableElement.focus();\n event.preventDefault();\n }\n } else {\n if (document.activeElement === lastFocusableElement) {\n firstFocusableElement.focus();\n event.preventDefault();\n }\n }\n }\n };\n const handleEscKeyPress = (event: KeyboardEvent) => {\n if (event.key === 'Escape') {\n if (disableCloseOnOutsideClick) {\n event.preventDefault();\n return;\n }\n onClose?.();\n }\n };\n const handleOutsideClick = (event: MouseEvent) => {\n if (disableCloseOnOutsideClick) return;\n if (\n contentRef.current &&\n !contentRef.current.contains(event.target as Node)\n ) {\n onClose?.();\n }\n };\n dialog.addEventListener('click', handleOutsideClick);\n dialog.addEventListener('keydown', lockFocusToModal);\n dialog.addEventListener('keydown', handleEscKeyPress);\n return () => {\n dialog.removeEventListener('click', handleOutsideClick);\n dialog.removeEventListener('keydown', lockFocusToModal);\n dialog.removeEventListener('keydown', handleEscKeyPress);\n };\n }, [disableCloseOnOutsideClick, isOpen, onClose]);\n \n return (\n \n
    \n {!hideHeader && (\n \n )}\n \n {children}\n \n
    \n
    \n );\n};\nconst DialogContent: FC = ({\n children,\n removePaddingTop,\n}) => {\n return (\n
    \n {children}\n
    \n );\n};\nDialogContent.displayName = 'DialogContent';\nconst DialogHeader: FC = ({\n headerContent,\n onClose,\n closeButtonAriaLabel,\n}) => {\n return (\n \n {headerContent}\n \n \n \n \n );\n};\nDialogHeader.displayName = 'DialogHeader';\nexport default Dialog;","import React from 'react';\nimport Icon from '../../Icon';\nimport { translate } from '../../../Services/translation';\n\ninterface NavigatorCTAItemProps {\n item: NavigatorCTAItem;\n}\n\nexport interface NavigatorCTAItem {\n title: string;\n description: string;\n imageUrl: string;\n linkUrl: string;\n}\n\nconst NavigatorCTADialogItem = ({ item }: NavigatorCTAItemProps) => {\n return (\n
    \n
    \n );\n};\n\nexport default NavigatorCTADialogItem;\n","import React, { useEffect, useState } from 'react';\nimport Dialog from '../../Dialog/Dialog';\nimport NavigatorCTADialogItem, {\n NavigatorCTAItem,\n} from './NavigatorCTADialogItem';\nimport { get } from '../../../Services/http';\nimport LoadingSpinner from '../../LoadingSpinner';\nimport { translate } from '../../../Services/translation';\n\ninterface NavigatorCTADialogProps {\n modalHeader?: string;\n isOpen: boolean;\n onClose: () => void;\n}\n\nconst NavigatorCTADialog = ({\n modalHeader,\n isOpen,\n onClose,\n}: NavigatorCTADialogProps) => {\n const [items, setItems] = useState([]);\n const [isLoading, setIsLoading] = useState(true);\n const [hasError, setHasError] = useState(false);\n const rootRoute = '/api/navigatorctamodal';\n\n const fetchItems = async () => {\n try {\n setHasError(false);\n setIsLoading(true);\n const res = await get(`${rootRoute}`);\n const items = await res.json();\n\n setItems(items);\n setIsLoading(false);\n } catch (ex) {\n setIsLoading(false);\n setHasError(true);\n console.log(ex);\n }\n };\n\n useEffect(() => {\n if (isOpen) {\n fetchItems();\n }\n }, [isOpen]);\n\n return (\n \n
    \n
    \n

    {modalHeader}

    \n
    \n {isLoading && (\n
    \n \n
    \n )}\n {hasError && !isLoading && (\n
    \n {translate('general.navigator.error')}\n
    \n )}\n
    \n {!isLoading && !hasError &&\n items.map((item, idx) => (\n \n ))}\n
    \n
    \n \n );\n};\n\nexport default NavigatorCTADialog;\n","import React, { useState } from 'react';\nimport Button from '../Button';\nimport NavigatorCTADialog from './NavigatorCTADialog/NavigatorCTADialog';\nimport { NavigatorCTAHeaderButtonProps } from './NavigatorCTAHeaderButtonProps';\nimport clsx from 'clsx';\n\nconst NavigatorCTAHeaderButton = ({\n className,\n btnSizeLarge,\n buttonText,\n headerText,\n isDesktop,\n}: NavigatorCTAHeaderButtonProps) => {\n const [isDialogOpen, setIsDialogOpen] = useState(false);\n\n const handleButtonClick = () => {\n setIsDialogOpen(true);\n };\n\n const handleCloseDialog = () => {\n setIsDialogOpen(false);\n };\n\n return (\n
    \n \n {buttonText}\n \n \n
    \n );\n};\n\nexport default NavigatorCTAHeaderButton;\n","import React from 'react';\nimport Button from '../../Components/Button';\nimport Icon from '../../Components/Icon';\nimport { LinkModel } from '../../Types/LinkModel';\nimport StyledBannerItem from './Styles/Banner-item.styling';\nimport NavigatorCTAHeaderButton from '../../Components/NavigatorCTA/NavigatorCTAHeaderButton';\nimport clsx from 'clsx';\n\nexport interface BannerItemProps {\n imageUrl: string;\n mobileImageUrl?: string;\n linkText?: string;\n actionText?: string;\n overlay: boolean;\n triggerCTAModal: boolean;\n link?: LinkModel;\n bodyText?: string;\n lazyLoadImage?: boolean;\n className?: string;\n modalHeader?: string;\n}\n\nconst BannerItem = ({\n imageUrl,\n mobileImageUrl,\n linkText,\n actionText,\n overlay,\n link,\n bodyText,\n triggerCTAModal,\n lazyLoadImage = false,\n className,\n modalHeader,\n}: BannerItemProps) => {\n const hasLinkButton = link && actionText;\n\n return (\n \n \n \n
    \n {linkText &&

    {linkText}

    }\n {bodyText &&

    {bodyText}

    }\n {triggerCTAModal && actionText && (\n \n )}\n {hasLinkButton && !triggerCTAModal && (\n \n \n \n )}\n \n
    \n {overlay &&
    }\n \n );\n};\n\nexport default BannerItem;\n","import styled from 'styled-components';\nimport { Swiper } from 'swiper/react';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\n\nimport swiperCss from '!!raw-loader!node_modules/swiper/swiper.min.css';\nimport swiperPagination from '!!raw-loader!node_modules/swiper/modules/pagination/pagination.min.css';\nimport swiperNavigation from '!!raw-loader!node_modules/swiper/modules/navigation/navigation.min.css';\nimport { section } from '../../../styling/utils/grid';\n\ninterface BannerSliderStylingProps {\n $fullwidth: boolean;\n}\nexport const StyledBannerSliderSection = styled.div`\n ${section}\n max-width: ${(props) => (props.$fullwidth ? 'none !important' : '1608px')};\n padding-left: 0 !important;\n padding-right: 0 !important;\n\n .banner-item__overlay {\n background: linear-gradient(\n 90deg,\n rgba(0, 0, 0, 0.75) 0%,\n rgba(0, 0, 0, 0) 50%\n );\n }\n`;\n\nexport const StyledSwiper = styled(Swiper)`\n ${swiperCss}\n ${swiperPagination}\n ${swiperNavigation}\n & .swiper-button-prev {\n display: none;\n ${breakpoint('large')} {\n display: flex;\n }\n &::after {\n font-size: 2rem;\n font-weight: 600;\n color: ${getColor('white')};\n }\n }\n & .swiper-button-next {\n display: none;\n ${breakpoint('large')} {\n display: flex;\n }\n &::after {\n font-size: 2rem;\n font-weight: 600;\n color: ${getColor('white')};\n }\n }\n & .swiper-pagination-bullet {\n background-color: ${getColor('white')};\n\n &-active {\n background-color: ${getColor('primary')};\n }\n }\n`;\n","import styled from 'styled-components';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { header } from '../../../styling/mixins/typography';\nimport { cells } from '../../../styling/utils/grid';\n\ninterface BannerSectionStylingProps {\n $fullwidth: boolean;\n}\nexport const StyledBannerSection = styled.div`\n padding-left: ${(props) => (props.$fullwidth ? '0 !important' : null)};\n padding-right: ${(props) => (props.$fullwidth ? '0 !important' : null)};\n max-width: ${(props) => (props.$fullwidth ? 'none !important' : null)};\n\n .banner-item__content {\n padding: 1.6rem;\n justify-content: flex-end;\n position: relative;\n ${breakpoint('medium')} {\n padding: 2.4rem;\n }\n\n .banner-item__arrow {\n display: block;\n font-size: 2.4rem;\n color: ${getColor('primary')};\n position: absolute;\n right: 1.6rem;\n bottom: 1.6rem;\n ${breakpoint('medium')} {\n right: 2.4rem;\n bottom: 2.4rem;\n }\n }\n }\n\n .banner-item__title {\n ${header('h5')}\n }\n\n .banner__one-cell {\n ${cells(1)}\n }\n .banner__two-cells {\n ${cells(1)}\n ${breakpoint('small')} {\n ${cells(2)}\n }\n ${breakpoint('medium')} {\n ${cells(2)}\n }\n }\n .banner__three-cells {\n ${breakpoint('xsmall')} {\n ${cells(1)}\n }\n ${breakpoint('small')} {\n ${cells(2)}\n }\n ${breakpoint('medium')} {\n ${cells(3)}\n }\n }\n .banner__four-cells {\n ${breakpoint('medium')} {\n ${cells(2)}\n }\n ${breakpoint('large')} {\n ${cells(4)}\n }\n }\n .banner__five-cells {\n ${cells(6)}\n\n ${breakpoint('large')} {\n ${cells(5)}\n }\n }\n .banner__six-cells {\n ${breakpoint('small')} {\n ${cells(2)}\n }\n ${breakpoint('medium')} {\n ${cells(3)}\n }\n ${breakpoint('large')} {\n ${cells(6)}\n }\n }\n`;\n","import React, { useMemo } from 'react';\nimport BannerItem, { BannerItemProps } from './_banner-item';\nimport { StyledBannerSection } from './Styles/Banner-block.styling';\n\nexport interface BannerBlockProps {\n banners: BannerItemProps[];\n numPerRow: number;\n systemId: string;\n fullwidth: boolean;\n}\n\nconst BannerBlock = ({\n systemId,\n banners,\n numPerRow,\n fullwidth,\n}: BannerBlockProps) => {\n const cellsClass = useMemo(() => {\n switch (numPerRow) {\n case 1:\n default:\n return 'banner__one-cell';\n case 2:\n return 'banner__two-cells';\n case 3:\n return 'banner__three-cells';\n case 4:\n return 'banner__four-cells';\n case 5:\n return 'banner__five-cells';\n case 6:\n return 'banner__six-cells';\n }\n }, [numPerRow]);\n\n return banners?.length > 0 ? (\n \n
    \n {banners.map((banner, idx) => (\n \n ))}\n
    \n \n ) : null;\n};\n\nexport default BannerBlock;\n","import React, { useState, useEffect } from 'react';\nimport { SwiperSlide } from 'swiper/react';\nimport { Pagination, Navigation } from 'swiper';\nimport BannerItem, { BannerItemProps } from './_banner-item';\nimport {\n StyledBannerSliderSection,\n StyledSwiper,\n} from './Styles/Banner-Slider.styling';\nimport BannerBlock from './BannerBlock';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { displayHeader, header } from '../../styling/mixins/typography';\nimport { section } from '../../styling/utils/grid';\n\ninterface BannerBlockProps {\n slides: BannerItemProps[];\n numPerRow: number;\n systemId: string;\n fullwidth: boolean;\n}\n\nconst StyledSwiperPlaceholder = styled.div`\n .banner__section {\n ${section}\n max-width: 1608px;\n padding-left: 0 !important;\n padding-right: 0 !important;\n }\n\n .banner-item__title {\n ${header('h1')}\n margin-bottom: 2.4rem;\n ${breakpoint('medium')} {\n ${displayHeader('small')}\n }\n }\n\n .banner-item__content {\n justify-content: center;\n padding: 0 1.6rem 0 1.6rem;\n ${breakpoint('large')} {\n padding: 0 6.4rem 0 6.4rem;\n }\n\n .banner-item__arrow {\n display: none;\n }\n }\n\n .banner-item__overlay {\n background: linear-gradient(\n 90deg,\n rgba(0, 0, 0, 0.75) 0%,\n rgba(0, 0, 0, 0) 50%\n );\n }\n`;\n\nconst BannerSliderBlock = ({\n systemId,\n slides,\n numPerRow,\n fullwidth,\n}: BannerBlockProps) => {\n const [ready, setReady] = useState(false);\n\n useEffect(() => setReady(true), []);\n\n if (!slides || slides.length == 0) {\n return null;\n }\n\n return !ready ? (\n \n \n \n ) : (\n \n {ready && (\n \n {slides.map((slide: BannerItemProps, index: number) => (\n \n \n \n ))}\n \n )}\n \n );\n};\n\nexport default BannerSliderBlock;\n","import React from 'react';\nimport BuyButton from '../BuyButton/BuyButton';\nimport ProductCardProps from './types/ProductCardProps';\n\nconst ProductCardBuyButton = ({\n product,\n isVariantListing,\n}: ProductCardProps) => {\n return (\n \n );\n};\n\nexport default ProductCardBuyButton;\n","import React, { useEffect, useMemo } from 'react';\nimport { create } from 'zustand';\nimport { round } from 'lodash-es';\n\ninterface LipscoreState {\n ratings: { [id: string]: LipscoreRating };\n addRating: (id: string, rating: any) => void;\n}\n\ninterface LipscoreRating {\n lipscore: string;\n}\n\nconst useLipscoreState = create((set) => ({\n ratings: {},\n addRating: (id: string, rating: LipscoreRating) =>\n set((state) => ({ ratings: { ...state.ratings, [id]: rating } })),\n}));\n\nconst fetchRating = (id: string) => {\n if (!globalThis.lipscoreApiKey) {\n return new Promise((_, reject) => reject('No Lipscore API key found'));\n }\n const url = `https://wapi.lipscore.com/initial_data/products/show?api_key=${globalThis.lipscoreApiKey}&internal_id=${id}&widgets=r,r_sm,rw_l&translate_to_lang=${globalThis.lipscoreLocale}`;\n return fetch(url).then((res) => res.json());\n};\n\nconst Star = ({ starState }) => (\n \n \n \n \n \n \n \n \n);\n\nconst ProductCardLipscoreStars = ({ productId }: { productId: string }) => {\n const { ratings, addRating } = useLipscoreState();\n const rating = useMemo(() => {\n const ratingValue = ratings[productId]?.lipscore;\n return typeof ratingValue !== 'undefined'\n ? round(parseFloat(ratingValue) / 2, 1)\n : undefined;\n }, [ratings, productId]);\n\n useEffect(() => {\n if (!ratings[productId]) {\n fetchRating(productId)\n .then((rating) => addRating(productId, rating))\n .catch((err) => console.log(err));\n }\n }, []);\n\n const getStarState = (index: number) => {\n if (typeof rating === 'undefined') return undefined;\n\n const diff = rating - index;\n if (diff > 0 && diff < 1) {\n return 'incomplete';\n } else if (diff <= 0) {\n return 'inactive';\n }\n return undefined;\n };\n\n return rating ? (\n <>\n {Array.from({ length: 5 }).map((_, idx) => (\n \n ))}\n \n ) : null;\n};\n\nexport default ProductCardLipscoreStars;\n","import React from 'react';\nimport ProductCardProps from './types/ProductCardProps';\nimport ResponsiveImage from '../ResponsiveImage/ResponsiveImage';\nimport ProductTag from '../ProductTags/ProductTag';\nimport ProductCardBuyButton from './ProductCardBuyButton';\nimport EditorString from '../EditorString/EditorString';\nimport ProductCardLipscoreStars from '../Lipscore/ProductCard.LipscoreStars';\nimport { translate } from '../../Services/translation';\nimport StockStatus from '../StockStatus/StockStatus';\n\nconst ProductCard = ({\n product,\n isVariantListing,\n lazyLoadImage,\n}: ProductCardProps) => {\n\n const buildUrl = (url) => { \n return isVariantListing ? (url + \"?v=\" + product.id) : url;\n }\n\n return (\n
    \n \n \n {product.images && product.images.length > 0 && (\n \n )}\n {product.tags?.length ? (\n
    \n {product.tags.map((tag) => (\n \n {tag.name}\n \n ))}\n
    \n ) : null}\n
    \n
    \n
    \n \n {product.name}\n \n {product.showRating && product.baseProductId && (\n \n )}\n {product.descriptionShort && (\n \n )}\n
    \n
    \n {isVariantListing && }\n {!isVariantListing && product.fromPrice.useFromPrice ? (\n

    \n {translate('product.fr')} {product.fromPrice.formattedPrice}\n

    \n ) : product.price.formattedCampaignPrice ? (\n

    \n {product.price.formattedCampaignPrice}{' '}\n \n {product.price.formattedPrice}\n \n

    \n ) : (\n product.price.formattedPrice && (\n

    {product.price.formattedPrice}

    \n )\n )}\n
    \n
    \n \n
    \n
    \n
    \n );\n};\n\nexport default ProductCard;\n","import React, { useMemo } from 'react';\nimport styled from 'styled-components';\nimport ProductCard from '../Components/ProductCards/ProductCard';\nimport { breakpoint } from '../styling/mixins/breakpoints';\nimport { cells } from '../styling/utils/grid';\nimport Product from '../Types/Product';\n\nexport interface ProductNoSliderProps {\n products: Product[];\n numPerRow: number;\n}\n\nconst StyledNoSliderProductBlock = styled.div`\n display: grid;\n\n .product-block-wrapper {\n display: grid;\n gap: 2.4rem;\n }\n .cells-1 {\n ${cells(1)};\n }\n\n .cells-2 {\n ${cells(1)}\n ${breakpoint('medium')} {\n ${cells(2)}\n }\n }\n .cells-3 {\n ${cells(1)}\n ${breakpoint('small')} {\n ${cells(2)}\n }\n ${breakpoint('medium')} {\n ${cells(3)}\n }\n }\n .cells-4 {\n ${cells(2)}\n ${breakpoint('large')} {\n ${cells(4)}\n }\n }\n .cells-5 {\n ${cells(6)}\n ${breakpoint('large')} {\n ${cells(5)}\n }\n }\n .cells-6 {\n ${cells(2)}\n ${breakpoint('medium')} {\n ${cells(3)}\n }\n ${breakpoint('large')} {\n ${cells(6)}\n }\n }\n`;\n\nconst ProductBlockNoSlider = (props: ProductNoSliderProps) => {\n const { products, numPerRow } = props;\n\n let cells = useMemo(() => {\n switch (numPerRow) {\n case 1:\n return 'cells-1';\n case 2:\n return 'cells-2';\n case 3:\n return 'cells-3';\n case 4:\n return 'cells-4';\n case 5:\n return 'cells-5';\n case 6:\n return 'cells-6';\n }\n }, [numPerRow]);\n\n return (\n \n
    \n {products.map((product, idx) => (\n \n ))}\n
    \n
    \n );\n};\n\nexport default ProductBlockNoSlider;\n","import { Swiper, SwiperSlide } from 'swiper/react';\nimport React, { useEffect, useState } from 'react';\nimport ProductCard from '../Components/ProductCards/ProductCard';\nimport swiperCss from '!!raw-loader!../../../node_modules/swiper/swiper.min.css';\nimport swiperPagination from '!!raw-loader!../../../node_modules/swiper/modules/pagination/pagination.min.css';\nimport { Pagination } from 'swiper';\nimport Product from '../Types/Product';\nimport ProductBlockNoSlider from './ProductBlockNoSlider';\nimport styled from 'styled-components';\nimport { getColor } from '../styling/mixins/colors';\n\ninterface ProductSliderProps {\n products: Product[];\n}\n\nconst StyledNoSwiperWrapper = styled.div`\n padding-bottom: 3.2rem;\n`;\n\nconst StyledProductSwiper = styled(Swiper)`\n ${swiperCss}\n ${swiperPagination}\n padding-bottom: 3.2rem;\n & .swiper-slide {\n height: auto;\n }\n\n & .swiper-wrapper {\n padding-bottom: 45px;\n }\n\n & .swiper-pagination {\n height: auto;\n bottom: 0;\n }\n\n .swiper-pagination-bullet {\n &-active {\n background-color: ${getColor('primary')};\n }\n }\n`;\n\nconst ProductSlider = ({ products }: ProductSliderProps) => {\n const [renderSlider, setRenderSlider] = useState(false);\n\n useEffect(() => setRenderSlider(true), []);\n\n return renderSlider ? (\n \n {products.map((product, idx) => (\n \n \n \n ))}\n \n ) : (\n //Render product block without slider on server to avoid layout shifting\n \n \n \n );\n};\n\nexport default ProductSlider;","import React, { useState, useEffect, useMemo } from 'react';\nimport { translate } from '../Services/translation';\nimport styled from 'styled-components';\nimport { text } from '../styling/mixins/typography';\nconst MAX_LEN = 300;\n\nconst StyledShowButton = styled.a`\n ${text('medium')}\n text-decoration: underline;\n cursor: pointer;\n`;\n\nconst StyledHidden = styled.div`\n ${text('medium')}\n max-height: 8.1rem;\n overflow-wrap: break-word;\n overflow: hidden;\n margin-bottom: 0.8rem;\n`;\n\nconst StyledFull = styled.div`\n ${text('medium')}\n margin-bottom: 0.8rem;\n\n p:not(:last-child) {\n margin-bottom: 0.4rem;\n }\n`;\n\nconst ProductListHeaderText = (props) => {\n const [showMore, setShowMore] = useState(false);\n const wordLength = useMemo(() => props.value?.length, [props.value]);\n\n const resultSubstr = useMemo(() => props.value?.substring(0, MAX_LEN), [\n props.value,\n ]);\n const result = useMemo(\n () =>\n resultSubstr.substring(\n 0,\n Math.min(resultSubstr.length, resultSubstr.lastIndexOf(' '))\n ),\n [resultSubstr]\n );\n\n useEffect(() => {\n setShowMore(wordLength >= MAX_LEN);\n }, [wordLength]);\n\n return (\n <>\n {!showMore && (\n <>\n \n {wordLength >= MAX_LEN && (\n setShowMore(true)}>\n {translate('productlist.showless')}\n \n )}\n \n )}\n {showMore && (\n <>\n \n setShowMore(false)}>\n {translate('productlist.showmore')}\n \n \n )}\n \n );\n};\n\nexport default ProductListHeaderText;\n","import React from 'react';\nimport { useMemo } from 'react';\nimport { useDispatch } from 'react-redux';\nimport Chip from '../Chip';\nimport { FilterGroup } from '../ProductFiltering/types/FilterGroup';\nimport { FilterGroupType } from '../ProductFiltering/types/FilterGroupType';\nimport { clearFilterGroup } from '../../Actions/ProductFiltering.action';\n\ninterface FilterGroupChipsAttributes {\n filterGroup: FilterGroup;\n}\n\nconst FilterGroupChips = (props: FilterGroupChipsAttributes) => {\n const dispatch = useDispatch();\n const { selectedOptions, id, label, filterGroupType } = props.filterGroup;\n\n const chipText = useMemo(() => selectedOptions.join(', '), [selectedOptions]);\n\n if (selectedOptions.length == 0) return null;\n\n return (\n <>\n {filterGroupType == FilterGroupType.Checkbox && (\n 30 ? chipText : undefined }}\n onDeleteClick={() => dispatch(clearFilterGroup(id))}\n >\n \n {label}: {chipText.substring(0, 30)}\n {chipText.length > 30 ? '...' : ''}\n \n \n )}\n {filterGroupType == FilterGroupType.Range && selectedOptions.length == 2 && (\n dispatch(clearFilterGroup(id))}>\n \n {label}: {selectedOptions[0]}-{selectedOptions[1]}\n \n \n )}\n \n );\n};\n\nexport default FilterGroupChips;\n","import React, { useEffect } from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport FilterGroupChips from './FilterGroupChips';\nimport { translate } from '../../Services/translation';\nimport { useDispatch } from 'react-redux';\nimport { clearAllFilters } from '../../Actions/ProductFiltering.action';\nimport { useMemo } from 'react';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { text } from '../../styling/mixins/typography';\n\nconst StyledActiveFilterChip = styled.div`\n gap: 0.8rem;\n margin-bottom: 2.4rem;\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n display: none;\n\n ${breakpoint('large')} {\n display: flex;\n }\n\n .clear {\n ${text('small')}\n text-decoration: underline;\n cursor: pointer;\n }\n`;\n\nconst ActiveFilterChips = () => {\n const dispatch = useDispatch();\n const filters = useTypedSelector((state) => state.productFiltering.filters);\n const hasAnyOptionSelected = useMemo(\n () => filters?.findIndex((f) => f.selectedOptions.length > 0) >= 0,\n [filters]\n );\n\n return hasAnyOptionSelected ? (\n \n {filters.map((g) => (\n \n ))}\n dispatch(clearAllFilters())}>\n {translate('product-filtering.clear-all-filters')}\n \n \n ) : null;\n};\n\nexport default ActiveFilterChips;\n","import Icon from '../Icon';\nimport React from 'react';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\n\nconst QuickSearchNoHitWrapper = styled.div`\n display: flex;\n align-items: center;\n justify-content: center;\n\n ${breakpoint('large')} {\n margin: 3.2rem 0;\n }\n .container {\n display: flex;\n align-items: center;\n text-align: center;\n flex-direction: column;\n }\n .icon {\n font-size: 6rem;\n }\n .title {\n font-weight: bold;\n margin-top: 1.4rem;\n }\n .description {\n margin-top: 0.8rem;\n }\n`;\n\nconst QuickSearchNoHit = (props) => {\n const { title, description } = props;\n\n return (\n \n
    \n \n {title &&

    {title}

    }\n {description && (\n \n )}\n
    \n
    \n );\n};\n\nexport default QuickSearchNoHit;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { span } from '../../styling/utils/grid';\nimport { text } from '../../styling/mixins/typography';\nimport { SearchItem } from '../../Types/SearchItem';\nimport { StyledBrandLogo } from './styles/ProductCard.styling';\nimport EditorString from '../EditorString/EditorString';\n\nconst StyledQuickSearchCard = styled.a`\n display: flex;\n flex-direction: row;\n ${span(2)}\n padding: 1.2rem;\n background-color: ${getColor('grey', 100)};\n gap: 1.2rem;\n\n ${breakpoint('medium')} {\n ${span(1)}\n }\n\n .image-wrapper {\n display: flex;\n justify-content: center;\n width: 72px;\n height: 72px;\n }\n .image {\n aspect-ratio: 1/1;\n object-fit: contain;\n max-width: 72px;\n height: 72px;\n }\n .text-wrapper {\n display: flex;\n flex-direction: column;\n }\n .text {\n font-weight: 700;\n ${text('medium')}\n }\n .brand {\n ${text('medium')}\n color: ${getColor('grey', 500)};\n }\n`;\n\nconst StyledImageBackground = styled.div`\n position: relative;\n background: ${getColor('white')};\n\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0, 0, 0, 0.04);\n pointer-events: none;\n z-index: 2;\n }\n`;\n\nconst StyledBrandImage = styled.img`\n height: 16px;\n width: auto;\n`;\n\nconst ProductCardQuickSearch = ({ product }: { product: SearchItem }) => {\n return (\n \n {product.hasImage && (\n
    \n \n \n \n
    \n )}\n
    \n {product.brandImageUrl != null ? (\n \n \n \n ) : (\n {product.brand} \n )}\n \n {product.name}\n \n {product?.description?.value && (\n \n )}\n
    \n
    \n );\n};\n\nexport default ProductCardQuickSearch;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport { span } from '../../styling/utils/grid';\n\nconst StyledLinkItem = styled.a`\n ${text('medium')}\n ${span(1)}\n`;\n\nconst QuickSearchLinkItem = ({ name, url }) => {\n return (\n \n {name}\n \n );\n};\n\nexport default QuickSearchLinkItem;\n","import React from 'react';\nimport ProductCardQuickSearch from '../ProductCards/ProductCardQuickSearch';\nimport QuickSearchLinkItem from './QuickSearch.LinkItem';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { cells } from '../../styling/utils/grid';\nimport { SearchItem } from '../../Types/SearchItem';\n\ninterface QuickSearchResultTabProps {\n modelKey: string;\n results: SearchItem[];\n}\n\nconst QuickSearchResultItem = ({\n modelKey,\n item,\n}: {\n modelKey: string;\n item: SearchItem;\n}) => {\n switch (modelKey) {\n case 'products':\n return ;\n default:\n return ;\n }\n};\n\nconst QuickSearchTab = styled.div`\n margin-top: 2rem;\n gap: 0.8rem !important;\n overflow-y: auto;\n height: calc(100vh - 100px);\n padding-bottom: 14rem;\n grid-auto-rows: min-content;\n ${cells(1)}\n\n ${breakpoint('medium')} {\n ${cells(2)}\n }\n ${breakpoint('large')} {\n max-height: 256px;\n height: 'unset';\n padding-bottom: 1.6rem;\n }\n`;\n\nconst QuickSearchResultTab = ({\n modelKey,\n results,\n}: QuickSearchResultTabProps) => {\n return (\n \n {results.map((result, index) => (\n \n ))}\n \n );\n};\n\nexport default QuickSearchResultTab;\n","import { post } from '../Services/http';\nimport { catchError } from './Error.action';\nimport {\n QUICK_SEARCH_QUERY,\n QUICK_SEARCH_RECEIVE,\n QUICK_SEARCH_ERROR,\n QUICK_SEARCH_SHOW_FULL_FORM,\n QUICK_SEARCH_SELECT_ITEM,\n QUICK_SEARCH_ACTIVE_TAB,\n QUICK_SEARCH_INPUT_ACTIVE,\n} from '../constants';\n\nlet abortController;\n\nexport const query = (q) => (dispatch, getState) => {\n // abort any existing, pending request.\n // It's ok to call .abort() after the fetch has already completed, fetch simply ignores it.\n abortController && abortController.abort();\n abortController = new AbortController();\n\n if (!q || q.trim() == '') {\n dispatch(receive());\n return;\n }\n\n return post('/api/quickSearch', q, abortController)\n .then((response) => response.json())\n .then((result) => dispatch(receive(result)))\n .catch((ex) => dispatch(catchError(ex, (error) => searchError(error))));\n};\n\nexport const setSearchQuery = (query) => ({\n type: QUICK_SEARCH_QUERY,\n payload: {\n query,\n },\n});\n\nexport const searchError = (error) => ({\n type: QUICK_SEARCH_ERROR,\n payload: {\n error,\n },\n});\n\nexport const setActiveTab = (key) => ({\n type: QUICK_SEARCH_ACTIVE_TAB,\n payload: {\n activeTab: key,\n },\n});\n\nexport const toggleInputActive = (active, clear = false) => (\n dispatch,\n getState\n) => {\n const { query } = getState().quickSearch;\n return dispatch({\n type: QUICK_SEARCH_INPUT_ACTIVE,\n payload: {\n inputActive: active,\n query: clear && !active ? '' : query,\n },\n });\n};\n\nexport const receive = (result) => (dispatch, getState) => {\n const { query } = getState().quickSearch;\n return dispatch({\n type: QUICK_SEARCH_RECEIVE,\n payload: {\n result,\n showResult: result && Object.keys(result).length > 0 && query.length > 0,\n activeTab:\n result && result.results?.length ? result.results[0].key : undefined,\n },\n });\n};\n\nexport const toggleShowFullForm = () => (dispatch, getState) => {\n dispatch(show(!getState().quickSearch.showFullForm));\n};\n\nconst show = (visible) => ({\n type: QUICK_SEARCH_SHOW_FULL_FORM,\n payload: {\n showFullForm: visible,\n },\n});\n\nexport const handleKeyDown = (event, opt) => (dispatch, getState) => {\n const { result, selectedItem } = getState().quickSearch;\n\n if (!result || !result.length) {\n return;\n }\n const max = result.length - 1,\n clip = (index) => (index < 0 ? max : index > max ? 0 : index);\n switch (event.keyCode) {\n case 38:\n dispatch(selectItem(clip(selectedItem - 1)));\n break;\n case 40:\n dispatch(selectItem(clip(selectedItem + 1)));\n break;\n case 13:\n const selectedObject = result[selectedItem];\n if (selectedObject && selectedObject.url) {\n location.href = selectedObject.url;\n } else {\n location.href = opt.searchUrl;\n }\n break;\n default:\n break;\n }\n};\n\nexport const handleClickSearch = (opt) => (dispatch, getState) => {\n const { result } = getState().quickSearch;\n\n if (!result || !result.length) {\n return;\n }\n location.href = opt.searchUrl;\n};\n\nconst selectItem = (selectedItem) => ({\n type: QUICK_SEARCH_SELECT_ITEM,\n payload: {\n selectedItem,\n },\n});\n","import React from 'react';\nimport { translate } from '../../../Services/translation';\nimport { setActiveTab } from '../../../Actions/QuickSearch.action';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\n\ninterface StyledNavigationItemProps {\n active?: boolean;\n}\nconst StyledNavigationItem = styled.li`\n padding: 0.8rem 0;\n color: ${(props) => (props.active ? getColor('black') : getColor('grey'))};\n border-bottom: ${(props) => (props.active ? '1px solid' : null)};\n border-color: ${getColor('grey', 900)};\n cursor: pointer;\n .text {\n font-weight: bold;\n }\n`;\n\nconst QuickSearchResultTabItem = ({ resultKey, quantity, active }) => {\n const dispatch = useDispatch();\n var translation = translate(`quicksearchheader.${resultKey}`);\n return (\n dispatch(setActiveTab(resultKey))}\n active={active}\n >\n {translation}\n {'(' + quantity + ')'}\n \n );\n};\n\nexport default QuickSearchResultTabItem;\n","import React, { useMemo } from 'react';\nimport { translate } from '../../Services/translation';\nimport QuickSearchNoHit from './QuickSearch.NoHit';\nimport QuickSearchResultTab from './QuickSearchResultTab';\nimport QuickSearchResultTabItem from './utils/QuickSearchResult.TabItem';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { getColor } from '../../styling/mixins/colors';\nimport { QuickSearchResultItem } from '../../Types/QuickSearchResultItem';\nimport { EditorStringModel } from '../../Types/EditorString';\nimport Button from '../Button';\n\ninterface QuickSearchWrapperProps {\n results: number;\n}\nconst Wrapper = styled.div`\n position: absolute;\n top: 5rem;\n left: 0;\n right: 0;\n padding: 0 1.6rem;\n background-color: ${getColor('white')};\n border: 1px solid ${getColor('grey', 300)};\n height: 100vh;\n z-index: 55;\n ${breakpoint('large')} {\n top: 4.5rem;\n height: ${(props) => (props.results > 0 ? '380px' : 'auto')};\n }\n .tabs-navigation {\n display: flex;\n list-style-type: none;\n gap: 1.6rem;\n padding-top: 2.4rem;\n overflow-y: auto;\n margin-right: -1.6rem;\n padding-right: 1.6rem;\n -ms-overflow-style: none;\n scrollbar-width: none;\n &::-webkit-scrollbar {\n display: none;\n }\n }\n .button-wrapper {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n position: fixed;\n height: 64px;\n bottom: 0;\n padding: 0.8rem 1.6rem;\n left: -1.6rem;\n margin-left: 1.6rem;\n border-top: 1px solid ${getColor('grey', 300)};\n background-color: ${getColor('white', 500)};\n z-index: 2;\n ${breakpoint('large')} {\n position: absolute;\n bottom: 0;\n left: 0;\n margin-left: 0;\n }\n\n a {\n flex: 1;\n }\n }\n`;\n\ninterface QuickSearchResultProps {\n result: { results: QuickSearchResultItem[] };\n searchUrl: string;\n activeTab?: string;\n noHitHeader: string;\n noHitDescription: EditorStringModel;\n}\n\nconst QuickSearchResult = ({\n result,\n searchUrl,\n activeTab,\n noHitHeader,\n noHitDescription,\n}: QuickSearchResultProps) => {\n const items = useMemo(() => result?.results, [result]);\n const totalNumResults = useMemo(\n () => items?.reduce((total, curr) => curr.items.length + total, 0) ?? 0,\n [items]\n );\n\n return (\n \n
    \n
      \n {items?.map(\n (item, idx) =>\n item.items.length > 0 && (\n \n )\n )}\n
    \n {totalNumResults > 0 &&\n items?.map(\n (item, idx) =>\n item.items.length > 0 &&\n item.key == activeTab && (\n \n )\n )}\n
    \n {totalNumResults == 0 && (\n \n )}\n {totalNumResults > 0 && (\n \n )}\n
    \n );\n};\n\nexport default QuickSearchResult;\n","import React from 'react';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { cells } from '../../styling/utils/grid';\n\nconst QuickSearchInitWrapper = styled.div`\n position: absolute;\n top: 5rem;\n padding: 2.4rem;\n background-color: ${getColor('white')};\n border: 1px solid ${getColor('grey', 500)};\n height: 100vh;\n width: 100vw;\n z-index: 55;\n ${breakpoint('large')} {\n padding: 3.2rem;\n top: 4.5rem;\n height: auto;\n width: 100%;\n }\n .quick-search-grid {\n ${cells(1)}\n ${breakpoint('small')} {\n ${cells(2)}\n }\n }\n .section-item {\n display: flex;\n flex-direction: column;\n }\n .section-link {\n margin-top: 1.4rem;\n &:first-child {\n margin-top: unset;\n }\n }\n`;\n\nconst QuickSearchInitialTab = ({ sectionList }) => {\n return (\n \n
    \n {sectionList.map((listItem, index) => (\n
    \n
    {listItem.sectionTitle}
    \n {listItem.sectionLinkList.map((subListItem, index) => (\n \n {subListItem.text}\n \n ))}\n
    \n ))}\n
    \n
    \n );\n};\n\nexport default QuickSearchInitialTab;\n","import { getColor } from '../../../styling/mixins/colors';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport Icon from '../../Icon';\n\nexport const QuickSearchWrapper = styled.div`\n z-index: 55;\n display: flex;\n flex-grow: 1;\n .quick-search__form {\n width: 100%;\n position: relative;\n }\n\n .quick-search__input-section {\n width: 100%;\n margin: 0;\n ${breakpoint('large')} {\n padding: 0;\n }\n }\n .quick-search__input-wrapper {\n position: relative;\n width: 100%;\n }\n`;\n\ninterface QuickSearchInputProps {\n $inputActive: boolean;\n}\n\nexport const QuickSearchInput = styled.input`\n display: flex;\n width: 100%;\n flex-grow: 1;\n padding: 0 1.2rem;\n height: 4rem;\n font-weight: 400;\n line-height: 150%;\n color: ${getColor('grey', 500)};\n background-color: ${getColor('grey', 100)};\n border: 1px solid ${getColor('grey', 400)};\n font-size: 1.6rem !important;\n border-color: ${(props) =>\n props.$inputActive ? getColor('grey', 600) : getColor('grey', 400)};\n &::-webkit-search-decoration,\n &::-webkit-search-cancel-button,\n &::-webkit-search-results-button,\n &::-webkit-search-results-decoration {\n display: none;\n }\n`;\n\nexport const QuickSearchIcon = styled(Icon)`\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n right: 1.2rem;\n margin: 0;\n font-size: 2rem;\n color: ${(props) => (props.$inputActive ? getColor('grey', 500) : null)};\n width: 2rem;\n height: 2rem;\n`;\n","import React, { useRef, useEffect, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport * as debounce from 'lodash.debounce';\nimport QuickSearchResult from './QuickSearchResult';\nimport { uniqueId } from 'lodash';\nimport { translate } from '../../Services/translation';\nimport { addOverlay, removeOverlay } from '../../Actions/Overlay.action';\nimport {\n query,\n setSearchQuery,\n handleKeyDown,\n toggleInputActive,\n} from '../../Actions/QuickSearch.action';\nimport QuickSearchInitialTab from './QuickSearch.InitialTab';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport {\n QuickSearchWrapper,\n QuickSearchInput,\n QuickSearchIcon,\n} from './styles/QuickSearch.styling';\nimport { QuickSearchModel } from '../../Types/QuickSearchModel';\n\nconst debouncedQuery = debounce((dispatch, text) => dispatch(query(text)), 200);\n\nconst QuickSearch = (props: QuickSearchModel) => {\n const quickSearch = useTypedSelector((state) => state.quickSearch);\n const { query, result, showResult, activeTab, inputActive } = quickSearch;\n\n const [id] = useState(uniqueId());\n const searchContainer = useRef(null);\n const searchInput = useRef(null);\n const dispatch = useDispatch();\n const searchUrl =\n global['LitiumQuickSearchUrl'] + (query.length > 0 ? `?q=${query}` : '');\n\n useEffect(() => {\n if (inputActive) {\n dispatch(\n addOverlay('quick-search__' + id, () =>\n dispatch(toggleInputActive(false))\n )\n );\n } else {\n dispatch(removeOverlay('quick-search__' + id));\n }\n }, [dispatch, inputActive, id]);\n\n return (\n \n
    \n
    \n
    \n \n dispatch(toggleInputActive(!inputActive, inputActive))\n }\n />\n {\n const text = encodeURIComponent(event.target.value);\n dispatch(setSearchQuery(text));\n debouncedQuery(dispatch, text);\n }}\n onClick={() => {\n dispatch(toggleInputActive(true));\n }}\n onKeyDown={(event) =>\n dispatch(handleKeyDown(event, { searchUrl }))\n }\n ref={searchInput}\n />\n
    \n
    \n {showResult && inputActive && result && (\n \n )}\n\n {!showResult && inputActive && }\n
    \n \n );\n};\n\nexport default QuickSearch;\n","import React, { useMemo } from 'react';\nimport { translate } from '../../Services/translation';\n\ninterface ProgressBarProps {\n progress?: number;\n maxProgress?: number;\n showLabel?: boolean;\n}\n\nconst ProgressBar = ({\n progress = 0,\n maxProgress = 100,\n showLabel = true,\n}: ProgressBarProps) => {\n if (maxProgress == 0) console.warn('maxProgress cannot be 0');\n\n const progressPercent = useMemo(\n () => Math.min((progress / maxProgress) * 100, 100),\n [progress, maxProgress]\n );\n\n return (\n <>\n
    \n
    \n \n {showLabel && (\n \n )}\n \n );\n};\n\nexport default ProgressBar;","import React, { forwardRef, useEffect, useState } from 'react';\nimport ProgressBar from '../ProgressBar/ProgressBar';\nimport { translate } from '../../Services/translation';\nimport clsx from 'clsx';\n\ninterface LoadMoreButtonAttributes\n extends React.HTMLAttributes {\n disabled?: boolean;\n count?: number;\n totalCount?: number;\n isLoading?: boolean;\n productsPerLoad?: number;\n location?: string;\n canLoadMore?: boolean;\n onClick: () => void;\n}\n\nconst LoadMoreButton = forwardRef<\n HTMLDivElement,\n LoadMoreButtonAttributes\n>(\n (\n {\n onClick,\n disabled = false,\n count,\n totalCount,\n isLoading = false,\n productsPerLoad,\n location,\n canLoadMore,\n ...props\n }: LoadMoreButtonAttributes,\n wrapperRef\n ) => {\n \n const [crawlerCount, setCrawlerCount] = useState(\n count >= totalCount\n ? count\n : count + productsPerLoad < totalCount\n ? count + productsPerLoad\n : totalCount\n );\n\n useEffect(() => {\n if (count >= totalCount) {\n setCrawlerCount(count);\n } else {\n if (count + productsPerLoad < totalCount) {\n setCrawlerCount(count + productsPerLoad);\n } else {\n setCrawlerCount(totalCount);\n }\n }\n }, [count, productsPerLoad, totalCount]);\n\n return (\n \n {/* Anchor tag with a link to support crawlers */}\n {canLoadMore && count !== totalCount && (\n {\n if (onClick) {\n e.preventDefault();\n onClick();\n }\n }}\n href={`${location}?count=${crawlerCount}`}\n >\n {isLoading\n ? translate('general.loading') + '...'\n : translate('general.load-more')}\n \n )}\n \n \n );\n }\n);\n\nLoadMoreButton.displayName = 'LoadMoreButton';\n\nexport default LoadMoreButton;\n","export const breakpoints = {\n 'sm': '640px',\n 'md': '768px',\n 'lg': '1024px',\n 'xl': '1280px',\n '2xl': '1536px',\n}","import { useEffect, useMemo, useState } from 'react';\nimport useWindowSize from './useWindowSize';\nimport { breakpoints as breakpointVars } from '../styling/variables/breakpoints';\n\nconst useBreakpoint = () => {\n\n const [windowWidth] = useWindowSize();\n const [currentBreakpoint, setCurrentBreakpoint] = useState<\n string | undefined\n >();\n const [breakpointValues, setBreakpointValues] = useState([]);\n const [breakpoints, setBreakpoints] = useState([]);\n\n useEffect(() => {\n const _breakpoints = Object.keys(breakpointVars).reduce(\n (obj, key) => ({\n ...obj,\n [key]: parseInt(breakpointVars[key]?.replace('px', '') ?? '0'),\n }),\n {}\n );\n\n const sortedValues: any = Object.values(_breakpoints).sort(\n (a: number, b: number) => a - b\n );\n const keyArray: string[] = [];\n for (let sortedValue of sortedValues) {\n for (let key of Object.keys(_breakpoints)) {\n const value = _breakpoints[key];\n if (value == sortedValue) {\n keyArray.push(key);\n }\n }\n }\n\n setBreakpoints(keyArray);\n setBreakpointValues(sortedValues);\n }, [breakpointVars]);\n\n useEffect(() => {\n console.log(currentBreakpoint);\n }, [currentBreakpoint]);\n\n useEffect(() => {\n var index = 0;\n for (let key of breakpoints) {\n const value = !breakpointValues[index];\n\n if (index == breakpointValues.length - 1 && windowWidth >= value) {\n setCurrentBreakpoint(key);\n break;\n }\n\n const nextValue = breakpointValues[index + 1] ?? 0;\n if (windowWidth >= value && windowWidth < nextValue) {\n setCurrentBreakpoint(key);\n break;\n }\n index++;\n }\n }, [windowWidth, breakpointValues, breakpoints]);\n\n return currentBreakpoint;\n};\n\nexport default useBreakpoint;\n","import { useState, useEffect } from 'react';\n\nexport default function () {\n var initialWidth = global.window && window.innerWidth ? window.innerWidth : 0;\n var initialHeight =\n global.window && window.innerHeight ? window.innerHeight : 0;\n const [size, setSize] = useState([initialWidth, initialHeight]);\n useEffect(() => {\n function updateSize() {\n setSize([window.innerWidth, window.innerHeight]);\n }\n window.addEventListener('resize', updateSize);\n updateSize();\n return () => window.removeEventListener('resize', updateSize);\n }, []);\n return size;\n}\n","import React, { useEffect, useCallback, useMemo } from 'react';\nimport { useDispatch } from 'react-redux';\nimport {\n setProductListingType,\n setProductsPerRow,\n} from '../../Actions/ProductListing.action';\nimport useBreakpoint from '../../Hooks/useBreakpoint';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport useIsMobile from '../../Hooks/useIsMobile';\nimport { ProductListingType } from '../../Reducers/ProductListing.reducer';\n\nconst ProductListingResizeObserver = () => {\n const { productListingType } = useTypedSelector(\n (state) => state.productListing\n );\n\n const dispatch = useDispatch();\n\n const breakpoint = useBreakpoint();\n const isMedium = useMemo(() => breakpoint == 'md', [breakpoint]);\n\n const getProductsPerRowForBreakpoint = useCallback(() => {\n switch (breakpoint) {\n case 'xsmall':\n case 'small':\n return 2;\n case 'medium':\n return 3;\n case 'large':\n default:\n return 4;\n }\n }, [breakpoint]);\n\n useEffect(() => {\n switch (productListingType) {\n case ProductListingType.Grid:\n dispatch(setProductsPerRow(getProductsPerRowForBreakpoint()));\n return;\n case ProductListingType.List:\n if (isMedium) {\n dispatch(setProductListingType(ProductListingType.SingleCard));\n } else {\n dispatch(setProductsPerRow(1));\n }\n return;\n case ProductListingType.SingleCard:\n if (isMedium) {\n dispatch(setProductsPerRow(1));\n } else {\n dispatch(setProductListingType(ProductListingType.List));\n }\n return;\n }\n }, [\n dispatch,\n getProductsPerRowForBreakpoint,\n productListingType,\n breakpoint,\n isMedium,\n ]);\n\n return null;\n};\n\nexport default ProductListingResizeObserver;\n","import React from 'react';\nimport clsx from 'clsx';\n\nconst ProductCardPlaceholder = () => {\n return (\n
    \n
    \n \n
    \n \n  \n
    \n \n  \n \n \n  \n \n \n
    \n \n  \n
    \n \n \n
     
    \n
     
    \n
     
    \n \n
    \n  \n
    \n \n \n );\n};\n\nexport default ProductCardPlaceholder;\n","import styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\n\nexport const StyledLandscapeProductCard = styled.div`\n display: flex;\n background-color: ${getColor('grey', 100)};\n padding: 1.2rem;\n gap: 1.2rem;\n\n .buy-button {\n flex-direction: column;\n\n .quantity-input input {\n ${text('large')}\n padding: 0.8rem 1.2rem;\n max-width: 100%;\n }\n\n button {\n display: flex;\n align-items: center;\n }\n }\n\n .image-wrapper {\n background-color: ${getColor('white')};\n max-width: 180px;\n width: 100%;\n height: 180px;\n position: relative;\n\n img {\n width: 100%;\n aspect-ratio: 1/1;\n object-fit: cover;\n }\n\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0, 0, 0, 0.04);\n pointer-events: none;\n }\n }\n\n .information {\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n flex: 1;\n }\n\n .overline {\n ${text('medium')}\n color: ${getColor('grey', 500)};\n margin-bottom: 0.2rem;\n }\n\n .name {\n ${text('large')}\n font-weight: bold;\n }\n\n .description {\n ${text('medium')};\n }\n\n .price {\n display: flex;\n flex-direction: column;\n text-align: right;\n }\n\n .original-price {\n ${text('small')}\n text-decoration: line-through;\n font-weight: 400;\n color: ${getColor('grey', 500)};\n }\n\n .campaign-price {\n color: ${getColor('red')};\n }\n\n .right-col {\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n min-width: 180px;\n }\n`;\n\nexport const StyledProductTagWrapperLandscape = styled.div`\n display: flex;\n gap: 0.8rem;\n margin-bottom: 0.4rem;\n`;\n\nexport const StyledBrandLogo = styled.img`\n height: 20px;\n width: auto;\n`;\n","import React from 'react';\nimport StockStatus from '../StockStatus/StockStatus';\nimport ProductCardProps from './types/ProductCardProps';\nimport {\n StyledBrandLogo,\n StyledLandscapeProductCard,\n StyledProductTagWrapperLandscape,\n} from './styles/ProductCardLandscape.styling';\nimport ResponsiveImage from '../ResponsiveImage/ResponsiveImage';\nimport ProductTag from '../ProductTags/ProductTag';\nimport ProductCardBuyButton from './ProductCardBuyButton';\nimport EditorString from '../EditorString/EditorString';\nimport { translate } from '../../Services/translation';\n\nconst ProductCardLandscape = ({\n product,\n isVariantListing = false,\n lazyLoadImage,\n}: ProductCardProps) => {\n return (\n \n
    \n {product.images && product.images.length > 0 && (\n \n \n \n )}\n
    \n
    \n {product.tags?.length ? (\n \n {product.tags.map((tag) => (\n \n {tag.name}\n \n ))}\n \n ) : null}\n
    \n \n
    \n \n {product.name}\n \n {product.descriptionShort && (\n \n )}\n\n {isVariantListing && }\n
    \n
    \n {!isVariantListing && product.fromPrice.useFromPrice ? (\n

    \n {translate('product.fr')} {product.fromPrice.formattedPrice}\n

    \n ) : product.price.formattedCampaignPrice ? (\n

    \n {product.price.formattedCampaignPrice}{' '}\n \n {product.price.formattedPrice}\n \n

    \n ) : product.price.formattedPrice ? (\n

    {product.price.formattedPrice}

    \n ) : (\n

     

    \n )}\n \n
    \n
    \n );\n};\n\nexport default ProductCardLandscape;\n","import React from 'react';\nimport { StyledLandscapeProductCard } from './styles/ProductCardLandscape.styling';\n\nconst LandscapeProductCardPlaceholder = () => {\n return (\n \n
    \n
    \n
     
    \n
     
    \n
     
    \n
     
    \n
    \n
    \n
     
    \n
     
    \n
    \n
    \n );\n};\n\nexport default LandscapeProductCardPlaceholder;\n","import React, {\n useEffect,\n useMemo,\n useState,\n useCallback,\n HTMLAttributes,\n useRef,\n} from 'react';\nimport LoadMoreButton from '../LoadMoreButton/LoadMoreButton';\nimport {\n AutoSizer,\n CellMeasurer,\n CellMeasurerCache,\n Index,\n InfiniteLoader,\n List,\n WindowScroller,\n} from 'react-virtualized';\nimport {\n addPlaceholderProducts,\n fetchProducts,\n setIsLoadingReverse,\n setIsLoadingMore,\n} from '../../Actions/ProductListing.action';\nimport { useDispatch } from 'react-redux';\nimport ProductListingResizeObserver from './ProductListingResizeObserver';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { ProductListingType } from '../../Reducers/ProductListing.reducer';\nimport ProductCard from '../ProductCards/ProductCard';\nimport ProductCardPlaceholder from '../ProductCards/ProductCardPlaceholder';\nimport ProductCardLandscape from '../ProductCards/ProductCardLandscape';\nimport LandscapeProductCardPlaceholder from '../ProductCards/ProductCardLandscapePlaceholder';\nimport { pushEcommerce } from '../../Services/Gtm.service';\nimport clsx from 'clsx';\n\nconst cache = new CellMeasurerCache({\n defaultWidth: 150,\n minWidth: 70,\n defaultHeight: 600, // TODO denna bör ändras beroende på vilken typ av vy som används på listan\n fixedWidth: true,\n fixedHeight: false,\n});\n\nconst oneColRowClass = 'grid grid-cols-1 !gap-x-4 pb-4';\nconst PRODUCTS_PER_LOAD = 24;\n\nconst ProductListing = () => {\n const dispatch = useDispatch();\n const {\n products,\n isLoadingMore,\n isLoadingReverse,\n totalProductsCount,\n productsPerRow = 4,\n canLoadMore,\n productListingType = ProductListingType.Grid,\n pageSize,\n gtmViewModel,\n location,\n isLoading,\n } = useTypedSelector((state) => state.productListing);\n\n const [ready, setReady] = useState(false);\n const rowCount = useMemo(() => Math.ceil(products.length / productsPerRow), [\n products.length,\n productsPerRow,\n ]);\n let listRef: List | null = null;\n\n const RowComponent = useCallback(\n ({\n children,\n className,\n ...props\n }: HTMLAttributes) => (\n <>\n {productListingType == ProductListingType.Grid && (\n \n {children}\n \n )}\n {productListingType == ProductListingType.List && (\n
    \n {children}\n
    \n )}\n {productListingType == ProductListingType.SingleCard && (\n
    \n {children}\n
    \n )}\n \n ),\n [productListingType]\n );\n\n const [ProductComponent, ProductPlaceholderComponent] = useMemo(() => {\n switch (productListingType) {\n case ProductListingType.Grid:\n case ProductListingType.SingleCard:\n default:\n return [ProductCard, ProductCardPlaceholder];\n case ProductListingType.List:\n return [ProductCardLandscape, LandscapeProductCardPlaceholder];\n }\n }, [productListingType]);\n\n useEffect(() => {\n if (!ready) return;\n cache.clearAll();\n listRef?.recomputeRowHeights(0);\n }, [listRef, ready, productListingType, products]);\n\n useEffect(() => {\n if (!ready) {\n pushEcommerce(gtmViewModel);\n }\n setReady(true);\n }, []);\n\n const loadMoreClick = () => {\n const productsPerLoad = PRODUCTS_PER_LOAD;\n const startIndex = rowCount;\n const endIndex = rowCount + Math.ceil(productsPerLoad / productsPerRow);\n\n dispatch(addPlaceholderProducts(startIndex, endIndex));\n dispatch(setIsLoadingMore(true));\n };\n\n const isRowLoaded = ({ index }: Index) => {\n if (isLoadingReverse) return true;\n\n return index >= rowCount || !!products[index * productsPerRow];\n };\n\n const loadMoreRows = ({ startIndex, stopIndex }): Promise => {\n if (startIndex >= rowCount) {\n return new Promise((resolve) => resolve(null));\n }\n\n const endIndex = stopIndex + 1;\n dispatch(setIsLoadingReverse(true));\n return dispatch(fetchProducts(startIndex, endIndex))\n .then(() => {\n for (let i = startIndex; i < endIndex; i++) {\n cache.clear(i, 0);\n }\n listRef?.recomputeRowHeights(startIndex);\n })\n .finally(() => dispatch(setIsLoadingReverse(false)));\n };\n\n const rowRenderer = useCallback(\n ({ index, key, parent, style }) => {\n const startIndex = index * productsPerRow;\n const endIndex = startIndex + productsPerRow;\n const productsForRow = products.slice(startIndex, endIndex);\n\n return (\n \n
    \n \n {productsForRow.length > 0 &&\n productsForRow.map((product, idx) =>\n product ? (\n \n ) : (\n \n )\n )}\n \n
    \n \n );\n },\n [products, productsPerRow]\n );\n\n return (\n <>\n {!ready && (\n \n {products.map((product, idx) =>\n product ? (\n \n ) : (\n \n )\n )}\n \n )}\n {ready && (\n \n {({ height, isScrolling, onChildScroll, scrollTop }) => (\n \n {({ width }) => (\n \n {({ onRowsRendered, registerChild }) => (\n {\n if (ref) {\n registerChild(ref);\n listRef = ref;\n }\n }}\n height={height}\n onRowsRendered={onRowsRendered}\n width={width}\n isScrolling={isScrolling}\n onScroll={onChildScroll}\n scrollTop={scrollTop}\n rowCount={rowCount}\n rowRenderer={rowRenderer}\n rowHeight={cache.rowHeight}\n />\n )}\n \n )}\n \n )}\n \n )}\n = totalProductsCount\n }\n isLoading={isLoadingMore}\n count={products.length}\n totalCount={totalProductsCount}\n canLoadMore={canLoadMore}\n location={location}\n />\n \n \n );\n};\n\nexport default ProductListing;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { cells, span } from '../../styling/utils/grid';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\n\nconst StyledResultLinkWrapper = styled.div`\n display: grid;\n gap: 1.6rem;\n padding-bottom: 2.4rem;\n\n ${breakpoint('medium')} {\n padding-bottom: 3.2rem;\n }\n ${breakpoint('large')} {\n ${cells(4)}\n padding-bottom: 4rem;\n }\n\n .link-item {\n ${text('medium')}\n ${span(1)}\n text-decoration: none;\n cursor: pointer;\n color: ${getColor('grey', 900)};\n }\n`;\n\nconst SearchResultLinkTab = ({ items }) => {\n return (\n \n {items.value.map((item) => {\n return (\n \n {item.name}\n \n );\n })}\n \n );\n};\nexport default SearchResultLinkTab;\n","import React from 'react';\nimport FilterBar from '../FilterBar/FilterBar';\nimport ProductFiltering from '../ProductFiltering/ProductFiltering';\nimport ProductListing from '../ProductListing/ProductListing';\nimport SearchResultLinkTab from './SearchResultLinkTab';\nimport styled from 'styled-components';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { grid, span } from '../../styling/utils/grid';\nimport { showFor } from '../../styling/utils/visibility';\n\nconst StyledColumnWrapper = styled.div`\n ${grid}\n\n .left {\n ${span(2)}\n ${showFor('large')}\n }\n`;\n\nconst SearchResult = (props) => {\n const { activeTab = 'products' } = useTypedSelector(\n (state) => state.search\n );\n\n return (\n <>\n {props.productListing?.totalProductsCount > 0 && activeTab == 'products' && (\n \n \n
    \n \n \n
    \n
    \n )}\n {props.brandListing?.total > 0 && activeTab == 'brands' && (\n \n )}\n {props.pagesListing?.total > 0 && activeTab == 'pages' && (\n \n )}\n {props.categoryListing?.total > 0 && activeTab == 'categories' && (\n \n )}\n \n );\n};\n\nexport default SearchResult;\n","import { SEARCH_ACTIVE_TAB } from '../constants';\n\nexport const setActiveTab = (key) => ({\n type: SEARCH_ACTIVE_TAB,\n payload: {\n activeTab: key,\n },\n});\n","import React from 'react';\nimport { translate } from '../../Services/translation';\nimport { useDispatch } from 'react-redux';\nimport { setActiveTab } from '../../Actions/Search.action';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\n\ninterface NavigationItemProps {\n active: boolean;\n}\n\nconst StyledNavigationItem = styled.li`\n padding: 0.8rem 0rem;\n cursor: pointer;\n color: ${(props) =>\n props.active ? getColor('grey', 900) : getColor('grey', 500)};\n border-bottom: 1px solid\n ${(props) => (props.active ? getColor('grey', 900) : 'transparent')};\n\n span {\n ${text('medium')};\n }\n .bold {\n font-weight: bold;\n }\n`;\n\nconst SearchNavigationItem = ({ resultKey, quantity, active }) => {\n const dispatch = useDispatch();\n\n return (\n dispatch(setActiveTab(resultKey))}\n >\n \n {translate(`quicksearchheader.${resultKey}`)}\n \n {'(' + quantity + ')'}\n \n );\n};\n\nexport default SearchNavigationItem;\n","import React, { useEffect, useCallback } from 'react';\nimport SearchNavigationItem from './SearchNavigationItem';\nimport { useDispatch } from 'react-redux';\nimport { setActiveTab as setActiveTabAction } from '../../Actions/Search.action';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\n\nconst StyledSearchNavigation = styled.ul`\n display: flex;\n flex-direction: row;\n margin-top: 2.4rem;\n margin-bottom: 1.6rem;\n gap: 1.6rem;\n ${breakpoint('large')} {\n margin-bottom: 2.4rem;\n margin-top: 3.2rem;\n }\n`;\n\nconst SearchNavigation = (props) => {\n const { activeTab = 'products' } = useTypedSelector(\n (state) => state.search\n );\n const dispatch = useDispatch();\n\n const setActiveTab = useCallback(() => {\n var productListingHits = props.productListing?.totalProductsCount;\n var categoryListingHits = props.categoryListing?.total ?? 0;\n var pagesListingHits = props.pagesListing?.total ?? 0;\n var brandListingHits = props.brandListing?.total ?? 0;\n\n if (productListingHits > 0) {\n dispatch(setActiveTabAction('products'));\n } else if (categoryListingHits > 0) {\n dispatch(setActiveTabAction('categories'));\n } else if (pagesListingHits > 0) {\n dispatch(setActiveTabAction('pages'));\n } else if (brandListingHits > 0) {\n dispatch(setActiveTabAction('brands'));\n }\n }, [\n dispatch,\n props.brandListing?.total,\n props.categoryListing?.total,\n props.pagesListing?.total,\n props.productListing?.totalProductsCount,\n ]);\n\n useEffect(() => {\n setActiveTab();\n }, [setActiveTab]);\n\n return (\n
    \n {props.totalHits > 0 && (\n \n {props.productListing.totalProductsCount > 0 && (\n \n )}\n {props.categoryListing.total > 0 && (\n \n )}\n {props.pagesListing.total > 0 && (\n \n )}\n {props.brandListing.total > 0 && (\n \n )}\n \n )}\n
    \n );\n};\n\nexport default SearchNavigation;\n","import { get } from '../Services/http';\nimport { catchError } from './Error.action';\nimport { NAVIGATION_LOAD_ERROR, NAVIGATION_RECEIVE } from '../constants';\n\nexport const load = () => (dispatch, getState) => {\n return get('/api/navigation')\n .then((response) => response.json())\n .then((data) => dispatch(receive(data)))\n .catch((ex) => dispatch(catchError(ex, (error) => loadError(error))));\n};\n\nexport const loadError = (error) => ({\n type: NAVIGATION_LOAD_ERROR,\n payload: {\n error,\n },\n});\n\nexport const receive = (data) => ({\n type: NAVIGATION_RECEIVE,\n payload: {\n contentLinks: data.contentLinks,\n },\n});\n\nexport const setMobileMenuOpen = (mobileMenuOpen) => ({\n type: NAVIGATION_RECEIVE,\n payload: {\n mobileMenuOpen,\n },\n});\n","import Icon from '../Icon';\nimport React from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setMobileMenuOpen } from '../../Actions/Navigation.action';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\n\nconst StyledNavMobileTrigger = styled(Icon)`\n width: 24px !important;\n height: 24px !important;\n cursor: pointer;\n color: ${getColor('grey', 900)};\n`;\n\nconst NavigationMobileTrigger = () => {\n const dispatch = useDispatch();\n\n return (\n dispatch(setMobileMenuOpen(true))}\n >\n );\n};\n\nexport default NavigationMobileTrigger;\n","import React from 'react';\nimport Icon from '../../Icon';\nimport styled from 'styled-components';\nimport { text } from '../../../styling/mixins/typography';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { ContentLinkModel } from '../../../Types/ContentLinkModel';\n\ninterface NavigationItemTypes {\n link: ContentLinkModel;\n onLinkClick?: (link: ContentLinkModel) => void;\n icon?: string;\n wrapperClassName?: string;\n}\n\nconst StyledMenuItem = styled.li`\n display: flex;\n justify-content: space-between;\n ${text('large')}\n\n &:not(:last-child) {\n border-bottom: 1px solid ${getColor('grey', 300)};\n }\n\n &.bold-item {\n font-weight: bold;\n }\n\n a {\n display: flex;\n gap: 0.8rem;\n padding: 1.6rem;\n color: ${getColor('grey', 900)};\n flex: 1;\n }\n`;\n\nconst StyledIconWrapper = styled.div`\n display: flex;\n align-items: center;\n padding: 1.6rem;\n border-left: 1px solid ${getColor('grey', 300)};\n cursor: pointer;\n`;\n\nconst StyledIcon = styled(Icon)`\n font-size: 2.4rem;\n color: ${getColor('grey', 900)};\n`;\n\nconst MobileNavigationItem = ({\n link,\n onLinkClick,\n icon,\n wrapperClassName,\n}: NavigationItemTypes) => {\n return (\n \n \n {icon && }\n {link.name}\n \n {link.links?.length ? (\n onLinkClick && onLinkClick(link)}>\n \n \n ) : null}\n \n );\n};\nexport default MobileNavigationItem;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { text } from '../../styling/mixins/typography';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport FloorHeatingCardProps from './types/FHGuideCardProps';\n\nconst StyledFloorNavigationCard = styled.a`\n display: none;\n\n ${breakpoint('large')} {\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 0.8rem;\n margin-right: 0.8rem;\n }\n\n .navigation-image {\n aspect-ratio: 1/1;\n width: 3.2rem;\n height: 3.2rem;\n object-fit: contain;\n }\n .navigation-title {\n ${text('medium')}\n font-weight: bold;\n }\n`;\nconst FloorHeatingNavigationCard = ({\n title,\n imageUrl,\n link,\n}: FloorHeatingCardProps) => {\n return (\n \n {imageUrl && }\n

    {title}

    \n \n );\n};\n\nexport default FloorHeatingNavigationCard;\n","import Icon from '../../Icon';\nimport SideMenu from '../../SideMenu/SideMenu';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport { StyledSideMenuContent } from '../../SideMenu/styles/SideMenu.styling';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\n\nexport const StyledSideMenu = styled(SideMenu)`\n z-index: 60;\n max-width: 480px;\n\n ${breakpoint('small')} {\n border-right: 1px solid ${getColor('grey', 300)};\n }\n`;\n\nexport const StyledMenuIcon = styled(Icon)`\n font-size: 2.4rem;\n color: ${getColor('grey', 900)};\n`;\n\nexport const StyledCloseIcon = styled.div`\n padding: 1.6rem;\n border-left: 1px solid ${getColor('grey', 300)};\n cursor: pointer;\n margin: -1.6rem; //override standard side-menu-header padding\n`;\n\nexport const StyledHeader = styled.div`\n display: flex;\n justify-content: space-between;\n align-items: center;\n flex: 1;\n`;\n\nexport const StyledHeaderImg = styled.img`\n max-height: 32px;\n`;\n\nexport const StyledContent = styled(StyledSideMenuContent)`\n padding: 0;\n overflow-y: auto;\n`;\n\nexport const StyledIconWrapper = styled.div`\n display: flex;\n align-items: center;\n cursor: pointer;\n flex: 1;\n`;\n\nexport const StyledLinks = styled.ul`\n display: flex;\n flex-direction: column;\n`;\n\nexport const StyledSocialWrapper = styled.div`\n display: flex;\n gap: 2.4rem;\n\n & .social {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 40px;\n height: 40px;\n background-color: ${getColor('primary')};\n border-radius: 50%;\n\n img {\n width: 20px;\n height: 20px;\n }\n }\n`;\n\nexport const StyledFHGuideNavigationCard = styled.li`\n .navigation-wrapper {\n display: flex !important;\n padding: 1.2rem 1.6rem;\n flex: 1;\n border-bottom: 1px solid ${getColor('grey', 300)};\n justify-content: flex-start;\n margin: 0;\n }\n\n .navigation-title {\n ${text('large')}\n font-weight: bold;\n }\n`;\n\nexport const GlobalNavigationMobileStyling = createGlobalStyle`\nbody #overlay-container .overlay--navigation-mobile {\n z-index: 55;\n}\n`;\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { translate } from '../../../Services/translation';\nimport { text } from '../../../styling/mixins/typography';\nimport Button from '../../Button';\nimport Dropdown from '../../Dropdown';\n\nconst StyledLanguageMenu = styled.div`\n display: flex;\n flex-direction: column;\n padding: 1.6rem;\n gap: 1.6rem;\n\n button {\n max-width: fit-content;\n margin: 0 auto;\n }\n\n p {\n ${text('large')}\n font-weight: bold;\n\n span {\n font-weight: 400;\n }\n }\n`;\n\nconst LanguageMenu = () => {\n const countriesList = globalThis.LitiumConstants.countries;\n const [currentCountry, setCurrentCountry] = useState(\n countriesList[0].value\n );\n const [currentLanguage, setCurrentLanguage] = useState('test');\n return (\n \n ({\n value: country.value,\n label: country.text,\n }))}\n selectedValue={currentCountry}\n onChange={({ value }) => setCurrentCountry(value)}\n />\n setCurrentLanguage(value)}\n />\n

    \n {translate('general.currency')}: kr / SEK\n

    \n \n
    \n );\n};\n\nexport default LanguageMenu;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setMobileMenuOpen } from '../../Actions/Navigation.action';\nimport MobileNavigationItem from './ui/MobileNavigationItem';\nimport { translate } from '../../Services/translation';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport FHGuideNavigationCard from '../FloorHeatingGuide/FHGuideNavigationCard';\nimport {\n GlobalNavigationMobileStyling,\n StyledCloseIcon,\n StyledContent,\n StyledFHGuideNavigationCard,\n StyledHeader,\n StyledHeaderImg,\n StyledIconWrapper,\n StyledLinks,\n StyledMenuIcon,\n StyledSideMenu,\n StyledSocialWrapper,\n} from './styles/MobileMenu.styling';\nimport { ContentLinkModel } from '../../Types/ContentLinkModel';\nimport LanguageMenu from './ui/LanguageMenu';\nimport NavigatorCTAHeaderButton from '../NavigatorCTA/NavigatorCTAHeaderButton';\n\ninterface PreviousLinkModel extends ContentLinkModel {\n previousLink?: ContentLinkModel;\n}\n\nconst NavigationMobile = () => {\n const dispatch = useDispatch();\n const {\n mobileMenuOpen,\n logoUrl,\n contentLinks,\n phoneNumber,\n fhGuide,\n navigatorCTAHeaderButtonText,\n navigationCTAModalHeader,\n socialMediaLinks,\n } = useTypedSelector((state) => state.navigation);\n\n const [currentLink, setCurrentLink] = useState<\n ContentLinkModel | undefined\n >();\n const [previousLink, setPreviousLink] = useState<\n PreviousLinkModel | undefined\n >();\n const [languageMenuOpen, setLanguageMenuOpen] = useState(false);\n\n const Header = () => (\n \n {!currentLink && (\n <>\n \n dispatch(setMobileMenuOpen(false))}\n >\n \n \n \n )}\n {currentLink && (\n <>\n \n \n {translate('general.back')}\n \n dispatch(setMobileMenuOpen(false))}\n >\n \n \n \n )}\n \n );\n\n const Content = () => (\n \n {languageMenuOpen ? (\n \n ) : (\n \n {currentLink?.url && (\n \n )}\n {!currentLink && navigatorCTAHeaderButtonText && (\n
    \n \n
    \n )}\n {!currentLink && !navigatorCTAHeaderButtonText && fhGuide && (\n \n \n \n )}\n {links.map((link) => (\n \n ))}\n {!currentLink && phoneNumber && (\n <>\n \n \n )}\n
    \n )}\n
    \n );\n\n const footer = () => (\n <>\n {!currentLink && socialMediaLinks?.length && (\n \n {socialMediaLinks.map((social, index) => (\n \n \n \n ))}\n \n )}\n \n );\n const onLinkClick = (link) => {\n link.previousLink = previousLink;\n setPreviousLink(currentLink);\n setCurrentLink(link);\n };\n const onBackClick = () => {\n setPreviousLink(previousLink?.previousLink);\n setCurrentLink(previousLink);\n setLanguageMenuOpen(false);\n };\n const links = useMemo(\n () =>\n (!previousLink && currentLink?.mobileLinks\n ? currentLink.mobileLinks\n : currentLink?.links ?? contentLinks\n )\n .filter((l) => !l.rightAligned)\n .sort((a, b) => (b.links?.length ?? 0 > 0 ? 1 : -1)),\n [\n currentLink?.links,\n currentLink?.mobileLinks,\n previousLink,\n contentLinks,\n ]\n );\n useEffect(() => {\n if (mobileMenuOpen) {\n setCurrentLink(undefined);\n setLanguageMenuOpen(false);\n }\n }, [mobileMenuOpen]);\n return (\n <>\n dispatch(setMobileMenuOpen(false))}\n components={{ Header, Content, Footer: footer }}\n showCloseButton={false}\n >\n \n \n );\n};\nexport default NavigationMobile;\n","import React, { useCallback, useEffect } from 'react';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport { removeOverlay as removeOverlayAction } from '../Actions/Overlay.action';\nimport { useTypedSelector } from '../Hooks/useTypedSelector';\nimport { getColor } from '../styling/mixins/colors';\n\nconst OVERLAY_CLASS = 'overlay';\n\nconst StyledOverlay = styled.div`\n position: fixed;\n inset: 0;\n width: 100%;\n height: 100%;\n z-index: 30;\n animation: 0.2s ease-in-out 0s both 1 fade-in;\n -webkit-animation: 0.2s ease-in-out 0s both 1 fade-in;\n background-color: ${getColor('overlay')};\n opacity: 1;\n`;\n\nconst Overlay = () => {\n const dispatch = useDispatch();\n\n const { activeOverlays, disableOverlayClick } = useTypedSelector(\n (state) => state.overlay\n );\n\n const removeOverlay = (componentName: string) =>\n dispatch(removeOverlayAction(componentName));\n\n const overlayClasses = activeOverlays\n ? activeOverlays.map((c) => `${OVERLAY_CLASS}--${c.name}`)\n : [];\n /**\n * Adds overlay classes to body to enable styling on components based on active overlays\n */\n useEffect(() => {\n // Remove all overlay classes that are not active anymore, before adding new\n const classesToRemove = Array.from(document.body.classList).filter(\n (c) => c.startsWith(OVERLAY_CLASS) || c == OVERLAY_CLASS\n );\n if (classesToRemove && classesToRemove.length > 0) {\n for (let className of classesToRemove) {\n document.body.classList.remove(className);\n }\n }\n\n // Add overlay classes to body\n if (activeOverlays && activeOverlays.length > 0) {\n for (let className of overlayClasses) {\n document.body.classList.add(className);\n }\n }\n }, [activeOverlays]);\n\n /**\n * Removes all overlays.\n * Triggers onOverLay click on all active overlay components\n */\n const onOverlayClick = useCallback(() => {\n if (disableOverlayClick) return;\n\n for (let component of activeOverlays) {\n if (component.onOverlayClick) {\n if (component.onOverlayClick() !== false) {\n removeOverlay(component.name);\n }\n }\n }\n }, [activeOverlays, disableOverlayClick]);\n\n return (\n activeOverlays &&\n activeOverlays.length > 0 && (\n \n )\n );\n};\n\nexport default Overlay;\n","import React, { useEffect, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setBuyButtonArticleNumber } from '../../Actions/BuyButton.action';\nimport styled from 'styled-components';\nimport Dropdown, { DropdownOption } from '../Dropdown';\nimport { translate } from '../../Services/translation';\nimport Product from '../../Types/Product';\nimport {\n setProductPageSelectedVariant,\n setProductPageSelectedVariantQuery,\n} from '../../Actions/ProductPage.action';\nimport VariantPickerProps from './types/VariantPickerProps';\n\nconst FIRST_VARIANT_VALUE = 'firstVariantValue';\nconst SECOND_VARIANT_VALUE = 'secondVariantValue';\n\ninterface StyledVariantWrapperProps {\n $dropDownSize: 'small' | 'large' | undefined;\n}\n\nconst StyledVariantWrapper = styled.div`\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n margin-bottom: ${(p) => (p.$dropDownSize == 'small' ? '0.8rem' : '1.6rem')};\n`;\n\nconst VariantMultiPickerDropdown = ({\n variants,\n variantPickerOptions,\n hasSelectedVariant,\n productItem,\n}: {\n hasSelectedVariant: boolean;\n productItem: Product;\n variantPickerOptions: VariantPickerProps;\n}) => {\n let dispatch = useDispatch();\n const GetUniqueRows = (): DropdownOption[] => {\n var uniqueRowOptions = [\n ...new Map(\n variantPickerOptions.options.map((item) => [\n item[FIRST_VARIANT_VALUE],\n item,\n ])\n ).values(),\n ];\n\n return uniqueRowOptions.map((x) => {\n const isAnyEnabled = variantPickerOptions.options.some(\n (item) =>\n item[FIRST_VARIANT_VALUE] === x[FIRST_VARIANT_VALUE] && !item.disabled\n );\n\n return {\n value: x.variantId,\n label: x.firstVariantValue,\n disabled: !isAnyEnabled,\n legendLabel: x.firstVariantLabel\n };\n });\n };\n\n const GetUniqueColumns = (): DropdownOption[] => {\n var uniqueColumnOptions = [\n ...new Map(\n variantPickerOptions.options.map((item) => [\n item[SECOND_VARIANT_VALUE],\n item,\n ])\n ).values(),\n ];\n return uniqueColumnOptions.map((x) => {\n return {\n value: x.variantId,\n label: x.secondVariantValue,\n disabled: x.disabled,\n legendLabel: x.secondVariantLabel\n };\n });\n };\n\n const [rowOptions, setRowOptions] = useState>(\n GetUniqueRows()\n );\n const [columnOptions, setColumnOptions] = useState>(\n GetUniqueColumns()\n );\n const [hasVariant, setHasVariant] = useState(hasSelectedVariant);\n const [selectedVariant, setSelectedVariant] = useState(\n hasSelectedVariant ? productItem! : null\n );\n const [selectedRow, setSelectedRow] = useState(\n hasVariant\n ? variantPickerOptions.options.filter(\n (x) => x.variantId == productItem.id\n )[0].firstVariantValue\n : null\n );\n const [selectedColumn, setSelectedColumn] = useState(\n hasVariant\n ? variantPickerOptions.options.filter(\n (x) => x.variantId == productItem.id\n )[0].secondVariantValue\n : null\n );\n\n useEffect(() => {\n updateRowOptions();\n updateColumnOptions();\n if (selectedRow != '' && selectedColumn != '') {\n selectVariant();\n }\n }, [selectedRow, selectedColumn]);\n\n useEffect(() => {\n if (selectedVariant) {\n dispatch(setBuyButtonArticleNumber(selectedVariant?.id!));\n dispatch(setProductPageSelectedVariant(selectedVariant!));\n setProductPageSelectedVariantQuery(selectedVariant);\n }\n }, [selectedVariant]);\n\n const selectVariant = () => {\n let _selectedVariant = variantPickerOptions.options.find(\n (x) =>\n x.firstVariantValue == selectedRow &&\n x.secondVariantValue == selectedColumn\n );\n if (_selectedVariant) {\n let selectedVariantObj = variants.find(\n (v) => v.id == _selectedVariant.variantId\n );\n setSelectedVariant(selectedVariantObj);\n variantPickerOptions.setSelectedArticleNumber &&\n variantPickerOptions.setSelectedArticleNumber(\n _selectedVariant.variantId\n );\n } else {\n setSelectedVariant(undefined);\n variantPickerOptions.setSelectedArticleNumber &&\n variantPickerOptions.setSelectedArticleNumber('');\n setSelectedColumn('');\n }\n };\n\n const updateRowOptions = () => {\n if (selectedColumn != '') {\n var uniqueRowOptions = [\n ...new Map(\n variantPickerOptions.options\n .filter((x) => x.secondVariantValue == selectedColumn)\n .map((item) => [item[FIRST_VARIANT_VALUE], item])\n ).values(),\n ];\n var rowOptions = uniqueRowOptions.map((x) => {\n return {\n value: x.variantId,\n label: x.firstVariantValue,\n disabled: false,\n };\n });\n setRowOptions(rowOptions);\n } else {\n setRowOptions(GetUniqueRows());\n }\n };\n\n const updateColumnOptions = () => {\n if (selectedRow != '') {\n var uniqueColumnOptions = [\n ...new Map(\n variantPickerOptions.options.map((item) => [\n item[SECOND_VARIANT_VALUE],\n item,\n ])\n ).values(),\n ];\n\n var uniqueAvailableColumnOptions = [\n ...new Map(\n variantPickerOptions.options\n .filter((x) => x.firstVariantValue == selectedRow)\n .map((item) => [item[SECOND_VARIANT_VALUE], item])\n ).values(),\n ];\n\n var columnOptions = uniqueColumnOptions.map((x) => {\n return {\n value: x.variantId,\n label: x.secondVariantValue,\n legendLabel: x.secondVariantLabel,\n disabled: uniqueAvailableColumnOptions.find(\n (y) => y.secondVariantValue == x.secondVariantValue\n )\n ? false\n : true,\n };\n });\n setColumnOptions(columnOptions);\n } else {\n setColumnOptions(GetUniqueColumns());\n }\n };\n\n const onVariantRowChange = (event) => {\n setHasVariant(false);\n setSelectedRow(event.label);\n };\n\n const onVariantColumnChange = (event) => {\n setHasVariant(false);\n setSelectedColumn(event.label);\n };\n\n function compare(a, b) {\n if (a.label < b.label) {\n return -1;\n }\n if (a.label > b.label) {\n return 1;\n }\n return 0;\n }\n\n const getVariantValue = (product: Product, number: Number) => {\n return number == 1\n ? variantPickerOptions.options.filter((x) => x.variantId == product.id)[0]\n .variantId\n : columnOptions\n .sort(compare)\n .filter(\n (x) =>\n x.label ==\n variantPickerOptions.options.filter(\n (y) => y.variantId == product.id\n )[0].secondVariantValue\n )[0]?.value!;\n };\n\n return (\n \n \n \n \n );\n};\n\nexport default VariantMultiPickerDropdown;\n","import React, { useCallback, useEffect } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setBuyButtonArticleNumber } from '../../Actions/BuyButton.action';\nimport VariantPickerOption from './types/VariantPickerOption';\nimport VariantPickerProps from './types/VariantPickerProps';\nimport { createUseStyles } from 'react-jss';\nimport { Theme } from '../../styling/variables';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport styled from 'styled-components';\nimport buttons from '../../styling/utils/buttons';\nimport Button from '../Button';\nimport { getColor } from '../../styling/mixins/colors';\n\ninterface VariantButtonStylingProps {\n selected?: boolean;\n}\nconst StyledVariantWrapper = styled.div`\n display: flex;\n gap: 0.4rem;\n`;\n\nconst StyledVariantButton = styled(Button)`\n height: 40px;\n min-width: 40px;\n background-color: ${(props) =>\n props.selected ? getColor('primary', 50) : null};\n`;\n\nconst VariantPickerButtons = ({\n options,\n selectedValue,\n}: VariantPickerProps) => {\n const dispatch = useDispatch();\n\n const { articleNumber } = useTypedSelector((state) => state.buyButton);\n\n const onClick = useCallback(\n (option: VariantPickerOption) => {\n dispatch(setBuyButtonArticleNumber(option.value));\n },\n [dispatch]\n );\n\n useEffect(() => {\n if (selectedValue) {\n let option = options.find((opt) => opt.value == selectedValue);\n setTimeout(() => option && onClick(option), 1);\n }\n }, [dispatch, selectedValue, onClick, options]);\n\n return (\n \n {options.map((opt, idx) => (\n onClick(opt)}\n key={'variant-picker' + opt.value + idx}\n selected={opt.value == articleNumber}\n >\n {opt.label}\n \n ))}\n \n );\n};\n\nexport default VariantPickerButtons;\n","import styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { header, text } from '../../../styling/mixins/typography';\n\nexport const StyledLogin = styled.div`\n h3 {\n ${header('h1')}\n }\n\n .form {\n margin-top: 2.4rem;\n }\n\n .input__wrapper:not(:last-child) {\n margin-bottom: 1.6rem;\n }\n\n .submit {\n margin-top: 1.6rem;\n }\n\n .additional {\n display: flex;\n flex-direction: column;\n align-items: center;\n text-align: center;\n margin-top: 2.4rem;\n\n &__btn {\n text-decoration: underline;\n }\n }\n\n .error {\n ${text('small')}\n color: ${getColor('alert')};\n margin-bottom: 1.6rem;\n }\n`;\n","import React, { useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport { submitChangePassword } from '../../../Actions/Login.action';\nimport { useTypedSelector } from '../../../Hooks/useTypedSelector';\nimport { translate } from '../../../Services/translation';\nimport Button from '../../Button';\nimport Input from '../../Inputs/Input';\nimport { StyledLogin } from '../styles/LoginForm.styles';\n\nconst StyledChangePasswordForm = styled(StyledLogin)``;\n\nconst LoginChangePassword = () => {\n const { isLoading, username = '', password = '' } = useTypedSelector(\n (state) => state.login\n );\n const [newPassword, setNewPassword] = useState('');\n const [passwordConfirmation, setPasswordConfirmation] = useState('');\n const dispatch = useDispatch();\n\n const onSubmit = (e?: any) => {\n if (e) {\n e.preventDefault();\n }\n dispatch(\n submitChangePassword(\n username,\n password,\n newPassword,\n passwordConfirmation\n )\n );\n };\n\n return (\n \n

    {translate('login.change-password')}

    \n
    \n setNewPassword(e.target.value)}\n placeholder={translate('general.password')}\n type=\"password\"\n disabled={isLoading}\n />\n setPasswordConfirmation(e.target.value)}\n placeholder={translate('login.confirm-password')}\n type=\"password\"\n disabled={isLoading}\n />\n \n {!isLoading && translate('general.send')}\n {isLoading && translate('general.loading')}\n \n \n
    \n );\n};\n\nexport default LoginChangePassword;\n","import React, { useEffect, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport {\n submitForgotPassword,\n setUsername,\n setLoginMode,\n submitMagicLink,\n} from '../../../Actions/Login.action';\nimport { useTypedSelector } from '../../../Hooks/useTypedSelector';\nimport { translate } from '../../../Services/translation';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport LoginMode from '../../../Types/LoginMode';\nimport Button from '../../Button';\nimport Input from '../../Inputs/Input';\nimport { StyledLogin } from '../styles/LoginForm.styles';\n\nconst StyledForgotPasswordForm = styled(StyledLogin)`\n p {\n ${text('medium')}\n margin-top: 1.6rem;\n }\n .error {\n margin-top: 0;\n color: ${getColor('alert')};\n }\n`;\n\nconst LoginForgotPassword = () => {\n const { username = '', isLoading, magicLinkModel } = useTypedSelector(\n (state) => state.login\n );\n const [isSuccessful, setIsSuccessful] = useState(false);\n const dispatch = useDispatch();\n\n const onSubmit = (e?: any) => {\n if (e) {\n e.preventDefault();\n }\n dispatch(submitForgotPassword(username)).then((success) =>\n setIsSuccessful(success)\n );\n };\n\n useEffect(() => {\n // Send magic link on first render only, if magic link model is in state\n if (!magicLinkModel?.link) return;\n dispatch(submitMagicLink(magicLinkModel));\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n return (\n \n

    \n {!magicLinkModel ? (\n translate('login.forgot-password')\n ) : (\n <>{translate('general.loading')}...\n )}\n

    \n {!isSuccessful && !magicLinkModel && (\n <>\n
    \n dispatch(setUsername(e.target.value))}\n placeholder={translate('general.username')}\n />\n \n {!isLoading && translate('general.send')}\n {isLoading && translate('general.loading')}\n \n \n
    \n dispatch(setLoginMode(LoginMode.Login))}\n disabled={isLoading}\n btnType=\"clear\"\n btnSize=\"large\"\n >\n {!isLoading && translate('general.back')}\n {isLoading && translate('general.loading')}\n \n
    \n \n )}\n {isSuccessful && (\n <>\n

    \n {translate('login.forgot-password.success')}\n

    \n
    \n dispatch(setLoginMode(LoginMode.Login))}\n btnType=\"clear\"\n btnSize=\"large\"\n >\n {translate('general.back')}\n \n
    \n \n )}\n
    \n );\n};\n\nexport default LoginForgotPassword;\n","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport {\n performLogin as performLoginAction,\n setLoginMode,\n setPassword,\n setUsername,\n} from '../../../Actions/Login.action';\nimport { useTypedSelector } from '../../../Hooks/useTypedSelector';\nimport { translate } from '../../../Services/translation';\nimport LoginMode from '../../../Types/LoginMode';\nimport Button from '../../Button';\nimport Input from '../../Inputs/Input';\nimport { StyledLogin } from '../styles/LoginForm.styles';\n\nconst StyledLoginForm = styled(StyledLogin)``;\n\nconst LoginForm = () => {\n const { isLoading, username = '', password = '' } = useTypedSelector(\n (state) => state.login\n );\n const dispatch = useDispatch();\n\n const performLogin = (e?: any) => {\n if (e) {\n e.preventDefault();\n }\n dispatch(performLoginAction(username, password));\n };\n\n return (\n \n

    {translate('general.login')}

    \n
    \n dispatch(setUsername(e.target.value))}\n disabled={isLoading}\n />\n dispatch(setPassword(e.target.value))}\n disabled={isLoading}\n type=\"password\"\n />\n \n {!isLoading && translate('general.login')}\n {isLoading && translate('general.loading')}\n \n \n
    \n dispatch(setLoginMode(LoginMode.ForgotPassword))}\n disabled={isLoading}\n className=\"additional__btn\"\n >\n {translate('login.forgot-password')}\n \n
    \n
    \n );\n};\n\nexport default LoginForm;\n","import React, { useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\nimport { selectOrganization } from '../../../Actions/Login.action';\nimport { useTypedSelector } from '../../../Hooks/useTypedSelector';\nimport { translate } from '../../../Services/translation';\nimport Button from '../../Button';\nimport Dropdown from '../../Dropdown';\nimport { StyledLogin } from '../styles/LoginForm.styles';\n\nconst StyledOrganizationForm = styled(StyledLogin)`\n .title {\n margin-bottom: 2.4rem;\n }\n\n .button {\n margin-top: 3.2rem;\n }\n`;\n\nconst LoginSelectOrganization = () => {\n const dispatch = useDispatch();\n const { organizations, isLoading } = useTypedSelector((state) => state.login);\n const [selectedOrganizationId, setSelectedOrganizationId] = useState<\n string | undefined\n >();\n\n return organizations ? (\n \n

    {translate('login.choose-organization')}

    \n setSelectedOrganizationId(value)}\n options={organizations.map((org) => ({\n value: org.systemId,\n label: org.name,\n }))}\n disabled={isLoading}\n />\n \n selectedOrganizationId &&\n dispatch(selectOrganization(selectedOrganizationId))\n }\n disabled={isLoading || !selectedOrganizationId}\n >\n {!isLoading && translate('general.select')}\n {isLoading && translate('general.loading')}\n \n
    \n ) : null;\n};\n\nexport default LoginSelectOrganization;\n","import React from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport LoginMode from '../../Types/LoginMode';\nimport LoginChangePassword from './ui/LoginChangePassword';\nimport LoginForgotPassword from './ui/LoginForgotPassword';\nimport LoginForm from './ui/LoginForm';\nimport LoginSelectOrganization from './ui/LoginSelectOrganization';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\n\nconst StyledLoginError = styled.div`\n ${text('medium')}\n color: ${getColor('alert')};\n margin-bottom: 1.6rem;\n`;\n\nconst LoginContainer = () => {\n const { loginMode, error } = useTypedSelector((state) => state.login);\n\n return (\n <>\n {error && {error}}\n {loginMode == LoginMode.Login && }\n {loginMode == LoginMode.SelectOrganization && }\n {loginMode == LoginMode.ChangePassword && }\n {loginMode == LoginMode.ForgotPassword && }\n \n );\n};\n\nexport default LoginContainer;\n","import React, { useMemo } from 'react';\nimport { useDispatch } from 'react-redux';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport { setLoginModalOpen } from '../../Actions/Login.action';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport LoginMode from '../../Types/LoginMode';\nimport LoginContainer from './LoginContainer';\nimport SideMenu from '../SideMenu/SideMenu';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { getColor } from '../../styling/mixins/colors';\n\nconst StyledLoginModal = styled(SideMenu)`\n z-index: 60;\n\n ${breakpoint('small')} {\n border-left: 1px solid ${getColor('grey', 300)};\n }\n\n .content {\n padding: 4rem 2.4rem;\n }\n`;\n\nconst GlobalLoginModalStyling = createGlobalStyle`\n body #overlay-container .overlay--login-modal {\n z-index: 55;\n }\n`;\n\nconst LoginModal = () => {\n const { modalOpen, loginMode, isLoading } = useTypedSelector(\n (state) => state.login\n );\n const dispatch = useDispatch();\n const disableClosing = useMemo(\n () =>\n loginMode == LoginMode.ChangePassword ||\n loginMode == LoginMode.SelectOrganization,\n [loginMode]\n );\n\n return (\n dispatch(setLoginModalOpen(false))}\n disableClosing={disableClosing || isLoading}\n >\n
    \n \n
    \n \n \n );\n};\n\nexport default LoginModal;\n","import React from 'react';\nimport LoginContainer from './LoginContainer';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { section, grid } from '../../styling/utils/grid';\n\nconst StyledLoginContainer = styled.div`\n ${section}\n ${grid}\n padding-top: 2.4rem;\n padding-bottom: 2.4rem;\n place-items: center;\n\n ${breakpoint('medium')} {\n padding-top: 3.2rem;\n padding-bottom: 3.2rem;\n }\n\n ${breakpoint('large')} {\n padding-top: 4rem;\n padding-bottom: 4rem;\n }\n`;\n\nconst StyledLoginWrapper = styled.div`\n width: 100%;\n\n ${breakpoint('small')} {\n max-width: 480px;\n }\n`;\nconst LoginPage = () => {\n return (\n \n \n \n \n \n );\n};\nexport default LoginPage;\n","import Icon from '../Icon';\nimport React from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setLoginModalOpen } from '../../Actions/Login.action';\nimport styled from 'styled-components';\n\nconst StyledLoginIcon = styled(Icon)`\n font-size: 2rem;\n cursor: pointer;\n`;\nconst LoginModalTrigger = () => {\n const dispatch = useDispatch();\n return (\n dispatch(setLoginModalOpen(true))}\n />\n );\n};\nexport default LoginModalTrigger;\n","import React from 'react';\nimport styled, { useTheme } from 'styled-components';\nimport { breakpoint } from '../styling/mixins/breakpoints';\nimport { getColor } from '../styling/mixins/colors';\nimport Button from './Button';\nimport Checkbox from './Inputs/Checkbox';\nimport Input from './Inputs/Input';\nimport RadioButton from './Inputs/Radiobutton';\nimport TextArea from './Inputs/TextArea';\nimport FilterRangeSlider from './ProductFiltering/FilterOptions/FilterRangeSlider';\nimport { FilterGroupType } from './ProductFiltering/types/FilterGroupType';\n\nconst Wrapper = styled.div`\n background-color: ${(props) => props.color};\n color: ${(props) => props.theme.colors.primary};\n font-size: 32px;\n padding: 0 120px;\n\n .xD {\n background-color: cyan;\n }\n`;\n\nconst StyledSpan = styled.span`\n background-color: ${getColor('grey', 800)};\n ${breakpoint('large')} {\n background-color: red;\n }\n`;\n\nconst Test = ({ color }: { color: string }) => {\n return (\n \n Test\n \n \n \n \n \n \n \n \n );\n};\n\nexport default Test;\n","import { PRICE_HISTORY_SET_MODAL_OPEN } from '../constants';\n\nexport const setPriceHistoryModalOpen = (\n modalOpen: boolean,\n previouslyLowestPrice: string,\n numberOfDays: number,\n description: string,\n title: string\n) => {\n const action = {\n type: PRICE_HISTORY_SET_MODAL_OPEN,\n payload: {\n modalOpen,\n previouslyLowestPrice,\n numberOfDays,\n description,\n title,\n },\n };\n return action;\n};\n","import Icon from '../Icon';\nimport React from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setPriceHistoryModalOpen } from '../../Actions/PriceHistory.actions';\nimport styled from 'styled-components';\nimport PriceModal from '../../Types/PriceModal';\n\nconst StyledPriceHistoryIcon = styled(Icon)`\n font-size: 2rem;\n cursor: pointer;\n margin-left: 1.2rem;\n #price-history-icon {\n font-size: 2rem;\n font-weight: normal;\n vertical-align: top;\n cursor: pointer;\n height: 20px;\n width: 20px;\n }\n`;\nconst PriceHistoryModalTrigger = (productPriceHistory: PriceModal) => {\n const {\n title,\n previouslyLowestPrice,\n numberOfDays,\n description,\n } = productPriceHistory;\n const dispatch = useDispatch();\n return (\n \n dispatch(\n setPriceHistoryModalOpen(\n true,\n previouslyLowestPrice,\n numberOfDays,\n description,\n title\n )\n )\n }\n >\n \n \n );\n};\nexport default PriceHistoryModalTrigger;\n","import React from 'react';\nimport { LinkModel } from '../../Types/LinkModel';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { cells, section } from '../../styling/utils/grid';\nimport Icon from '../../Components/Icon';\nimport { getColor } from '../../styling/mixins/colors';\nimport { btn } from '../../styling/mixins/buttons';\n\ninterface LinkBlockProps {\n links: LinkBlockItem[];\n title?: string;\n allowThumbnails: boolean;\n}\n\ninterface LinkBlockItem {\n thumbnailUrl?: string;\n link: LinkModel;\n}\n\ninterface LinkBlockWrapperProps {\n $allowThumbnails: boolean;\n}\n\nconst StyledLinkBlock = styled.div`\n ${section}\n`;\n\nconst StyledWrapper = styled.div`\n display: grid;\n gap: 1.6rem;\n position: relative;\n\n ${breakpoint('small')} {\n ${cells(2)}\n }\n ${breakpoint('large')} {\n ${cells(4)}\n gap: 2.4rem;\n }\n`;\n\nconst StyledLink = styled.a<{ $allowThumbnails: boolean }>`\n ${(p) => (!p.$allowThumbnails ? btn('clear', 'large') : null)};\n background-color: ${getColor('grey', 100)};\n padding: 0;\n\n img {\n object-fit: cover;\n max-height: 160px;\n height: 100%;\n width: 100%;\n }\n\n .content {\n display: flex;\n gap: 0.8rem;\n align-items: center;\n padding: 0.8rem 0.8rem 0.8rem 1.6rem;\n border: none;\n width: 100%;\n }\n\n .link-text-wrapper {\n flex: 1;\n }\n\n &:hover .icon {\n background-color: ${getColor('primary', 600)};\n }\n`;\n\nconst StyledIcon = styled(Icon)`\n && {\n width: 4rem;\n height: 4rem;\n font-size: 2.4rem;\n padding: 0.8rem;\n background-color: ${getColor('primary')};\n }\n`;\n\nconst StyledHeader = styled.h2`\n margin-bottom: 1.6rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 2.4rem;\n }\n`;\n\nconst LinkBlock = ({ links, title, allowThumbnails }: LinkBlockProps) => {\n const Link = React.memo<{ item: LinkBlockItem }>(({ item }) => (\n \n {allowThumbnails && item.thumbnailUrl && (\n {item.link.text}\n )}\n
    \n
    \n
    {item.link.text}
    \n
    \n \n
    \n
    \n ));\n\n return (\n \n {title ? {title} : null}\n \n {links.map((item, idx) => (\n \n ))}\n \n \n );\n};\n\nexport default LinkBlock;\n","import React from 'react';\nimport { LinkModel } from '../../Types/LinkModel';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { cells, section } from '../../styling/utils/grid';\nimport { getColor } from '../../styling/mixins/colors';\nimport { btn } from '../../styling/mixins/buttons';\n\ninterface LinkCardBlockProps {\n links: LinkCardBlockItem[];\n title?: string;\n allowThumbnails: boolean;\n}\n\ninterface LinkCardBlockItem {\n thumbnailUrl?: string;\n link: LinkModel;\n}\n\ninterface LinkCardBlockWrapperProps {\n $allowThumbnails: boolean;\n}\n\nconst StyledLinkBlock = styled.div`\n ${section}\n`;\n\nconst StyledWrapper = styled.div`\n display: flex;\n gap: 2.4rem;\n position: relative;\n justify-content: center;\n flex-wrap: wrap;\n`;\n\nconst StyledLink = styled.a<{ $allowThumbnails: boolean }>`\n ${(p) => (!p.$allowThumbnails ? btn('clear', 'large') : null)};\n padding: 0;\n display: flex;\n flex: 1;\n max-width: calc(1656px / 4);\n min-width: 300px;\n\n img {\n aspect-ratio: 3/2;\n object-fit: cover;\n max-height: 250px;\n width: 100%;\n }\n\n .content {\n padding: 1.6rem;\n width: 100%;\n flex: 1;\n\n ${breakpoint('medium')} {\n padding: 2.4rem;\n }\n }\n\n &:hover .icon {\n background-color: ${getColor('primary', 600)};\n }\n`;\n\nconst StyledLinkCard = styled.div`\n display: flex;\n flex-direction: column;\n background-color: ${getColor('white')};\n width: 100%;\n`;\n\nconst StyledHeader = styled.h2`\n margin-bottom: 1.6rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 2.4rem;\n }\n`;\n\nconst LinkCardBlock = ({\n links,\n title,\n allowThumbnails,\n}: LinkCardBlockProps) => {\n const Link = React.memo<{ item: LinkCardBlockItem }>(({ item }) => (\n \n \n {allowThumbnails && item.thumbnailUrl && (\n {item.link?.text}\n )}\n
    \n

    {item.link?.text}

    \n
    \n
    \n
    \n ));\n\n return (\n \n {title ? {title} : null}\n \n {links.map((item, idx) => (\n \n ))}\n \n \n );\n};\n\nexport default LinkCardBlock;\n","import React from 'react';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { LinkModel } from '../../Types/LinkModel';\nimport { ResponsiveImageModel } from '../../Types/ResponsiveImageModel';\nimport OrderDetail from '../OrderDetail/OrderDetail';\n\nconst StyledOrderConfirmationWrapper = styled.div``;\n\nexport interface ConfirmationReviewItem {\n link: LinkModel;\n imageUrl: string;\n responsiveImage: ResponsiveImageModel;\n}\n\nconst GlobalOrderConfirmationStyling = createGlobalStyle`\nbody {\n background-color: ${getColor('grey', 100)};\n}\n`;\n\nconst OrderConfirmation = ({ title, text, order, extraText, reviewItems }) => {\n return (\n \n {order && (\n \n )}\n \n \n );\n};\n\nexport default OrderConfirmation;\n","import React from 'react';\nimport { LinkModel } from '../Types/LinkModel';\nimport styled from 'styled-components';\nimport { grid } from '../styling/utils/grid';\nimport { breakpoint } from '../styling/mixins/breakpoints';\nimport { text } from '../styling/mixins/typography';\n\ninterface BrandsBlockProps {\n title?: string;\n brands: BrandItem[];\n link?: LinkModel;\n}\n\ninterface BrandItem {\n link: LinkModel;\n imageUrl?: string;\n}\n\nconst StyledWrapper = styled.div`\n padding-top: 2.4rem;\n padding-bottom: 3.2rem;\n\n ${breakpoint('medium')} {\n padding-top: 3.2rem;\n padding-bottom: 4rem;\n }\n\n ${breakpoint('large')} {\n padding-top: 4rem;\n padding-bottom: 4.8rem;\n }\n`;\n\nconst StyledBlockHeader = styled.div`\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-bottom: 2.4rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 3.2rem;\n }\n\n a {\n ${text('xlarge')}\n text-decoration: underline;\n }\n`;\n\nconst StyledBrandsList = styled.ul<{ $brandsCount: number }>`\n display: grid;\n justify-content: center;\n align-items: center;\n padding: 0 0.8rem;\n gap: 1.6rem;\n grid-template-columns: repeat(${(p) => Math.min(p.$brandsCount, 2)}, 1fr);\n ${breakpoint('medium')} {\n grid-template-columns: repeat(${(p) => Math.min(p.$brandsCount, 3)}, 1fr);\n }\n ${breakpoint('large')} {\n grid-template-columns: repeat(${(p) => Math.min(p.$brandsCount, 6)}, 1fr);\n gap: 2.4rem;\n }\n`;\n\nconst StyledBrandItem = styled.li`\n height: 100%;\n\n a {\n display: flex;\n justify-content: center;\n height: 100%;\n }\n\n img {\n aspect-ratio: 1/1;\n object-fit: contain;\n }\n`;\n\nconst BrandsBlock = ({ title, link, brands }: BrandsBlockProps) => {\n return (\n \n \n

    {title}

    \n {link && {link.text}}\n
    \n \n {brands.map((brand) => (\n \n \n {brand.imageUrl && (\n \n )}\n \n \n ))}\n \n
    \n );\n};\n\nexport default BrandsBlock;\n","import React, { useState } from 'react';\nimport { Collapse } from 'react-collapse';\nimport { useCookies } from 'react-cookie';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport Icon from '../Icon';\n\ninterface StyledTopMessageProps {\n bgColor?: string;\n textColor?: string;\n}\n\nconst StyledTopMessageWrapper = styled.div`\n position: relative;\n background-color: ${(p)=>p.bgColor};\n text-align: center;\n`;\n\nconst StyledTopMessage = styled.a`\n color: ${(p)=>p.textColor};\n ${text('medium')}\n display: block;\n padding: 0.8rem 3.6rem 0.8rem 1.6rem;\n width: 100%;\n & a {\n color: ${(p)=>p.textColor} !important;\n }\n`;\n\nconst StyledCloseIcon = styled(Icon)`\n color: ${(p)=>p.textColor};\n font-size: 3.6rem;\n padding: 0.8rem;\n position: absolute;\n right: 0;\n top: 50%;\n transform: translateY(-50%);\n cursor: pointer;\n`;\n\nconst TopMessage = ({ systemId, message, link, backgroundColor, textColor }) => {\n const [isOpen, setIsOpen] = useState(true);\n const [_, setCookie] = useCookies([`top-message-${systemId}-visible`]);\n\n return (\n <>\n {message.value && (\n \n 0 ? backgroundColor : getColor('orange')}\n >\n 0 ? textColor : getColor('white')}\n href={link}\n as={!link ? 'span' : 'a'}\n dangerouslySetInnerHTML={{\n __html: message.value,\n }}\n >\n 0 ? textColor : getColor('white')}\n name=\"close\"\n onClick={() => {\n setCookie(`top-message-${systemId}-visible`, 'close');\n setIsOpen(false);\n }}\n />\n \n \n )}\n \n );\n};\n\nexport default TopMessage;\n","import React from 'react';\nimport styled from 'styled-components';\nimport Collapsible from '../Components/Collapsible';\nimport { breakpoint } from '../styling/mixins/breakpoints';\nimport { getColor } from '../styling/mixins/colors';\nimport { text } from '../styling/mixins/typography';\nimport { section } from '../styling/utils/grid';\nimport { EditorStringModel } from '../Types/EditorString';\nimport EditorString from '../Components/EditorString/EditorString';\n\ninterface FaqAccordionProps {\n systemId: string;\n title: string;\n faqItems: FaqAccordionItem[];\n}\n\ninterface FaqAccordionItem {\n title?: string;\n text?: EditorStringModel;\n}\n\nconst StyledFaqWrapper = styled.div`\n ${section}\n display: flex;\n flex-direction: column;\n align-items: center;\n`;\n\nconst StyledCollapsible = styled(Collapsible)`\n background-color: ${getColor('grey', 100)};\n max-width: 768px;\n width: 100%;\n\n &.collapsible {\n border: none;\n\n &:last-child {\n border: none;\n }\n\n &:not(:last-child) {\n margin-bottom: 0.8rem;\n }\n\n label {\n padding: 0.8rem 0.8rem 0.8rem 1.6rem;\n }\n\n .icon-wrapper {\n width: 40px;\n height: 40px;\n background-color: ${getColor('primary')};\n\n .icon {\n font-size: 2.4rem;\n }\n }\n\n .ReactCollapse--content {\n ${text('large')}\n padding: 1.6rem;\n background-color: ${getColor('white')};\n border: 1px solid ${getColor('grey', 100)};\n border-top: none;\n }\n }\n`;\n\nconst FaqAccordion = (props: FaqAccordionProps) => {\n const faqList = props.faqItems;\n\n return (\n \n {faqList.map((faq) => (\n \n \n \n ))}\n \n );\n};\n\nexport default FaqAccordion;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport FloorHeatingCardProps from './types/FHGuideCardProps';\nimport Icon from '../Icon';\nimport EditorString from '../EditorString/EditorString';\n\ninterface StyledFloorGuideCardProps {\n $backgroundUrl?: string;\n}\n\nconst StyledFloorGuideCard = styled.a`\n display: flex;\n align-items: center;\n padding: 0.8rem 1.6rem;\n gap: 1.2rem;\n background-color: ${getColor('graphic')};\n background-image: url(${(p) => p.$backgroundUrl});\n background-size: cover;\n`;\n\nconst StyledGuideCardImg = styled.img`\n width: 56px;\n height: 56px;\n object-fit: cover;\n`;\n\nconst StyledGuideCardDescription = styled.div`\n display: flex;\n flex-direction: column;\n flex: 1;\n color: ${getColor('white')};\n\n .desc-title {\n margin-bottom: 0.4rem;\n }\n\n div {\n ${text('small')}\n }\n`;\n\nconst StyledGuideCardIcon = styled(Icon)`\n font-size: 2.4rem;\n color: ${getColor('primary')};\n`;\n\nconst FloorGuideCard = ({\n title,\n description,\n imageUrl,\n backgroundUrl,\n link,\n}: FloorHeatingCardProps) => {\n return (\n \n \n \n
    {title}
    \n \n
    \n \n \n );\n};\n\nexport default FloorGuideCard;\n","import React from 'react';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../styling/mixins/breakpoints';\nimport { text } from '../styling/mixins/typography';\nimport { cells, section } from '../styling/utils/grid';\nimport EditorString from '../Components/EditorString/EditorString';\nimport { EditorStringModel } from '../Types/EditorString';\nimport { getColor } from '../styling/mixins/colors';\n\ninterface UspBlockProps {\n title?: string;\n items: UspItem[];\n}\n\ninterface UspItem {\n title: string;\n imageUrl: string;\n text: EditorStringModel;\n}\n\nconst GlobalUspStyling = createGlobalStyle`\n.usp-block__container {\n background: linear-gradient(125deg, #F5E597 15%, #EED351 75%);\n}\n`;\n\nconst StyledUspWrapper = styled.div`\n ${section}\n padding-top: 2.4rem;\n padding-bottom: 2.4rem;\n\n ${breakpoint('medium')} {\n padding-top: 2.4rem;\n padding-bottom: 2.4rem;\n }\n ${breakpoint('large')} {\n padding-top: 4rem;\n padding-bottom: 4rem;\n }\n`;\n\nconst StyledUspList = styled.ul`\n display: grid;\n ${cells(2)}\n gap: 1.6rem;\n\n ${breakpoint('medium')} {\n ${cells(4)}\n }\n`;\n\nconst StyledUspItem = styled.li`\n display: flex;\n flex-direction: column;\n align-items: center;\n\n img {\n margin-bottom: 1.6rem;\n height: 40px;\n width: 40px;\n max-height: 40px;\n max-width: 40px;\n width: 100%;\n padding: 0.8rem;\n background-color: ${getColor('white')};\n border-radius: 50%;\n }\n\n h6 {\n margin-bottom: 0.8rem;\n text-align: center;\n }\n\n div {\n ${text('medium')}\n text-align: center;\n max-width: 320px;\n }\n`;\n\nconst UspBlock = ({ items, title }: UspBlockProps) => {\n return (\n \n \n {items.map((item, index) => (\n \n {item.title}\n
    {item.title}
    \n \n
    \n ))}\n
    \n \n
    \n );\n};\n\nexport default UspBlock;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { getColor } from '../../styling/mixins/colors';\nimport { section } from '../../styling/utils/grid';\nimport Button from '../Button';\nimport { translate } from '../../Services/translation';\nimport EditorString from '../EditorString/EditorString';\nconst MAX_DESCRIPTION_LENGTH = 360;\nconst DESC_HEADER1_TAG = '

    ';\nconst DESC_HEADER2_TAG = '

    ';\n\nconst StyledCategoryDescription = styled.div<{ $showMore: boolean }>`\n ${section}\n padding-top: 1.6rem;\n padding-bottom: 2.4rem;\n\n ${breakpoint('medium')} {\n padding-bottom: 3.2rem;\n }\n\n ${breakpoint('large')} {\n margin-bottom: 3.2rem;\n }\n\n .content {\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n\n ${breakpoint('large')} {\n max-width: 660px;\n }\n }\n\n .content__text {\n position: relative;\n max-height: ${(p) => (p.$showMore ? '160px' : 'unset')};\n overflow: hidden;\n -webkit-mask-image: ${(p) =>\n p.$showMore ? 'linear-gradient(#000 92%, transparent 100%)' : 'none'};\n }\n`;\n\nconst StyledExpandButton = styled(Button)`\n text-transform: uppercase;\n font-weight: bold;\n border: none;\n border-bottom: 2px solid ${getColor('primary')};\n max-width: max-content;\n padding: 0;\n\n &:not(:disabled):hover {\n background-color: transparent;\n border-color: ${getColor('primary', 600)};\n }\n`;\n\nconst GlobalCategoryDescriptionStyling = createGlobalStyle`\n.category-page .breadcrumbs__container, .category-description {\n background-color: ${getColor('grey', 100)};\n}`;\n\nconst CategoryDescription = ({ name, description }) => {\n const [showMore, setShowMore] = useState(true);\n const descriptionLength = useMemo(() => description?.length, [description]);\n\n useEffect(() => {\n setShowMore(descriptionLength >= MAX_DESCRIPTION_LENGTH);\n }, [descriptionLength]);\n\n return (\n \n
    \n
    \n {name &&\n !description?.includes(DESC_HEADER1_TAG) &&\n !description?.includes(DESC_HEADER2_TAG) ? (\n

    {name}

    \n ) : null}\n {description && }\n
    \n {descriptionLength >= MAX_DESCRIPTION_LENGTH && (\n setShowMore(!showMore)}\n >\n {!showMore\n ? translate('general.showless')\n : translate('general.showmore')}\n \n )}\n
    \n \n \n );\n};\n\nexport default CategoryDescription;\n","import React from 'react';\nimport { EditorStringModel as EditorStringType } from '../../Types/EditorStringModel';\nimport RadioButton from '../Inputs/Radiobutton';\nimport Input from '../Inputs/Input';\nimport debounce from 'lodash-es/debounce';\n\ninterface FHGuideModuleItemProps {\n title: string;\n description: EditorStringType;\n checked: boolean;\n index: number;\n onChange: Function;\n type: string;\n}\n\nconst FHGuideModuleItem = (props: FHGuideModuleItemProps) => {\n const setInputValue = debounce((val) => handleInputChange(val), 400);\n\n const handleOnChange = () => {\n props.onChange(props.index);\n };\n\n const handleInputChange = (val) => {\n props.onChange(!isNaN(val) && val > 0 ? val : -1);\n };\n\n return (\n
    \n {props.type === 'input' ? (\n setInputValue(e.target.value)}\n type=\"number\"\n wrapperClassName=\"FHGuide__selection-input\"\n />\n ) : (\n \n )}\n {props.description}\n
    \n );\n};\n\nexport default FHGuideModuleItem;\n","import React, { useState } from 'react';\nimport { EditorStringModel as EditorStringType } from '../../Types/EditorStringModel';\nimport FHGuideModuleItem from './_fhGuideContainerModuleItem';\n\ninterface FHGuideModuleProps {\n module: FHGuideModuleProps;\n title: string;\n description: EditorStringType;\n helpText?: string;\n type: string;\n handleIsSelected: Function;\n index: number;\n}\n\nconst FHGuideModule = ({\n module,\n title,\n description,\n helpText,\n type,\n handleIsSelected,\n index,\n}: FHGuideModuleProps) => {\n const [selected, setSelected] = useState(-1);\n\n const onChange = (itemIndex) => {\n setSelected(itemIndex);\n handleIsSelected(index, itemIndex);\n };\n\n return (\n
    \n {title && (\n
    \n

    {index + 1}

    \n

    {title}

    \n
    \n )}\n
    \n {helpText &&
    {helpText}
    }\n {description &&
    {description}
    }\n {module &&\n module.length > 0 &&\n module.map((module, index) => (\n \n ))}\n
    \n
    \n );\n};\n\nexport default FHGuideModule;\n","import { breakpoint } from '../../../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { cells, section } from '../../../styling/utils/grid';\nimport { text } from '../../../styling/mixins/typography';\nimport { hideFor, showFor } from '../../../styling/utils/visibility';\n\nexport const StyledFHContainer = styled.div`\n ${section}\n padding-bottom: 2.4rem;\n ${breakpoint('medium')} {\n padding-bottom: 3.2rem;\n }\n ${breakpoint('large')} {\n padding-bottom: 4rem;\n }\n .module-container {\n display: flex;\n flex-direction: column;\n max-width: 1100px;\n gap: 1.6rem;\n margin: 0 auto 2.4rem auto;\n\n ${breakpoint('medium')} {\n margin: 0 auto 3.2rem auto;\n }\n ${breakpoint('large')} {\n gap: 2.4rem;\n }\n }\n\n .FHGuide {\n &__container-title {\n text-align: center;\n margin-bottom: 0.8rem;\n }\n\n &__desc {\n max-width: 800px;\n text-align: center;\n margin: 0 auto 1.6rem auto;\n ${breakpoint('medium')} {\n margin: 0 auto 2.4rem auto;\n }\n }\n\n &__item {\n display: flex;\n flex-direction: column;\n width: 100%;\n }\n\n &__title-wrapper {\n height: 64px;\n display: flex;\n background-color: ${getColor('graphic')};\n }\n\n &__title-index {\n width: 64px;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: ${getColor('primary')};\n color: ${getColor('graphic')};\n }\n\n &__title {\n display: flex;\n align-items: center;\n padding: 0 1.6rem;\n color: ${getColor('white')};\n }\n\n &__content {\n flex: 1;\n padding: 2.4rem 1.6rem;\n border: 1px solid ${getColor('grey', 300)};\n border-top: none;\n background-color: ${getColor('grey', 100)};\n }\n\n &__help-text {\n ${text('medium')}\n max-width: 560px;\n margin-bottom: 1.6rem;\n }\n\n &__selection {\n ${text('medium')}\n display: flex;\n flex-direction: column;\n gap: 0.4rem;\n\n &:not(:last-child) {\n margin-bottom: 1.6rem;\n }\n\n &-radio label span {\n font-weight: bold;\n }\n\n &-input input {\n background-color: ${getColor('white')};\n }\n\n &-help-text {\n max-width: 560px;\n }\n\n & input {\n &:checked {\n background-color: ${getColor('primary')};\n }\n }\n }\n\n &__results {\n ${showFor('medium')}\n display: flex;\n flex-direction: column;\n gap: 1.6rem;\n max-width: 1100px;\n margin: 0 auto;\n\n &-mobile {\n ${hideFor('medium')}\n display: grid;\n gap: 1.6rem;\n max-width: 1100px;\n margin: 0 auto;\n ${breakpoint('small')} {\n ${cells(2)}\n }\n }\n }\n }\n`;\n\nexport const StyledNoResults = styled.h4`\n text-align: center;\n`;\n","import React, { useState } from 'react';\nimport { EditorStringModel as EditorStringType } from '../../Types/EditorStringModel';\nimport EditorString from '../EditorString/EditorString';\nimport FHGuideModule from './_fhGuideContainerModule';\nimport {\n StyledFHContainer,\n StyledNoResults,\n} from './styles/FHGuideContainer.styling';\nimport { post } from '../../Services/http';\nimport ProductCardLandscape from '../ProductCards/ProductCardLandscape';\nimport ProductCard from '../ProductCards/ProductCard';\nimport { translate } from '../../Services/translation';\nimport Button from '../Button';\n\ninterface FHGuideContainerProps {\n title: string;\n description: EditorStringType;\n helpText: string;\n type: string;\n mapVal: string;\n}\n\nconst FHGuideContainer = (props: FHGuideContainerProps) => {\n const [showResults, setShowResults] = useState(false);\n const [results, setResults] = useState([]);\n const [btnDisabled, setBtnDisabled] = useState(true);\n const [guideModules, setGuideModules] = useState([\n {\n Title: translate('fhconst1.title'),\n HelpText: '',\n Type: 'radio',\n SelectedChoiceIndex: -1,\n Items: [\n {\n title: translate('fhconst1.item1.title'),\n description: translate('fhconst1.item1.description'),\n mapVal: '100',\n },\n {\n title: translate('fhconst1.item2.title'),\n description: translate('fhconst1.item2.description'),\n mapVal: '50',\n },\n ],\n },\n {\n Title: translate('fhconst2.title'),\n HelpText: translate('fhconst2.helptext'),\n Type: 'radio',\n SelectedChoiceIndex: -1,\n Items: [\n { title: translate('fhconst2.item1.title'), mapVal: '0.15' },\n { title: translate('fhconst2.item2.title'), mapVal: '0.25' },\n ],\n },\n {\n Title: translate('fhconst3.title'),\n HelpText: translate('fhconst3.helptext'),\n Type: 'radio',\n SelectedChoiceIndex: -1,\n Items: [\n { title: translate('fhconst3.item1.title'), mapVal: '1.1' },\n { title: translate('fhconst3.item2.title'), mapVal: '1.1' },\n { title: translate('fhconst3.item3.title'), mapVal: '1' },\n { title: translate('fhconst3.item4.title'), mapVal: '1' },\n { title: translate('fhconst3.item5.title'), mapVal: '0.9' },\n { title: translate('fhconst3.item6.title'), mapVal: '1.5' },\n { title: translate('fhconst3.item7.title'), mapVal: '0.8' },\n ],\n },\n {\n Title: translate('fhconst4.title'),\n HelpText: translate('fhconst4.helptext'),\n Type: 'radio',\n SelectedChoiceIndex: -1,\n Items: [\n { title: translate('fhconst4.item1.title'), mapVal: 'Trä' },\n { title: translate('fhconst4.item2.title'), mapVal: 'Kakel' },\n { title: translate('fhconst4.item3.title'), mapVal: 'Trä' },\n { title: translate('fhconst4.item4.title'), mapVal: 'Plastmatta' },\n { title: translate('fhconst4.item5.title'), mapVal: 'Kakel' },\n { title: translate('fhconst4.item6.title'), mapVal: 'Trä' },\n ],\n },\n {\n Title: translate('fhconst5.title'),\n HelpText: translate('fhconst5.helptext'),\n Type: 'input',\n SelectedChoiceIndex: -1,\n Items: [{ title: translate('fhconst5.item1.title'), mapVal: '-1' }],\n },\n ]);\n\n const handleIsSelected = (objectIndex, selectionIndex) => {\n setShowResults(false);\n let tempGuideModule = guideModules;\n tempGuideModule[objectIndex].SelectedChoiceIndex = selectionIndex;\n setGuideModules(tempGuideModule);\n\n if (\n tempGuideModule.filter((x) => x.SelectedChoiceIndex === -1).length === 0\n ) {\n let m2 = Number(tempGuideModule[4].SelectedChoiceIndex);\n let heatingType = Number(\n tempGuideModule[0].Items[tempGuideModule[0].SelectedChoiceIndex].mapVal\n );\n let roomType = Number(\n tempGuideModule[2].Items[tempGuideModule[2].SelectedChoiceIndex].mapVal\n );\n let projectType = Number(\n tempGuideModule[1].Items[tempGuideModule[1].SelectedChoiceIndex].mapVal\n );\n\n let filterItem = {\n Effect: m2 * heatingType * roomType,\n CableLength: m2 / projectType,\n Area: m2,\n Wetroom: tempGuideModule[2].SelectedChoiceIndex === 0,\n FloorType:\n tempGuideModule[3].Items[tempGuideModule[3].SelectedChoiceIndex]\n .mapVal,\n };\n\n post('/api/filteredsearch', filterItem)\n .then((response) => response.json())\n .then((result) => {\n setResults(result.products);\n setBtnDisabled(false);\n })\n .catch((ex) => {\n console.log('Something went wrong: ' + ex);\n });\n } else {\n setBtnDisabled(true);\n }\n };\n\n return (\n \n

    {props.title}

    \n \n
    \n {guideModules.map((module, index) => (\n \n ))}\n setShowResults(true)}\n disabled={btnDisabled || showResults}\n >\n {translate('fhguide.show-results')}\n \n
    \n {showResults && (\n <>\n {results.length >= 1 ? (\n <>\n
    \n {results.map((product) => (\n \n ))}\n
    \n
    \n {results.map((product) => (\n \n ))}\n
    \n \n ) : (\n {translate('fhguide.no-results')}\n )}\n \n )}\n
    \n );\n};\n\nexport default FHGuideContainer;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport Product from '../../Types/Product';\nimport ProductCardLandscape from '../ProductCards/ProductCardLandscape';\n\ninterface ProductPageVariantListProps {\n variants: Product[];\n}\n\nconst StyledProductPageVariantList = styled.div`\n display: grid;\n grid-template-columns: 1fr;\n gap: 0.8rem;\n margin-top: 1.6rem;\n ${breakpoint('medium')} {\n margin-top: 2.4rem;\n }\n`;\n\nconst ProductPageVariantList = ({ variants }: ProductPageVariantListProps) => {\n return (\n \n {variants.map((p) => (\n \n ))}\n \n );\n};\n\nexport default ProductPageVariantList;\n","import React, { useCallback, useMemo } from 'react';\nimport Button from '../Button';\nimport Icon from '../Icon';\n\ninterface ScrollToElementButtonProps {\n btnType: 'default' | 'primary' | 'secondary' | 'outlined';\n btnSize: 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge';\n selector: string;\n label: string | JSX.Element;\n fullwidth?: boolean;\n iconBefore?: string | JSX.Element;\n iconAfter?: string | JSX.Element;\n}\n\nconst ScrollToElementButton = ({\n btnType,\n btnSize,\n selector,\n label,\n fullwidth = false,\n iconBefore,\n iconAfter,\n}: ScrollToElementButtonProps) => {\n const onClick = () => {\n const elementTopPosition =\n document.querySelector(selector)?.getBoundingClientRect().top ?? 0;\n if (!elementTopPosition) return;\n\n const headerHeight =\n document.querySelector('#header')?.getBoundingClientRect().height ?? 0;\n\n window.scrollTo({\n top: elementTopPosition - headerHeight,\n behavior: 'smooth',\n });\n };\n\n const IconElement = useCallback(\n ({ icon }: { icon: string | JSX.Element }) => {\n if (typeof icon == 'string') {\n return ;\n } else {\n return icon;\n }\n },\n []\n );\n\n return (\n \n {iconBefore && }\n {label}\n {iconAfter && }\n \n );\n};\n\nexport default ScrollToElementButton;\n","import React, { useEffect, useState } from 'react';\nimport { Collapse } from 'react-collapse';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport Icon from '../Icon';\n\ninterface CollapsibleAttributes {\n label?: string | JSX.Element;\n className?: string;\n transitionDuration?: string;\n onStateChange?: Function;\n isOpen?: boolean;\n hideBorder?: boolean;\n children?: any;\n}\n\ninterface CollapsibleIconProps {\n $isOpen: boolean;\n $transitionDuration: string;\n}\n\nconst StyledCollapsible = styled.div`\n label {\n padding-top: 0 !important;\n padding-bottom: 0 !important;\n font-weight: 400 !important;\n border-bottom: 1px solid ${getColor('gray', 300)};\n > a {\n flex: 1;\n &.is-selected {\n background: ${getColor('gray', 100)};\n font-weight: bold;\n }\n }\n ${text('medium')}\n }\n .icon-wrapper {\n border-left: 1px solid ${getColor('gray', 300)};\n width: 40px;\n height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n ul {\n > li {\n border-bottom: 1px solid ${getColor('gray', 300)};\n a {\n ${text('medium')}\n padding-left: 2.8rem;\n &:hover {\n background-color: ${getColor('gray', 100)};\n }\n }\n }\n }\n .ReactCollapse--content {\n padding-bottom: 0 !important;\n }\n`;\n\nconst StyledCollapsibleIcon = styled(Icon)`\n transform: ${(p) => (p.$isOpen ? 'rotate(180deg)' : 'rotate(0)')};\n transition-duration: ${(p) => p.$transitionDuration};\n height: 20px;\n width: 20px;\n`;\n\nexport default ({\n children,\n label,\n className = '',\n transitionDuration = '0.2s',\n onStateChange: externalStateChange,\n isOpen: externalIsOpen,\n hideBorder,\n}: CollapsibleAttributes) => {\n const [isOpen, setIsOpen] = useState(externalIsOpen ?? false);\n\n const onStateChange = (open: boolean) => {\n externalStateChange && externalStateChange(open);\n setIsOpen(open);\n };\n\n useEffect(() => {\n setIsOpen(externalIsOpen ?? false);\n }, [externalIsOpen]);\n\n return (\n \n \n
    \n {children}\n
    \n \n );\n};\n","import React from 'react';\nimport SubNavigationCollapsible from './SubNavigationCollapsible';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { SubNavigationLinkModel } from '../../Types/SubNavigationLinkModel';\n\nconst StyledSecondLevelNavigationList = styled.ul`\n > li {\n &:not(:last-child) {\n border-bottom: 1px solid ${getColor('gray', 300)};\n }\n &.has-children {\n border-bottom: none;\n }\n a {\n height: 40px;\n display: flex;\n align-items: center;\n padding-left: 1.6rem;\n ${text('medium')};\n &:hover {\n background-color: ${getColor('gray', 100)};\n }\n }\n }\n .collapsible {\n border-top: none !important;\n border-bottom: none !important;\n }\n li.is-selected {\n background: ${getColor('gray', 100)};\n a {\n font-weight: bold;\n }\n }\n`;\nconst StyledNavigationList = styled.ul`\n border-radius: 0 0 4px 4px;\n border-top: 1px solid ${getColor('gray', 300)};\n ${breakpoint('medium')} {\n border-radius: 4px;\n border: 1px solid ${getColor('gray', 300)};\n margin-bottom: 1.6rem;\n }\n\n > li {\n &:not(:last-child) {\n border-bottom: 1px solid ${getColor('gray', 300)};\n }\n a {\n height: 40px;\n display: flex;\n align-items: center;\n padding-left: 0.8rem;\n ${text('medium')};\n font-weight: bold;\n &:hover {\n background-color: ${getColor('gray', 100)};\n }\n }\n }\n`;\nconst SubNavigation = ({ links, name, url }: SubNavigationLinkModel) => {\n return (\n \n
  • \n {name}\n
  • \n {links?.length >= 1 && (\n \n {links.map((link, idx) =>\n link.links?.length >= 1 ? (\n
  • \n l.isSelected == true)\n }\n label={\n \n {link.name}\n \n }\n >\n \n \n
  • \n ) : (\n \n {link.name}\n \n )\n )}\n
    \n )}\n
    \n );\n};\n\nexport default SubNavigation;\n","import React from 'react';\nimport SubNavigation from './SubNavigation';\nimport Collapsible from '../Collapsible';\nimport { getColor } from '../../styling/mixins/colors';\nimport styled from 'styled-components';\nimport { translate } from '../../Services/translation';\nimport { SubNavigationLinkModel } from '../../Types/SubNavigationLinkModel';\n\nconst StyledMobileCollapsible = styled(Collapsible)`\n border: 1px solid ${getColor('gray', 300)};\n border-radius: 4px;\n margin-bottom: 2.4rem;\n padding-bottom: 0 !important;\n .ReactCollapse--content {\n padding-bottom: 0 !important;\n }\n > label {\n font-weight: bold;\n padding-left: 1.6rem !important;\n padding-right: 1.6rem !important;\n }\n`;\n\nconst SubNavigationContainer = ({\n links,\n name,\n url,\n}: SubNavigationLinkModel) => {\n return (\n <>\n
    \n \n \n \n
    \n
    \n \n
    \n \n );\n};\n\nexport default SubNavigationContainer;\n","import React, { useMemo } from 'react';\nimport ProductCard from '../Components/ProductCards/ProductCard';\nimport BannerItem from './BannerBlock/_banner-item';\nimport { breakpoint } from '../styling/mixins/breakpoints';\nimport styled from 'styled-components';\nimport { cells, grid } from '../styling/utils/grid';\nimport { BannerBlockProps } from './BannerBlock/BannerBlock';\nimport { ProductNoSliderProps } from './ProductBlockNoSlider';\nimport { LinkModel } from '../Types/LinkModel';\nimport { text } from '../styling/mixins/typography';\n\ninterface ProductAndBannerProps {\n products: ProductNoSliderProps;\n banners: BannerBlockProps;\n showBannerToTheRight: boolean;\n productQuantity: number;\n title?: string;\n link?: LinkModel;\n}\n\nconst StyledWrapper = styled.div`\n ${grid}\n ${cells(1)}\n ${breakpoint('large')} {\n ${cells(2)}\n }\n\n ${breakpoint('large')} {\n .banner-item {\n height: 100%;\n }\n img.banner-item__image {\n height: 100%;\n aspect-ratio: unset;\n }\n }\n`;\n\nconst StyledProductsWrapper = styled.div<{ $numPerRow: number }>`\n ${grid};\n ${cells(2)}\n\n ${breakpoint('large')} {\n ${(p) => cells(p.$numPerRow)}\n }\n\n &.remaining {\n margin-top: 1.6rem;\n ${breakpoint('medium')} {\n margin-top: 2.4rem;\n }\n }\n`;\n\nconst StyledTitleWrapper = styled.div`\n ${grid};\n ${cells(2)}\n margin-bottom: 2.4rem;\n\n div {\n display: flex;\n align-items: center;\n\n &:last-child {\n justify-content: flex-end;\n }\n\n a {\n ${text('xlarge')}\n text-decoration: underline;\n }\n }\n`;\n\nconst LeftBannerItemWrapper = styled.div<{ $showBannerToRight: boolean }>`\n ${breakpoint('large')} {\n display: ${(p) => (p.$showBannerToRight ? 'none' : null)};\n }\n`;\n\nconst RightBannerItemWrapper = styled.div`\n ${breakpoint('medium', 'down')} {\n display: none;\n }\n`;\n\nconst ProductsAndBannerBlock = ({\n products: productsBlock,\n banners: bannersBlock,\n showBannerToTheRight,\n title,\n link,\n}: ProductAndBannerProps) => {\n const bannerBlockItem = useMemo(\n () => (bannersBlock.banners?.length ? bannersBlock.banners[0] : null),\n [bannersBlock.banners]\n );\n\n const firstTwoProducts = useMemo(() => productsBlock.products?.slice(0, 2), [\n productsBlock,\n ]);\n const remainingProducts = useMemo(() => productsBlock.products?.slice(3), [\n productsBlock,\n ]);\n\n if (!bannerBlockItem) return null;\n return (\n <>\n \n
    {title &&

    {title}

    }
    \n
    {link?.href && {link.text}}
    \n
    \n \n \n \n \n {firstTwoProducts && (\n \n {firstTwoProducts.map((product, idx) => (\n \n ))}\n \n )}\n {showBannerToTheRight && (\n \n \n \n )}\n \n {remainingProducts?.length ? (\n \n {remainingProducts.map((product, idx) => (\n \n ))}\n \n ) : null}\n \n );\n};\n\nexport default ProductsAndBannerBlock;\n","import React, { useEffect, useState } from 'react';\nimport Collapsible from '../Collapsible';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport {\n InstallationData,\n InstallationType,\n} from '../../Types/MaterialCalculator';\nimport Dropdown from '../Dropdown';\nimport Checkbox from '../Inputs/Checkbox';\nimport { useDispatch } from 'react-redux';\nimport { materialCalculatorActions } from '../../Reducers/MaterialCalculator.reducer';\nimport { translate } from '../../Services/translation';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport Input from '../Inputs/Input';\nimport { flexColumn } from '../../styling/utils/flex';\n\nconst StyledCollapsible = styled(Collapsible)`\n .label {\n font-size: 1.4rem;\n line-height: 150%;\n color: ${getColor('grey', 500)};\n font-weight: 400;\n }\n .dropdown-wrapper {\n display: flex;\n ${flexColumn}\n flex: 1;\n width: 100%;\n }\n\n .ReactCollapse--content {\n padding: unset !important;\n }\n .room-row {\n display: flex;\n flex-direction: column !important;\n gap: 1.6rem;\n align-items: center;\n }\n`;\n\nconst MaterialCalculatorAdvancedTab = ({\n installationData,\n installationType,\n floorIndex,\n roomIndex,\n}: {\n installationData: InstallationData;\n installationType: InstallationType;\n floorIndex: number;\n roomIndex: number;\n}) => {\n const dispatch = useDispatch();\n const { installationTypes, defaultDistanceToDistributor } = useTypedSelector(\n (state) => state.materialCalculator\n );\n\n const [distanceToDistributor, setDistanceToDistributor] = useState<\n number | undefined\n >(defaultDistanceToDistributor);\n\n useEffect(() => {\n dispatch(\n materialCalculatorActions.setRoomInstallationData({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n data: distanceToDistributor,\n key: 'distanceToDistributor',\n })\n );\n }, [distanceToDistributor, dispatch, floorIndex, roomIndex]);\n\n return (\n \n
    \n {installationType?.showCCInput && (\n
    \n \n {installationType?.availableCCs && (\n ({\n label: cc.toString(),\n value: cc,\n }))}\n onChange={({ value }) =>\n dispatch(\n materialCalculatorActions.setRoomInstallationData({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n data: value,\n key: 'cc',\n })\n )\n }\n />\n )}\n
    \n )}\n {installationType?.showMillCheckbox && (\n
    \n \n dispatch(\n materialCalculatorActions.setRoomInstallationData({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n data: e.target.checked,\n key: 'millSelfChecked',\n })\n )\n }\n />\n
    \n )}\n {!installationData?.millSelfChecked &&\n installationType?.showTurnZoneInput && (\n
    \n {installationTypes && (\n \n dispatch(\n materialCalculatorActions.setRoomInstallationData({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n data: e.target.valueAsNumber,\n key: 'turnZone',\n })\n )\n }\n />\n )}\n
    \n )}\n
    \n {installationTypes && (\n \n setDistanceToDistributor(e.target.valueAsNumber ?? 0)\n }\n />\n )}\n
    \n
    \n \n );\n};\n\nexport default MaterialCalculatorAdvancedTab;\n","import React, { useEffect, useState } from 'react';\nimport { addOverlay, removeOverlay } from '../../Actions/Overlay.action';\nimport { useDispatch } from 'react-redux';\nimport Modal from 'react-modal';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport EditorString from '../EditorString/EditorString';\nimport Icon from '../Icon';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\ninterface MoreInfoProps {\n onClosed?: () => void;\n}\n\nconst StyledMoreInfo = styled.div`\n z-index: 150;\n position: fixed;\n inset: 0;\n margin: auto;\n width: 50%;\n height: max-content;\n max-height: 100%;\n background-color: white;\n padding: 4rem;\n box-sizing: border-box;\n overflow-y: auto;\n ${breakpoint('small', 'down')} {\n width: 100%;\n height: 100%;\n padding: 1.6rem;\n }\n\n .moreInfo-title {\n display: flex;\n justify-content: space-between;\n align-items: center;\n ${breakpoint('small', 'down')} {\n display: none;\n }\n }\n .mobileMoreInfo-title {\n display: flex;\n flex-direction: column;\n align-items: center;\n ${breakpoint('small', 'up')} {\n display: none;\n }\n }\n .moreInfo-description {\n margin-top: 1.6rem;\n }\n .icon {\n cursor: pointer;\n }\n .icon-mobile {\n align-self: flex-end;\n }\n .title-mobile {\n align-self: flex-start;\n }\n`;\n\nconst MaterialCalculatorMoreInfo = ({ onClosed }: MoreInfoProps) => {\n const { moreInfoTitle, moreInfoDescription } = useTypedSelector(\n (state) => state.materialCalculator\n );\n\n const dispatch = useDispatch();\n const [open, setOpen] = useState(true);\n const onKeyDown = (e) => {\n if (e.key == 'Escape') {\n setOpen(false);\n }\n };\n\n useEffect(() => {\n dispatch(\n addOverlay('MaterialCalculatorMoreInfo', () => {\n setOpen(false);\n })\n );\n document.addEventListener('keydown', onKeyDown, false);\n\n return () => {\n document.removeEventListener('keydown', onKeyDown, false);\n };\n }, [dispatch]);\n\n useEffect(() => {\n if (!open) {\n dispatch(removeOverlay('MaterialCalculatorMoreInfo'));\n onClosed && onClosed();\n }\n }, [dispatch, open, onClosed]);\n\n const onClick = () => {\n setOpen(false);\n };\n\n return (\n \n {moreInfoTitle && (\n

    \n {moreInfoTitle}{' '}\n \n

    \n )}\n {moreInfoTitle ? (\n

    \n \n {moreInfoTitle}\n

    \n ) : null}\n {moreInfoDescription?.value ? (\n \n ) : null}\n
    \n );\n};\n\nexport default MaterialCalculatorMoreInfo;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport styled from 'styled-components';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport { flexColumn } from '../../styling/utils/flex';\nimport {\n MaterialCalculatorFloor,\n MaterialCalculatorRoom,\n} from '../../Types/MaterialCalculator';\nimport MaterialCalculatorAdvancedTab from './MaterialCalculator.Advanced';\nimport Dropdown from '../Dropdown';\nimport Input from '../Inputs/Input';\nimport { materialCalculatorActions } from '../../Reducers/MaterialCalculator.reducer';\nimport { useDispatch } from 'react-redux';\nimport Checkbox from '../Inputs/Checkbox';\nimport Collapsible from '../Collapsible';\nimport { translate } from '../../Services/translation';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport Button from '../Button';\nimport Icon from '../Icon';\nimport { addOverlay, removeOverlay } from '../../Actions/Overlay.action';\nimport MaterialCalculatorMoreInfo from './MaterialCalculator.MoreInfo';\n\nconst StyledFloorItem = styled.div`\n display: grid;\n align-items: center;\n box-sizing: border-box;\n\n border-bottom: 1px solid ${getColor('grey', 300)};\n h5 {\n margin-bottom: 0.8rem;\n }\n\n .labelWrapper {\n background-color: ${getColor('primary')};\n padding: 0.8rem 1.6rem;\n margin-bottom: 0;\n }\n\n .collapsible {\n border: none !important;\n margin-bottom: 0.4rem;\n }\n\n .ReactCollapse--content {\n display: flex;\n flex-direction: column;\n gap: 1.6rem;\n padding: 1.6rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n\n button {\n max-width: fit-content;\n }\n }\n\n .dropdown-wrapper {\n display: flex;\n ${flexColumn}\n flex: 1;\n width: 100%;\n }\n\n .installationType-label {\n display: flex;\n justify-content: space-between;\n align-items: center;\n }\n\n .more-info {\n cursor: pointer;\n }\n\n .checkbox-wrapper {\n flex: 1;\n }\n\n .input-wrapper {\n flex: 1;\n\n ${breakpoint('large')} {\n & input {\n max-height: 42px;\n }\n }\n }\n\n .room-row {\n display: flex;\n flex-direction: column !important;\n gap: 1.6rem;\n align-items: center;\n }\n\n .add-room {\n padding-left: unset !important;\n ${breakpoint('small', 'down')} {\n padding-left: 1rem !important;\n }\n }\n\n .mc-room__footer {\n display: flex;\n\n & button {\n color: ${getColor('alert')};\n }\n }\n`;\n\nconst MCCalculatorFloorItem = ({\n floor,\n room,\n roomIndex,\n floorIndex,\n}: {\n floor: MaterialCalculatorFloor;\n room: MaterialCalculatorRoom;\n roomIndex: number;\n floorIndex: number;\n}) => {\n const { installationTypes, DisplayMoreInfo } = useTypedSelector(\n (state) => state.materialCalculator\n );\n\n const calculateTurnZone = (area: number) => {\n return (Math.sqrt(area) * 2).toFixed(2);\n };\n const dispatch = useDispatch();\n\n const [moreInfoOpen, setMoreInfoOpen] = useState(false);\n const OnClick = () => {\n setMoreInfoOpen(true);\n };\n\n useEffect(() => {\n room.area &&\n room.installationType?.showTurnZoneInput &&\n dispatch(\n materialCalculatorActions.setRoomInstallationData({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n data: calculateTurnZone(room.area),\n key: 'turnZone',\n })\n );\n }, [\n room.installationData,\n dispatch,\n floorIndex,\n room.area,\n roomIndex,\n room.installationType?.showTurnZoneInput,\n ]);\n\n const roomNo = roomIndex + 1;\n\n return floor ? (\n \n {moreInfoOpen ? (\n setMoreInfoOpen(false)} />\n ) : null}\n
    {translate('materialcalculator.room') + ' ' + roomNo}
    \n
    \n {\n dispatch(\n materialCalculatorActions.setRoomArea({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n area: e.target.valueAsNumber,\n })\n );\n room.installationType?.showTurnZoneInput &&\n dispatch(\n materialCalculatorActions.setRoomInstallationData({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n data: calculateTurnZone(e.target.valueAsNumber),\n key: 'turnZone',\n })\n );\n }}\n />\n
    \n {installationTypes && (\n <>\n \n ({\n label: type.name,\n value: JSON.stringify(type),\n }))}\n onChange={({ value }) =>\n dispatch(\n materialCalculatorActions.setRoomInstallationType({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n installationType: JSON.parse(value),\n })\n )\n }\n />\n \n )}\n
    \n
    \n \n
    \n \n dispatch(\n materialCalculatorActions.removeRoom({\n floorIndex: floorIndex,\n roomIndex: roomIndex,\n })\n )\n }\n >\n {translate('materialcalculator.removeroom')}\n \n
    \n
    \n ) : null;\n};\n\nexport default MCCalculatorFloorItem;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport MCCalculatorRoomItem from './MaterialCalculator.RoomItem';\nimport { materialCalculatorActions } from '../../Reducers/MaterialCalculator.reducer';\nimport { useDispatch } from 'react-redux';\nimport { MaterialCalculatorFloor } from '../../Types/MaterialCalculator';\nimport { translate } from '../../Services/translation';\nimport Button from '../Button';\nimport Icon from '../Icon';\nimport { cells, grid } from '../../styling/utils/grid';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\n\nconst StyledMCFloorWrapper = styled.div`\n margin-top: 2rem;\n padding: 1.6rem;\n box-sizing: border-box;\n border: 1px solid ${getColor('grey', 300)};\n background: ${getColor('grey', 100)};\n\n .mc-floor__header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-bottom: 1.6rem;\n }\n\n .room-grid {\n ${grid}\n ${cells(3)}\n ${breakpoint('small', 'down')} {\n ${cells(2)}\n }\n ${breakpoint('xsmall', 'down')} {\n ${cells(1)}\n }\n }\n\n .addButton {\n color: ${getColor('grey')};\n & .icon {\n color: ${getColor('grey')};\n }\n }\n\n .mc-floor__footer {\n margin-top: 1.2rem;\n }\n\n & input,\n .dropdown-select,\n .options-list {\n background: ${getColor('white')};\n }\n`;\n\nconst MCFloorItemWrapper = ({\n floor,\n index,\n}: {\n floor: MaterialCalculatorFloor;\n index: number;\n}) => {\n const dispatch = useDispatch();\n const floorNumber = index + 1;\n return (\n \n
    \n

    \n {translate('materialcalculator.floor')} {floorNumber}\n

    \n \n dispatch(\n materialCalculatorActions.removeFloor({ floorIndex: index })\n )\n }\n >\n \n \n
    \n
    \n {floor.rooms?.map((room, roomIndex) => (\n \n ))}\n
    \n
    \n \n dispatch(\n materialCalculatorActions.setRooms({\n floorIndex: index,\n floorId: floor.id,\n })\n )\n }\n >\n \n {translate('materialcalculator.addroom')}\n \n
    \n
    \n );\n};\n\nexport default MCFloorItemWrapper;\n","import styled from 'styled-components';\nimport { getColor } from '../../../../styling/mixins/colors';\nimport { text } from '../../../../styling/mixins/typography';\n\nexport const StyledLandscapeProductCard = styled.div`\n display: flex;\n background-color: ${getColor('grey', 100)};\n padding: 1.2rem;\n gap: 1.2rem;\n margin-bottom: 0.8rem;\n\n .buy-button {\n flex-direction: column;\n\n .quantity-input input {\n ${text('large')}\n padding: 0.8rem 1.2rem;\n max-width: 100%;\n }\n\n button {\n display: flex;\n align-items: center;\n }\n }\n\n .image-wrapper {\n background-color: ${getColor('white')};\n max-width: 100px;\n width: 100%;\n height: 100px;\n position: relative;\n\n img {\n width: 100%;\n aspect-ratio: 1/1;\n object-fit: cover;\n }\n\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0, 0, 0, 0.04);\n pointer-events: none;\n }\n }\n\n .information {\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n flex: 1;\n }\n\n .overline {\n ${text('medium')}\n color: ${getColor('grey', 500)};\n margin-bottom: 0.2rem;\n }\n\n .name {\n ${text('large')}\n font-weight: bold;\n }\n\n .description {\n ${text('medium')};\n }\n\n .price {\n display: flex;\n flex-direction: column;\n text-align: right;\n }\n\n .original-price {\n ${text('small')}\n text-decoration: line-through;\n font-weight: 400;\n color: ${getColor('grey', 500)};\n }\n\n .campaign-price {\n color: ${getColor('red')};\n }\n\n .right-col {\n display: flex;\n flex-direction: column;\n text-align: right;\n }\n`;\n\nexport const StyledProductTagWrapperLandscape = styled.div`\n display: flex;\n gap: 0.8rem;\n margin-bottom: 0.4rem;\n`;\n\nexport const StyledBrandLogo = styled.img`\n height: 20px;\n width: auto;\n`;\n","import React from 'react';\nimport StockStatus from '../../StockStatus/StockStatus';\nimport ProductCardProps from '../../ProductCards/types/ProductCardProps';\nimport {\n StyledBrandLogo,\n StyledLandscapeProductCard,\n StyledProductTagWrapperLandscape,\n} from './styles/ProductCardLandscape.styling';\nimport ResponsiveImage from '../../ResponsiveImage/ResponsiveImage';\nimport ProductTag from '../../ProductTags/ProductTag';\n\nconst MaterialCalculatorProductCard = ({\n product,\n isVariantListing = false,\n lazyLoadImage,\n}: ProductCardProps) => {\n return (\n \n
    \n {product.images && product.images.length > 0 && (\n \n \n \n )}\n
    \n
    \n {product.tags?.length ? (\n \n {product.tags.map((tag) => (\n \n {tag.name}\n \n ))}\n \n ) : null}\n \n {product.name}\n \n

    {product.id}

    \n \n
    \n
    \n {product.price.formattedCampaignPrice ? (\n

    \n {product.price.formattedCampaignPrice}{' '}\n \n {product.price.formattedPrice}\n \n

    \n ) : (\n product.price.formattedPrice && (\n

    {product.price.formattedPrice}

    \n )\n )}\n {product.quantity > 1 && (\n \n
    {product.quantity} st
    \n
    \n )}\n
    \n
    \n
    \n );\n};\n\nexport default MaterialCalculatorProductCard;\n","import { MaterialCalculatorRoom } from '../../../Types/MaterialCalculator';\nimport React from 'react';\nimport Collapsible from '../../Collapsible';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { text } from '../../../styling/mixins/typography';\nimport { translate } from '../../../Services/translation';\nimport { breakpoint } from '../../../styling/mixins/breakpoints';\n\nconst StyledMenuItem = styled.div`\n margin-bottom: 0.8rem;\n\n h5 {\n margin-top: 10px;\n }\n\n .disclaimer-list {\n display: flex;\n gap: 0.8rem;\n flex-direction: column;\n ${breakpoint('small', 'up')} {\n flex-direction: row;\n }\n }\n li {\n font-size: 1.4rem;\n ${text('bold')}\n }\n`;\nconst MCDisclaimerItem = ({\n room,\n index,\n}: {\n room: MaterialCalculatorRoom;\n index: number;\n}) => {\n const roomNo = index + 1;\n return (\n \n {room.materialCalculatorFormulas && (\n
    \n
      \n
    • \n {' '}\n {translate('materialcalculator.room')} \n {roomNo}\n
    • \n {room.materialCalculatorFormulas?.coilQuantity && (\n
    • \n {translate('materialcalculator.coilquantity')}: \n {room.materialCalculatorFormulas?.coilQuantity}\n
    • \n )}\n {room.materialCalculatorFormulas?.coilLength && (\n
    • \n {translate('materialcalculator.coillength')}: \n {room.materialCalculatorFormulas?.coilLength.toFixed(2)}\n
    • \n )}\n
    \n
    \n )}\n
    \n );\n};\n\nexport default MCDisclaimerItem;\n","import React from 'react';\nimport { useDispatch } from 'react-redux';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport MCDisclaimerItem from './utils/_materialCalculatorDisclaimerItem';\nimport styled from 'styled-components';\nimport { getColor } from '../../styling/mixins/colors';\nimport EditorString from '../EditorString/EditorString';\nimport { translate } from '../../Services/translation';\nimport Icon from '../Icon';\n\nconst StyledDisclaimer = styled.div`\n background-color: ${getColor('primary', 100)};\n border: 1px solid ${getColor('primary', 800)};\n gap: 0.8rem;\n\n .disclaimer-title {\n padding: 1.2rem;\n gap: 0.8rem;\n padding-bottom: unset;\n display: flex;\n align-items: center;\n }\n .disclaimer-description {\n font-size: 1.6rem;\n margin-bottom: 0.8rem;\n }\n .disclaimer-content {\n padding: 0.4rem 1.2rem 1.2rem 4.4rem;\n }\n .floor-item {\n margin-bottom: 1.2rem;\n }\n`;\n\nconst MaterialCalculatorDisclaimer = () => {\n const { floors, result, shunt, disclaimerDescription } = useTypedSelector(\n (state) => state.materialCalculator\n );\n\n const dispatch = useDispatch();\n\n return (\n \n
    \n \n {translate('materialcalculator.important')}\n
    \n
    \n \n {floors?.map((floor, floorIndex) => (\n
    \n
    \n {translate('materialcalculator.floor')} {floorIndex + 1}\n
    \n {floor.rooms?.map((room, roomIndex) => (\n \n ))}\n
    \n ))}\n
    \n
    \n );\n};\n\nexport default MaterialCalculatorDisclaimer;\n","import Product from '../../Types/Product';\nimport React, { useCallback, useState } from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport MaterialCalculatorProductCard from './utils/_materialCalculatorProductCard';\nimport { addMultiple } from '../../Services/MaterialCalculator.service';\nimport {\n receive as receiveCart,\n triggerAddToCartAnimation,\n} from '../../Actions/Cart.action';\nimport Button from '../Button';\nimport { useDispatch } from 'react-redux';\nimport LoadingSpinner from '../LoadingSpinner';\nimport styled, { keyframes } from 'styled-components';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { translate } from '../../Services/translation';\nimport MaterialCalculatorDisclaimer from './MaterialCalculator.Disclaimer';\n\nconst rotate = keyframes`\nfrom {\n transform: rotate(0deg);\n }\n\n to {\n transform: rotate(360deg);\n }\n`;\n\nconst StyledProductListing = styled.div`\n .buy-button {\n flex-grow: 1;\n align-self: stretch;\n position: relative;\n width: 100%;\n margin-top: 1.6rem;\n margin-bottom: 0.8rem;\n }\n .loading-spinner {\n display: flex;\n align-items: center;\n justify-content: center;\n margin: 0 auto;\n & svg {\n width: 1.6rem;\n height: 1.6rem;\n animation: ${rotate} 2s linear infinite;\n ${breakpoint('large')} {\n width: 2.4rem;\n height: 2.4rem;\n }\n }\n }\n`;\n\nconst MaterialCalculatorProductListing = () => {\n const { result } = useTypedSelector((state) => state.materialCalculator);\n\n const dispatch = useDispatch();\n\n const [isLoading, setIsLoading] = useState(false);\n const [showLoadingSpinner, setShowLoadingSpinner] = useState(false);\n\n const onClick = async () => {\n setIsLoading(true);\n const loadingSpinnerTimeout = setTimeout(\n () => setShowLoadingSpinner(true),\n 150\n );\n try {\n const cart = await addMultiple(\n result?.products ? result?.products : null\n );\n dispatch(receiveCart(cart));\n dispatch(triggerAddToCartAnimation());\n } catch (err) {\n // TODO Error handling\n alert('Kunde inte lägga i varukorgen');\n console.log(err);\n } finally {\n clearTimeout(loadingSpinnerTimeout);\n setShowLoadingSpinner(false);\n setIsLoading(false);\n }\n };\n\n const LoadingComponent = useCallback(\n () => (\n <>\n  \n \n \n \n \n ),\n []\n );\n\n return (\n \n {result?.rooms && (\n
    \n {result?.rooms.map((room) => (\n \n {room.materialCalculatorFormulas?.coilQuantity && (\n

    {room.materialCalculatorFormulas.coilQuantity}

    \n )}\n {room.materialCalculatorFormulas?.coilLength && (\n

    {room.materialCalculatorFormulas.coilLength}

    \n )}\n
    \n ))}\n
    \n )}\n {result?.products &&\n result.products.map((product) => (\n \n ))}\n \n onClick()}\n disabled={isLoading}\n >\n {showLoadingSpinner ? (\n \n ) : (\n

    {translate('materialcalculator.buypackage')}

    \n )}\n \n
    \n );\n};\n\nexport default MaterialCalculatorProductListing;\n","import { post, put } from '../Services/http';\nimport Product from '../Types/Product';\nimport { pushEcommerce, dataLayerAddToCart } from '../Services/Gtm.service';\n\nexport const addMultiple = async (products: Product[]) => {\n if (\n products.filter((p) => !p.quantity || isNaN(p.quantity) || p.quantity <= 0)\n .length > 0\n ) {\n throw 'Invalid quantity';\n }\n\n const response = await post(\n '/api/cart/addMultiple',\n products.map((product) => {\n return {\n articleNumber: product.id,\n quantity: product.quantity,\n };\n })\n );\n\n try {\n let gtmProducts = products.map((prod) => prod.gtmProduct);\n if (gtmProducts) {\n pushEcommerce({\n event: 'productImpressions',\n ecommerce: {\n currencyCode: gtmProducts[0].currency,\n add: {\n products: gtmProducts,\n },\n },\n });\n }\n } catch (error) {\n console.log('error', error);\n }\n\n return response.json();\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport { getColor } from '../../../styling/mixins/colors';\nimport { materialCalculatorActions } from '../../../Reducers/MaterialCalculator.reducer';\nimport { useDispatch } from 'react-redux';\nimport { useTypedSelector } from '../../../Hooks/useTypedSelector';\nimport { translate } from '../../../Services/translation';\n\nconst StyledInput = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n input[type='checkbox'] {\n height: 0;\n width: 0;\n visibility: hidden;\n }\n\n label {\n cursor: pointer;\n text-indent: -9999px;\n width: 4rem;\n height: 2rem;\n background: grey;\n display: block;\n border-radius: 100px;\n position: relative;\n margin-bottom: unset !important;\n }\n\n label:after {\n content: '';\n position: absolute;\n top: 2px;\n left: 2px;\n width: 1.6rem;\n height: 1.6rem;\n background: #fff;\n border-radius: 90px;\n transition: 0.3s;\n }\n\n input:checked + label {\n background: ${getColor('primary', 500)};\n }\n\n input:checked + label:after {\n left: calc(100% - 2px);\n transform: translateX(-100%);\n }\n span {\n margin-left: 1.2rem;\n color: #171717;\n cursor: pointer;\n font-size: 1.6rem;\n line-height: 150%;\n font-weight: 700;\n }\n`;\n\nconst MaterialCalculatorToggle = () => {\n const dispatch = useDispatch();\n const { shunt } = useTypedSelector((state) => state.materialCalculator);\n\n return (\n \n \n dispatch(\n materialCalculatorActions.setShunt({\n shunt: e.target.checked,\n })\n )\n }\n type=\"checkbox\"\n id=\"switch\"\n />\n \n \n dispatch(\n materialCalculatorActions.setShunt({\n shunt: !shunt,\n })\n )\n }\n >\n {translate('materialcalculator.addshunt')}\n \n \n );\n};\n\nexport default MaterialCalculatorToggle;\n","import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport { cells, section, span } from '../../styling/utils/grid';\nimport EditorString from '../EditorString/EditorString';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport Dropdown from '../Dropdown';\nimport { DropdownOption } from '../Dropdown';\nimport MCFloorItemWrapper from './MaterialCalculator.FloorItemWrapper';\nimport { useDispatch } from 'react-redux';\nimport {\n getProducts,\n materialCalculatorActions,\n} from '../../Reducers/MaterialCalculator.reducer';\nimport Button from '../Button';\nimport MaterialCalculatorProductListing from './MaterialCalculator.ProductListing';\nimport MCSideMenu from './MaterialCalculator.SideMenu';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { translate } from '../../Services/translation';\nimport { text } from '../../styling/mixins/typography';\nimport { getColor } from '../../styling/mixins/colors';\nimport Checkbox from '../Inputs/Checkbox';\nimport MaterialCalculatorMoreInfo from './MaterialCalculator.MoreInfo';\nimport MaterialCalculatorToggle from './utils/_materialCalculatorToggle';\nimport LoadingSpinner from '../LoadingSpinner';\n\nconst rotate = keyframes`\nfrom {\n transform: rotate(0deg);\n }\n\n to {\n transform: rotate(360deg);\n }\n`;\n\ninterface StyledMaterialCalculatorProps {\n $error?: boolean;\n}\n\nconst StyledMcWrapperContainer = styled.div`\n margin-top: 2.4rem;\n label {\n ${text('large')}\n color: ${getColor('grey', 900)};\n font-weight: 700;\n margin-bottom: 0.8rem;\n }\n .mc-options {\n display: flex;\n flex-direction: row;\n margin-top: 2.4rem;\n gap: 3.2rem;\n align-items: center;\n justify-content: space-between;\n ${breakpoint('small', 'down')} {\n flex-direction: column;\n gap: 1.4rem;\n }\n & .mc-checkbox label {\n margin-bottom: 0;\n }\n }\n\n .add-floor-button {\n width: unset;\n ${breakpoint('small', 'down')} {\n width: 100%;\n }\n }\n\n .button {\n margin-top: 1.6rem;\n margin-bottom: 0.8rem;\n width: 100%;\n background-color: ${(p) => (p.$error ? getColor('alert', 500) : null)};\n border-color: ${(p) => (p.$error ? getColor('alert', 500) : null)};\n :hover {\n background-color: ${(p) => (p.$error ? getColor('alert', 300) : null)};\n border-color: ${(p) => (p.$error ? getColor('alert', 500) : null)};\n }\n }\n\n .loading-spinner {\n display: flex;\n align-items: center;\n justify-content: center;\n margin: 0 auto;\n & svg {\n width: 1.6rem;\n height: 1.6rem;\n animation: ${rotate} 2s linear infinite;\n ${breakpoint('large')} {\n width: 2.4rem;\n height: 2.4rem;\n }\n }\n }\n`;\n\nconst MCContainer = () => {\n const {\n errors,\n floors,\n result,\n shunt,\n productsLoading,\n error,\n } = useTypedSelector((state) => state.materialCalculator);\n\n var materialCalculatorState = useTypedSelector(\n (state) => state.materialCalculator\n );\n const dispatch = useDispatch();\n\n useEffect(() => {\n dispatch(materialCalculatorActions.setFloors());\n }, []);\n\n useEffect(() => {\n dispatch(\n materialCalculatorActions.setError({\n error: false,\n })\n );\n }, [dispatch, floors]);\n\n const LoadingComponent = useCallback(\n () => (\n <>\n  \n \n \n \n \n ),\n []\n );\n\n return (\n \n {floors?.map((floor, index) => (\n \n ))}\n
    \n dispatch(materialCalculatorActions.setFloors())}\n >\n {translate('materialcalculator.addfloor')}\n \n \n
    \n \n floors && dispatch(getProducts(materialCalculatorState))\n }\n disabled={productsLoading}\n >\n {productsLoading ? (\n \n ) : error ? (\n

    {translate('general.error')}

    \n ) : (\n

    {translate('materialcalculator.calculate')}

    \n )}\n \n {result?.products && result?.products.length > 0 && (\n \n )}\n
    \n );\n};\n\nexport default MCContainer;\n","import React, { useEffect, useState } from 'react';\nimport { translate } from '../../../Services/translation';\nimport Icon from '../../Icon';\nimport Input from '../../Inputs/Input';\nimport Dropdown from '../../Dropdown';\nconst ROOM_TYPES = [\n 'Sovrum',\n 'Hall',\n 'Kök',\n 'Badrum',\n 'Vardagsrum',\n 'WC',\n 'Garage/Verkstad',\n 'Uterum',\n 'Övrigt',\n];\nconst ROOM_FLOORING = [\n 'På träbjälklag',\n 'På befintligt trägolv',\n 'I Glespanel',\n 'På befintlig betong',\n 'I ny betongplatta',\n];\nconst ROOM_MATERIAL = ['Klinker/Sten/Betong', 'Trä/Parkett'];\n\nconst RoomContainer = ({ room, idx, removeRoom, updateRoom }) => {\n const [roomSpecs, setRoomSpecs] = useState(room);\n\n const onChange = (value, key) => {\n const updatedRoomSpecs = roomSpecs;\n updatedRoomSpecs[key] = value;\n setRoomSpecs(updatedRoomSpecs);\n updateRoom(idx, updatedRoomSpecs);\n };\n\n return (\n
    \n
    \n

    \n {translate('quotation.room')} {idx + 1}\n

    \n {idx > 0 && (\n \n )}\n
    \n
    \n
    \n onChange(e.target.value, 'yta')}\n label={translate('quotation.room-area')}\n type=\"number\"\n />\n ({\n value: roomType,\n label: roomType,\n }))}\n selectedValue={roomSpecs.rum}\n onChange={({ value }) => onChange(value, 'rum')}\n label={translate('quotation.room-type')}\n placeholder={translate('general.select')}\n />\n
    \n
    \n ({\n value: flooring,\n label: flooring,\n }))}\n selectedValue={roomSpecs.typ}\n onChange={({ value }) => onChange(value, 'typ')}\n label={translate('quotation.room-flooring')}\n placeholder={translate('general.select')}\n />\n ({\n value: material,\n label: material,\n }))}\n selectedValue={roomSpecs.material}\n onChange={({ value }) => onChange(value, 'material')}\n label={translate('quotation.room-material')}\n placeholder={translate('general.select')}\n />\n
    \n
    \n
    \n );\n};\n\nexport default RoomContainer;\n","import React, { useState } from 'react';\nimport RadioButton from '../../Inputs/Radiobutton';\nimport { translate } from '../../../Services/translation';\nimport Icon from '../../Icon';\nimport RoomContainer from './RoomContainer';\nimport { v4 } from 'uuid';\nconst ERROR_CLASSES = ['!border-2', 'border-solid', '!border-error-500'];\n\nconst FloorContainer = ({ floor, idx, updateFloor, onInvalid }) => {\n const [rooms, setRooms] = useState(floor.r);\n const [plan, setPlan] = useState(floor.plan);\n const floorIdx = idx;\n const generateNewRoom = () => {\n return {\n yta: 0,\n rum: '',\n typ: '',\n material: '',\n key: v4(),\n };\n };\n\n const removeRoom = (idx) => {\n const updatedRooms = rooms.filter((_, i) => i !== idx);\n setRooms(updatedRooms);\n updateFloor(floorIdx, updatedRooms, null);\n };\n\n const updateRoom = (roomIdx, roomSpecs) => {\n const updatedRooms = rooms;\n updatedRooms[roomIdx] = roomSpecs;\n setRooms(updatedRooms);\n updateFloor(floorIdx, updatedRooms, null);\n };\n\n const addRoom = () => {\n const newRoom = generateNewRoom();\n const updatedRooms = [...rooms, newRoom];\n setRooms(updatedRooms);\n updateFloor(floorIdx, updatedRooms, null);\n };\n\n const updateFloorType = (type) => {\n setPlan(type);\n updateFloor(floorIdx, null, type);\n };\n\n const onRadioClick = (e) => {\n updateFloorType(e.target.value);\n\n if (e.target.classList.contains(...ERROR_CLASSES)) {\n removeErrorClasses(e.target);\n }\n };\n\n const removeErrorClasses = (input) => {\n if (input.type == 'radio') {\n const radioButtons = document.getElementsByName(input.name);\n\n radioButtons.forEach((radioButton) => {\n radioButton.classList.remove(...ERROR_CLASSES);\n });\n }\n };\n\n return (\n \n

    \n {translate('quotation.floor')} {idx + 1}\n

    \n
    \n {translate('quotation.floortype')}\n
    \n
    \n onRadioClick(e)}\n onInvalid={(e) => onInvalid(e)}\n required\n />\n onRadioClick(e)}\n onInvalid={(e) => onInvalid(e)}\n />\n onRadioClick(e)}\n onInvalid={(e) => onInvalid(e)}\n />\n
    \n {rooms.length > 0 && (\n
    \n {rooms.map((room, idx) => (\n \n ))}\n
    \n )}\n addRoom()}\n >\n \n
    {translate('quotation.add-room')}
    \n \n \n );\n};\n\nexport default FloorContainer;\n","import React, { useEffect } from 'react';\nimport { translate } from '../../../Services/translation';\n\nconst StatusMessage = ({\n status,\n setStatus,\n}: {\n status: string;\n setStatus: React.Dispatch>;\n}) => {\n const onClick = (event) => {\n event.preventDefault();\n if (status == 'success') {\n window.location.href = event.target.href;\n } else \n setStatus('');\n };\n\n useEffect(() => {\n window.scrollTo({\n top: 0,\n behavior: 'smooth',\n });\n }, []);\n\n return (\n
    \n

    \n {translate(\n status == 'success'\n ? 'quotation.success-title'\n : 'quotation.error-title'\n )}\n

    \n
    \n {translate(\n status == 'success'\n ? 'quotation.success-message'\n : 'quotation.error-message'\n )}\n
    \n \n {translate(\n status == 'success'\n ? 'quotation.success-btn'\n : 'quotation.error-btn'\n )}\n \n
    \n );\n};\n\nexport default StatusMessage;\n","import React, { useEffect, useState } from 'react';\nimport EditorString from '../EditorString/EditorString';\nimport { translate } from '../../Services/translation';\nimport RadioButton from '../Inputs/Radiobutton';\nimport FloorContainer from './ui/FloorContainer';\nimport Input from '../Inputs/Input';\nimport TextArea from '../Inputs/TextArea';\nimport Checkbox from '../Inputs/Checkbox';\nimport { v4 } from 'uuid';\nimport StatusMessage from './ui/StatusMessage';\nimport clsx from 'clsx';\nconst QUOTATION_TYPE = ['Nybyggnation', 'Renovering', 'Tillbyggnad'];\nconst ERROR_CLASSES = ['!border-2', 'border-solid', '!border-error-500'];\n\nconst QuotationRequest = ({\n title,\n description,\n termsAndConditionsLink,\n}) => {\n const [status, setStatus] = useState('');\n const [currentError, setCurrentError] = useState(false);\n const [generalInfo, setGeneralInfo] = useState({\n typ: '',\n befintliga_vattenradiatorer: '',\n });\n const [floors, setFloors] = useState([\n {\n plan: '',\n r: [{ yta: 0, rum: '', typ: '', material: '', key: v4() }],\n key: v4(),\n },\n ]);\n const [userInfo, setUserInfo] = useState({\n namn: '',\n adress: '',\n postnummer: '',\n ort: '',\n email: '',\n telefonnummer: '',\n fastighetsbeteckning: '',\n information: '',\n files: null,\n });\n\n const generateNewFloor = () => {\n return {\n plan: '',\n r: [{ yta: 0, rum: '', typ: '', material: '', key: v4() }],\n key: v4(),\n };\n };\n\n const updateFloor = (floorIdx, rooms, type) => {\n const updatedFloors = [...floors];\n if (rooms != null) {\n const updatedRooms = rooms;\n updatedFloors[floorIdx]!.r = updatedRooms;\n } else {\n updatedFloors[floorIdx]!.plan = type;\n }\n setFloors(updatedFloors);\n };\n\n const changeFloorAmount = (num) => {\n let updatedFloors = [...floors];\n\n if (num > floors.length) {\n for (let i = floors.length; i < num; i++) {\n const newFloor = generateNewFloor();\n updatedFloors = [...updatedFloors, newFloor];\n }\n } else {\n updatedFloors = updatedFloors.slice(0, num);\n }\n setFloors(updatedFloors);\n };\n\n const updateGeneralInfo = (value, key) => {\n const updatedInfo = Object.assign({}, generalInfo);\n updatedInfo[key] = value;\n setGeneralInfo(updatedInfo);\n };\n\n const updateUserInfo = (value, key) => {\n const updatedInfo = Object.assign({}, userInfo);\n updatedInfo[key] = value;\n setUserInfo(updatedInfo);\n };\n\n const handleInvalidInput = (e) => {\n e.preventDefault();\n\n setCurrentError(true);\n\n const invalidInput = e.target;\n\n invalidInput.classList.add(...ERROR_CLASSES);\n };\n\n const removeErrorClasses = (input) => {\n if (input.type == 'radio') {\n const radioButtons = document.getElementsByName(input.name);\n\n radioButtons.forEach((radioButton) => {\n radioButton.classList.remove(...ERROR_CLASSES);\n });\n } else {\n input.classList.remove(...ERROR_CLASSES);\n }\n };\n\n const onRadioClick = (e, key) => {\n updateGeneralInfo(e.target.value, key);\n\n if (e.target.classList.contains(...ERROR_CLASSES)) {\n removeErrorClasses(e.target);\n }\n };\n\n const onInputChange = (e, key) => {\n updateUserInfo(e.target.value, key);\n\n if (e.target.classList.contains(...ERROR_CLASSES)) {\n removeErrorClasses(e.target);\n }\n };\n\n const onSubmit = async (e) => {\n e.preventDefault();\n\n const formData = new FormData();\n\n formData.append('OffertFormSent', 'yes');\n\n for (const key in generalInfo) {\n formData.append(key, generalInfo[key]);\n }\n\n formData.append('antal_plan', `${floors.length}`);\n\n for (let i = 0; i < floors.length; i++) {\n const floor = floors[i];\n\n formData.append(`p${i + 1}_antal_rum`, `${floor!.r.length}`);\n\n for (const objKey in floor) {\n if (objKey === 'r') {\n for (let j = 0; j < floor[objKey].length; j++) {\n for (const roomKey in floor[objKey][j]) {\n formData.append(\n `p${i + 1}_${objKey}${j + 1}_${roomKey}`,\n floor[objKey][j]![roomKey]\n );\n }\n }\n } else {\n formData.append(`p${i + 1}_${objKey}`, floor[objKey]);\n }\n }\n }\n\n for (const key in userInfo) {\n formData.append(key, userInfo[key]);\n }\n\n try {\n const response = await fetch(\n 'https://www.idrelay.com/customers/14/kelvin/offertformgvb.asp',\n {\n method: 'POST',\n body: formData,\n }\n );\n\n if (response.ok) {\n setStatus('success');\n } else {\n setStatus('error');\n }\n } catch (error) {\n setStatus('error');\n }\n };\n\n useEffect(() => {\n setCurrentError(false);\n }, [generalInfo, userInfo]);\n\n useEffect(() => {\n const errorMessage = document.getElementById('error-message');\n if (currentError) {\n errorMessage?.scrollIntoView({\n behavior: 'smooth',\n block: 'end',\n inline: 'start',\n });\n }\n }, [currentError]);\n\n return (\n
    \n {status ? (\n \n ) : (\n <>\n
    \n {title &&

    {title}

    }\n {description && }\n
    \n {currentError && (\n \n {translate('quotation.submit-error')}\n
    \n )}\n
    onSubmit(e)} className=\"w-full max-w-7xl\">\n

    {translate('quotation.general')}

    \n
    \n {translate('quotation.type')}\n
    \n
    \n {QUOTATION_TYPE.map((type) => (\n handleInvalidInput(e)}\n onClick={(e) => onRadioClick(e, 'typ')}\n required\n />\n ))}\n
    \n
    \n {translate('quotation.radiator')}\n
    \n
    \n handleInvalidInput(e)}\n onClick={(e) =>\n onRadioClick(e, 'befintliga_vattenradiatorer')\n }\n required\n />\n handleInvalidInput(e)}\n onClick={(e) =>\n onRadioClick(e, 'befintliga_vattenradiatorer')\n }\n required\n />\n
    \n
    \n {translate('quotation.floors')}\n
    \n
    \n {Array.from(Array(5), (e, i) => {\n return (\n changeFloorAmount(e.target.value)}\n />\n );\n })}\n
    \n
    \n {floors.map((floor, idx) => (\n \n ))}\n
    \n

    {translate('quotation.information')}

    \n
    \n onInputChange(e, 'namn')}\n onInvalid={(e) => handleInvalidInput(e)}\n required\n />\n onInputChange(e, 'adress')}\n onInvalid={(e) => handleInvalidInput(e)}\n required\n />\n onInputChange(e, 'ort')}\n onInvalid={(e) => handleInvalidInput(e)}\n required\n />\n onInputChange(e, 'postnummer')}\n onInvalid={(e) => handleInvalidInput(e)}\n required\n />\n onInputChange(e, 'email')}\n onInvalid={(e) => handleInvalidInput(e)}\n required\n />\n\n onInputChange(e, 'telefonnummer')}\n onInvalid={(e) => handleInvalidInput(e)}\n required\n />\n
    \n

    {translate('quotation.extra')}

    \n \n updateUserInfo(e.target.value, 'fastighetsbeteckning')\n }\n className=\"mb-4\"\n />\n \n updateUserInfo(e.target.value, 'information')\n }\n />\n
    \n
    \n {translate('quotation.document')}\n
    \n \n updateUserInfo(e.target.files![0], 'files')\n }\n type=\"file\"\n className=\"[&::file-selector-button]:cursor-pointer [&::file-selector-button]:border-0 [&::file-selector-button]:bg-primary-500 [&::file-selector-button]:px-4 [&::file-selector-button]:py-2 [&::file-selector-button]:font-bold [&::file-selector-button]:uppercase [&::file-selector-button]:text-black [&::file-selector-button]:md:py-4\"\n />\n
    \n
    \n handleInvalidInput(e)}\n />\n {termsAndConditionsLink?.href && (\n \n {termsAndConditionsLink.text}\n \n )}\n
    \n \n {currentError\n ? translate('general.error')\n : translate('quotation.submit')}\n \n {' '}\n \n )}\n \n );\n};\n\nexport default QuotationRequest;\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { translate } from '../../Services/translation';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport { cells } from '../../styling/utils/grid';\n\ninterface VariantSpecRow {\n name: string;\n value: string | number | undefined;\n}\n\nconst StyledTechnicalTable = styled.div`\n border: 1px solid ${getColor('grey', 300)};\n`;\n\nconst StyledTableRow = styled.div`\n padding: 0.8rem;\n display: grid;\n ${cells(2)}\n gap: 1.6rem;\n\n &:nth-child(even) {\n background: ${getColor('grey', 100)};\n }\n\n &:not(:last-child) {\n border-bottom: 1px solid ${getColor('grey', 300)};\n }\n`;\n\nconst StyledPlaceholderRow = styled(StyledTableRow)`\n span {\n grid-column: span 2;\n ${text('large')}\n font-weight: bold;\n }\n`;\n\nconst ProductPageTechnicalTable = () => {\n const [variantSpecs, setVariantSpecs] = useState([]);\n const { selectedVariant } = useTypedSelector((state) => state.productPage);\n\n useEffect(() => {\n selectedVariant &&\n setVariantSpecs([\n { name: 'product.id', value: selectedVariant.id },\n { name: 'product.dimension', value: selectedVariant.dimension },\n { name: 'product.effect', value: selectedVariant.effect },\n { name: 'product.height', value: selectedVariant.height },\n { name: 'product.length', value: selectedVariant.length },\n { name: 'product.weight', value: selectedVariant.weight },\n { name: 'product.width', value: selectedVariant.width },\n ]);\n }, [selectedVariant]);\n\n return (\n <>\n \n {selectedVariant ? (\n <>\n {variantSpecs.length > 0 &&\n variantSpecs\n .filter((spec) => spec.value)\n .map((spec, idx) => (\n \n {translate(spec.name)}\n {spec.value}\n \n ))}{' '}\n \n ) : (\n \n {translate('product.no-variant')}\n \n )}\n \n \n );\n};\n\nexport default ProductPageTechnicalTable;\n","import React from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { translate } from '../../Services/translation';\n\nconst ProductPageArticleNumber = () => {\n const { selectedVariant } = useTypedSelector((state) => state.productPage);\n return (\n <>\n {selectedVariant ? (\n
    \n {translate('product.id')} {selectedVariant?.id}\n
    \n ) : null}\n \n );\n};\n\nexport default ProductPageArticleNumber;\n","import React from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { translate } from '../../Services/translation';\nimport PriceModel from '../../Types/PriceModel';\n\nconst ProductPagePrice = (price: PriceModel) => {\n const priceFrom = price.formattedPrice;\n const { selectedVariant } = useTypedSelector((state) => state.productPage);\n return (\n <>\n {selectedVariant ? (\n

    \n {selectedVariant.price?.formattedCampaignPrice ? (\n <>\n \n {selectedVariant.price?.formattedCampaignPrice}\n \n \n {selectedVariant.price?.formattedPrice}\n \n \n \n \n ) : (\n <>\n \n {selectedVariant.price?.formattedPrice}\n \n \n \n \n )}\n

    \n ) : (\n

    \n {translate('product.from')} {priceFrom}\n

    \n )}\n \n );\n};\n\nexport default ProductPagePrice;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport StockStatus from '../StockStatus/StockStatus';\n\nconst StyledStockStatusPlaceholder = styled.div`\n height: 24px;\n width: 100%;\n`;\n\nconst ProductPageStockStatus = () => {\n const { selectedVariant } = useTypedSelector((state) => state.productPage);\n\n return selectedVariant ? (\n \n ) : (\n \n );\n};\n\nexport default ProductPageStockStatus;\n","import React, { useEffect, useState } from 'react';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport BuyButton from '../BuyButton/BuyButton';\n\nconst ProductPageBuyButton = () => {\n const { selectedVariant } = useTypedSelector((state) => state.productPage);\n const [isDisabled, setIsDisabled] = useState(false);\n\n useEffect(() => {\n setIsDisabled(false);\n if (selectedVariant?.disabled) {\n setIsDisabled(true);\n }\n }, [selectedVariant]);\n\n return ;\n};\n\nexport default ProductPageBuyButton;\n","import React, { useEffect, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport { setBuyButtonArticleNumber } from '../../Actions/BuyButton.action';\nimport {\n setProductPageSelectedVariant,\n setProductPageSelectedVariantQuery,\n} from '../../Actions/ProductPage.action';\nimport { translate } from '../../Services/translation';\nimport Product from '../../Types/Product';\nimport Dropdown from '../Dropdown';\nimport VariantPickerProps from './types/VariantPickerProps';\n\nconst VariantDropdown = ({\n variants,\n hasSelectedVariant,\n productItem,\n variantPickerOptions,\n}: {\n hasSelectedVariant: boolean;\n productItem: Product;\n variantPickerOptions: VariantPickerProps;\n}) => {\n const dispatch = useDispatch();\n\n const [hasVariant, setHasVariant] = useState(hasSelectedVariant);\n const [selectedVariant, setSelectedVariant] = useState(\n hasVariant ? productItem! : null\n );\n\n useEffect(() => {\n if (selectedVariant) {\n dispatch(setBuyButtonArticleNumber(selectedVariant?.id!));\n dispatch(setProductPageSelectedVariant(selectedVariant!));\n setProductPageSelectedVariantQuery(selectedVariant);\n }\n }, [selectedVariant]);\n\n const getOptions = () => {\n return variants.map((variant) => {\n var filteredVariant = variantPickerOptions?.options?.filter(v => v.variantId == variant.id);\n return {\n value: variant.id,\n label: filteredVariant[0]?.firstVariantValue ?? variant.name,\n disabled: false,\n legendLabel: filteredVariant[0]?.firstVariantLabel,\n };\n });\n };\n\n const onChange = (event) => {\n setHasVariant(false);\n let selectedVariantObj = variants.find((v) => v.id == event.value);\n setSelectedVariant(selectedVariantObj);\n };\n\n const compare = (a, b) => {\n if (a.label < b.label) {\n return -1;\n }\n if (a.label > b.label) {\n return 1;\n }\n return 0;\n };\n\n return (\n \n );\n};\n\nexport default VariantDropdown;\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { translate } from '../../Services/translation';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { text } from '../../styling/mixins/typography';\nimport Button from '../Button';\nimport Input from '../Inputs/Input';\n\nconst StyledNewsLetterContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 0.8rem;\n max-width: 440px;\n`;\n\nconst StyledNewsLetterForm = styled.form`\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n width: 100%;\n\n ${breakpoint('small')} {\n flex-direction: row;\n }\n\n & .news-letter__input {\n width: unset;\n flex: 1;\n }\n`;\n\nconst StyledNewsLetterText = styled.div`\n ${text('large')}\n text-align: center;\n`;\n\nconst NewsLetter = ({ newsLetterText }) => {\n const [isSubmitting, setIsSubmitting] = useState(false);\n const [status, setStatus] = useState('default');\n const [emailInputValue, setEmaiInputValue] = useState('');\n\n const submitNewsLetterSignUp = (e) => {\n e.preventDefault();\n setIsSubmitting(true);\n\n const url =\n 'https://trk.idrelay.com/3032/act/60583599fcb74da292b76a858e34ff68';\n const request = {\n method: 'POST',\n mode: 'cors',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n },\n body: `email=${emailInputValue}`,\n };\n\n const re = /^(([^<>()\\[\\]\\\\.,;:\\s@\"]+(\\.[^<>()\\[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/;\n\n if (re.test(emailInputValue)) {\n fetch(url, request).then(({ status }) => {\n if (status === 200) {\n setIsSubmitting(false);\n setStatus('success');\n setEmaiInputValue('');\n } else {\n setIsSubmitting(false);\n setStatus('error');\n }\n });\n } else {\n setIsSubmitting(false);\n setStatus('error');\n }\n };\n return (\n \n {newsLetterText}\n submitNewsLetterSignUp(e)}>\n {\n setStatus('default');\n setEmaiInputValue(e.target.value);\n }}\n />\n \n {translate('general.add')}\n \n \n {status !== 'default' && (\n \n {status == 'success' && translate('newsletter.success')}\n {status == 'error' && translate('newsletter.error')}\n \n )}\n \n );\n};\n\nexport default NewsLetter;\n","import React, { useCallback } from 'react';\nimport styled from 'styled-components';\nimport Modal from 'react-modal';\nimport { useTypedSelector } from '../../Hooks/useTypedSelector';\nimport { useDispatch } from 'react-redux';\nimport { setPriceHistoryModalOpen } from '../../Actions/PriceHistory.actions';\nimport Icon from '../Icon';\nimport { text } from '../../styling/mixins/typography';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\nimport { getColor } from '../../styling/mixins/colors';\n\nconst customModalStyles = {\n content: {\n background: 'none',\n padding: 0,\n border: 'none',\n },\n overlay: {\n background: 'rgba(0, 0, 0, 0.8)',\n zIndex: 2003,\n },\n};\n\nconst StyledModalContent = styled.div`\n background-color: ${getColor('grey', 100)};\n margin: auto;\n border: 1px solid ${getColor('grey', 400)};\n border-radius: 4px;\n max-width: 640px;\n transform: translateY(-50%);\n top: 40%;\n position: relative;\n padding: 2.8rem;\n ${breakpoint('large')} {\n padding: 4rem;\n }\n\n .close-button-container {\n position: absolute;\n top: 0.5rem;\n right: 0.5rem;\n font-size: 2.4rem;\n }\n .close {\n position: absolute;\n width: 14px;\n height: 14px;\n top: 5px;\n right: 5px;\n color: ${getColor('grey', 400)};\n cursor: pointer;\n }\n .modal-body {\n ${text('large')}\n }\n .modal-header {\n margin-bottom: 0.8rem;\n }\n .lowest-price {\n margin-top: 0.8rem;\n }\n`;\n\nconst PriceHistoryModal = () => {\n const {\n modalOpen,\n previouslyLowestPrice,\n numberOfDays,\n description,\n title,\n } = useTypedSelector((state) => state.priceHistory);\n\n const dispatch = useDispatch();\n\n const close = useCallback(() => {\n dispatch(\n setPriceHistoryModalOpen(\n false,\n previouslyLowestPrice,\n numberOfDays,\n description,\n title\n )\n );\n }, [dispatch, previouslyLowestPrice, numberOfDays, description, title]);\n\n return (\n
    \n \n \n
    \n
    \n \n
    \n
    {title}
    \n

    {previouslyLowestPrice}

    \n
    \n
    \n

    {description}

    \n
    \n
    \n \n
    \n );\n};\n\nexport default PriceHistoryModal;\n","import React from 'react';\nimport { LinkModel } from '../../Types/LinkModel';\nimport styled from 'styled-components';\nimport { cells } from '../../styling/utils/grid';\nimport { getColor } from '../../styling/mixins/colors';\nimport { text } from '../../styling/mixins/typography';\nimport { breakpoint } from '../../styling/mixins/breakpoints';\n\ninterface CardList {\n links: CardItem[];\n}\n\ninterface CardItem {\n link: LinkModel;\n title: string;\n description: string;\n imageUrl: string;\n}\n\nconst StyledWrapper = styled.div<{ amountOfLinks: number }>`\n display: grid;\n gap: 2.4rem;\n position: relative;\n ${(p) => cells(p.amountOfLinks)}\n padding-right: 1.6rem;\n\n ${breakpoint('large')} {\n padding-right: 2.4rem;\n }\n`;\n\nconst StyledLink = styled.a`\n padding: 0;\n display: flex;\n\n img {\n aspect-ratio: 3/2;\n object-fit: cover;\n max-height: 250px;\n width: 100%;\n }\n\n .content {\n display: flex;\n flex-direction: column;\n gap: 0.4rem;\n width: 100%;\n\n .title {\n ${text('medium')}\n font-weight: bold;\n }\n\n .description {\n ${text('small')}\n }\n }\n\n &:hover .icon {\n background-color: ${getColor('primary', 600)};\n }\n`;\n\nconst StyledLinkCard = styled.div`\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n width: 100%;\n`;\n\nconst MegaMenuCardBlock = ({ links }: CardList) => {\n const Link = React.memo<{ item: CardItem }>(({ item }) => (\n \n \n {item.imageUrl && (\n {item.link?.text}\n )}\n
    \n
    {item.title}
    \n
    {item.description}
    \n
    \n
    \n
    \n ));\n\n return (\n \n {links?.map((item) => (\n \n ))}\n \n );\n};\n\nexport default MegaMenuCardBlock;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { StyledBrandLogo } from '../ProductCards/styles/ProductCard.styling';\n\nconst StyledBrandImage = styled.img`\n height: 2.4rem;\n width: auto;\n`;\n\nconst ProductPageBrandImage = ({ brandLogoUrl }: { brandLogoUrl: string }) => {\n return (\n
    \n \n
    \n );\n};\n\nexport default ProductPageBrandImage;\n","import { Swiper, SwiperSlide } from 'swiper/react';\nimport React, { useEffect, useState } from 'react';\nimport ProductCard from '../Components/ProductCards/ProductCard';\nimport swiperCss from '!!raw-loader!../../../node_modules/swiper/swiper.min.css';\nimport swiperPagination from '!!raw-loader!../../../node_modules/swiper/modules/pagination/pagination.min.css';\nimport { Pagination } from 'swiper';\nimport Product from '../Types/Product';\nimport ProductBlockNoSlider from './ProductBlockNoSlider';\nimport styled from 'styled-components';\nimport { getColor } from '../styling/mixins/colors';\nimport { useTypedSelector } from '../Hooks/useTypedSelector';\n\ninterface SimilarProductsProps {\n relationProducts: {[key: string]: KeyValuePair};\n title: string;\n}\n\ninterface KeyValuePair {\n key: K;\n value: V;\n}\n\nconst StyledNoSwiperWrapper = styled.div`\n padding-bottom: 3.2rem;\n`;\n\nconst StyledProductSwiper = styled(Swiper)`\n ${swiperCss}\n ${swiperPagination}\n padding-bottom: 3.2rem;\n & .swiper-slide {\n height: auto;\n }\n\n & .swiper-wrapper {\n padding-bottom: 45px;\n }\n\n & .swiper-pagination {\n height: auto;\n bottom: 0;\n }\n\n .swiper-pagination-bullet {\n &-active {\n background-color: ${getColor('primary')};\n }\n }\n`;\n\nconst SimilarProductsSlider = ({ relationProducts, title }: SimilarProductsProps) => {\n const [renderSlider, setRenderSlider] = useState(false);\n const [productList, setProductList] = useState();\n\n useEffect(() => setRenderSlider(true), []);\n\n const { selectedVariant } = useTypedSelector((state) => state.productPage);\n \n useEffect(() => {}, [selectedVariant]);\n\n useEffect(() => {\n if(selectedVariant){\n Object.keys(relationProducts).forEach(key => {\n if(key === selectedVariant.id){\n setProductList(relationProducts[key]?.value)\n }\n })\n }\n else {\n Object.keys(relationProducts).forEach(key => {\n if(key.startsWith('b')){\n setProductList(relationProducts[key]?.value)\n }\n })\n }\n }, [selectedVariant]);\n\n return productList?.length > 0 && renderSlider ? (\n
    \n

    {title}

    \n \n {productList?.map((product, idx) => (\n \n \n \n ))}\n \n
    \n ) : productList?.length > 0 && (\n //Render product block without slider on server to avoid layout shifting\n \n \n \n );\n};\n\nexport default SimilarProductsSlider;","import { css, createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { getColor } from '../../mixins/colors';\nimport { section } from '../../utils/grid';\nimport { hideFor } from '../../utils/visibility';\n\nconst Header = createGlobalStyle`\n #header.header {\n position: sticky;\n top: 0;\n left: 0;\n right: 0;\n z-index: 50;\n background-color: ${getColor('white')};\n }\n .header {\n &__top-section {\n background-color: ${getColor('primary', 500)};\n }\n\n &__main-content {\n ${section}\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding-top: 0.8rem;\n padding-bottom: 0.8rem;\n gap: 2.4rem;\n height: ${(p) => p.theme.header.headerMainContentHeightMobile};\n\n ${breakpoint('large')} {\n padding-top: 1.6rem;\n padding-bottom: 1.6rem;\n height: auto;\n }\n }\n\n &__menu-wrapper {\n ${hideFor('large')}\n flex: 1;\n justify-content: start;\n align-items: center;\n }\n\n &__logo-wrapper {\n display: flex;\n flex: 1;\n justify-content: center;\n align-items: center;\n padding: 0;\n\n ${breakpoint('large')} {\n flex: none;\n }\n }\n\n &__logo {\n & img {\n height: 32px;\n width: auto;\n max-width: max-content;\n\n ${breakpoint('large')} {\n height: 40px;\n width: 235px;\n }\n }\n }\n\n &__quick-search {\n &--mobile {\n display: flex;\n padding-bottom: 1.2rem;\n background-color: ${getColor('white')};\n border-bottom: 1px solid ${getColor('grey', 300)};\n height: ${(p) => p.theme.header.headerQuickSearchHeightMobile};\n }\n\n ${breakpoint('large')} {\n display: none;\n }\n\n &--desktop {\n display: none;\n\n ${breakpoint('large')} {\n display: flex;\n flex-grow: 1;\n }\n }\n }\n\n &__components {\n display: flex;\n flex: 1;\n justify-content: flex-end;\n align-items: center;\n box-sizing: border-box;\n gap: 1.6rem;\n padding-left: 0.4rem;\n text-decoration: none;\n\n ${breakpoint('large')} {\n flex: none;\n }\n\n & img {\n width: 20px;\n height: auto;\n }\n\n & .icon {\n font-size: 2rem;\n }\n }\n\n &__navigation {\n border-top: 1px solid ${getColor('grey', 300)};\n border-bottom: 1px solid ${getColor('grey', 300)};\n box-sizing: border-box;\n display: none;\n position: relative;\n z-index: 1;\n\n ${breakpoint('large')} {\n display: block;\n }\n }\n\n &__mobile-button {\n height: 1.5em !important;\n width: 1.5em !important;\n }\n\n & .quick-search {\n padding-bottom: 0.8rem;\n border-bottom: 1px solid ${getColor('grey', 300)};\n\n &__form {\n position: relative;\n }\n\n &__icon {\n position: absolute;\n right: 0;\n margin: 0 1rem;\n max-height: 20px;\n max-width: 20px;\n }\n\n &__magnifier {\n color: ${getColor('grey', 500)} !important;\n }\n\n &__input {\n flex-grow: 1;\n padding: 0 12px 0 12px;\n height: 40px;\n font-family: ${(p) => p.theme.typography.fontFamily};\n font-weight: 400;\n line-height: 150%;\n color: ${getColor('grey', 500)};\n border: 1px solid ${getColor('grey', 400)};\n border-radius: 4px;\n }\n }\n & .navigation {\n position: static;\n }\n\n & .login__btn {\n font-size: 2rem;\n cursor: pointer;\n }\n }\n`;\n\nexport default Header;\n","import { css, createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { getColor } from '../../mixins/colors';\nimport { text } from '../../mixins/typography';\nimport { section } from '../../utils/grid';\n\nconst TopMenu = createGlobalStyle`\n .top-menu {\n ${section}\n padding-top: 0.4rem;\n padding-bottom: 0.4rem;\n display: none;\n justify-content: space-between;\n\n ${breakpoint('large')} {\n display: flex;\n }\n\n &__navigation {\n display: flex;\n gap: 1.6rem;\n\n &--left{\n gap: 0.4rem;\n }\n }\n\n &__item {\n ${text('small')}\n color: ${getColor('grey', 900)};\n\n &:hover {\n opacity: 0.8;\n }\n }\n\n &__phoneNumber{\n ${text('medium')}\n color: ${getColor('grey', 900)};\n }\n }\n`;\n\nexport default TopMenu;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { getColor } from '../../mixins/colors';\nimport { text } from '../../mixins/typography';\nimport { section } from '../../utils/grid';\n\nconst Breadcrumbs = createGlobalStyle`\n .breadcrumbs {\n &__container {\n overflow-x: auto;\n white-space: nowrap;\n scrollbar-width: none;\n -ms-overflow-style: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n &__list {\n ${section}\n padding-top: 0.8rem;\n padding-bottom: 0.8rem;\n display: flex;\n align-items: center;\n }\n\n &__item {\n ${text('small')}\n display: flex;\n align-items: center;\n\n ${breakpoint('medium')} {\n ${text('medium')}\n }\n\n &--anchor {\n color: ${getColor('grey', 500)};\n\n &:hover {\n text-decoration: underline;\n }\n\n &:last-child {\n color: ${getColor('grey', 900)};\n pointer-events: none;\n padding-right: 0.8rem;\n }\n }\n }\n\n &__icon {\n margin: 0 0.8rem;\n color: ${getColor('grey', 400)};\n }\n }\n`;\n\nexport default Breadcrumbs;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { getColor } from '../../mixins/colors';\nimport { displayHeader, text } from '../../mixins/typography';\nimport { section } from '../../utils/grid';\n\nconst BrandsList = createGlobalStyle`\n .brands-list {\n width: 100%;\n\n &__container {\n ${section}\n display: flex;\n flex-direction: column;\n align-items: center;\n padding-top: 2.4rem;\n\n ${breakpoint('medium')} {\n padding-top: 3.2rem;\n padding-bottom: 0.8rem;\n }\n\n ${breakpoint('large')} {\n padding-top: 4rem;\n padding-bottom: 1.6rem;\n }\n }\n\n &__header {\n margin-bottom: 4.4rem;\n\n ${breakpoint('large')} {\n display: flex;\n flex-direction: column;\n justify-content: center;\n margin-bottom: 5.2rem;\n }\n\n ${breakpoint('xlarge')} {\n margin-bottom: 6.8rem;\n }\n }\n\n &__title {\n margin-bottom: 0.8rem;\n }\n\n &__para {\n ${text('xlarge')}\n margin-bottom: 3.6rem;\n\n ${breakpoint('large')} {\n margin-bottom: 4.2rem;\n max-width: 640px;\n }\n\n ${breakpoint('xlarge')} {\n margin-bottom: 6rem;\n max-width: 680px;\n }\n\n ${breakpoint('xxlarge')} {\n max-width: 760px;\n }\n }\n\n &__filtering {\n display: flex;\n justify-content: center;\n padding: 0 1.2rem;\n gap: 2.8rem;\n }\n\n &__filtering-item {\n &:last-child {\n margin-right: 0;\n }\n\n &--anchor {\n ${text('xlarge')}\n font-weight: bold;\n text-transform: uppercase;\n }\n }\n\n &__group {\n margin-bottom: 1.6rem;\n }\n\n &__group-letter {\n ${displayHeader('small')}\n margin-bottom: 1.6rem;\n border-bottom: 1px solid ${getColor('grey', 200)};\n padding-bottom: 0.8rem;\n }\n\n &__sublist {\n display: flex;\n flex-direction: column;\n\n ${breakpoint('medium')} {\n flex-direction: row;\n flex-wrap: wrap;\n }\n }\n\n &__sublist-item {\n margin-bottom: 1.6rem;\n\n ${breakpoint('medium')} {\n width: 50%;\n }\n\n ${breakpoint('large')} {\n width: 25%;\n }\n\n &--anchor {\n ${text('xlarge')}\n }\n }\n }\n`;\n\nexport default BrandsList;\n","var _path;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nconst SvgCheck = props => /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: \"1em\",\n height: \"1em\",\n viewBox: \"0 0 24 24\",\n xmlns: \"http://www.w3.org/2000/svg\"\n}, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"m9.55 18-5.7-5.7 1.425-1.425L9.55 15.15l9.175-9.175L20.15 7.4 9.55 18Z\"\n})));\nexport default SvgCheck;","import React from 'react';\nimport ReactDOMServer from 'react-dom/server';\nimport { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport CheckIcon from '../../../../icons/check.svg';\nimport base64 from 'base-64';\nimport { getColor } from '../../mixins/colors';\nimport { header, text } from '../../mixins/typography';\nimport { cells } from '../../utils/grid';\nconst svgTest = ReactDOMServer.renderToString();\nconst checkAsBase64 = base64.encode(svgTest);\n\nconst ProductPage = createGlobalStyle`\n .product-page {\n display: flex;\n flex-direction: column;\n padding-bottom: 2.4rem;\n gap: 1.6rem;\n\n .variant-offers{\n display: none;\n }\n\n ${breakpoint('medium')} {\n padding-bottom: 3.2rem;\n }\n ${breakpoint('large')} {\n padding-bottom: 4rem;\n gap: 3.2rem;\n }\n\n &__wrapper {\n display: flex;\n flex-direction: column;\n width: 100%;\n gap: 2.4rem;\n\n ${breakpoint('large')}{\n display: grid;\n ${cells(2)}\n gap: 3.2rem;\n }\n }\n\n &__image {\n overflow: hidden;\n }\n\n &__related {\n width: 100%;\n\n & .swiper-block {\n overflow-y: hidden;\n }\n }\n\n &__related-title {\n margin-bottom: 1.6rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 2.4rem;\n }\n }\n\n &__brand {\n ${text('xlarge')}\n color: ${getColor('grey', 500)};\n }\n\n &__name {\n ${header('h1')};\n ${breakpoint('large')};\n margin-bottom: 0.8rem;\n }\n\n &__art-no-rating-container {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n padding: 0px;\n gap: .5rem;\n }\n &__label-and-rating {\n display: flex;\n align-items: center;\n gap: 0.5rem;\n }\n\n &__art-no {\n ${text('small')}\n }\n\n &__rating {\n display: flex;\n align-items: center;\n gap: .25rem;\n \n & [data-ls-product-review-count=\"0\"] {\n display: none;\n }\n &__count {\n ${text('small')}\n color: ${getColor('grey', 900)};\n }\n }\n\n &__description {\n ${text('large')}\n padding: 2.4rem 0;\n }\n\n &__editor {\n & ul, ol {\n padding-left: 2rem;\n list-style-type: initial;\n }\n }\n\n &__price {\n margin-bottom: 1.6rem;\n display:flex; \n\n .product__old-price {\n -webkit-text-decoration: line-through;\n text-decoration: line-through;\n font-weight: 400;\n margin-left: 0.8rem;\n color: ${getColor('grey', 500)};\n }\n }\n\n &__buttons-container {\n margin-bottom: 1.6rem;\n\n & .buy-button__wrapper {\n flex: 1;\n }\n }\n\n &__buy-button-wrapper {\n .quantity-input {\n width: 100%;\n max-width: 56px;\n min-height: 56px;\n }\n }\n \n & .quantity-input {\n max-width: 112px;\n min-height: 56px;\n }\n\n &__buy-button {\n flex: 1;\n height: 56px;\n width: 100%;\n display: flex;\n justify-content: center;\n align-items: center;\n }\n\n &__stock-status {\n margin-top: 1.6rem;\n margin-bottom: 2.4rem;\n line-height: 120%;\n display: flex;\n\n & svg {\n font-size: 2rem !important;\n margin-right: 0.4rem !important;\n }\n\n & span {\n font-size: 16px !important;\n }\n }\n\n &__usp {\n margin-bottom: 2.4rem;\n\n & ul {\n display: flex;\n flex-direction: column;\n gap: 1.2rem;\n\n ${breakpoint('large')}{\n flex-direction: row;\n flex-wrap: wrap;\n }\n }\n\n & li {\n display: flex;\n align-items: center;\n\n &:before {\n content: '';\n width: 24px;\n height: 24px;\n background: url(data:image/svg+xml;base64,${checkAsBase64});\n background-size: cover;\n background-repeat: no-repeat;\n margin-right: 0.8rem;\n }\n\n &::marker {\n font-size: 30px;\n padding-right: 0.4rem;\n }\n }\n }\n\n &__variant-picker {\n margin-bottom: 1.6rem;\n }\n\n &__variant-list {\n width: 100%;\n margin-top: 2.4rem;\n\n ${breakpoint('medium')} {\n margin-top: 3.2rem;\n }\n\n ${breakpoint('large')} {\n margin-top: 4.0rem;\n }\n }\n }\n .information-tabs {\n display:flex;\n flex-direction: column;\n gap: 0.2rem;\n\n &-wrapper {\n padding: 1.6rem;\n\n &--reviews {\n padding: 0 0.8rem 0.8rem;\n }\n }\n\n .attachments__list {\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n font-weight: bold;\n text-transform: uppercase;\n }\n\n .attachment__anchor {\n display: flex;\n justify-content: center;\n align-items: center;\n flex-direction: column;\n gap: 0.8rem;\n border: 1px solid ${getColor('grey', 300)};\n padding: 1.2rem; \n transition: background 150ms;\n ${breakpoint('medium')}{\n flex-direction: row;\n }\n\n & span {\n display:inline-block;\n word-wrap: break-word;\n max-width: 100%;\n text-align: center;\n }\n \n &:hover {\n background: ${getColor('grey', 100)}\n }\n }\n\n .help__btns {\n margin-top: 1.2rem;\n display: flex;\n flex-direction: column;\n gap: 1.2rem;\n\n ${breakpoint('small')}{\n flex-direction: row;\n }\n }\n\n .help__btn {\n flex: 1;\n background: ${getColor('primary')};\n font-weight: bold;\n text-transform: uppercase;\n text-align: center;\n padding: 1.2rem;\n }\n \n &__item-details {\n display: grid;\n }\n\n &__item {\n display: flex;\n padding: 0.4rem;\n box-sizing: border-box;\n line-height: 150%;\n\n &:nth-child(odd) {\n background-color: ${getColor('grey', 100)};\n }\n }\n\n &__item-name {\n flex: 0 0 30%;\n font-weight: 600;\n }\n\n &__item-value {\n flex: 1;\n }\n\n .collapsible {\n border: none;\n\n &:last-child {\n border: none;\n }\n\n label {\n ${header('h5')};\n background-color: ${getColor('grey', 100)};\n padding: 0.8rem 0.8rem 0.8rem 1.6rem;\n\n & span {\n pointer-events: none;\n }\n }\n\n .icon-wrapper {\n pointer-events: none;\n display: flex;\n justify-content: center;\n align-items: center;\n width: 40px;\n height: 40px;\n background-color: ${getColor('primary')};\n\n icon {\n display: flex;\n }\n\n .icon {\n font-size: 2.4rem;\n }\n }\n\n .collapsible__content {\n ${text('large')}\n background-color: ${getColor('white')};\n border: 1px solid ${getColor('grey', 100)};\n border-top: none;\n }\n\n .collapsed > * {\n display: none;\n }\n }\n}\n\n.collapsible:has(.lipscore-review-count[data-ls-product-review-count=\"0\"]){\n display: none;\n}\n\n`;\n\nexport default ProductPage;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\n\nconst ErrorPage = createGlobalStyle`\n .error-page {\n padding-top: 2.4rem;\n padding-bottom: 2.4rem;\n\n ${breakpoint('medium')} {\n padding-top: 3.2rem;\n padding-bottom: 3.2rem;\n }\n\n ${breakpoint('large')} {\n padding-top: 4rem;\n padding-bottom: 4rem;\n display: flex;\n justify-content: center;\n }\n\n &__container {\n max-width: 768px;\n display: flex;\n flex-direction: column;\n }\n\n &__title {\n margin-bottom: 0.8rem;\n }\n }\n`;\n\nexport default ErrorPage;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { getColor } from '../../mixins/colors';\nimport { header } from '../../mixins/typography';\nimport { section } from '../../utils/grid';\n\nconst ProductList = createGlobalStyle`\n .product-list {\n position: relative;\n background: ${getColor('white')};\n\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0, 0, 0, 0.04);\n pointer-events: none;\n z-index: 2;\n }\n\n &__content {\n ${section}\n margin-bottom: 1.6rem;\n flex-direction: column;\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 2.4rem;\n padding-top: 2.4rem;\n padding-bottom: 2.4rem;\n\n ${breakpoint('medium')} {\n padding-top: 2.4rem;\n padding-bottom: 3.2rem;\n flex-direction: row;\n }\n & .category-description__wrapper {\n padding: 0;\n margin-bottom: 0;\n\n & .content {\n max-width: none;\n }\n }\n }\n\n &__header-text {\n flex: 1;\n\n .product-list__header-title {\n ${header('h1')}\n margin-bottom: 0.8rem;\n }\n }\n\n &__header-banner {\n flex: 1;\n\n & img {\n width: 100%;\n }\n }\n\n &__aside {\n grid-column: span 2;\n }\n\n &_no-banner__text {\n max-width: unset;\n\n ${breakpoint('medium')} {\n max-width: 50%;\n }\n }\n\n &__wrapper {\n & .filter-bar-buttons__wrapper {\n display: none;\n }\n }\n }\n`;\n\nexport default ProductList;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { btn } from '../../mixins/buttons';\nimport { getColor } from '../../mixins/colors';\nimport { cells } from '../../utils/grid';\n\nconst LinkBlock = createGlobalStyle`\n .link-block {\n &__header {\n margin-bottom: 2.4rem;\n }\n\n &__wrapper {\n display: flex;\n overflow-x: auto;\n overflow-y: hidden;\n -ms-overflow-style: none;\n scrollbar-width: none;\n padding-right: 3rem;\n gap: 1.6rem;\n /* ${cells(6)} */\n\n ${breakpoint('medium')} {\n padding-right: unset;\n display: grid;\n -ms-overflow-style: unset;\n scrollbar-width: unset;\n overflow: unset;\n }\n\n &:after {\n content: '';\n width: 40px;\n height: 45px;\n right: 0;\n pointer-events: none;\n position: absolute;\n background: linear-gradient(\n 270deg,\n rgba(255, 255, 255, 1) 0%,\n rgba(255, 255, 255, 0) 100%\n );\n\n ${breakpoint('medium')} {\n display: none;\n }\n }\n }\n\n &__wrapper-thumbnail {\n ${breakpoint('medium')} {\n display: flex !important;\n flex-wrap: wrap;\n -ms-overflow-style: unset;\n scrollbar-width: unset;\n overflow: unset;\n }\n\n &:after {\n content: '';\n height: 12rem !important;\n }\n }\n\n &__button {\n ${btn('outlined', 'small')}\n min-width: max-content;\n text-align: center;\n }\n\n &__thumbnail {\n aspect-ratio: 1/1;\n min-height: 72px;\n min-width: 72px;\n\n ${breakpoint('medium')} {\n min-width: 100%;\n min-height: auto;\n }\n margin-bottom: 0.8rem;\n }\n\n &__text {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-direction: column;\n }\n\n &__thumbnail-wrapper {\n display: unset;\n flex-grow: unset;\n\n ${breakpoint('medium')} {\n display: inline-block;\n flex-grow: 1;\n width: calc(100% * (1 / 8) - 16px);\n }\n\n &:hover .link-block__thumbnail {\n opacity: 0.8;\n transition: 0.3s;\n }\n\n &:hover .link-block__text {\n text-decoration: underline;\n }\n }\n }\n`;\n\nexport default LinkBlock;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { getColor } from '../../mixins/colors';\nimport { section } from '../../utils/grid';\n\nconst LipscoreServiceReviewsBlock = createGlobalStyle`\n .lipscore-service-review-list-container {\n ${section}\n }\n\n .lipscore-real-reviews-badge-container {\n margin-top: 0;\n overflow: hidden;\n }\n\n .lipscore-review-list-box-container {\n ${breakpoint('medium')} {\n display: grid;\n gap: 2rem;\n grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));\n }\n }\n\n .lipscore-paginator {\n display: flex;\n justify-content: center;\n }\n\n .lipscore-review-box {\n background-color: ${getColor('white')};\n margin-top: 15px;\n }\n\n .lipscore-review-box:first-child {\n margin-top: 15px;\n }\n`;\n\nexport default LipscoreServiceReviewsBlock;\n","import { createGlobalStyle } from 'styled-components';\nimport { getColor } from '../../mixins/colors';\nimport { text } from '../../mixins/typography';\nimport { breakpoint } from '../../mixins/breakpoints';\n\nconst CheckoutPage = createGlobalStyle`\n .checkout-header {\n padding: 1.6rem 0;\n border-bottom: 1px solid ${getColor('grey', 300)};\n font-family: ${(p) => p.theme.typography.fontFamily};\n\n &__wrapper {\n display: flex;\n align-items: center;\n }\n\n &__back {\n flex: 1;\n }\n\n a {\n ${text('medium')}\n font-weight: bold;\n }\n\n &__logo {\n max-width: 140px;\n max-height: 32px;\n display: flex;\n justify-content: center;\n flex: 1;\n ${breakpoint('large')} {\n max-width: 240px;\n max-height: 42px;\n }\n }\n\n &__customer-support {\n display: flex;\n flex: 1;\n justify-content: flex-end;\n\n a {\n ${text('medium')}\n font-weight: bold;\n }\n }\n }\n`;\n\nexport default CheckoutPage;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { getColor } from '../../mixins/colors';\nimport { header, text } from '../../mixins/typography';\nimport { section } from '../../utils/grid';\nimport { hideFor, showFor } from '../../utils/visibility';\n\nconst Footer = createGlobalStyle`\n #footer.footer {\n background-color: ${getColor('graphic')};\n color: ${getColor('white')};\n position: relative;\n }\n .footer {\n &__top {\n ${section}\n padding-top: 4rem;\n }\n\n &__lists {\n display: flex;\n flex-wrap: wrap;\n\n ${breakpoint('large')} {\n margin-bottom: 4rem;\n }\n\n &--desktop {\n display: none;\n\n ${breakpoint('medium')} {\n display: flex;\n }\n }\n\n &--mobile {\n display: block;\n margin-bottom: 1.6rem;\n\n ${breakpoint('medium')} {\n display: none;\n }\n }\n\n & .collapsible {\n border: none !important;\n\n & > label {\n padding: 1.6rem 0;\n }\n }\n }\n\n &__list {\n display: flex;\n flex-direction: column;\n width: 100%;\n margin-bottom: 2.8rem;\n\n ${breakpoint('medium')} {\n width: 50%;\n }\n\n ${breakpoint('large')} {\n width: 25%;\n margin-bottom: 0;\n }\n\n &--mobile {\n display: flex;\n flex-direction: column;\n }\n }\n\n &__title {\n ${header('h5')}\n ${breakpoint('medium')} {\n margin-bottom: 1.2rem;\n }\n }\n\n &__icon {\n transition: rotate 300ms;\n }\n\n &__link {\n color: ${getColor('white')};\n ${text('large')}\n\n &:not(:last-child){\n margin-bottom: 1.8rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 1.2rem;\n }}\n }\n\n &__span {\n ${text('large')}\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n\n & p {\n display: flex;\n align-items: center;\n }\n }\n\n &__container {\n display: flex;\n flex-direction: column;\n align-items: center;\n position: relative;\n gap: 2.4rem;\n z-index: 1;\n margin-bottom: 2.4rem;\n ${breakpoint('medium')} {\n margin-bottom: 3.2rem;\n }\n }\n\n &__para {\n ${text('large')}\n text-align: center;\n max-width: 800px;\n }\n\n &__logo{\n img{\n width: 232px;\n height: 40px;\n }\n }\n\n &__socials {\n display: flex;\n gap: 2.4rem;\n\n & .social { \n display: flex;\n justify-content: center;\n align-items: center;\n width: 40px;\n height: 40px;\n background-color: ${getColor('primary')};\n border-radius: 50%; \n\n img {\n width: 24px;\n height: 24px;\n }\n }\n }\n\n &__svg {\n position: absolute;\n pointer-events: none;\n bottom: 52px;\n z-index: 0;\n\n &--desktop {\n max-height: 64%;\n\n &--right {\n ${showFor('large')}\n right: 0;\n }\n &--left {\n ${showFor('medium')}\n left: 0;\n }\n }\n\n &--mobile {\n ${hideFor('large')}\n right: 0;\n }\n }\n\n &__bottom {\n padding: 1.6rem 0;\n background-color: ${getColor('primary')};\n }\n\n &__payments {\n ${section}\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 1.6rem;\n\n img {\n height: 20px;\n }\n }\n }\n`;\n\nexport default Footer;\n","import { css, createGlobalStyle } from 'styled-components';\n\nconst Quicksearch = createGlobalStyle`\n .quicksearch {\n flex-grow: 1;\n }\n`;\n\nexport default Quicksearch;\n","import { css } from 'styled-components';\nimport { breakpoint } from '../mixins/breakpoints';\n\nexport default css`\n section[data-litium-block-id] {\n background-position: center;\n background-size: cover;\n }\n\n .block__title {\n margin-bottom: 1.6rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 2.4rem;\n }\n }\n\n .block__cta-btn {\n background: #eed351;\n padding: 1.2rem 2rem;\n color: #191919;\n text-transform: uppercase;\n font-weight: bold;\n }\n\n .cls {\n &-banner-block {\n aspect-ratio: 2/1;\n max-height: 720px;\n }\n }\n`;\n","import { css } from 'styled-components';\nimport { getColor } from '../mixins/colors';\n\nexport default css`\n .collapsible {\n border-top: 1px solid ${getColor('grey', 300)};\n\n &:last-child {\n border-bottom: 1px solid ${getColor('grey', 300)};\n }\n\n &--no-border {\n border-top: none;\n border-bottom: none;\n }\n\n &__toggle-wrapper {\n display: flex;\n align-items: center;\n\n & span {\n margin-right: 0.4rem;\n }\n }\n &__label {\n min-height: 57px;\n }\n\n & > label {\n display: flex;\n justify-content: space-between;\n align-items: center;\n width: 100%;\n padding: 1.2rem 0;\n cursor: pointer;\n font-weight: 700;\n\n & svg,\n & icon {\n transition: 0.2s ease-in-out;\n pointer-events: none;\n font-size: 2rem;\n }\n\n &[aria-expanded='true'] .icon-wrapper .icon {\n transform: rotate(180deg);\n }\n }\n\n & .collapsed {\n visibility: hidden;\n height: 0;\n }\n }\n\n .ReactCollapse--collapse {\n transition: height 200ms;\n }\n\n .collapsible__content[aria-hidden='false'] {\n overflow: hidden;\n transition: height 0.2s ease-in-out;\n }\n\n .collapsible__content[aria-hidden='true'] {\n transition: height 0.2s ease-in-out;\n }\n`;\n","import { breakpoint } from '../mixins/breakpoints';\nimport { css } from 'styled-components';\nimport { span } from '../utils/grid';\nimport { showFor } from '../utils/visibility';\n\nexport default css`\n .layout-two-columns {\n grid-template-columns: 1fr;\n\n ${breakpoint('large')} {\n grid-template-columns: repeat(12, 1fr);\n }\n\n &__left {\n ${showFor('large')}\n ${span(2)}\n }\n\n &__right {\n ${span(10)}\n flex-grow: 1;\n ${breakpoint('large')} {\n grid-column: span 10;\n }\n }\n }\n`;\n","import { css } from 'styled-components';\nimport { getColor } from '../mixins/colors';\n\nexport default css`\n html {\n font-size: 62.5% !important; // 62.5% makes it easier to convert px to rem from design-files. 10px = 1rem, 16px = 1.6rem\n }\n\n body {\n font-family: ${(p) => p.theme.typography.fontFamily};\n font-size: 1.6rem; // Here we are reseting the font-size to default to 16px\n margin: 0;\n padding: 0;\n border: 0;\n vertical-align: baseline;\n line-height: 1;\n color: ${getColor('grey', 900)};\n background-color: ${getColor('white')};\n\n // Scrollbar should always be visible\n overflow-y: scroll;\n &.overlay {\n // Disable scrolling in body, but keep scroll bar visible, while overlay is visible\n position: fixed;\n inset: 0;\n }\n\n & * {\n box-sizing: border-box;\n }\n }\n\n html,\n div,\n span,\n applet,\n object,\n iframe,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n p,\n blockquote,\n pre,\n a,\n abbr,\n acronym,\n address,\n big,\n cite,\n code,\n del,\n dfn,\n em,\n img,\n ins,\n kbd,\n q,\n s,\n samp,\n small,\n strike,\n strong,\n sub,\n sup,\n tt,\n var,\n b,\n u,\n i,\n center,\n dl,\n dt,\n dd,\n ol,\n ul,\n li,\n fieldset,\n form,\n label,\n legend,\n table,\n caption,\n tbody,\n tfoot,\n thead,\n tr,\n th,\n td,\n article,\n aside,\n canvas,\n details,\n embed,\n figure,\n figcaption,\n footer,\n header,\n hgroup,\n menu,\n nav,\n output,\n ruby,\n section,\n summary,\n time,\n mark,\n audio,\n video {\n margin: 0;\n padding: 0;\n border: 0;\n vertical-align: baseline;\n }\n\n /* HTML5 display-role reset for older browsers */\n article,\n aside,\n details,\n figcaption,\n figure,\n footer,\n header,\n hgroup,\n menu,\n nav,\n section {\n display: block;\n }\n\n ul,\n ol {\n list-style: none;\n }\n\n blockquote,\n q {\n quotes: none;\n }\n\n blockquote:before,\n blockquote:after,\n q:before,\n q:after {\n content: '';\n }\n\n table {\n border-collapse: collapse;\n border-spacing: 0;\n }\n\n a {\n text-decoration: none;\n color: ${getColor('grey', 900)};\n }\n\n input,\n textarea {\n &:focus,\n &:active,\n &:focus-visible {\n outline: none;\n }\n }\n\n img {\n max-width: 100%;\n height: auto;\n }\n\n button,\n input[type='submit'],\n input[type='reset'] {\n background: none;\n color: inherit;\n border: none;\n padding: 0;\n font: inherit;\n cursor: pointer;\n outline: inherit;\n }\n\n .normal-list {\n ul {\n list-style-type: disc;\n list-style-position: inside;\n margin-block-start: 1em;\n margin-block-end: 1em;\n margin-inline-start: 0px;\n margin-inline-end: 0px;\n padding-inline-start: 40px;\n }\n ol {\n list-style-type: decimal;\n list-style-position: inside;\n margin-block-start: 1em;\n margin-block-end: 1em;\n margin-inline-start: 0px;\n margin-inline-end: 0px;\n padding-inline-start: 40px;\n }\n ul ul,\n ol ul {\n list-style-type: circle;\n list-style-position: inside;\n margin-block-start: 0;\n margin-block-end: 0;\n margin-inline-start: 0px;\n margin-inline-end: 0px;\n padding-inline-start: 40px;\n }\n ol ol,\n ul ol {\n list-style-type: lower-latin;\n list-style-position: inside;\n margin-block-start: 0;\n margin-block-end: 0;\n margin-inline-start: 0px;\n margin-inline-end: 0px;\n padding-inline-start: 40px;\n }\n }\n\n .links-list {\n ul {\n padding-top: 0.8rem;\n }\n }\n`;\n","import { css } from 'styled-components';\nimport { getColor } from '../mixins/colors';\n\nexport default css`\n /* #overlay-container .overlay {\n position: fixed;\n inset: 0;\n width: 100%;\n height: 100%;\n z-index: 30;\n animation: 0.2s ease-in-out 0s both 1 fade-in;\n -webkit-animation: 0.2s ease-in-out 0s both 1 fade-in;\n background-color: ${getColor('overlay')};\n opacity: 1;\n } */\n`;\n","import { css } from 'styled-components';\nimport { getColor } from '../mixins/colors';\n\nexport default css`\n .skeleton {\n position: relative;\n overflow: hidden;\n\n &__text {\n background-color: ${getColor('grey', 200)};\n\n &.name {\n max-width: 300px;\n }\n\n &.overline {\n max-width: 80px;\n margin-bottom: 0.8rem;\n }\n\n &.description {\n max-width: 80%;\n margin-bottom: 0.8rem;\n }\n\n &.price {\n max-width: 100px;\n }\n\n &.stock {\n max-width: 64px;\n margin-bottom: 0.8rem;\n }\n }\n\n .actions {\n width: 100px;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n }\n\n &__action {\n height: 50px;\n background-color: ${getColor('grey', 200)};\n }\n\n &::after {\n position: absolute;\n inset: 0;\n transform: translateX(-100%);\n background-image: linear-gradient(\n 90deg,\n rgba(255, 255, 255, 0) 0,\n rgba(255, 255, 255, 0.2) 20%,\n rgba(255, 255, 255, 0.5) 60%,\n rgba(255, 255, 255, 0)\n );\n animation: shimmer 2s infinite;\n content: '';\n }\n }\n\n @keyframes shimmer {\n 100% {\n transform: translateX(100%);\n }\n }\n`;\n","import { css } from 'styled-components';\nimport blocks from './blocks';\nimport collapsible from './collapsible';\nimport layoutTwoColumns from './layout-two-columns';\nimport normalize from './normalize';\nimport overlay from './overlay';\nimport skeleton from './skeleton';\n\nexport default css`\n ${collapsible}\n ${normalize}\n ${overlay}\n ${skeleton}\n ${layoutTwoColumns}\n ${blocks}\n`;\n","import { css } from 'styled-components';\n\nexport default css`\n .icon {\n display: inline-block;\n fill: currentColor;\n height: 1em;\n width: 1em;\n\n &--small {\n height: 0.6em;\n width: 0.6em;\n }\n\n &--large {\n height: 1.25em;\n width: 1.25em;\n }\n\n &--larger {\n height: 1.5em;\n width: 1.5em;\n }\n\n &--largest {\n height: 2em;\n width: 2em;\n }\n }\n`;\n","import { css } from 'styled-components';\nimport { breakpoint } from '../mixins/breakpoints';\n\nexport default css`\n .mb-xlarge {\n margin-bottom: 4.8rem;\n ${breakpoint('medium')} {\n margin-bottom: 9.6rem;\n }\n }\n .mb-large {\n margin-bottom: 3.2rem;\n ${breakpoint('medium')} {\n margin-bottom: 6.4rem;\n }\n }\n .mb-medium {\n margin-bottom: 2.4rem;\n ${breakpoint('medium')} {\n margin-bottom: 4.8rem;\n }\n }\n .mb-small {\n margin-bottom: 1.6rem;\n ${breakpoint('medium')} {\n margin-bottom: 3.2rem;\n }\n }\n .mb-xsmall {\n margin-bottom: 0.8rem;\n ${breakpoint('medium')} {\n margin-bottom: 1.6rem;\n }\n }\n .mb-none {\n margin-bottom: 0;\n }\n\n //margin top\n .mt-xlarge {\n margin-top: 4.8rem;\n ${breakpoint('medium')} {\n margin-top: 9.6rem;\n }\n }\n .mt-large {\n margin-top: 3.2rem;\n ${breakpoint('medium')} {\n margin-top: 6.4rem;\n }\n }\n .mt-medium {\n margin-top: 2.4rem;\n ${breakpoint('medium')} {\n margin-top: 4.8rem;\n }\n }\n .mt-small {\n margin-top: 1.6rem;\n ${breakpoint('medium')} {\n margin-top: 3.2rem;\n }\n }\n .mt-xsmall {\n margin-top: 0.8rem;\n ${breakpoint('medium')} {\n margin-top: 1.6rem;\n }\n }\n .mt-none {\n margin-top: 0;\n }\n\n // global margins\n .m-xlarge {\n margin: 4.8rem;\n ${breakpoint('medium')} {\n margin: 9.6rem;\n }\n }\n .m-large {\n margin: 3.2rem;\n ${breakpoint('medium')} {\n margin: 6.4rem;\n }\n }\n .m-medium {\n margin: 2.4rem;\n ${breakpoint('medium')} {\n margin: 4.8rem;\n }\n }\n .m-small {\n margin: 1.6rem;\n ${breakpoint('medium')} {\n margin: 3.2rem;\n }\n }\n .m-xsmall {\n margin: 0.8rem;\n ${breakpoint('medium')} {\n margin: 1.6rem;\n }\n }\n .m-none {\n margin: 0;\n }\n .m-auto {\n margin: auto;\n }\n .mx-auto {\n margin-left: auto;\n margin-right: auto;\n }\n`;\n","import { css } from 'styled-components';\nimport { breakpoint } from '../mixins/breakpoints';\n\nexport default css`\n .pb-xlarge {\n padding-bottom: 4.8rem;\n ${breakpoint('medium')} {\n padding-bottom: 9.6rem;\n }\n }\n .pb-large {\n padding-bottom: 3.2rem;\n ${breakpoint('medium')} {\n padding-bottom: 6.4rem;\n }\n }\n .pb-medium {\n padding-bottom: 2.4rem;\n ${breakpoint('medium')} {\n padding-bottom: 4.8rem;\n }\n }\n .pb-small {\n padding-bottom: 1.6rem;\n ${breakpoint('medium')} {\n padding-bottom: 3.2rem;\n }\n }\n .pb-xsmall {\n padding-bottom: 0.8rem;\n ${breakpoint('medium')} {\n padding-bottom: 1.6rem;\n }\n }\n .pb-none {\n padding-bottom: 0;\n }\n\n //padding top\n .pt-xlarge {\n padding-top: 4.8rem;\n ${breakpoint('medium')} {\n padding-top: 9.6rem;\n }\n }\n .pt-large {\n padding-top: 3.2rem;\n ${breakpoint('medium')} {\n padding-top: 6.4rem;\n }\n }\n .pt-medium {\n padding-top: 2.4rem;\n ${breakpoint('medium')} {\n padding-top: 4.8rem;\n }\n }\n .pt-small {\n padding-top: 1.6rem;\n ${breakpoint('medium')} {\n padding-top: 3.2rem;\n }\n }\n .pt-xsmall {\n padding-top: 0.8rem;\n ${breakpoint('medium')} {\n padding-top: 1.6rem;\n }\n }\n .pt-none {\n padding-top: 0;\n }\n\n // global paddings\n .p-xlarge {\n padding: 4.8rem;\n ${breakpoint('medium')} {\n padding: 9.6rem;\n }\n }\n .p-large {\n padding: 3.2rem;\n ${breakpoint('medium')} {\n padding: 6.4rem;\n }\n }\n .p-medium {\n padding: 2.4rem;\n ${breakpoint('medium')} {\n padding: 4.8rem;\n }\n }\n .p-small {\n padding: 1.6rem;\n ${breakpoint('medium')} {\n padding: 3.2rem;\n }\n }\n .p-xsmall {\n padding: 0.8rem;\n ${breakpoint('medium')} {\n padding: 1.6rem;\n }\n }\n .p-none {\n padding: 0;\n }\n`;\n","import { css } from 'styled-components';\n\nexport default css`\n json-data {\n display: none;\n }\n`;\n","import { header } from '../mixins/typography';\nimport fontRegular from '../../../fonts/SourceSansPro-Regular.woff?asset-inline';\nimport fontBold from '../../../fonts/SourceSansPro-Bold.woff?asset-inline';\nimport fontItalic from '../../../fonts/SourceSansPro-Italic.woff?asset-inline';\nimport { css } from 'styled-components';\n\nexport default css`\n /* Source Sans Regular */\n @font-face {\n font-family: 'Source Sans Pro';\n font-style: normal;\n font-weight: 400;\n src: url(${fontRegular}) format('woff');\n }\n /* Source Sans Bold */\n @font-face {\n font-family: 'Source Sans Pro';\n font-style: normal;\n font-weight: 700;\n src: url(${fontBold}) format('woff');\n }\n /* Source Sans Italic */\n @font-face {\n font-family: 'Source Sans Pro';\n font-style: italic;\n font-weight: 400;\n src: url(${fontItalic}) format('woff');\n }\n\n h1 {\n ${header('h1')};\n }\n h2 {\n ${header('h2')};\n }\n h3 {\n ${header('h3')};\n }\n h4 {\n ${header('h4')};\n }\n h5 {\n ${header('h5')};\n }\n h6 {\n ${header('h6')};\n }\n .styled-editor-string{\n p {\n line-height: 1.5;\n & + p {\n margin-top: 1.2rem;\n }\n }\n \n h1,\n h2,\n h3,\n h4,\n h5,\n h6 {\n margin-bottom: 1.2rem;\n \n &:last-child {\n margin-bottom: 0;\n }\n }\n \n p + h1,\n p + h1,\n p + h2,\n p + h3,\n p + h4,\n p + h5,\n p + h6 {\n margin-top: 2.4rem;\n }\n \n ul,\n ol {\n list-style-type: initial;\n padding-left: 2rem;\n margin: 1.2rem 0;\n line-height: 1.5;\n }\n }\n`;\n","import { createGlobalStyle } from 'styled-components';\nimport globals from './globals';\nimport grid from './utils/grid';\nimport icons from './utils/icons';\nimport margins from './utils/margins';\nimport paddings from './utils/paddings';\nimport misc from './utils/misc';\nimport text from './utils/text';\nimport visibility from './utils/visibility';\n\nexport const GlobalStyle = createGlobalStyle`\n ${grid}\n ${misc}\n ${text}\n ${visibility}\n ${icons}\n ${margins}\n ${paddings}\n ${globals}\n`;\n","import { breakpoint } from '../../mixins/breakpoints';\nimport { createGlobalStyle } from 'styled-components';\nimport { text } from '../../mixins/typography';\nimport { cells, grid } from '../../utils/grid';\n\nconst brandsBlock = createGlobalStyle`\n .brand-block {\n padding-top: 2.4rem;\n padding-bottom: 3.2rem;\n\n ${breakpoint('medium')} {\n padding-top: 3.2rem;\n padding-bottom: 4rem;\n }\n\n ${breakpoint('large')} {\n padding-top: 4rem;\n padding-bottom: 4.8rem;\n }\n\n &__header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-bottom: 2.4rem;\n\n ${breakpoint('medium')} {\n margin-bottom: 3.2rem;\n }\n }\n\n &__link {\n ${text('xlarge')}\n text-decoration: underline;\n }\n\n &__list {\n ${grid}\n justify-content: center;\n align-items: center;\n padding: 0 0.8rem;\n\n ${breakpoint('medium', 'down')} {\n grid-template-columns: repeat(2, 1fr) !important;\n }\n }\n\n &__image {\n aspect-ratio: 1/1;\n object-fit: contain;\n }\n }\n`;\n\nexport default brandsBlock;\n","import { createGlobalStyle } from 'styled-components';\nimport { getColor } from '../../mixins/colors';\nimport { text } from '../../mixins/typography';\n\nconst ArticlePage = createGlobalStyle`\n .article-page {\n .layout-two-columns__right .section {\n padding-left: 0;\n padding-right: 0;\n }\n\n &__image {\n img {\n width: 100%;\n }\n\n figcaption {\n ${text('small')}\n color: ${getColor('grey', 400)};\n }\n }\n\n &__title {\n margin-bottom: 1.2rem;\n }\n\n &__intro {\n ${text('xlarge')}\n line-height: 1.5;\n font-weight: 700;\n margin-bottom: 2.4rem;\n }\n }\n`;\n\nexport default ArticlePage;\n","import { createGlobalStyle } from 'styled-components';\nimport { getColor } from '../../mixins/colors';\nimport { text } from '../../mixins/typography';\n\nconst FileList = createGlobalStyle`\n .file-list-wrapper {\n margin-bottom: 1.6rem;\n }\n \n .file-list {\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n }\n\n .file-list-title {\n margin-bottom: 0.8rem;\n }\n\n .file-list-item {\n display: flex;\n align-items: center;\n gap: 0.8rem;\n\n &:hover {\n & .file-list-icon-wrapper{\n background-color: ${getColor('primary', 600)};\n }\n & .file-list-text {\n text-decoration: underline;\n }\n }\n }\n\n .file-list-text-wrapper {\n ${text('medium')}\n display: flex;\n flex-direction: column;\n }\n\n .file-list-size {\n ${text('small')}\n color: ${getColor('grey', 500)};\n }\n\n .file-list-icon {\n color: ${getColor('secondary')};\n font-size: 2.4rem;\n }\n\n .file-list-icon-wrapper {\n min-width: 40px;\n min-height: 40px;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: ${getColor('primary')};\n transition: background-color 0.125s;\n align-self: flex-start;\n }\n`;\n\nexport default FileList;\n","import { createGlobalStyle } from 'styled-components';\nimport { getColor } from '../../mixins/colors';\nimport { text } from '../../mixins/typography';\n\nconst LinkList = createGlobalStyle`\n .link-list-wrapper {\n margin-bottom: 1.6rem;\n }\n \n .link-list {\n display: flex;\n flex-direction: column;\n gap: 0.8rem;\n }\n\n .link-list-title {\n margin-bottom: 0.8rem;\n }\n\n .link-list-item {\n display: flex;\n align-items: center;\n gap: 0.8rem;\n\n &:hover {\n & .link-list-icon-wrapper{\n background-color: ${getColor('primary', 600)};\n }\n & .link-list-text {\n text-decoration: underline;\n }\n }\n }\n\n .link-list-text {\n ${text('medium')}\n display: flex;\n flex-direction: column;\n }\n\n .link-list-icon {\n color: ${getColor('secondary')};\n font-size: 2.4rem;\n }\n\n .link-list-icon-wrapper {\n min-width: 40px;\n min-height: 40px;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: ${getColor('primary')};\n transition: background-color 160ms;\n }\n`;\n\nexport default LinkList;\n","import { createGlobalStyle } from 'styled-components';\nimport { getColor } from '../../mixins/colors';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { cells } from '../../utils/grid';\nimport { text } from '../../mixins/typography';\n\nconst NewsList = createGlobalStyle`\n .news-list {\n background-color: ${getColor('grey', 100)};\n\n &__container {\n padding-top: 2.4rem;\n padding-bottom: 2.4rem;\n\n ${breakpoint('medium')}{\n padding-top: 3.2rem;\n padding-bottom: 3.2rem;\n }\n ${breakpoint('large')}{\n padding-top: 4.0rem;\n padding-bottom: 4.0rem;\n }\n }\n\n &__intro {\n max-width: 768px;\n margin: 0 auto;\n margin-bottom: 2.4rem;\n\n ${breakpoint('large')}{\n margin-bottom: 3.2rem;\n }\n ${breakpoint('xlarge')}{\n margin-bottom: 4.8rem;\n }\n\n p {\n ${text('xlarge')}\n }\n }\n\n &__list {\n display: grid;\n gap: 1.6rem;\n margin-bottom: 2.4rem;\n\n ${breakpoint('medium')}{\n ${cells(2)}\n gap: 2.4rem;\n }\n ${breakpoint('large')}{\n ${cells(3)}\n margin-bottom: 3.2rem;\n }\n ${breakpoint('xlarge')}{\n ${cells(4)}\n margin-bottom: 4.8rem;\n }\n }\n \n &__item-image {\n width: 100%;\n aspect-ratio: 4 / 3;\n object-fit: cover;\n }\n\n &__item-content {\n background-color: ${getColor('white')};\n padding: 2.4rem;\n }\n\n &__item-date {\n ${text('medium')}\n color: ${getColor('grey', 600)};\n margin-bottom: 0.8rem;\n }\n}\n\n`;\n\nexport default NewsList;\n","import { createGlobalStyle } from 'styled-components';\nimport { getColor } from '../../mixins/colors';\nimport { text } from '../../mixins/typography';\n\nconst Pagination = createGlobalStyle`\n .pagination {\n display: flex;\n justify-content: center;\n }\n\n .pagination__item {\n overflow: hidden;\n border: 1px solid ${getColor('grey', 200)};\n\n &:first-child {\n border-radius: 4px 0 0 4px;\n }\n\n &:last-child {\n border-radius: 0 4px 4px 0;\n }\n }\n\n .pagination__link {\n ${text('medium')}\n font-weight: bold;\n width: 40px;\n height: 40px;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: ${getColor('white')};\n \n &--current {\n background-color: ${getColor('grey', 100)};\n }\n\n &--disabled {\n cursor: not-allowed;\n \n .icon{\n opacity: 0.24;\n }\n }\n }\n`;\n\nexport default Pagination;\n","import React from 'react';\nimport ReactDOMServer from 'react-dom/server';\nimport { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport CheckIcon from '../../../../icons/check.svg';\nimport base64 from 'base-64';\nimport { getColor } from '../../mixins/colors';\nimport { header, text } from '../../mixins/typography';\nconst svgTest = ReactDOMServer.renderToString();\nconst checkAsBase64 = base64.encode(svgTest);\n\nconst SearchNoResultPage = createGlobalStyle`\n .search-result__header-wrapper{\n background-color: ${getColor('grey', 100)};\n }\n .search-result__hit-header{\n padding-top: 2.4rem;\n color: ${getColor('grey', 900)}\n }\n .search-result__hits{\n margin-top: 0.8rem;\n ${text('xlarge')}\n }\n\n .search-result__no-hit-text{\n ${text('xlarge')}\n margin-top: 0.8rem;\n padding-bottom: 2.4rem;\n }\n`;\n\nexport default SearchNoResultPage;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\n\nconst ContentPage = createGlobalStyle`\n .content-page {\n min-height: calc(100vh - 1000px);\n\n ${breakpoint('small')}{\n min-height: calc(100vh - 900px);\n }\n ${breakpoint('medium')}{\n min-height: calc(100vh - 1000px);\n }\n ${breakpoint('large')}{\n min-height: calc(100vh - 900px);\n }\n\n .subnav{\n &--mobile{\n ${breakpoint('medium')} {\n display: none; }\n }\n &--desktop{\n display: none;\n ${breakpoint('medium')} {\n display: block; }\n }\n }\n }\n`;\n\nexport default ContentPage;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { text } from '../../mixins/typography';\nimport { getColor } from '../../mixins/colors';\n\nconst ProductsBlock = createGlobalStyle`\n .product-block__header{\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: 0.8rem;\n\n & .block__title {\n margin-bottom: 0;\n }\n margin-bottom: 1.6rem;\n\n ${breakpoint('medium')}{\n margin-bottom: 2.4rem;\n }\n }\n\n .block__link{\n ${text('large')}\n font-weight: bold;\n text-transform: uppercase;\n border-bottom: 2px solid ${getColor('primary')};\n white-space: nowrap;\n }\n`;\n\nexport default ProductsBlock;\n","import { createGlobalStyle } from 'styled-components';\nimport { breakpoint } from '../../mixins/breakpoints';\nimport { section } from '../../utils/grid';\n\nconst MaterialCalculatorPage = createGlobalStyle`\n .mc-container {\n ${section}\n gap: 3.2rem;\n padding-bottom: 2.4rem;\n\n .title {\n margin-bottom: 1.2rem;\n }\n\n ${breakpoint('large')} {\n gap: 6.4rem;\n padding-bottom: 4rem;\n }\n }\n`;\n\nexport default MaterialCalculatorPage;\n","import React from 'react';\nimport renderWrapper from './render-wrapper';\nimport Header from '../styling/razor/components/header';\nimport TopMenu from '../styling/razor/components/top-menu';\nimport Breadcrumbs from '../styling/razor/components/breadcrumbs';\nimport BrandsList from '../styling/razor/components/brands-list';\nimport ProductPage from '../styling/razor/pages/product-page';\nimport ErrorPage from '../styling/razor/pages/error-page';\nimport ProductList from '../styling/razor/pages/product-list';\nimport LinkBlock from '../styling/razor/block/link-block';\nimport LipscoreServiceReviewsBlock from '../styling/razor/block/lipscoreservicereviews-block';\nimport CheckoutPage from '../styling/razor/pages/checkout-page';\nimport Footer from '../styling/razor/components/footer';\nimport Quicksearch from '../styling/razor/components/quicksearch';\nimport { GlobalStyle } from '../styling/global.styled';\nimport BrandsBlock from '../styling/razor/block/brands-block';\nimport ArticlePage from '../styling/razor/pages/article-page';\nimport FileList from '../styling/razor/components/file-list';\nimport LinkList from '../styling/razor/components/link-list';\nimport NewsList from '../styling/razor/pages/news-list';\nimport Pagination from '../styling/razor/components/pagination';\nimport SearchNoResultPage from '../styling/razor/pages/search-no-result-page';\nimport ContentPage from '../styling/razor/pages/content-page';\nimport ProductsBlock from '../styling/razor/block/product-block';\nimport MaterialCalculatorPage from '../styling/razor/pages/material-calculator';\n\nglobal['Styles'] = {\n // ProductPage: () => ,\n // BrandsList: () => ,\n // ErrorPage: () => ,\n // ContentPage: () => ,\n // ProductList: () => ,\n // LinkBlock: () => ,\n // LipscoreServiceReviewsBlock: () => ,\n // CheckoutPage: () => ,\n Global: () => (\n <>\n \n \n \n \n \n \n \n \n \n \n \n \n
    \n \n \n \n