{"version":3,"sources":["webpack:///./Avensia.Common/Features/Shared/Blocks/DXCProducts/Components/ProductCarousel.tsx","webpack:///./Avensia.Common/Features/Shared/Blocks/DXCProducts/Components/ProductList.tsx","webpack:///./Avensia.Common/Features/Shared/Blocks/DXCProducts/ProductsBlock.tsx","webpack:///./Avensia.Common/Features/Shared/PageContent/CampaignPageContent.tsx","webpack:///./Avensia.Common/Features/Pages/Campaign/CampaignBrandPage.tsx","webpack:///./Avensia.Common/Features/Product/ProductCard/ProductCard.tsx","webpack:///./Avensia.Common/Features/Shared/Sigvaris/CampaignThemeLink/util.tsx","webpack:///./Avensia.Common/Features/Shared/Sigvaris/CampaignThemeLink/index.tsx","webpack:///./Avensia.Common/Features/Product/ProductCard/Color.tsx","webpack:///./Avensia.Common/Features/Product/ProductCard/ColorsDisplay.tsx","webpack:///./Avensia.Common/Features/Product/ProductAvailability/ProductAvailability.tsx","webpack:///./Avensia.Common/Features/Shared/Blocks/BlockSpacing.ts","webpack:///./Avensia.Common/Features/Shared/BlockBase/index.tsx","webpack:///./Avensia.Common/Features/Shared/Sigvaris/ThemeTextColor/index.tsx","webpack:///./Avensia.Common/Features/Shared/Carousel/index.tsx","webpack:///./Avensia.Common/Features/Product/ProductCard/List.tsx","webpack:///./Avensia.Common/Features/Shared/PageContent/StandardContentContext.tsx","webpack:///./Avensia.Common/Features/Shared/Generic/Teaser.tsx","webpack:///./Avensia.Common/Features/Pages/ContentOverviewPageContext.tsx","webpack:///./Avensia.Common/Features/Shared/Blocks/Video/VideoContent.tsx","webpack:///./Avensia.Common/Features/Shared/ContentCard/index.tsx","webpack:///./Avensia.Common/Features/Shared/PageContent/Components/SocialShare.tsx","webpack:///./Avensia.Common/Features/Shared/ContentCard/OverviewContentCardList.tsx"],"names":["memo","props","_a","children","slideTo","arrows","dots","emblaOptions","options","containScroll","loop","getVisibleCount","visibleItemCount","itemGap","edgeGap","renderThumbs","breakpoint","visibleCount","slidesToScroll","emblaRef","emblaCarousel","prevBtnEnabled","setPrevBtnEnabled","nextBtnEnabled","setNextBtnEnabled","selectedIndex","setSelectedIndex","scrollSnaps","setScrollSnaps","slideRef","scrollTo","index","scrollPrev","scrollNext","length","scrollSnapList","updateArrows","canScrollPrev","canScrollNext","onSelect","selectedScrollSnap","on","previousNumChildren","reInit","slideStyle","width","paddingLeft","display","styleSlides","marginRight","marginLeft","slideNodes","Children","map","slide","createElement","Slide","key","css","Fragment","Container","PrevButton","onClick","enabled","CarouselContainer","ref","Slides","NextButton","Dots","_","DotButton","backgroundColor","height","current","offsetHeight","restProps","CarouselButton","Object","assign","color","left","large","disabled","right","div","position","transform","bottom","padding","xy","tiny","borderRadius","medium","property","top","fontSize","zIndex","ProductBadge","willChange","flex","grow","shrink","basis","overflow","actions","isCompact","isRowLayout","RowLayoutContext","trackingListName","products","align","visibleNumber","Small","lastItemGap","product","ProductCardWrapper","code","ProductCard","addToCart","quantity","ticket","margin","y","justifyContent","isStandardContentPage","StandardContentContext","isCampaignPage","isContentOviewPage","ContentOverviewPageContext","isTablet","titleColor","block","title","preamble","desktopTop","mobileTop","desktopBottom","mobileBottom","blockSpacing","BlockSpacing","additionalStyles","ThemeTextColor","bodyStyle","flexDirection","marginBottom","BlockBase","appearance","ProductsBlock","Div","Title","Preamble","RecommendedProductWrapper","maxWidth","unknown","textAlign","boxSizing","p","_b","_c","disableSocialSharing","content","disableSharing","headline","teaser","isMobile","recommendedProducts","recommendedProductsList","connectedArticlesList","logoUrl","mediaHeight","mediaUrl","mobileImageUrl","imagePreset","Medium","Gigantic","isMediaImage","url","titlePosition","titlePositionTop","titlePositionBottom","isWithContent","mainBody","items","mediaStyle","minWidth","backgroundSize","minHeight","maxHeight","objectFit","objectPosition","videoStyle","imageStyle","headerStyle","x","StyledH1","H1","videoContainerStyle","baseStyle","contentAreaItems","renderHeader","Teaser","Page","Full","ContentPage","Base","Body","LogoWrapper","src","alt","preset","Thumb","lazy","subscribeToCache","fetchpriority","StyledImage","format","JPG","VideoContainer","ClickPreventingOverlay","style","VideoWrapper","VideoContent","videoUrl","autoPlay","muted","__$hoisted_o0","slice","item","componentName","OverviewContentCardList","contentItemList","SocialShare","labelText","socialShareCaption","theme","alignItems","withContent","Provider","value","themeColor","themeColorLight","themeColorDark","isTitlePositionBottom","campaignHeadline","campaignTeaser","isWithCampaignContent","campaignTitleColor","ProductPrice","price","realTimePrice","data","fallbackData","PriceLabel","minPrice","maxPrice","isLoading","nonBoldPrice","explicitCurrency","description","shortDescription","marketType","state","appShellData","countrySettings","currentUser","shouldResolveData","defaultArePricesHidden","arePricesHidden","setArePricesHidden","isBuyable","setIsBuyable","buyable","isB2BPriceSpecific","B2B","B2B_B2C","isB2B","checkBuyable","this","realtimePriceResolve","exclVat","e","then","productCardContent","MediaWrapper","Media","medias","displayName","itemProp","ratio","ThreeToFour","Tiny","promotionName","PromotionFlag","ContentWrapper","Model","model","Colors","colors","colorList","Description","horizontal","findRetailerAvailabilityText","StyledProductAvailability","text","icon","findRetailerAvailabilityIcon","to","linkIdentifier","ProductLink","id","NO_COMMERCE","Favorite","transparent","isNew","NewFlag","priceLabelDecorator","flexGrow","boxShadow","transition","duration","direction","filter","fontWeight","SemiBold","font","weight","size","textTransform","WebkitLineClamp","WebkitBoxOrient","MODEL_LINE_HEIGHT","textOverflow","mapLinkColor","siteTheme","fillInBlock","themeType","lightBlue","darkBlue","mapHoverLinkColor","Link","isTextUnderline","textDecoration","target","ThemePrimary","mapTheme","primary","secondary","primaryDark","A","hex","name","swatch","blackBorder","toLowerCase","colorStyle","border","ColorComponent","SwatchColor","opacity","Tooltip","visibility","whiteSpace","marginTop","Image","hasMore","colorsToDisplay","ExtraColorCount","flexWrap","span","IconWrapper","getAvailabilityIcon","availabilityIcon","getPaddingStyle","spacing","Spacing","desktopLeftRight","desktopTopBottom","mobileLeftRight","mobileTopBottom","paddingRight","paddingTop","paddingBottom","desktopLeft","mobileLeft","desktopRight","mobileRight","BlockHorizontalSpacing","isFullWidth","Content","textColor","darkTextTheme","showNextSlide","edgeMarginRight","edgeMarginLeft","isDesktop","undefined","lineHeight","controls","playsInline","descriptor","FourToThree","CardContent","TextContentSection","TopInfo","Descriptor","ContentCardHeadline","ContentCardTeaser","ReadMoreSection","as","small","overflowWrap","showBorder","isCopied","setIsCopied","currentUrl","window","location","href","handleCopyClick","navigator","clipboard","writeText","document","execCommand","copyTextToClipboard","setTimeout","catch","err","onClickShare","includeOptions","open","StyledLinkedIn","fill","StyledFacebook","StyledTwitter","StyledLink","cursor","LinkedIn","CenteredIconItem","IconText","Twitter","Facebook","CopyLink","CopiedText","Icons","isCentered","gridTemplateColumns","showCopyLink","LabelText","__$hoisted_o1","gridGap","Grid","ArticleCard","columnGap","rowGap"],"mappings":"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","file":"assets/40.chunk.f615634a77755aea9913.js","sourcesContent":["import { __rest } from \"tslib\";\r\nimport React, { useState, useEffect, useCallback, useRef, useMemo, useLayoutEffect } from 'react';\r\nimport { translate } from '@avensia/scope';\r\nimport { useEmblaCarousel } from 'embla-carousel/react';\r\nimport { styled } from '@glitz/react';\r\nimport { monochrome, depthDecorator, margin, alpha, white, createTransitionDecorator, ZIndex, secondary, outlineGrey, huge, } from 'Shared/Style';\r\nimport { PlainButton } from 'Shared/Button';\r\nimport { ArrowRight, ArrowLeft } from 'Shared/Icon';\r\nimport { WhiteThemeBlock } from 'Shared/Theme';\r\nimport usePrevious from 'Shared/use-previous';\r\nimport { useCurrentBreakpoint } from 'Shared/use-viewport';\r\nimport { format } from 'Shared/Translate';\r\nfunction ProductCarousel(props) {\r\n var _a;\r\n const { children, slideTo, arrows, dots, emblaOptions: options = { containScroll: 'keepSnaps', loop: true }, getVisibleCount, visibleItemCount, itemGap = 0, edgeGap, renderThumbs, } = props;\r\n const breakpoint = useCurrentBreakpoint();\r\n const visibleCount = getVisibleCount ? getVisibleCount(breakpoint, visibleItemCount) : 1;\r\n options.slidesToScroll = visibleCount;\r\n const [emblaRef, emblaCarousel] = useEmblaCarousel(options);\r\n const [prevBtnEnabled, setPrevBtnEnabled] = useState(false);\r\n const [nextBtnEnabled, setNextBtnEnabled] = useState(false);\r\n const [selectedIndex, setSelectedIndex] = useState(0);\r\n const [scrollSnaps, setScrollSnaps] = useState([]);\r\n const slideRef = useRef(null);\r\n const scrollTo = useCallback(index => emblaCarousel.scrollTo(index), [emblaCarousel]);\r\n const scrollPrev = useCallback(() => emblaCarousel.scrollPrev(), [emblaCarousel]);\r\n const scrollNext = useCallback(() => emblaCarousel.scrollNext(), [emblaCarousel]);\r\n if (emblaCarousel && scrollSnaps.length === 0) {\r\n setScrollSnaps(emblaCarousel.scrollSnapList());\r\n }\r\n const updateArrows = useCallback(() => {\r\n setPrevBtnEnabled(emblaCarousel.canScrollPrev());\r\n setNextBtnEnabled(emblaCarousel.canScrollNext());\r\n }, [emblaCarousel]);\r\n const onSelect = useCallback(() => {\r\n if (!emblaCarousel)\r\n return;\r\n setSelectedIndex(emblaCarousel.selectedScrollSnap());\r\n updateArrows();\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [emblaCarousel]);\r\n useEffect(() => {\r\n if (emblaCarousel) {\r\n emblaCarousel.on('select', onSelect);\r\n updateArrows();\r\n }\r\n }, [emblaCarousel, onSelect, updateArrows]);\r\n useEffect(() => {\r\n if (typeof slideTo === 'number' && emblaCarousel) {\r\n scrollTo(slideTo);\r\n }\r\n }, [slideTo, emblaCarousel, scrollTo]);\r\n const previousNumChildren = usePrevious(children === null || children === void 0 ? void 0 : children.length);\r\n useLayoutEffect(() => {\r\n if (previousNumChildren !== (children === null || children === void 0 ? void 0 : children.length)) {\r\n if (emblaCarousel) {\r\n /**\r\n * update embla when amount of children changes.\r\n * this is needed when doing a partial render on pdp\r\n * when we do not have all the images yet.\r\n */\r\n emblaCarousel.reInit();\r\n setScrollSnaps(emblaCarousel.scrollSnapList());\r\n }\r\n }\r\n }, [children, emblaCarousel, previousNumChildren]);\r\n const slideStyle = useMemo(() => ({\r\n width: `calc(${100 / visibleCount}% + 6px)`,\r\n paddingLeft: itemGap,\r\n display: 'grid',\r\n }), [itemGap, visibleCount]);\r\n const styleSlides = useMemo(() => {\r\n return edgeGap ? { marginRight: itemGap } : { marginLeft: `-${itemGap}px` };\r\n }, [edgeGap, itemGap]);\r\n const slideNodes = useMemo(() => React.Children.map(children, (slide, index) => (React.createElement(Slide, { key: index, css: slideStyle }, slide))), [children, slideStyle]);\r\n return (React.createElement(React.Fragment, null,\r\n React.createElement(Container, null,\r\n arrows && (React.createElement(PrevButton, { onClick: scrollPrev, enabled: prevBtnEnabled, \"aria-label\": translate('/Shared/Carousel/Next') })),\r\n React.createElement(CarouselContainer, { ref: emblaRef },\r\n React.createElement(Slides, { css: styleSlides, ref: slideRef, key: slideNodes.length }, slideNodes)),\r\n arrows && (React.createElement(NextButton, { onClick: scrollNext, enabled: nextBtnEnabled, \"aria-label\": translate('/Shared/Carousel/Next') })),\r\n dots && (React.createElement(Dots, null, scrollSnaps.map((_, index) => (React.createElement(DotButton, { key: index, css: { backgroundColor: index === selectedIndex ? secondary : outlineGrey }, onClick: () => scrollTo(index), \"aria-label\": `${format(translate('/Shared/Carousel/GoToSlideNumber'), index + 1)}` })))))), renderThumbs === null || renderThumbs === void 0 ? void 0 :\r\n renderThumbs({ emblaCarousel, selectedIndex, height: (_a = slideRef.current) === null || _a === void 0 ? void 0 : _a.offsetHeight })));\r\n}\r\nexport default React.memo(styled(ProductCarousel));\r\nconst PrevButton = (_a) => {\r\n var { enabled, onClick } = _a, restProps = __rest(_a, [\"enabled\", \"onClick\"]);\r\n return (React.createElement(CarouselButton, Object.assign({ css: { color: enabled ? white : monochrome, left: margin.large } }, restProps, { onClick: onClick, disabled: !enabled }),\r\n React.createElement(ArrowLeft, null)));\r\n};\r\nconst NextButton = (_a) => {\r\n var { enabled, onClick } = _a, restProps = __rest(_a, [\"enabled\", \"onClick\"]);\r\n return (React.createElement(CarouselButton, Object.assign({ css: { color: enabled ? white : monochrome, right: margin.large } }, restProps, { onClick: onClick, disabled: !enabled }),\r\n React.createElement(ArrowRight, null)));\r\n};\r\nconst Container = styled.div({\r\n position: 'relative',\r\n width: '100%',\r\n});\r\nconst Dots = styled(WhiteThemeBlock, {\r\n position: 'absolute',\r\n left: '50%',\r\n transform: 'translateX(-50%)',\r\n display: 'flex',\r\n bottom: -huge,\r\n padding: { xy: margin.tiny },\r\n borderRadius: '100vw',\r\n backgroundColor: 'unset',\r\n});\r\nconst DotButton = styled(PlainButton, Object.assign({ display: 'block', width: 10, height: 10, borderRadius: '100%', backgroundColor: 'transparent', marginLeft: margin.medium, ':first-child': {\r\n marginLeft: 0,\r\n } }, createTransitionDecorator({ property: 'background' })));\r\nconst CarouselButton = styled(PlainButton, Object.assign(Object.assign({ display: 'block', position: 'absolute', top: '50%', transform: 'translateY(-50%)', fontSize: alpha }, depthDecorator()), { color: white, zIndex: ZIndex.ProductBadge }));\r\nconst Slides = styled.div({\r\n display: 'flex',\r\n willChange: 'transform',\r\n});\r\nconst Slide = styled.div({\r\n position: 'relative',\r\n flex: { grow: 0, shrink: 0, basis: 'auto' },\r\n});\r\nconst CarouselContainer = styled.div({\r\n flex: { grow: 1, shrink: 0, basis: 'auto' },\r\n overflow: 'hidden',\r\n});\r\n","import React, { useContext } from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport { useCheckoutActions } from 'Checkout/Context';\r\nimport { Breakpoint } from '@avensia/scope';\r\nimport { useIsCompact } from 'Shared/use-viewport';\r\nimport { small, large, medium } from 'Shared/Style';\r\nimport ProductCard from 'Product/ProductCard/ProductCard';\r\nimport ProductCarousel from './ProductCarousel';\r\nimport { RowLayoutContext } from 'Shared/Blocks/RowLayout/RowLayoutContext';\r\nfunction ProductList(props) {\r\n var _a;\r\n const actions = useCheckoutActions();\r\n const isCompact = useIsCompact();\r\n const { isRowLayout } = useContext(RowLayoutContext);\r\n const { trackingListName, visibleItemCount, products } = props;\r\n const options = {\r\n containScroll: isCompact && products.length > 2 ? 'trimSnaps' : '',\r\n align: 'center',\r\n };\r\n function getVisibleCount(breakpoint, visibleNumber) {\r\n if (visibleNumber && !isCompact && !isRowLayout) {\r\n return visibleNumber;\r\n }\r\n if (breakpoint === Breakpoint.Small) {\r\n return 3;\r\n }\r\n else {\r\n return 2;\r\n }\r\n }\r\n return (((_a = props.products) === null || _a === void 0 ? void 0 : _a.length) > 0 && (React.createElement(ProductCarousel, { visibleItemCount: visibleItemCount, getVisibleCount: getVisibleCount, emblaOptions: options, edgeGap: true, itemGap: isCompact ? medium : large, lastItemGap: 15 }, props.products.map(product => (React.createElement(ProductCardWrapper, { key: product.code },\r\n React.createElement(ProductCard, { trackingListName: trackingListName, product: product, addToCart: (code, quantity, ticket) => actions.addToCart(code, quantity, ticket, trackingListName) })))))));\r\n}\r\nexport default styled(ProductList);\r\nconst ProductCardWrapper = styled.div({\r\n margin: { y: small },\r\n display: 'flex',\r\n width: '100%',\r\n justifyContent: 'center',\r\n});\r\n","/**\r\n * @ComponentFor ProductListBlockViewModel\r\n */\r\nimport React, { useContext } from 'react';\r\nimport { epiPropertyValue } from '@avensia/scope-episerver';\r\nimport ProductCardList from 'Product/ProductCard/List';\r\nimport { Part, Appearance as PageAppearance } from 'Shared/PageLayout';\r\nimport { H2 } from 'Shared/Generic';\r\nimport { listNames } from 'TrackingInformation';\r\nimport { styled } from '@glitz/react';\r\nimport ProductList from './Components/ProductList';\r\nimport { StandardContentContext } from 'Shared/PageContent/StandardContentContext';\r\nimport { useIsCompact, useIsTablet } from 'Shared/use-viewport';\r\nimport { CampaignBrandContext } from 'Pages/Campaign/CampaignBrandPageContext';\r\nimport { ContentOverviewPageContext } from 'Pages/ContentOverviewPageContext';\r\nimport { ThemeTextColor } from 'Shared/Sigvaris/ThemeTextColor';\r\nimport BlockBase from 'Shared/BlockBase';\r\nimport { BlockSpacing } from '../BlockSpacing';\r\nimport { RowLayoutContext } from '../RowLayout/RowLayoutContext';\r\nfunction ProductsBlock(props) {\r\n var _a;\r\n const { isStandardContentPage } = useContext(StandardContentContext);\r\n const { isCampaignPage } = useContext(CampaignBrandContext);\r\n const { isContentOviewPage } = useContext(ContentOverviewPageContext);\r\n const { isRowLayout } = useContext(RowLayoutContext);\r\n const { products } = props;\r\n const isCompact = useIsCompact();\r\n const isTablet = useIsTablet();\r\n const titleColor = props.titleColor ? props.titleColor : epiPropertyValue(props.block.titleColor);\r\n const title = props.title ? props.title : epiPropertyValue(props.block.title);\r\n const preamble = props.preamble ? props.preamble : epiPropertyValue((_a = props.block) === null || _a === void 0 ? void 0 : _a.preamble);\r\n const desktopTop = epiPropertyValue(props.block.desktopTop);\r\n const mobileTop = epiPropertyValue(props.block.mobileTop);\r\n const desktopBottom = epiPropertyValue(props.block.desktopBottom);\r\n const mobileBottom = epiPropertyValue(props.block.mobileBottom);\r\n const blockSpacing = BlockSpacing(desktopTop, mobileTop, desktopBottom, mobileBottom);\r\n const additionalStyles = {\r\n color: `${ThemeTextColor(titleColor)}`,\r\n };\r\n const bodyStyle = Object.assign({ display: 'flex', flexDirection: 'column' }, ((mobileBottom !== 'none' || desktopBottom !== 'none') && {\r\n marginBottom: 0,\r\n }));\r\n return (React.createElement(BlockBase, { css: bodyStyle },\r\n React.createElement(Part, { appearance: [PageAppearance.ProductsBlock] },\r\n React.createElement(styled.Div, { css: blockSpacing },\r\n !!title && React.createElement(Title, { css: additionalStyles }, title),\r\n !!preamble && React.createElement(Preamble, null, preamble),\r\n products.length > 0 && (React.createElement(React.Fragment, null, isStandardContentPage || isCampaignPage || isContentOviewPage ? (React.createElement(RecommendedProductWrapper, { css: Object.assign({}, (!isCompact &&\r\n !isRowLayout && {\r\n maxWidth: `calc(100% + -${isTablet ? 188 : 233}px)`,\r\n })) },\r\n React.createElement(ProductList, { trackingListName: listNames.unknown, products: products, visibleItemCount: 3 }))) : (React.createElement(ProductCardList, { trackingListName: listNames.unknown, products: products }))))))));\r\n}\r\nexport default styled(ProductsBlock);\r\nconst Title = styled(H2, {\r\n textAlign: 'center',\r\n});\r\nconst RecommendedProductWrapper = styled.div({\r\n boxSizing: 'content-box',\r\n transform: 'translateX(-50%)',\r\n left: '50%',\r\n position: 'relative',\r\n});\r\nconst Preamble = styled.p({\r\n textAlign: 'center',\r\n});\r\n","import React from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport { epiPropertyValue, ContentArea } from '@avensia/scope-episerver';\r\nimport { Appearance as PageAppearance } from 'Shared/PageLayout';\r\nimport Page from 'Shared/Page';\r\nimport { charlie, fullViewportWidthBlock, gigantic, humongous, large, mediaMinMedium, medium, white, } from 'Shared/Style';\r\nimport Image, { Format, Preset as ImagePreset } from 'Shared/Image/Ratio';\r\nimport Teaser from 'Shared/Generic/Teaser';\r\nimport { useCurrentBreakpoint, useIsCompact, useIsMobile, useIsTablet } from 'Shared/use-viewport';\r\nimport { isMediageImage } from 'Shared/Image/utils';\r\nimport ProductsBlock from 'Shared/Blocks/DXCProducts/ProductsBlock';\r\nimport SocialShare from 'Shared/PageContent/Components/SocialShare';\r\nimport { translate, widthFromBreakpoint } from '@avensia/scope';\r\nimport { media } from '@glitz/core';\r\nimport VideoContent from 'Shared/Blocks/Video/VideoContent';\r\nimport H1 from 'Shared/Generic/H1';\r\nimport { ThemeTextColor } from '../Sigvaris/ThemeTextColor';\r\nimport OverviewContentCardList from 'Shared/ContentCard/OverviewContentCardList';\r\nexport default styled(function CampaignPageContent(props) {\r\n var _a, _b, _c;\r\n const disableSocialSharing = epiPropertyValue(props.content.disableSharing);\r\n const headline = epiPropertyValue(props.content.headline);\r\n const teaser = epiPropertyValue(props.content.teaser);\r\n const isCompact = useIsCompact();\r\n const isMobile = useIsMobile();\r\n const isTablet = useIsTablet();\r\n const breakpoint = useCurrentBreakpoint();\r\n const recommendedProducts = props.recommendedProductsList;\r\n const connectedArticlesList = props.connectedArticlesList;\r\n const logoUrl = epiPropertyValue(props.content.logoUrl);\r\n const mediaHeight = isMobile ? widthFromBreakpoint(breakpoint) / 2 : isTablet ? 0 : 270;\r\n const mediaUrl = isCompact && props.mobileImageUrl ? props.mobileImageUrl : props.mediaUrl;\r\n const imagePreset = isMobile ? ImagePreset.Small : isTablet ? ImagePreset.Medium : ImagePreset.Gigantic;\r\n const isMediaImage = isMediageImage(mediaUrl === null || mediaUrl === void 0 ? void 0 : mediaUrl.url);\r\n const titleColor = epiPropertyValue(props.content.titleColor);\r\n const titlePosition = epiPropertyValue(props.content.titlePosition);\r\n const titlePositionTop = titlePosition === 'top' ? true : false;\r\n const titlePositionBottom = titlePosition === 'bottom' ? true : false;\r\n const isWithContent = ((_a = epiPropertyValue(props.content.mainBody)) === null || _a === void 0 ? void 0 : _a.items[0]) ? true : false;\r\n const mediaStyle = {\r\n minWidth: '100vw',\r\n backgroundSize: 'cover',\r\n minHeight: `calc(100vh - ${mediaHeight}px)`,\r\n position: 'relative',\r\n maxHeight: '100%',\r\n objectFit: 'cover',\r\n objectPosition: 'top',\r\n height: `calc(100vh - ${mediaHeight}px)`,\r\n };\r\n const videoStyle = Object.assign({ top: 0 }, mediaStyle);\r\n const imageStyle = Object.assign(Object.assign(Object.assign({}, fullViewportWidthBlock), { margin: {\r\n bottom: isCompact ? 40 : 46,\r\n } }), (isCompact && Object.assign({}, mediaStyle)));\r\n const headerStyle = {\r\n textAlign: 'center',\r\n margin: {\r\n bottom: isCompact ? gigantic : large,\r\n x: isCompact ? medium : 'inherit',\r\n },\r\n };\r\n const StyledH1 = styled(H1, {\r\n color: `${ThemeTextColor(titleColor)}`,\r\n });\r\n function getAppearance() {\r\n if (isCompact) {\r\n return [PageAppearance.Full];\r\n }\r\n else {\r\n return [PageAppearance.ContentPage];\r\n }\r\n }\r\n const videoContainerStyle = Object.assign(Object.assign({ height: `calc(100vh - ${mediaHeight}px)` }, fullViewportWidthBlock), { marginBottom: 46 });\r\n const baseStyle = Object.assign({}, ((mediaUrl === null || mediaUrl === void 0 ? void 0 : mediaUrl.url) && {\r\n top: -48,\r\n }));\r\n const contentAreaItems = (_c = (_b = epiPropertyValue(props.content.mainBody)) === null || _b === void 0 ? void 0 : _b.items) !== null && _c !== void 0 ? _c : [];\r\n const renderHeader = (React.createElement(React.Fragment, null,\r\n headline && (React.createElement(styled.Div, { css: headerStyle },\r\n React.createElement(StyledH1, null, headline))),\r\n teaser && (React.createElement(styled.Div, { css: headerStyle },\r\n React.createElement(Teaser, null, teaser)))));\r\n return (React.createElement(Page, { appearance: getAppearance() },\r\n React.createElement(Base, { css: Object.assign({}, baseStyle) },\r\n React.createElement(Body, null,\r\n logoUrl && (React.createElement(LogoWrapper, null,\r\n React.createElement(Image, Object.assign({ src: logoUrl, alt: headline, preset: ImagePreset.Thumb, lazy: false, subscribeToCache: true }, { fetchpriority: 'high' })))),\r\n isMediaImage ? (React.createElement(StyledImage, Object.assign({ css: imageStyle, src: mediaUrl, alt: headline, preset: imagePreset, format: Format.JPG, lazy: false, subscribeToCache: true }, { fetchpriority: 'high' }))) : (mediaUrl === null || mediaUrl === void 0 ? void 0 : mediaUrl.url) && !isMediaImage ? (React.createElement(VideoContainer, { css: videoContainerStyle },\r\n React.createElement(ClickPreventingOverlay, { style: {\r\n height: `calc(100vh - ${mediaHeight}px)`,\r\n width: '50%',\r\n right: 0,\r\n } }),\r\n React.createElement(VideoWrapper, null,\r\n React.createElement(VideoContent, { css: videoStyle, videoUrl: mediaUrl === null || mediaUrl === void 0 ? void 0 : mediaUrl.url, autoPlay: true, loop: true, muted: true })))) : (\r\n //Add empty div as default first content if no media to prevent menu content shifting in desktop\r\n React.createElement(styled.Div, { css: __$hoisted_o0 }, \" \")),\r\n //Display only if many content blocks and title pos = top\r\n ((titlePositionBottom && !isWithContent) || titlePositionTop) && (React.createElement(React.Fragment, null,\r\n renderHeader,\r\n contentAreaItems.length > 0 && React.createElement(ContentArea, { items: contentAreaItems }))),\r\n (contentAreaItems === null || contentAreaItems === void 0 ? void 0 : contentAreaItems.length) > 0 && titlePositionBottom && (React.createElement(React.Fragment, null,\r\n React.createElement(ContentArea, { items: contentAreaItems === null || contentAreaItems === void 0 ? void 0 : contentAreaItems.slice(0, 1) }),\r\n renderHeader,\r\n React.createElement(ContentArea, { items: contentAreaItems === null || contentAreaItems === void 0 ? void 0 : contentAreaItems.slice(1, contentAreaItems === null || contentAreaItems === void 0 ? void 0 : contentAreaItems.length) }))),\r\n (recommendedProducts === null || recommendedProducts === void 0 ? void 0 : recommendedProducts.length) > 0 &&\r\n recommendedProducts.map((item, index) => {\r\n return (React.createElement(ProductsBlock, { products: item.products, block: item.block, title: item.title, titleColor: item.titleColor, key: index, preamble: item.preamble, componentName: '' }));\r\n }),\r\n connectedArticlesList && (React.createElement(OverviewContentCardList, { contentItemList: connectedArticlesList, title: translate('/Shared/FurtherReading') })),\r\n !disableSocialSharing && (React.createElement(SocialShare, { labelText: translate('/Shared/ShareThisArticle'), socialShareCaption: headline }))))));\r\n});\r\nconst Base = styled.div({\r\n margin: {\r\n top: 0,\r\n bottom: theme => (theme.isMobile ? medium : humongous),\r\n },\r\n backgroundColor: white,\r\n});\r\nconst Body = styled.div({\r\n margin: {\r\n x: theme => (theme.isCompact ? 16 : 0),\r\n },\r\n});\r\nconst StyledImage = styled(Image, {\r\n objectFit: 'cover',\r\n height: '100%',\r\n maxHeight: theme => (theme.isCompact ? `calc(75vh)` : 620),\r\n width: '100%',\r\n});\r\nconst LogoWrapper = styled.div({\r\n display: 'flex',\r\n justifyContent: 'center',\r\n padding: {\r\n xy: 50,\r\n },\r\n});\r\nconst ClickPreventingOverlay = styled.div({\r\n position: 'absolute',\r\n zIndex: 2,\r\n});\r\nconst VideoWrapper = styled.div(Object.assign({ display: 'flex', alignItems: 'center', justifyContent: 'center', flex: {\r\n basis: 'auto',\r\n grow: 1,\r\n shrink: 1,\r\n }, overflow: 'hidden', position: 'relative' }, media(mediaMinMedium, {\r\n flex: {\r\n basis: '100%',\r\n },\r\n})));\r\nconst VideoContainer = styled.div({\r\n backgroundColor: 'unset',\r\n});\r\nconst __$hoisted_o0 = { height: theme => (theme.isCompact ? 'inherit' : charlie) };\r\n","/**\r\n * @ComponentFor Models/CampaignBrandPageViewModel\r\n */\r\nimport { epiPropertyValue } from '@avensia/scope-episerver';\r\nimport React from 'react';\r\nimport CampaignPageContent from 'Shared/PageContent/CampaignPageContent';\r\nimport { CampaignBrandContext } from './CampaignBrandPageContext';\r\nfunction CampaignBrandPage(props) {\r\n var _a;\r\n const withContent = ((_a = epiPropertyValue(props.content.mainBody)) === null || _a === void 0 ? void 0 : _a.items[0]) ? true : false;\r\n return (React.createElement(CampaignBrandContext.Provider, { value: {\r\n themeColor: props.themeColor,\r\n themeColorLight: props.themeColorLight,\r\n themeColorDark: props.themeColorDark,\r\n isCampaignPage: true,\r\n isTitlePositionBottom: epiPropertyValue(props.content.titlePosition) === 'bottom' ? true : false,\r\n campaignHeadline: epiPropertyValue(props.content.headline),\r\n campaignTeaser: epiPropertyValue(props.content.teaser),\r\n isWithCampaignContent: withContent,\r\n campaignTitleColor: epiPropertyValue(props.content.titleColor),\r\n } },\r\n React.createElement(CampaignPageContent, Object.assign({}, props))));\r\n}\r\nexport default CampaignBrandPage;\r\n","import { __awaiter } from \"tslib\";\r\nimport React, { useCallback, useEffect, useState } from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport Price from 'Pricing/Price';\r\nimport Image, { Ratio, Preset, Format } from 'Shared/Image/Ratio';\r\nimport Link from 'Shared/Link';\r\nimport { WhiteThemeBlock } from 'Shared/Theme';\r\nimport { createTransitionDecorator, margin, defaultTextColor, small, tiny, white, epsilon, negative, mediaMinMedium, ZIndex, zeta, figma, black60, eta, FontWeight, average, medium, large, multilineEllipsis, } from 'Shared/Style';\r\nimport { resetLinkDecorator } from 'Shared/Generic/A';\r\nimport AddToWishlist from 'Wishlist';\r\nimport { translate, DynamicData, useDynamicData, resolveData } from '@avensia/scope';\r\nimport { testIdProps } from '../../test-automation';\r\nimport { media } from '@glitz/core';\r\nimport ColorsDisplay from './ColorsDisplay';\r\nimport { useIsCompact } from 'Shared/use-viewport';\r\nimport ProductAvailability from 'Product/ProductAvailability/ProductAvailability';\r\nimport { useSelector } from 'Shared/State';\r\nimport { MarketType } from 'Shared/constants';\r\nimport { getCurrentUser } from 'Shared/dynamic-data';\r\nexport default styled(function ProductCard(props) {\r\n const { product } = props;\r\n const description = product.shortDescription;\r\n const marketType = useSelector(state => state.appShellData.countrySettings.marketType);\r\n const isCompact = useIsCompact();\r\n const currentUser = useDynamicData(getCurrentUser(), { shouldResolveData: true });\r\n const defaultArePricesHidden = useSelector(state => state.appShellData.defaultArePricesHidden);\r\n const [arePricesHidden, setArePricesHidden] = useState(defaultArePricesHidden);\r\n useEffect(() => {\r\n if (currentUser !== null) {\r\n setArePricesHidden(currentUser.arePricesHidden);\r\n }\r\n }, [currentUser]);\r\n const [isBuyable, setIsBuyable] = useState(product.buyable);\r\n const isB2BPriceSpecific = (marketType === MarketType.B2B || marketType === MarketType.B2B_B2C) && currentUser !== null && currentUser.isB2B;\r\n const checkBuyable = useCallback(() => __awaiter(this, void 0, void 0, function* () {\r\n var _a, _b, _c;\r\n if (isB2BPriceSpecific) {\r\n try {\r\n const realtimePriceResolve = yield resolveData(product.realTimePrice);\r\n if (realtimePriceResolve &&\r\n ((_a = realtimePriceResolve.maxPrice) === null || _a === void 0 ? void 0 : _a.current) &&\r\n ((_c = (_b = realtimePriceResolve.maxPrice) === null || _b === void 0 ? void 0 : _b.current) === null || _c === void 0 ? void 0 : _c.exclVat) > 0) {\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n catch (e) {\r\n return false;\r\n }\r\n }\r\n else {\r\n return product.buyable;\r\n }\r\n }), [product.buyable, isB2BPriceSpecific, product.realTimePrice]);\r\n useEffect(() => {\r\n checkBuyable().then(value => {\r\n setIsBuyable(value);\r\n });\r\n }, [checkBuyable]);\r\n const productCardContent = (React.createElement(React.Fragment, null,\r\n React.createElement(MediaWrapper, null,\r\n React.createElement(Media, { src: product.medias[0], alt: product.displayName, itemProp: \"image\", ratio: Ratio.ThreeToFour, preset: Preset.Tiny, format: Format.JPG, lazy: true }),\r\n product.promotionName && React.createElement(PromotionFlag, null, product.promotionName)),\r\n React.createElement(ContentWrapper, null,\r\n React.createElement(Model, null, product.model),\r\n React.createElement(Colors, { colors: product.colorList }),\r\n React.createElement(Title, null, product.displayName),\r\n !isCompact && React.createElement(Description, null, description),\r\n isBuyable ? (!arePricesHidden && (React.createElement(ProductPrice, { price: product.price, maxPrice: product.price.maxPrice, realTimePrice: props.product.realTimePrice, horizontal: true, nonBoldPrice: true }))) : product.findRetailerAvailabilityText ? (React.createElement(StyledProductAvailability, { text: product.findRetailerAvailabilityText, icon: product.findRetailerAvailabilityIcon })) : (React.createElement(React.Fragment, null)))));\r\n return (React.createElement(Base, null,\r\n React.createElement(Body, Object.assign({ to: product.url, linkIdentifier: product.linkIdentifier }, testIdProps.ProductLink, { id: \"product-card\" }), productCardContent),\r\n marketType !== MarketType.NO_COMMERCE && React.createElement(Favorite, { code: product.code, transparent: true }),\r\n product.isNew && React.createElement(NewFlag, null, translate('/ProductListing/New'))));\r\n});\r\nexport function ProductPrice(props) {\r\n if (!props.price && !props.realTimePrice) {\r\n return null;\r\n }\r\n if (!props.realTimePrice) {\r\n return (React.createElement(PriceLabel, Object.assign({}, props.price.minPrice, { maxPrice: props.price.maxPrice, nonBoldPrice: props.nonBoldPrice, explicitCurrency: props.explicitCurrency })));\r\n }\r\n // `p` will be falsy if we do a real time price call and the server determines\r\n // that the price we had from the start was correct\r\n return (React.createElement(DynamicData, { data: props.realTimePrice, fallbackData: props.price }, p => (React.createElement(PriceLabel, Object.assign({}, (p.minPrice.current ? p.minPrice : props.price.minPrice), { maxPrice: p.maxPrice.current ? p.maxPrice : props.price.maxPrice, isLoading: p === props.price, nonBoldPrice: props.nonBoldPrice, explicitCurrency: props.explicitCurrency })))));\r\n}\r\nconst Colors = styled(ColorsDisplay, {\r\n marginBottom: ({ isCompact }) => (isCompact ? small : average),\r\n});\r\nconst priceLabelDecorator = styled({\r\n display: 'flex',\r\n alignItems: 'flex-end',\r\n flexGrow: 1,\r\n fontSize: ({ isCompact }) => (isCompact ? eta : epsilon),\r\n});\r\nconst PriceLabel = styled(Price, priceLabelDecorator);\r\nconst Base = styled(WhiteThemeBlock, {\r\n position: 'relative',\r\n display: 'flex',\r\n flexDirection: 'column',\r\n width: '100%',\r\n boxShadow: '0px 2px 6px rgba(0,0,0,0.15)',\r\n transition: {\r\n property: 'box-shadow',\r\n duration: '.2s',\r\n },\r\n});\r\nconst Body = resetLinkDecorator(Link, {\r\n backgroundColor: white,\r\n position: 'relative',\r\n display: 'flex',\r\n flex: {\r\n direction: 'column',\r\n grow: 1,\r\n },\r\n});\r\nconst Media = styled(Image, Object.assign({ marginBottom: margin.tiny }, media(mediaMinMedium, Object.assign(Object.assign({}, createTransitionDecorator({\r\n property: 'filter',\r\n willChange: true,\r\n})), { ':hover': {\r\n filter: 'brightness(90%)',\r\n } }))));\r\nconst MediaWrapper = styled.div({\r\n position: 'relative',\r\n});\r\nconst ContentWrapper = styled.div({\r\n display: 'flex',\r\n flex: { grow: 1, direction: 'column' },\r\n margin: {\r\n x: ({ isCompact }) => (isCompact ? 11 : medium),\r\n bottom: ({ isCompact }) => (isCompact ? average : large),\r\n },\r\n});\r\nconst Title = styled.div(multilineEllipsis(2), Object.assign({ marginBottom: 10, fontSize: epsilon, fontWeight: FontWeight.SemiBold }, media(mediaMinMedium, {\r\n fontSize: figma,\r\n marginBottom: tiny,\r\n})));\r\nconst Description = styled.div(multilineEllipsis(3), {\r\n marginBottom: average,\r\n color: black60,\r\n fontSize: zeta,\r\n});\r\nconst Favorite = styled(AddToWishlist, {\r\n position: 'absolute',\r\n top: 0,\r\n right: 0,\r\n});\r\nexport const PromotionFlag = styled.div({\r\n position: 'absolute',\r\n bottom: small + tiny,\r\n left: small,\r\n backgroundColor: white,\r\n color: negative,\r\n padding: {\r\n x: small,\r\n y: tiny,\r\n },\r\n font: {\r\n weight: 'bold',\r\n size: epsilon,\r\n },\r\n zIndex: ZIndex.ProductBadge,\r\n});\r\nexport const NewFlag = styled.div({\r\n position: 'absolute',\r\n // small + tiny here to compensate for body padding\r\n top: small + tiny,\r\n left: small + tiny,\r\n textTransform: 'uppercase',\r\n backgroundColor: white,\r\n color: defaultTextColor,\r\n padding: {\r\n x: small,\r\n y: tiny,\r\n },\r\n font: {\r\n weight: 'bold',\r\n size: epsilon,\r\n },\r\n zIndex: ZIndex.ProductBadge,\r\n});\r\nconst MODEL_LINE_HEIGHT = 17.5;\r\nconst MODEL_MAX_LINES = 2;\r\nexport const Model = styled.div({\r\n display: '-webkit-box',\r\n WebkitLineClamp: MODEL_MAX_LINES,\r\n WebkitBoxOrient: 'vertical',\r\n maxHeight: MODEL_LINE_HEIGHT * MODEL_MAX_LINES,\r\n marginBottom: tiny,\r\n fontSize: ({ isCompact }) => (isCompact ? eta : epsilon),\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis',\r\n});\r\nconst StyledProductAvailability = styled(ProductAvailability, priceLabelDecorator, {\r\n marginBottom: 0,\r\n});\r\n","import { white, black, grey } from 'Shared/Style';\r\nexport const mapLinkColor = (props, siteTheme) => {\r\n if (props.fillInBlock) {\r\n switch (props.themeType) {\r\n case 'white':\r\n return white;\r\n case 'black':\r\n return black;\r\n case 'grey':\r\n return grey;\r\n case 'themeLight':\r\n return props.themeColorLight;\r\n case 'themeDark':\r\n return props.themeColorDark;\r\n case 'theme':\r\n return props.themeColor;\r\n case 'lightBlue':\r\n return siteTheme.colors.lightBlue;\r\n case 'darkBlue':\r\n return siteTheme.colors.darkBlue;\r\n }\r\n }\r\n else {\r\n switch (props.themeType) {\r\n case 'theme':\r\n return white;\r\n case 'lightBlue':\r\n return white;\r\n case 'themeLight':\r\n return props.themeColor;\r\n case 'themeDark':\r\n return props.themeColorLight;\r\n default:\r\n return props.themeColor;\r\n }\r\n }\r\n};\r\nexport const mapHoverLinkColor = (props, siteTheme) => {\r\n if (props.fillInBlock) {\r\n switch (props.themeType) {\r\n case 'white':\r\n return props.themeColorDark;\r\n case 'black':\r\n return props.themeColorLight;\r\n case 'grey':\r\n return props.themeColor;\r\n case 'darkBlue':\r\n return siteTheme.colors.darkBlue;\r\n case 'lightBlue':\r\n return siteTheme.colors.darkBlue;\r\n default:\r\n return props.themeColorDark;\r\n }\r\n }\r\n else {\r\n switch (props.themeType) {\r\n case 'theme':\r\n return white;\r\n case 'themeLight':\r\n case 'lightBlue':\r\n return siteTheme.colors.darkBlue;\r\n case 'themeDark':\r\n return white;\r\n case 'darkBlue':\r\n return white;\r\n default:\r\n return props.themeColorDark;\r\n }\r\n }\r\n};\r\n","import React, { useContext } from 'react';\r\nimport A from 'Shared/Generic/A';\r\nimport { media } from '@glitz/core';\r\nimport { mediaMinMedium, delta, mediaMinSmall, figma, mediaMinMicro, epsilon, sourceSansPro, medium, } from 'Shared/Style';\r\nimport { styled } from '@glitz/react';\r\nimport { CampaignBrandContext } from 'Pages/Campaign/CampaignBrandPageContext';\r\nimport { useCurrentTheme } from 'SiteLayout/Theming';\r\nimport { mapHoverLinkColor, mapLinkColor } from './util';\r\nconst mapTheme = (props, theme, siteTheme) => {\r\n if (theme.themeColor) {\r\n return (React.createElement(Link, { css: Object.assign({ color: mapLinkColor(theme, siteTheme), ':hover': { color: mapHoverLinkColor(theme, siteTheme) } }, (props.isTextUnderline ? { textDecoration: 'underline' } : { textDecoration: 'none' })), to: props.to, target: props.target }, props.children));\r\n }\r\n return (React.createElement(ThemePrimary, { to: props.to, target: props.target }, props.children));\r\n};\r\nconst CampaignThemeLink = (props) => {\r\n const { themeColor, themeColorLight, themeColorDark } = useContext(CampaignBrandContext);\r\n const siteTheme = useCurrentTheme();\r\n const themeProps = {\r\n themeColor: themeColor ? themeColor : siteTheme.colors.primary,\r\n themeColorLight: themeColor ? themeColorLight : siteTheme.colors.secondary,\r\n themeColorDark: themeColor ? themeColorDark : siteTheme.colors.primaryDark,\r\n themeType: props.themeType,\r\n fillInBlock: props.fillInBlock,\r\n };\r\n return mapTheme(props, themeProps, siteTheme);\r\n};\r\nexport default styled(CampaignThemeLink);\r\nconst Link = styled(A, sourceSansPro(delta), Object.assign(Object.assign(Object.assign({ color: ({ siteTheme }) => siteTheme.colors.primary, margin: { y: medium } }, media(mediaMinMedium, {\r\n fontSize: delta,\r\n})), media(mediaMinSmall, {\r\n fontSize: figma,\r\n})), media(mediaMinMicro, {\r\n fontSize: epsilon,\r\n})));\r\nconst ThemePrimary = styled(Link, {\r\n color: ({ siteTheme }) => siteTheme.colors.primary,\r\n ':hover': { color: ({ siteTheme }) => siteTheme.colors.primaryDark },\r\n ':active': { color: ({ siteTheme }) => siteTheme.colors.primaryDark },\r\n});\r\n","import React, { useMemo } from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport { average, black, thin, tiny, tooltipColor, white, ZIndex } from 'Shared/Style';\r\nimport { translate } from '@avensia/scope';\r\nimport Image, { Preset } from 'Shared/Image';\r\nconst COLOR_MOBILE_SIZE = 14;\r\nconst COLOR_DESKTOP_SIZE = 20;\r\nconst Color = ({ hex, name, swatch }) => {\r\n const blackBorder = (hex === null || hex === void 0 ? void 0 : hex.toLowerCase()) === '#ffffff' || (name === null || name === void 0 ? void 0 : name.toLowerCase()) === 'white' || (name === null || name === void 0 ? void 0 : name.toLowerCase()) === 'natural';\r\n const colorStyle = useMemo(() => (Object.assign(Object.assign({ backgroundColor: hex ? hex : 'transparent' }, (swatch && { border: { xy: { style: 'none' } } })), (blackBorder && { border: { xy: { color: black } } }))), [blackBorder, hex, swatch]);\r\n return (React.createElement(Base, { \"data-title\": name ? name : translate('/ProductListing/Noname') },\r\n React.createElement(ColorComponent, { css: colorStyle }, swatch ? React.createElement(SwatchColor, { src: swatch, alt: name, preset: Preset.Thumb, lazy: true }) : React.createElement(React.Fragment, null))));\r\n};\r\nexport default styled(Color);\r\nconst Base = styled.div({\r\n ':after': {\r\n opacity: 0,\r\n content: '\"\"',\r\n },\r\n ':hover': {\r\n '::after': {\r\n content: 'attr(data-title)',\r\n backgroundColor: tooltipColor,\r\n color: white,\r\n textAlign: 'center',\r\n borderRadius: 5,\r\n position: 'absolute',\r\n zIndex: ZIndex.Tooltip,\r\n visibility: 'visible',\r\n whiteSpace: 'nowrap',\r\n overflow: 'visible',\r\n marginTop: '-3.2rem',\r\n height: 27,\r\n opacity: 1,\r\n fontSize: average,\r\n padding: {\r\n xy: 5,\r\n },\r\n },\r\n },\r\n});\r\nconst ColorComponent = styled.div({\r\n display: 'flex',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n height: ({ isCompact }) => (isCompact ? COLOR_MOBILE_SIZE : COLOR_DESKTOP_SIZE),\r\n width: ({ isCompact }) => (isCompact ? COLOR_MOBILE_SIZE : COLOR_DESKTOP_SIZE),\r\n marginRight: ({ isCompact }) => (isCompact ? tiny : 6),\r\n border: {\r\n xy: {\r\n style: 'solid',\r\n width: thin,\r\n color: 'transparent',\r\n },\r\n },\r\n});\r\nconst SwatchColor = styled(Image, {\r\n maxWidth: '100%',\r\n});\r\n","import React from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport Color from './Color';\r\nimport { average } from 'Shared/Style';\r\nconst MAX_COLORS_TO_DISPLAY = 6;\r\nconst ColorsDisplay = ({ colors }) => {\r\n const hasMore = (colors === null || colors === void 0 ? void 0 : colors.length) > MAX_COLORS_TO_DISPLAY;\r\n const colorsToDisplay = hasMore ? colors === null || colors === void 0 ? void 0 : colors.slice(0, MAX_COLORS_TO_DISPLAY) : colors;\r\n return (React.createElement(Base, null, colorsToDisplay === null || colorsToDisplay === void 0 ? void 0 :\r\n colorsToDisplay.map((color, index) => (React.createElement(Color, Object.assign({ key: index }, color)))),\r\n hasMore && React.createElement(ExtraColorCount, null, `+${(colors === null || colors === void 0 ? void 0 : colors.length) - MAX_COLORS_TO_DISPLAY}`)));\r\n};\r\nexport default styled(ColorsDisplay);\r\nconst Base = styled.div({\r\n position: 'relative',\r\n display: 'flex',\r\n alignItems: 'center',\r\n minHeight: ({ isCompact }) => (isCompact ? 14 : 20),\r\n flexWrap: 'wrap',\r\n});\r\nconst ExtraColorCount = styled.span({\r\n fontSize: average,\r\n});\r\n","import React from 'react';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faCartShopping, faFileMedical, faStore, faTag } from '@fortawesome/pro-light-svg-icons';\r\nimport { styled } from '@glitz/react';\r\nimport { medium, tiny } from 'Shared/Style';\r\nconst ProductAvailability = ({ text, icon }) => {\r\n return (React.createElement(Base, null,\r\n icon && React.createElement(IconWrapper, null, getAvailabilityIcon(icon)),\r\n text));\r\n};\r\nexport default styled(ProductAvailability);\r\nconst getAvailabilityIcon = (availabilityIcon) => {\r\n switch (availabilityIcon) {\r\n case 'fa-store':\r\n return React.createElement(FontAwesomeIcon, { icon: faStore });\r\n case 'fa-tag':\r\n return React.createElement(FontAwesomeIcon, { icon: faTag });\r\n case 'fa-cart-shopping':\r\n return React.createElement(FontAwesomeIcon, { icon: faCartShopping });\r\n case 'fa-file-medical':\r\n return React.createElement(FontAwesomeIcon, { icon: faFileMedical });\r\n default:\r\n return React.createElement(FontAwesomeIcon, { icon: faStore });\r\n }\r\n};\r\nconst Base = styled.div({\r\n marginBottom: medium,\r\n});\r\nconst IconWrapper = styled.span({\r\n marginRight: tiny,\r\n});\r\n","import * as style from 'Shared/Style';\r\nimport { media } from '@glitz/core';\r\nconst _HUGE_PADDING = 166;\r\nconst _LARGE_PADDING = 80;\r\nconst _MEDIUM_PADDING = 40;\r\nconst _SMALL_PADDING = 16;\r\nfunction getPaddingStyle(spacing) {\r\n if (spacing === 'huge') {\r\n return _HUGE_PADDING;\r\n }\r\n else if (spacing === 'large') {\r\n return _LARGE_PADDING;\r\n }\r\n else if (spacing === 'medium') {\r\n return _MEDIUM_PADDING;\r\n }\r\n else if (spacing === 'small') {\r\n return _SMALL_PADDING;\r\n }\r\n else {\r\n return 0;\r\n }\r\n}\r\nexport const Spacing = (desktopLeftRight, desktopTopBottom, mobileLeftRight, mobileTopBottom) => {\r\n return Object.assign({ paddingLeft: getPaddingStyle(mobileLeftRight), paddingRight: getPaddingStyle(mobileLeftRight), paddingTop: getPaddingStyle(mobileTopBottom), paddingBottom: getPaddingStyle(mobileTopBottom) }, media(style.mediaMinMedium, {\r\n paddingLeft: getPaddingStyle(desktopLeftRight),\r\n paddingRight: getPaddingStyle(desktopLeftRight),\r\n paddingTop: getPaddingStyle(desktopTopBottom),\r\n paddingBottom: getPaddingStyle(desktopTopBottom),\r\n }));\r\n};\r\nexport const BlockSpacing = (desktopTop, mobileTop, desktopBottom, mobileBottom, desktopLeft, mobileLeft, desktopRight, mobileRight) => {\r\n return Object.assign({ paddingTop: getPaddingStyle(mobileTop), paddingBottom: getPaddingStyle(mobileBottom), paddingLeft: getPaddingStyle(mobileLeft), paddingRight: getPaddingStyle(mobileRight) }, media(style.mediaMinMedium, {\r\n paddingTop: getPaddingStyle(desktopTop),\r\n paddingBottom: getPaddingStyle(desktopBottom),\r\n paddingLeft: getPaddingStyle(desktopLeft),\r\n paddingRight: getPaddingStyle(desktopRight),\r\n }));\r\n};\r\nexport const BlockHorizontalSpacing = (desktopLeft, mobileLeft, desktopRight, mobileRight) => {\r\n return Object.assign({ paddingLeft: getPaddingStyle(mobileLeft), paddingRight: getPaddingStyle(mobileRight) }, media(style.mediaMinMedium, {\r\n paddingLeft: getPaddingStyle(desktopLeft),\r\n paddingRight: getPaddingStyle(desktopRight),\r\n }));\r\n};\r\n","import React, { useContext } from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport { RowLayoutContext } from 'Shared/Blocks/RowLayout/RowLayoutContext';\r\nimport { fullViewportWidthBlock } from 'Shared/Style';\r\nconst BlockBase = (props) => {\r\n const { isRowLayout } = useContext(RowLayoutContext);\r\n const { height, isFullWidth } = props;\r\n return (React.createElement(Content, { id: props.id, css: Object.assign(Object.assign(Object.assign({}, (isRowLayout && {\r\n marginBottom: 0,\r\n })), (height && {\r\n height,\r\n })), (isFullWidth && Object.assign(Object.assign({}, fullViewportWidthBlock), { height: 'auto' }))) }, props.children));\r\n};\r\nexport default styled(BlockBase);\r\nconst Content = styled.div({\r\n marginBottom: ({ isCompact }) => (isCompact ? 40 : 60),\r\n});\r\n","import { white, grey80, titleBlockBlack } from 'Shared/Style';\r\nimport { CampaignBrandContext } from 'Pages/Campaign/CampaignBrandPageContext';\r\nimport { useContext } from 'react';\r\nimport { useCurrentTheme } from 'SiteLayout/Theming';\r\nexport const ThemeTextColor = (textColor) => {\r\n const { themeColor, themeColorLight, themeColorDark } = useContext(CampaignBrandContext);\r\n const siteTheme = useCurrentTheme();\r\n // If campaign color is set\r\n if (themeColor) {\r\n switch (textColor) {\r\n case 'theme':\r\n return themeColor;\r\n case 'themeLight':\r\n return themeColorLight;\r\n case 'themeDark':\r\n return themeColorDark;\r\n case 'white':\r\n return white;\r\n case 'grey':\r\n return grey80;\r\n case 'black':\r\n return titleBlockBlack;\r\n }\r\n }\r\n // Fallback text color\r\n switch (textColor) {\r\n case white:\r\n return white;\r\n case 'grey':\r\n return grey80;\r\n case 'black':\r\n return titleBlockBlack;\r\n case 'theme':\r\n return siteTheme.colors.primary;\r\n case 'themeLight':\r\n return siteTheme.colors.secondary;\r\n case 'themeDark':\r\n return siteTheme.colors.darkTextTheme;\r\n case 'lightBlue':\r\n return siteTheme.colors.lightBlue;\r\n case 'darkBlue':\r\n return siteTheme.colors.darkBlue;\r\n }\r\n};\r\n","import { __rest } from \"tslib\";\r\nimport React, { useState, useEffect, useCallback, useRef, useMemo, useLayoutEffect } from 'react';\r\nimport { translate } from '@avensia/scope';\r\nimport { useEmblaCarousel } from 'embla-carousel/react';\r\nimport { styled } from '@glitz/react';\r\nimport { monochrome, depthDecorator, margin, alpha, white, createTransitionDecorator, ZIndex, secondary, outlineGrey, huge, } from 'Shared/Style';\r\nimport { PlainButton } from 'Shared/Button';\r\nimport { ArrowRight, ArrowLeft } from 'Shared/Icon';\r\nimport { WhiteThemeBlock } from 'Shared/Theme';\r\nimport usePrevious from 'Shared/use-previous';\r\nimport { useCurrentBreakpoint } from 'Shared/use-viewport';\r\nimport { format } from 'Shared/Translate';\r\nfunction Carousel(props) {\r\n var _a;\r\n const { children, slideTo, arrows, dots, emblaOptions: options = { containScroll: 'keepSnaps', loop: true }, getVisibleCount, itemGap = 0, edgeGap, showNextSlide, renderThumbs, edgeMarginRight = null, edgeMarginLeft = null, } = props;\r\n const breakpoint = useCurrentBreakpoint();\r\n const visibleCount = getVisibleCount ? getVisibleCount(breakpoint) : 1;\r\n options.slidesToScroll = visibleCount;\r\n const [emblaRef, emblaCarousel] = useEmblaCarousel(options);\r\n const [prevBtnEnabled, setPrevBtnEnabled] = useState(false);\r\n const [nextBtnEnabled, setNextBtnEnabled] = useState(false);\r\n const [selectedIndex, setSelectedIndex] = useState(0);\r\n const [scrollSnaps, setScrollSnaps] = useState([]);\r\n const slideRef = useRef(null);\r\n const scrollTo = useCallback(index => emblaCarousel.scrollTo(index), [emblaCarousel]);\r\n const scrollPrev = useCallback(() => emblaCarousel.scrollPrev(), [emblaCarousel]);\r\n const scrollNext = useCallback(() => emblaCarousel.scrollNext(), [emblaCarousel]);\r\n if (emblaCarousel && scrollSnaps.length === 0) {\r\n setScrollSnaps(emblaCarousel.scrollSnapList());\r\n }\r\n const updateArrows = useCallback(() => {\r\n setPrevBtnEnabled(emblaCarousel.canScrollPrev());\r\n setNextBtnEnabled(emblaCarousel.canScrollNext());\r\n }, [emblaCarousel]);\r\n const onSelect = useCallback(() => {\r\n if (!emblaCarousel)\r\n return;\r\n setSelectedIndex(emblaCarousel.selectedScrollSnap());\r\n updateArrows();\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [emblaCarousel]);\r\n useEffect(() => {\r\n if (emblaCarousel) {\r\n emblaCarousel.on('select', onSelect);\r\n updateArrows();\r\n }\r\n }, [emblaCarousel, onSelect, updateArrows]);\r\n useEffect(() => {\r\n if (typeof slideTo === 'number' && emblaCarousel) {\r\n scrollTo(slideTo);\r\n }\r\n }, [slideTo, emblaCarousel, scrollTo]);\r\n const previousNumChildren = usePrevious(children === null || children === void 0 ? void 0 : children.length);\r\n useLayoutEffect(() => {\r\n if (previousNumChildren !== (children === null || children === void 0 ? void 0 : children.length)) {\r\n if (emblaCarousel) {\r\n /**\r\n * update embla when amount of children changes.\r\n * this is needed when doing a partial render on pdp\r\n * when we do not have all the images yet.\r\n */\r\n emblaCarousel.reInit();\r\n setScrollSnaps(emblaCarousel.scrollSnapList());\r\n }\r\n }\r\n }, [children, emblaCarousel, previousNumChildren]);\r\n const slideStyle = useMemo(() => {\r\n return {\r\n width: `calc(${100 / visibleCount}% - ${showNextSlide ? itemGap : 0}px)`,\r\n paddingLeft: itemGap,\r\n };\r\n }, [itemGap, showNextSlide, visibleCount]);\r\n const styleSlides = useMemo(() => {\r\n if (edgeGap) {\r\n if (edgeMarginRight && edgeMarginLeft) {\r\n return { marginRight: edgeMarginRight, marginLeft: edgeMarginLeft };\r\n }\r\n else {\r\n return { marginRight: itemGap };\r\n }\r\n }\r\n else {\r\n return { marginLeft: `-${itemGap}px` };\r\n }\r\n }, [edgeGap, edgeMarginLeft, edgeMarginRight, itemGap]);\r\n const slideNodes = useMemo(() => React.Children.map(children, (slide, index) => (React.createElement(Slide, { key: index, css: slideStyle }, slide))), [children, slideStyle]);\r\n return (React.createElement(React.Fragment, null,\r\n React.createElement(Container, null,\r\n arrows && (React.createElement(PrevButton, { onClick: scrollPrev, enabled: prevBtnEnabled, \"aria-label\": translate('/Shared/Carousel/Next') })),\r\n React.createElement(CarouselContainer, { ref: emblaRef },\r\n React.createElement(Slides, { css: styleSlides, ref: slideRef, key: slideNodes.length }, slideNodes)),\r\n arrows && (React.createElement(NextButton, { onClick: scrollNext, enabled: nextBtnEnabled, \"aria-label\": translate('/Shared/Carousel/Next') })),\r\n dots && (React.createElement(Dots, null, scrollSnaps.map((_, index) => (React.createElement(DotButton, { key: index, css: { backgroundColor: index === selectedIndex ? secondary : outlineGrey }, onClick: () => scrollTo(index), \"aria-label\": `${format(translate('/Shared/Carousel/GoToSlideNumber'), index + 1)}` })))))), renderThumbs === null || renderThumbs === void 0 ? void 0 :\r\n renderThumbs({ emblaCarousel, selectedIndex, height: (_a = slideRef.current) === null || _a === void 0 ? void 0 : _a.offsetHeight })));\r\n}\r\nexport default React.memo(styled(Carousel));\r\nconst PrevButton = (_a) => {\r\n var { enabled, onClick } = _a, restProps = __rest(_a, [\"enabled\", \"onClick\"]);\r\n return (React.createElement(CarouselButton, Object.assign({ css: { color: enabled ? white : monochrome, left: margin.large } }, restProps, { onClick: onClick, disabled: !enabled }),\r\n React.createElement(ArrowLeft, null)));\r\n};\r\nconst NextButton = (_a) => {\r\n var { enabled, onClick } = _a, restProps = __rest(_a, [\"enabled\", \"onClick\"]);\r\n return (React.createElement(CarouselButton, Object.assign({ css: { color: enabled ? white : monochrome, right: margin.large } }, restProps, { onClick: onClick, disabled: !enabled }),\r\n React.createElement(ArrowRight, null)));\r\n};\r\nconst Container = styled.div({\r\n position: 'relative',\r\n width: '100%',\r\n});\r\nconst Dots = styled(WhiteThemeBlock, {\r\n position: 'absolute',\r\n left: '50%',\r\n transform: 'translateX(-50%)',\r\n display: 'flex',\r\n bottom: -huge,\r\n padding: { xy: margin.tiny },\r\n borderRadius: '100vw',\r\n backgroundColor: 'unset',\r\n});\r\nconst DotButton = styled(PlainButton, Object.assign({ display: 'block', width: 10, height: 10, borderRadius: '100%', backgroundColor: 'transparent', marginLeft: margin.medium, ':first-child': {\r\n marginLeft: 0,\r\n } }, createTransitionDecorator({ property: 'background' })));\r\nconst CarouselButton = styled(PlainButton, Object.assign(Object.assign({ display: 'block', position: 'absolute', top: '50%', transform: 'translateY(-50%)', fontSize: alpha }, depthDecorator()), { color: white, zIndex: ZIndex.ProductBadge }));\r\nconst Slides = styled.div({\r\n display: 'flex',\r\n willChange: 'transform',\r\n});\r\nconst Slide = styled.div({\r\n display: 'flex',\r\n position: 'relative',\r\n flex: { grow: 0, shrink: 0, basis: 'auto' },\r\n});\r\nconst CarouselContainer = styled.div({\r\n display: 'flex',\r\n flexDirection: 'column',\r\n flex: { grow: 1, shrink: 0, basis: 'auto' },\r\n overflow: 'hidden',\r\n});\r\n","import React, { useContext } from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport { useCheckoutActions } from 'Checkout/Context';\r\nimport ProductCard from './ProductCard';\r\nimport Carousel from 'Shared/Carousel';\r\nimport { Breakpoint } from '@avensia/scope';\r\nimport { useIsCompact, useIsDesktop } from 'Shared/use-viewport';\r\nimport { small, large, medium } from 'Shared/Style';\r\nimport { RowLayoutContext } from 'Shared/Blocks/RowLayout/RowLayoutContext';\r\nfunction ProductCardList(props) {\r\n const actions = useCheckoutActions();\r\n const isCompact = useIsCompact();\r\n const isDesktop = useIsDesktop();\r\n const { isRowLayout } = useContext(RowLayoutContext);\r\n const options = {\r\n containScroll: isCompact && props.products.length > 2 ? 'trimSnaps' : '',\r\n align: 'center',\r\n };\r\n const { trackingListName } = props;\r\n const getVisibleCount = (breakpoint) => {\r\n if (breakpoint < Breakpoint.Small) {\r\n return 2;\r\n }\r\n else if (breakpoint === Breakpoint.Small) {\r\n return 3;\r\n }\r\n else {\r\n if (isRowLayout) {\r\n // Support a simple [1:2, 1:2] row layout\r\n return 2;\r\n }\r\n else {\r\n return 4;\r\n }\r\n }\r\n };\r\n return (React.createElement(Carousel, { getVisibleCount: getVisibleCount, emblaOptions: options, itemGap: isCompact ? medium : large, edgeMarginRight: isDesktop ? `${6}px` : undefined, edgeMarginLeft: isDesktop ? `${-6}px` : undefined, edgeGap: true }, props.products.map(product => (React.createElement(ProductCardWrapper, { key: product.code },\r\n React.createElement(ProductCard, { trackingListName: trackingListName, product: product, addToCart: (code, quantity, ticket) => actions.addToCart(code, quantity, ticket, trackingListName) }))))));\r\n}\r\nexport default styled(ProductCardList);\r\nconst ProductCardWrapper = styled.div({\r\n display: 'flex',\r\n width: '100%',\r\n margin: { y: small },\r\n justifyContent: 'center',\r\n});\r\n","import { createContext } from 'react';\r\nexport const StandardContentContext = createContext({ isStandardContentPage: false });\r\n","import { media } from '@glitz/core';\r\nimport { styled } from '@glitz/react';\r\nimport { kappa, mediaMinMedium, mediaMinMicro, mediaMinSmall, delta, sourceSansPro } from 'Shared/Style';\r\nexport default styled.p(sourceSansPro(kappa), Object.assign(Object.assign(Object.assign({ lineHeight: 1.5 }, media(mediaMinMedium, { fontSize: kappa })), media(mediaMinSmall, { fontSize: delta })), media(mediaMinMicro, { fontSize: delta })));\r\n","import { createContext } from 'react';\r\nexport const ContentOverviewPageContext = createContext({ isContentOviewPage: false });\r\n","import React from 'react';\r\nimport { styled } from '@glitz/react';\r\nconst VideoContent = props => {\r\n const { videoUrl, autoPlay = true, loop = true, muted = true, controls = true } = props;\r\n return (React.createElement(\"div\", null,\r\n React.createElement(\"video\", { playsInline: true, autoPlay: autoPlay, loop: loop, muted: muted, controls: controls, width: \"100%\" },\r\n React.createElement(\"source\", { src: videoUrl }))));\r\n};\r\nexport default styled(VideoContent);\r\n","import React from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport { translate } from '@avensia/scope';\r\nimport { figma, margin, medium, humongous, tiny, black } from 'Shared/Style';\r\nimport AspectRatioImage, { Ratio, Preset, Format } from 'Shared/Image/Ratio';\r\nimport CampaignThemeLink from 'Shared/Sigvaris/CampaignThemeLink';\r\nimport { useIsCompact } from 'Shared/use-viewport';\r\nimport { H3 } from 'Shared/Generic';\r\nfunction ArticleCard(props) {\r\n var _a;\r\n const isCompact = useIsCompact();\r\n const { headline, descriptor, teaser, url } = props;\r\n const mediaUrl = isCompact ? (_a = props.mobileImageUrl) !== null && _a !== void 0 ? _a : props.mediaUrl : props.mediaUrl;\r\n return (React.createElement(Base, null,\r\n React.createElement(AspectRatioImage, { src: mediaUrl, alt: headline, ratio: Ratio.FourToThree, preset: Preset.Small, format: Format.JPG }),\r\n React.createElement(CardContent, null,\r\n React.createElement(TextContentSection, null,\r\n React.createElement(TopInfo, null,\r\n React.createElement(Descriptor, null, descriptor)),\r\n React.createElement(ContentCardHeadline, null, headline),\r\n React.createElement(ContentCardTeaser, null, teaser)),\r\n React.createElement(ReadMoreSection, null,\r\n React.createElement(CampaignThemeLink, { as: 'theme', themeType: 'theme', to: url, fillInBlock: true, isTextUnderline: true }, translate('/Shared/ReadMore'))))));\r\n}\r\nexport default styled(ArticleCard);\r\nconst Base = styled.div({\r\n position: 'relative',\r\n});\r\nconst CardContent = styled.div({\r\n padding: { xy: medium },\r\n});\r\nconst TextContentSection = styled.div({\r\n padding: { bottom: humongous },\r\n});\r\nconst TopInfo = styled.div({\r\n display: 'flex',\r\n fontSize: figma,\r\n margin: { y: margin.small },\r\n color: black,\r\n flexDirection: 'row',\r\n});\r\nconst Descriptor = styled.div({\r\n paddingRight: tiny,\r\n});\r\nconst ContentCardHeadline = styled(H3, {\r\n margin: { y: margin.small },\r\n});\r\nconst ContentCardTeaser = styled.div({\r\n fontSize: figma,\r\n display: '-webkit-box',\r\n overflow: 'hidden',\r\n overflowWrap: 'break-word',\r\n WebkitLineClamp: 2,\r\n WebkitBoxOrient: 'vertical',\r\n});\r\nconst ReadMoreSection = styled.div({\r\n position: 'absolute',\r\n bottom: 16,\r\n});\r\n","import { __awaiter } from \"tslib\";\r\nimport React, { useState } from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport { LinkedIn as IconLinkedIn, Twitter as IconTwitter, Facebook as IconFacebook, Link } from 'Shared/Icon';\r\nimport { black, humongous, medium, small, tiny } from 'Shared/Style';\r\nconst windowOptions = 'toolbar=yes,location=0,status=no,menubar=yes,scrollbars=yes,resizable=yes,width=500,height=700';\r\nconst SocialShare = (props) => {\r\n const { showBorder = true } = props;\r\n const [isCopied, setIsCopied] = useState(false);\r\n const currentUrl = window.location.href;\r\n // Actions\r\n function copyTextToClipboard(url) {\r\n return __awaiter(this, void 0, void 0, function* () {\r\n if ('clipboard' in navigator) {\r\n return yield navigator.clipboard.writeText(url);\r\n }\r\n else {\r\n return document.execCommand('copy', true, url);\r\n }\r\n });\r\n }\r\n const handleCopyClick = () => {\r\n copyTextToClipboard(currentUrl)\r\n .then(() => {\r\n setIsCopied(true);\r\n setTimeout(() => {\r\n setIsCopied(false);\r\n }, 1500);\r\n })\r\n .catch(err => {\r\n console.log(err);\r\n });\r\n };\r\n const onClickShare = ({ url, includeOptions }) => {\r\n if (includeOptions) {\r\n return window.open(url, '_blank', windowOptions);\r\n }\r\n return window.open(url, '_blank');\r\n };\r\n // Styled icons\r\n const color = props.textColor || black;\r\n const StyledLinkedIn = styled(IconLinkedIn, { color, fill: color });\r\n const StyledFacebook = styled(IconFacebook, { color, fill: color });\r\n const StyledTwitter = styled(IconTwitter, { color, fill: color });\r\n const StyledLink = styled(Link, {\r\n color,\r\n fill: color,\r\n cursor: 'pointer',\r\n });\r\n // Clickable icons\r\n const LinkedIn = () => (React.createElement(CenteredIconItem, { onClick: () => onClickShare({\r\n url: `https://www.linkedin.com/sharing/share-offsite/?url=${currentUrl}`,\r\n includeOptions: true,\r\n }) },\r\n React.createElement(StyledLinkedIn, null),\r\n React.createElement(IconText, null, 'LinkedIn')));\r\n const Twitter = () => (React.createElement(CenteredIconItem, { onClick: () => onClickShare({\r\n url: `https://twitter.com/intent/tweet?url=${currentUrl}&text=${props.socialShareCaption}&hashtags=sigvaris`,\r\n }) },\r\n React.createElement(StyledTwitter, null),\r\n React.createElement(IconText, null, 'Twitter')));\r\n const Facebook = () => (React.createElement(CenteredIconItem, { onClick: () => onClickShare({ url: `https://www.facebook.com/sharer/sharer.php?display=page&u=${currentUrl}` }) },\r\n React.createElement(StyledFacebook, null),\r\n React.createElement(IconText, null, 'Facebook')));\r\n const CopyLink = () => (React.createElement(styled.Div, { css: { position: 'relative', marginTop: -tiny } },\r\n isCopied && React.createElement(CopiedText, null, \"Link copied\"),\r\n React.createElement(StyledLink, { onClick: () => handleCopyClick() })));\r\n const Icons = styled.div({\r\n display: props.isCentered ? 'flex' : 'grid',\r\n position: 'relative',\r\n justifyContent: 'center',\r\n gridTemplateColumns: props.showCopyLink ? 'repeat(4, 1fr)' : 'repeat(3, 1fr)',\r\n marginTop: props.isCentered ? medium : 0,\r\n });\r\n const baseStyle = Object.assign(Object.assign({}, (showBorder && { border: { top: { width: 2, color: '#d0d0d0', style: 'solid' } } })), { textAlign: 'center', color: props.textColor || color, display: props.isCentered ? 'block' : 'flex' });\r\n return (React.createElement(Base, { css: baseStyle },\r\n React.createElement(LabelText, null, props.labelText),\r\n props.isCentered ? (React.createElement(Icons, { css: __$hoisted_o0 },\r\n React.createElement(LinkedIn, null),\r\n React.createElement(Twitter, null),\r\n React.createElement(Facebook, null),\r\n props.showCopyLink && React.createElement(CopyLink, null))) : (React.createElement(Icons, { css: __$hoisted_o1 },\r\n React.createElement(LinkedIn, null),\r\n React.createElement(Twitter, null),\r\n React.createElement(Facebook, null),\r\n props.showCopyLink && React.createElement(CopyLink, null)))));\r\n};\r\nexport default SocialShare;\r\nconst Base = styled.div({\r\n display: 'flex',\r\n padding: { y: humongous },\r\n justifyContent: 'space-between',\r\n width: '100%',\r\n});\r\nconst LabelText = styled.div({\r\n fontWeight: 600,\r\n});\r\nconst CopiedText = styled.div({\r\n position: 'absolute',\r\n fontSize: small,\r\n top: -medium,\r\n right: -small,\r\n});\r\nconst CenteredIconItem = styled.div({\r\n display: 'flex',\r\n alignItems: 'center',\r\n cursor: 'pointer',\r\n});\r\nconst IconText = styled.div({\r\n display: 'flex',\r\n marginLeft: small,\r\n});\r\nconst __$hoisted_o0 = { gridGap: medium };\r\nconst __$hoisted_o1 = { gridGap: small };\r\n","import React from 'react';\r\nimport { styled } from '@glitz/react';\r\nimport ContentCard from '.';\r\nimport { H2 } from 'Shared/Generic';\r\nimport { useIsMobile, useIsTablet } from 'Shared/use-viewport';\r\nimport { gamma } from 'Shared/Style';\r\nfunction OverviewContentCardList(props) {\r\n const { contentItemList, title } = props;\r\n const isMobile = useIsMobile();\r\n const isTablet = useIsTablet();\r\n function gridStyle(items) {\r\n if (isMobile) {\r\n return {\r\n gridTemplateColumns: `repeat(1, minmax(0, 1fr))`,\r\n };\r\n }\r\n if (isTablet) {\r\n if ((items === null || items === void 0 ? void 0 : items.length) <= 2) {\r\n return {\r\n gridTemplateColumns: `repeat(auto-fit, ${330}px)`,\r\n };\r\n }\r\n else {\r\n return {\r\n gridTemplateColumns: `repeat(3, minmax(0, 1fr))`,\r\n };\r\n }\r\n }\r\n return {\r\n gridTemplateColumns: 'repeat(3, minmax(0, 1fr))',\r\n };\r\n }\r\n return (React.createElement(React.Fragment, null, (contentItemList === null || contentItemList === void 0 ? void 0 : contentItemList.length) > 0 && (React.createElement(Base, null,\r\n title && React.createElement(Title, null, title),\r\n React.createElement(Grid, { css: gridStyle(contentItemList) }, contentItemList === null || contentItemList === void 0 ? void 0 : contentItemList.map((item, index) => {\r\n return React.createElement(ArticleCard, Object.assign({ key: index }, item));\r\n }))))));\r\n}\r\nexport default styled(OverviewContentCardList);\r\nconst Grid = styled.div({\r\n justifyContent: 'center',\r\n display: 'grid',\r\n columnGap: gamma,\r\n rowGap: gamma,\r\n});\r\nconst Title = styled(H2, {\r\n textAlign: 'center',\r\n marginBottom: 50,\r\n});\r\nconst Base = styled.div({\r\n margin: {\r\n y: 40,\r\n },\r\n});\r\nconst ArticleCard = styled(ContentCard, {\r\n marginBottom: 40,\r\n});\r\n"],"sourceRoot":""}