@nuskin/react-mysite-elements 1.3.0 → 1.4.0-po-dashboard.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/README.md +124 -0
  2. package/dist/common/icon/icons/SocialMediaIcons.styled.d.ts +5 -0
  3. package/dist/common/index.d.ts +1 -0
  4. package/dist/common/shopping-dashboard/MysiteDashboardWithNavigation.d.ts +47 -0
  5. package/dist/common/shopping-dashboard/PoDashboardWithNavigation.d.ts +14 -0
  6. package/dist/common/shopping-dashboard/ProductOfferDashboard.d.ts +15 -0
  7. package/dist/common/shopping-dashboard/ProductOfferDashboard.styled.d.ts +20 -0
  8. package/dist/common/shopping-dashboard/ShoppingDashboard.d.ts +37 -0
  9. package/dist/common/shopping-dashboard/ShoppingDashboard.styled.d.ts +20 -0
  10. package/dist/common/shopping-dashboard/TranslationKeys/ProductOfferDashboardTranslationKeys.d.ts +241 -0
  11. package/dist/common/shopping-dashboard/TranslationKeys/ShoppingDashboardTranslationKeys.d.ts +630 -0
  12. package/dist/common/shopping-dashboard/fixtures/index.d.ts +1 -0
  13. package/dist/common/shopping-dashboard/fixtures/mockDashboardData.d.ts +8 -0
  14. package/dist/common/shopping-dashboard/fixtures/mockProductOfferData.d.ts +19 -0
  15. package/dist/common/shopping-dashboard/index.d.ts +44 -0
  16. package/dist/common/shopping-dashboard/shared/ConversionRate/ConversionRateChart.d.ts +11 -0
  17. package/dist/common/shopping-dashboard/shared/ConversionRate/ConversionRateChart.styled.d.ts +62 -0
  18. package/dist/common/shopping-dashboard/shared/ConversionRate/ConversionRateFullView.d.ts +15 -0
  19. package/dist/common/shopping-dashboard/shared/ConversionRate/ConversionRateFullView.styled.d.ts +37 -0
  20. package/dist/common/shopping-dashboard/shared/DashboardHeader.d.ts +13 -0
  21. package/dist/common/shopping-dashboard/shared/DashboardHeader.styled.d.ts +48 -0
  22. package/dist/common/shopping-dashboard/shared/DataTable.d.ts +18 -0
  23. package/dist/common/shopping-dashboard/shared/DataTable.styled.d.ts +42 -0
  24. package/dist/common/shopping-dashboard/shared/FilterBar.d.ts +7 -0
  25. package/dist/common/shopping-dashboard/shared/FilterBar.styled.d.ts +12 -0
  26. package/dist/common/shopping-dashboard/shared/FullViewComponents.styled.d.ts +54 -0
  27. package/dist/common/shopping-dashboard/shared/LoadingSkeletons.d.ts +14 -0
  28. package/dist/common/shopping-dashboard/shared/LoadingSkeletons.styled.d.ts +121 -0
  29. package/dist/common/shopping-dashboard/shared/PageHeader.d.ts +11 -0
  30. package/dist/common/shopping-dashboard/shared/PageHeader.styled.d.ts +56 -0
  31. package/dist/common/shopping-dashboard/shared/Pagination.d.ts +9 -0
  32. package/dist/common/shopping-dashboard/shared/Pagination.styled.d.ts +18 -0
  33. package/dist/common/shopping-dashboard/shared/Signups/SignupsChart.d.ts +11 -0
  34. package/dist/common/shopping-dashboard/shared/Signups/SignupsChart.styled.d.ts +56 -0
  35. package/dist/common/shopping-dashboard/shared/Signups/SignupsFullView.d.ts +15 -0
  36. package/dist/common/shopping-dashboard/shared/Signups/SignupsFullView.styled.d.ts +15 -0
  37. package/dist/common/shopping-dashboard/shared/StatsCard.d.ts +11 -0
  38. package/dist/common/shopping-dashboard/shared/StatsCard.styled.d.ts +38 -0
  39. package/dist/common/shopping-dashboard/shared/TopCategories/CategoriesFullView.d.ts +14 -0
  40. package/dist/common/shopping-dashboard/shared/TopCategories/CategoriesFullView.styled.d.ts +72 -0
  41. package/dist/common/shopping-dashboard/shared/TopCategories/TopCategoriesPieChart.d.ts +11 -0
  42. package/dist/common/shopping-dashboard/shared/TopCategories/TopCategoriesPieChart.styled.d.ts +84 -0
  43. package/dist/common/shopping-dashboard/shared/TopPerformingOffers/TopPerformingOffersFullView.d.ts +14 -0
  44. package/dist/common/shopping-dashboard/shared/TopPerformingOffers/TopPerformingOffersFullView.styled.d.ts +52 -0
  45. package/dist/common/shopping-dashboard/shared/TopPerformingOffers/TopPerformingOffersPieChart.d.ts +11 -0
  46. package/dist/common/shopping-dashboard/shared/TopProducts/ProductsFullView.d.ts +14 -0
  47. package/dist/common/shopping-dashboard/shared/TopProducts/ProductsFullView.styled.d.ts +53 -0
  48. package/dist/common/shopping-dashboard/shared/TopProducts/TopSellingProductsList.d.ts +11 -0
  49. package/dist/common/shopping-dashboard/shared/TopProducts/TopSellingProductsList.styled.d.ts +74 -0
  50. package/dist/common/shopping-dashboard/shared/WidgetMenu.d.ts +6 -0
  51. package/dist/common/shopping-dashboard/shared/WidgetMenu.styled.d.ts +5 -0
  52. package/dist/common/shopping-dashboard/shared/types.d.ts +25 -0
  53. package/dist/common/shopping-dashboard/shared/useViewport.d.ts +2 -0
  54. package/dist/common/shopping-dashboard/specs/MysiteDashboardWithNavigation.spec.d.ts +1 -0
  55. package/dist/common/shopping-dashboard/specs/PoDashboardWithNavigation.spec.d.ts +1 -0
  56. package/dist/common/shopping-dashboard/specs/SignupsFullView.spec.d.ts +1 -0
  57. package/dist/common/shopping-dashboard/stories/CategoriesFullView.stories.d.ts +10 -0
  58. package/dist/common/shopping-dashboard/stories/ConversionRateChart.stories.d.ts +9 -0
  59. package/dist/common/shopping-dashboard/stories/ConversionRateFullView.stories.d.ts +9 -0
  60. package/dist/common/shopping-dashboard/stories/DashboardHeader.stories.d.ts +9 -0
  61. package/dist/common/shopping-dashboard/stories/DataTable.stories.d.ts +8 -0
  62. package/dist/common/shopping-dashboard/stories/PageHeader.stories.d.ts +8 -0
  63. package/dist/common/shopping-dashboard/stories/Pagination.stories.d.ts +9 -0
  64. package/dist/common/shopping-dashboard/stories/ProductOfferDashboard.stories.d.ts +13 -0
  65. package/dist/common/shopping-dashboard/stories/ProductsFullView.stories.d.ts +9 -0
  66. package/dist/common/shopping-dashboard/stories/ShoppingDashboard.stories.d.ts +13 -0
  67. package/dist/common/shopping-dashboard/stories/SignupsChart.stories.d.ts +10 -0
  68. package/dist/common/shopping-dashboard/stories/SignupsFullView.stories.d.ts +9 -0
  69. package/dist/common/shopping-dashboard/stories/StatsCard.stories.d.ts +11 -0
  70. package/dist/common/shopping-dashboard/stories/TopCategoriesPieChart.stories.d.ts +10 -0
  71. package/dist/common/shopping-dashboard/stories/TopPerformingOffersFullView.stories.d.ts +10 -0
  72. package/dist/common/shopping-dashboard/stories/TopPerformingOffersPieChart.stories.d.ts +11 -0
  73. package/dist/common/shopping-dashboard/stories/TopSellingProductsList.stories.d.ts +11 -0
  74. package/dist/common/shopping-dashboard/utils/dataUtils.d.ts +14 -0
  75. package/dist/common/shopping-dashboard/utils/dateConstants.d.ts +14 -0
  76. package/dist/common/shopping-dashboard/utils/dateFormat.d.ts +16 -0
  77. package/dist/common/shopping-dashboard/utils/marketConstants.d.ts +14 -0
  78. package/dist/common/shopping-dashboard/utils/trendUtils.d.ts +16 -0
  79. package/dist/index.js +1 -1
  80. package/dist/index.js.map +1 -1
  81. package/dist/index.mjs +1 -1
  82. package/dist/index.mjs.map +1 -1
  83. package/package.json +7 -3
@@ -1 +1 @@
1
- {"version":3,"sources":["/gitlab-runner-data/builds/nextgen-development/mysite/npm/react-mysite-elements/dist/index.mjs","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../src/common/card/NsProductCard.tsx","../src/common/card/styles/NsProductCard.Styled.tsx","../src/common/carousel/NsProductCarousel.tsx","../src/common/carousel/NsProductCarousel.styled.ts","../src/common/carousel/ProductTabCarousel.tsx","../src/common/Nav-Category-Navigation/NsCategoryNavigation.tsx","../src/common/Nav-Category-Navigation/NsCategoryNavigation.styled.tsx","../src/common/carousel/ProductTabCarousel.styled.tsx","../src/common/headers/MysiteHero.tsx","../src/common/headers/MysiteHero.styled.tsx","../src/common/icon/icons/PlaceholderImage.tsx","../src/common/icon/icons/ArrowDownIcon.tsx","../src/common/utils/gtmTracking.ts"],"names":["St","Object","create","xe","defineProperty","Tt","getOwnPropertyDescriptor","Pt","getOwnPropertyNames","It","getPrototypeOf","Bt","prototype","hasOwnProperty","ie","e","t","exports","Nt","o","i","a","call","get","enumerable","Rt","__esModule","value","require_ReactPropTypesSecret","__commonJSMin","module","ReactPropTypesSecret","require_factoryWithThrowingShims","emptyFunction","emptyFunctionWithReset","$e","resetWarningCache","shim","props","propName","componentName","location","propFullName","secret","err","Error","name","isRequired","getShim","ReactPropTypes","array","bigint","bool","func","number","object","string","symbol","any","arrayOf","element","elementType","instanceOf","node","objectOf","oneOf","oneOfType","shape","exact","checkPropTypes","PropTypes","require_prop_types","je","ReactIs","throwOnDirectAccess","useState","NsImage","styled","PriceComponent","ProductCardContainer","isMobile","ImageContainer","bgColor","DefaultImage","ProductTitle","ProductBadgeContainer","AddToCartButton","disabled","isHovered","CartIcon","useMediaQuery","jsx","jsxs","NsProductCard","productTitle","imageDetails","className","button","onCardClick","productStatusBadge","directSellerBadge","mySitePriceComponent","testId","isButtonHovered","setIsButtonHovered","handleImageError","target","noImageFallback","fallbackImage","src","onClick","tabIndex","children","onError","imageSrc","alt","imageAlt","areaLabel","width","title","showButton","buttonText","stopPropagation","onMouseEnter","onMouseLeave","height","viewBox","fill","xmlns","fillRule","clipRule","d","NsProductCard_default","useCallback","useRef","Slider","NsCarouselControl","Box","NsTypography","SlickContainer","ScrollableContainer","CardList","ControlsContainer","ViewAllWrapper","$isMobile","ProductCountWrapper","ArrowsWrapper","$isDisabled","Scrollablewrapper","CustomTypography","ViewAllLink","EmptyProductCategories","ControlsHeaderRow","ProductInfoWrapper","CategoryNameWrapper","ProductCardCarousel","entries","renderEntry","settings","showControlButtons","allEntryLabel","allEntryLink","categoryName","emptyProductMessage","productsCountLabel","isInitialDataLoading","history","sliderRef","prev","current","slickPrev","next","slickNext","renderProductEntry","entry","index","directSeller","sliderSettings","dots","infinite","speed","slidesToShow","Math","min","length","slidesToScroll","swipe","draggable","arrows","responsive","breakpoint","shouldShowNavigation","renderCarouselContent","map","ref","variant","preventDefault","push","viewAllLabel","viewAllUrl","useEffect","import_prop_types","Ve","React","Tabs","Tab","NsCategoryNavigationContainer","div","TabPanel","other","role","hidden","id","propTypes","K","NsCategoryNavigation","itemArray","controlledValue","onChange","qe","internalValue","setInternalValue","orientation","event","newValue","item","label","categoryId","findIndex","content","NsSpinner","ProductTabCarouselContainer","TabsContainer","ContentContainer","LoadingContainer","NoTabsContainer","SpinnerContainer","ProductTabCarousel","fetchCategories","fetchProducts","showCustomCategory","emptyProductTabs","getCategoryId","categories","isLoadingInitialData","setIsLoadingInitialData","setCategories","selectedTab","setSelectedTab","products","setProducts","loading","setLoading","shouldShowSpinner","setShouldShowSpinner","checkForExistingSpinners","existingSpinners","document","querySelectorAll","then","finally","cat","_","ProductTabCarousel_default","useMemo","Typography","Tooltip","NsLink","getContactTextStyles","hasWhiteBackground","fontSize","fontStyle","fontWeight","lineHeight","letterSpacing","color","textDecoration","getSocialTitleStyles","textTransform","paddingLeft","getSocialIconsStyles","display","flexDirection","gap","alignItems","getContactTextMobileStyles","paddingBottom","wordBreak","overflowWrap","getSocialTitleMobileStyles","marginBottom","transition","opacity","transform","MysiteHeroContainer","bannerProps","isCircularImage","backgroundClip","background","backgroundColor","position","overflow","willChange","backfaceVisibility","top","left","right","boxShadow","paddingTop","justifyContent","fontFamily","headlineFont","padding","objectFit","objectPosition","marginLeft","marginRight","boxSizing","whiteSpace","textOverflow","paragraphFont","WebkitBoxOrient","WebkitLineClamp","MysiteHeroContainerMobile","paddingRight","maxHeight","bottom","pointerEvents","BadgeContainer","Badge","backdropFilter","borderRadius","border","ToggleButtonMobile","cursor","margin","StyledSpan","ImgTabIndex","ContactLink","BadgeValue","PlaceholderImage","sx","ArrowDownIcon","trackGTMEvent","eventData","window","url","href","updatedEventData","prefix","includes","dataLayer","console","error","Fragment","renderImageContent","placeholderClass","renderBadges","showBadges","expirationDate","renderMobileContent","isScrolled","renderSocialMediaIcons","shopTitle","socialTitleText","email","phone","renderContactLink","renderDesktopContent","shopDescription","arrow","checkIfImageIsCircular","Promise","resolve","reject","imageContext","Image","crossOrigin","onload","canvas","createElement","context","getContext","drawImage","isCircular","getImageData","data","every","corner","Array","slice","onerror","isWhiteOrNearWhite","hex","replace","toLowerCase","test","fullHex","split","char","join","r","Number","parseInt","substring","g","b","threshold","createContactClickHandler","contactType","contactValue","contact_type","contact_value","click_element","onKeyDown","key","globalThis","protocol","handlers","MysiteHero","socialIcons","setIsScrolled","isDescriptionExpanded","setIsDescriptionExpanded","setHasWhiteBackground","isImageCircular","setIsImageCircular","toggleDescription","debounceTimeout","lastScrollY","scrollY","currentScrollState","isTransitioning","lastUpdateTime","updateScrollState","newState","now","Date","clearTimeout","setTimeout","scrollTo","behavior","handleScroll","currentScrollY","abs","scrollingDown","scrollDownThreshold","scrollUpThreshold","initializeState","initialScrollY","shouldStartCompact","rafId","lastRafTime","throttledScrollHandler","requestAnimationFrame","addEventListener","passive","removeEventListener","cancelAnimationFrame","icon","social_platform","type","social_url","open","containerClass","getCharacterLimit","innerWidth","shouldShowToggle","ut","re","ne","U","ProductCarousel","Kt"],"mappings":"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","sourcesContent":["var St=Object.create;var xe=Object.defineProperty;var Tt=Object.getOwnPropertyDescriptor;var Pt=Object.getOwnPropertyNames;var It=Object.getPrototypeOf,Bt=Object.prototype.hasOwnProperty;var ie=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var Nt=(e,t,o,i)=>{if(t&&typeof t==\"object\"||typeof t==\"function\")for(let a of Pt(t))!Bt.call(e,a)&&a!==o&&xe(e,a,{get:()=>t[a],enumerable:!(i=Tt(t,a))||i.enumerable});return e};var Rt=(e,t,o)=>(o=e!=null?St(It(e)):{},Nt(t||!e||!e.__esModule?xe(o,\"default\",{value:e,enumerable:!0}):o,e));var $e=ie((qo,De)=>{\"use strict\";var Wt=\"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED\";De.exports=Wt});var je=ie((Zo,_e)=>{\"use strict\";var _t=$e();function Ae(){}function We(){}We.resetWarningCache=Ae;_e.exports=function(){function e(i,a,r,n,s,l){if(l!==_t){var g=new Error(\"Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types\");throw g.name=\"Invariant Violation\",g}}e.isRequired=e;function t(){return e}var o={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:We,resetWarningCache:Ae};return o.PropTypes=o,o}});var Ve=ie((Uo,Oe)=>{\"use strict\";Oe.exports=je()();var Go,Qo});import{useState as Ft}from\"react\";import{NsImage as Mt}from\"@nuskin/foundation-ui-components\";import{styled as F}from\"@nuskin/foundation-theme\";var he=F(\"div\")`\n width: 200px;\n text-align: left;\n margin-bottom: 5px;\n`,be=F(\"button\")`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: space-between;\n width: 240px;\n height: ${e=>e.isMobile?\"410px\":\"513px\"};\n overflow: hidden;\n cursor: pointer;\n border: 1px solid #ededed;\n background: var(--color-primary-n-10-primary-white, #fff);\n`,fe=F(\"div\")`\n width: '240px';\n height: '240px';\n background: ${e=>e.bgColor??\"#f5f5f5\"};\n border-radius: 8px;\n overflow: hidden;\n margin-bottom: 0;\n display: flex;\n align-items: normal;\n justify-content: center;\n position: relative;\n @media (max-width: 560px) {\n width: 200px;\n height: 200px;\n align-items: unset;\n }\n`,ue=F(\"img\")`\n width: 100%;\n height: 100%;\n object-fit: cover;\n border-radius: 8px;\n display: block;\n`,ye=F(\"div\")`\n width: 200px;\n margin-top: 16px;\n max-height: 66px;\n text-align: left;\n font-size: 16px;\n font-family: 'Inter', sans-serif;\n font-weight: 400;\n line-height: 22px;\n overflow: hidden;\n color: #666;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n text-overflow: ellipsis;\n @media (max-width: 560px) {\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n margin-top: 5px;\n max-height: 54px;\n line-height: 18px;\n }\n`,ae=F(\"div\")`\n width: 200px;\n text-align: left;\n margin-bottom: 12px;\n @media (max-width: 560px) {\n margin-bottom: 8px;\n }\n`,we=F(\"button\")`\n width: 200px;\n height: 40px;\n border-radius: 4px;\n display: flex;\n align-items: center;\n gap: 10px;\n font-family: 'Inter', sans-serif;\n font-size: 14px;\n font-weight: 600;\n line-height: 20px;\n letter-spacing: 0.14px;\n text-transform: none;\n justify-content: flex-start;\n padding-left: 31px;\n overflow: hidden;\n white-space: normal;\n word-break: break-word;\n overflow-wrap: break-word;\n text-overflow: ellipsis;\n margin-top: 8px;\n margin-bottom: 10px;\n -webkit-appearance: none;\n -webkit-tap-highlight-color: transparent;\n\n color: ${e=>e.disabled?\"#999\":\"#fff\"};\n background-color: ${e=>e.disabled?\"#e0e0e0\":!e.isMobile&&e.isHovered?\"#888\":\"#000\"};\n border: ${e=>e.disabled?\"1px solid #ccc\":\"none\"};\n cursor: ${e=>e.disabled?\"not-allowed\":\"pointer\"};\n opacity: ${e=>e.disabled?.6:1};\n transition: ${e=>e.isMobile?\"none\":\"all 0.3s ease\"};\n\n @media (max-width: 560px) {\n margin: 5px 0;\n }\n`,Ce=F(\"span\")`\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n display: inline-block;\n background: none;\n transition: all 0.3s ease;\n opacity: ${e=>e.disabled?.5:1};\n`;import{useMediaQuery as Et}from\"@mui/material\";import{jsx as T,jsxs as ke}from\"react/jsx-runtime\";var zt=({productTitle:e,imageDetails:t,className:o,button:i,onCardClick:a,productStatusBadge:r,directSellerBadge:n,mySitePriceComponent:s,testId:l})=>{let[g,b]=Ft(!1),d=Et(\"(max-width: 560px)\"),u=C=>{let S=C.target,k=t?.fallbackImage;k&&S.src!==k&&(S.src=k)};return ke(be,{className:o,onClick:a,tabIndex:0,\"data-testid\":\"product-card\",isMobile:d,children:[T(fe,{bgColor:t?.bgColor,onError:u,children:t?.imageSrc?T(Mt,{\"data-testid\":l??\"test-product-image\",className:t.className??\"\",src:t.imageSrc,alt:t.imageAlt,\"aria-label\":t.areaLabel??t.imageAlt,width:\"100%\"}):T(ue,{alt:\"\"})}),T(ye,{title:e,\"data-testid\":\"product-title\",children:e}),n&&T(ae,{children:n}),T(ae,{children:r}),T(he,{children:s}),i?.showButton&&ke(we,{tabIndex:0,\"aria-roledescription\":\":\",\"aria-label\":i.buttonText||\"ADD TO CART\",\"data-testid\":\"add-to-cart-button\",disabled:i?.disabled??!1,isMobile:d,isHovered:g,onClick:C=>{C.stopPropagation(),i?.disabled||i.onClick?.()},onMouseEnter:()=>{!d&&!i?.disabled&&b(!0)},onMouseLeave:()=>{d||b(!1)},children:[T(Ce,{className:\"cart-icon\",disabled:i?.disabled,children:T(\"svg\",{width:\"24\",height:\"22\",viewBox:\"0 0 24 22\",fill:\"none\",xmlns:\"http://www.w3.org/2000/svg\",children:T(\"path\",{fillRule:\"evenodd\",clipRule:\"evenodd\",d:\"M0 1.86358C0 1.26109 0.488416 0.772675 1.09091 0.772675H3.48173C4.51054 0.772675 5.39955 1.49136 5.61511 2.49733L5.71309 2.95456H22.9091C23.245 2.95456 23.5622 3.10933 23.7689 3.37411C23.9757 3.63889 24.0489 3.98415 23.9674 4.31005L22.4053 10.5583C21.9197 12.5009 20.1743 13.8636 18.172 13.8636H8.05068L8.28444 14.9546H20.7273C21.3298 14.9546 21.8182 15.443 21.8182 16.0455C21.8182 16.648 21.3298 17.1364 20.7273 17.1364H19.6364H8.18182H7.40252C6.88811 17.1364 6.4436 16.777 6.33582 16.274L3.76449 4.27405L3.48173 2.95449H1.09091C0.488416 2.95449 0 2.46608 0 1.86358ZM8.18182 17.1364C6.97683 17.1364 6 18.1132 6 19.3182C6 20.5232 6.97683 21.5 8.18182 21.5C9.3868 21.5 10.3636 20.5232 10.3636 19.3182C10.3636 18.1132 9.3868 17.1364 8.18182 17.1364ZM19.6364 17.1364C18.4314 17.1364 17.4545 18.1132 17.4545 19.3182C17.4545 20.5232 18.4314 21.5 19.6364 21.5C20.8413 21.5 21.8182 20.5232 21.8182 19.3182C21.8182 18.1132 20.8413 17.1364 19.6364 17.1364ZM7.58317 11.6818H18.172C19.1732 11.6818 20.0459 11.0005 20.2887 10.0292L21.5119 5.13638H6.18062L7.58317 11.6818Z\",fill:i?.disabled?\"#999\":\"#ffffff\"})})}),i.buttonText||\"ADD TO CART\"]})]})},ne=zt;import{useCallback as He,useRef as Ht}from\"react\";import Dt from\"react-slick\";import $t from\"@mui/material/useMediaQuery\";import{NsCarouselControl as At}from\"@nuskin/foundation-ui-components\";import{styled as f}from\"@nuskin/foundation-theme\";import V from\"@mui/material/Box\";import{NsTypography as Lt}from\"@nuskin/foundation-ui-components\";var ve=f(V)`\n padding: 30px 0 60px;\n width: 100%;\n margin: auto;\n margin-top: 50px;\n position: relative;\n\n .slick-list {\n padding-left: 24px;\n padding-right: 24px;\n }\n .slick-slide {\n display: flex;\n justify-content: center;\n padding: 0 12px;\n box-sizing: border-box;\n }\n .slick-prev,\n .slick-next {\n display: none !important;\n }\n\n @media (max-width: 1200px) {\n max-width: 1024px;\n .slick-list {\n padding-left: 12px;\n padding-right: 12px;\n }\n .slick-slide {\n padding: 0 6px;\n }\n }\n @media (max-width: 700px) {\n max-width: 100vw;\n padding: 10px 0 50px;\n .slick-list {\n padding-left: 4px;\n padding-right: 4px;\n }\n .slick-slide {\n padding: 0 2px;\n }\n }\n @media (max-width: 560px) {\n padding: 10px 0 10px;\n margin-top: 25px;\n }\n`,Se=f(\"div\")`\n overflow-x: auto;\n display: flex;\n scroll-snap-type: x mandatory;\n -webkit-overflow-scrolling: touch;\n gap: 16px;\n padding: 0 8px 16px;\n width: 100%;\n box-sizing: border-box;\n\n &::-webkit-scrollbar {\n height: 6px;\n }\n\n &::-webkit-scrollbar-thumb {\n background: #007bff;\n border-radius: 10px;\n }\n`,Te=f(\"div\")`\n display: flex;\n scroll-snap-align: start;\n justify-content: center;\n gap: 15px;\n`,Pe=f(V)`\n position: absolute;\n bottom: calc(100% + 1px);\n right: 1px;\n width: 100%;\n display: flex;\n justify-content: space-between;\n align-items: center;\n box-sizing: border-box;\n`,Ie=f(V)`\n display: flex;\n align-items: center;\n margin-left: auto;\n margin-right: ${({$isMobile:e})=>e?0:\"24px\"};\n\n @media (max-width: 560px) {\n margin-left: 0;\n order: 2;\n }\n`,Be=f(V)`\n display: none;\n\n @media (max-width: 560px) {\n color: #666666;\n font-family: Inter;\n font-size: 14px !important;\n font-style: normal;\n font-weight: 600;\n line-height: 18px;\n display: flex;\n align-items: center;\n order: 1;\n }\n`,Ne=f(V)`\n display: flex;\n align-items: center;\n opacity: ${({$isDisabled:e})=>e?.3:1};\n pointer-events: ${({$isDisabled:e})=>e?\"none\":\"auto\"};\n transition: opacity 0.3s ease;\n\n .carousal-prev-button,\n .carousal-next-button {\n transition: all 0.3s ease;\n border: 2px solid #000000;\n border-radius: 3px;\n padding: 9px;\n cursor: pointer;\n\n svg {\n transition: all 0.3s ease;\n }\n\n svg polyline {\n stroke: #000000;\n fill: none;\n }\n\n &:hover {\n background-color: #f5f5f5;\n border: 2px solid #ddd;\n\n svg {\n opacity: 0.5;\n }\n\n svg polyline {\n stroke: #000000;\n fill: none;\n }\n }\n }\n\n @media (max-width: 560px) {\n display: none;\n }\n`,Fo=f(\"div\")`\n @media (max-width: 560px) {\n overflow-y: hidden;\n scrollbar-width: thin;\n scrollbar-color: #007bff #eee;\n &::-webkit-scrollbar {\n width: 8px;\n }\n &::-webkit-scrollbar-track {\n background: #eee;\n }\n &::-webkit-scrollbar-thumb {\n background-color: red;\n border-radius: 8px;\n border: 2px solid #eee;\n }\n }\n`,Re=f(Lt)`\n color: #666666;\n font-family: Inter;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 22px;\n @media (max-width: 560px) {\n margin: 0 3px;\n }\n`,Fe=f(\"a\")`\n color: #000000;\n font-family: Inter, sans-serif;\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 22px;\n text-decoration: none;\n border-bottom: 1px solid #000000;\n padding-bottom: 4px;\n transition: all 0.3s ease;\n cursor: pointer;\n\n @media (max-width: 560px) {\n font-size: 14px;\n line-height: 18px;\n }\n\n &:hover {\n color: #666666;\n border-bottom: 1px solid #666666;\n cursor: pointer;\n }\n`,Me=f(\"div\")`\n padding-top: 20px;\n font-size: 20px;\n text-align: center;\n`,Ee=f(\"div\")`\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n`,ze=f(\"div\")`\n display: flex;\n align-items: center;\n flex: 1;\n min-width: 0;\n`,Le=f(\"div\")`\n font-family: 'Lora';\n font-weight: 400;\n font-size: 22px;\n margin-left: 16px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n margin-bottom: 13px;\n`;import{jsx as v,jsxs as Y}from\"react/jsx-runtime\";function U({entries:e,renderEntry:t,settings:o={},showControlButtons:i=!0,allEntryLabel:a=\"View All\",allEntryLink:r=\"\",categoryName:n,emptyProductMessage:s=\"No Products Available For The Selected Category\",productsCountLabel:l=\"Products\",isInitialDataLoading:g,history:b}){let d=Ht(null),u=$t(\"(max-width: 560px)\"),C=He(()=>{d.current?.slickPrev()},[]),S=He(()=>{d.current?.slickNext()},[]),k=t??((c,B)=>v(ne,{productTitle:c.productTitle,imageDetails:c.imageDetails,button:c.button,onCardClick:c.onCardClick,productStatusBadge:c.productStatusBadge,directSellerBadge:c.directSeller,mySitePriceComponent:c.mySitePriceComponent},`${c.productTitle}-${B}`)),y={dots:!0,infinite:!0,speed:500,slidesToShow:Math.min(e?.length??0,4),slidesToScroll:4,swipe:!0,draggable:!0,arrows:!0,responsive:[{breakpoint:1320,settings:{slidesToShow:Math.min(e?.length??0,3),slidesToScroll:3}},{breakpoint:900,settings:{slidesToShow:Math.min(e?.length??0,2),slidesToScroll:2}},{breakpoint:600,settings:{slidesToShow:1,slidesToScroll:1,arrows:!1}}],...o},W=(e?.length??0)>y.slidesToShow,I=()=>e?.length===0&&!g?v(Me,{children:s}):u?v(Se,{children:v(Te,{children:e.map((c,B)=>c&&k(c,B))})}):v(Dt,{...y,ref:d,children:e.map((c,B)=>c&&k(c,B))});return Y(ve,{children:[i&&Y(Pe,{children:[Y(Ee,{children:[Y(ze,{children:[v(Be,{children:Y(Re,{variant:\"body-m\",children:[e?.length??0,\" \",l]})}),!u&&n&&v(Le,{children:n})]}),v(Ie,{$isMobile:u,children:v(Fe,{onClick:c=>{b&&(c.preventDefault(),b.push(r))},children:a})})]}),!u&&v(Ne,{$isDisabled:!W,children:v(At,{prev:C,next:S,viewAllLabel:\"\",viewAllUrl:\"\"})})]}),I()]})}import{useState as A,useEffect as le,useCallback as Zt}from\"react\";import{useMediaQuery as Gt}from\"@mui/material\";var K=Rt(Ve());import*as qe from\"react\";import Ot from\"@mui/material/Tabs\";import Vt from\"@mui/material/Tab\";import Ze from\"@mui/material/Box\";import{styled as jt}from\"@nuskin/foundation-theme\";var Ye=jt.div`\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: flex-start;\n width: 100%;\n height: 100%;\n background-color: #fff;\n .tabsStyle {\n display: flex;\n padding-top: 8.533px;\n flex-direction: column;\n align-items: flex-start;\n gap: 12.8px;\n border-right: 1px;\n border-color: divider;\n width: 200px;\n & .Mui-selected {\n font-weight: 700;\n font-size: 14px;\n font-family: 'inter', sans-serif;\n font-style: normal;\n font-height: 20px;\n border-radius: 4px;\n }\n & .MuiTabs-indicator {\n left: 0;\n background-color: #5b81a5;\n color: #5b81a5;\n\n @media (max-width: 768px) {\n display: none;\n }\n }\n }\n\n .tabContainer {\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: flex-start;\n min-width: 100%;\n background-color: #fff;\n @media (max-width: 768px) {\n flex-direction: column;\n justify-content: center;\n align-items: center;\n }\n }\n\n .tabStyle {\n align-items: flex-start;\n display: flex;\n text-align: left;\n font-size: 14px;\n font-family: 'inter' sans-serif;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n min-height: 20px;\n padding: 1px;\n padding-left: 10px;\n margin-bottom: 10px;\n cursor: pointer;\n text-transform: none;\n }\n @media (max-width: 768px) {\n flex-direction: row;\n\n .tabsStyle {\n width: 100%;\n border-right: none;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding-top: 0px;\n }\n\n .tabStyle {\n display: flex;\n align-items: center;\n gap: 10px;\n font-size: 14px;\n border: 1px solid #ccc;\n border-radius: 70px;\n padding: 8px 16px;\n text-align: center;\n margin: 4px;\n background-color: #fff;\n cursor: pointer;\n color: black;\n font-family: Inter;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .tabStyle.Mui-selected {\n background-color: #5b81a5;\n color: #ffffff !important;\n font-weight: 700;\n border-radius: 70px;\n }\n }\n .tabPanel {\n padding: 8px;\n text-align: left;\n }\n`;import{useMediaQuery as Yt}from\"@mui/material\";import{jsx as D,jsxs as qt}from\"react/jsx-runtime\";function Ge(e){let{children:t,value:o,index:i,...a}=e;return D(\"div\",{role:\"tabpanel\",hidden:o!==i,id:`vertical-tabpanel-${i}`,\"aria-labelledby\":`vertical-tab-${i}`,...a,children:o===i&&D(Ze,{className:\"tabPanel\",children:t})})}Ge.propTypes={children:K.default.node,index:K.default.number.isRequired,value:K.default.number.isRequired};var re=({itemArray:e,value:t,onChange:o})=>{let[i,a]=qe.useState(0),r=Yt(\"(max-width:768px)\"),n=t??i;return D(Ye,{children:qt(Ze,{className:\"tabContainer\",children:[D(Ot,{orientation:r?\"horizontal\":\"vertical\",variant:\"scrollable\",value:n,onChange:(l,g)=>{o?o(l,g):a(g)},\"aria-label\":\"Vertical tabs example\",className:\"tabsStyle\",children:e.map(l=>D(Vt,{label:l.label,className:\"tabStyle\"},l.categoryId))}),e.map(l=>D(Ge,{value:n,index:e.findIndex(g=>g.categoryId===l.categoryId),children:l.content},l.categoryId))]})})};import{NsSpinner as Qt}from\"@nuskin/foundation-ui-components\";import{styled as $}from\"@nuskin/foundation-theme\";var Qe=$(\"div\")`\n display: flex;\n flex-direction: ${({isMobile:e})=>e?\"column\":\"row\"};\n align-items: ${({isMobile:e})=>e?\"stretch\":\"flex-start\"};\n width: 100%;\n max-width: 1920px;\n min-height: ${({isMobile:e})=>e?\"auto\":\"800px\"};\n margin: 0 auto;\n box-sizing: border-box;\n overflow: visible;\n background: #fff;\n padding: ${({isMobile:e})=>e?\"10px 16px 0px 16px\":\"50px 60px 0px 60px\"};\n\n @media (max-width: 768px) {\n padding: 10px 16px 0px 16px;\n min-height: auto;\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n padding: 30px 40px 0px 40px;\n gap: 20px;\n }\n\n transform: translateZ(0);\n will-change: auto;\n`,Ue=$(\"div\")`\n min-width: ${({isMobile:e})=>e?\"100%\":\"auto\"};\n height: ${({isMobile:e})=>e?\"auto\":\"100%\"};\n flex-shrink: 0;\n\n @media (max-width: 768px) {\n width: 100%;\n height: auto;\n\n overflow-x: auto;\n overflow-y: visible;\n -webkit-overflow-scrolling: touch;\n scrollbar-width: none;\n -ms-overflow-style: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n min-width: 200px;\n margin-right: 20px;\n }\n`,Ke=$(\"div\")`\n flex: 1;\n min-width: 0;\n height: ${({isMobile:e})=>e?\"auto\":\"100%\"};\n\n @media (max-width: 768px) {\n width: 100%;\n height: auto;\n min-height: 300px;\n\n -webkit-overflow-scrolling: touch;\n overflow-x: hidden;\n overflow-y: auto;\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n min-height: 400px;\n }\n\n contain: layout style paint;\n transform: translateZ(0);\n`,di=$(\"div\")`\n display: flex;\n justify-content: center;\n align-items: center;\n min-height: 200px;\n padding: 20px;\n\n @media (max-width: 768px) {\n min-height: 150px;\n padding: 16px;\n }\n`,Je=$(\"div\")`\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 40px 20px;\n color: #666;\n font-size: 16px;\n\n @media (max-width: 768px) {\n padding: 20px 16px;\n font-size: 14px;\n }\n`,Xe=$(\"div\")`\n padding: 10px;\n display: flex;\n justify-content: center;\n`;import{jsx as z,jsxs as Jt}from\"react/jsx-runtime\";var Ut=({allEntryLabel:e,allEntryLink:t,renderEntry:o,settings:i,showControlButtons:a=!0,fetchCategories:r,fetchProducts:n,showCustomCategory:s=!1,emptyProductTabs:l=\"No tabs available\",emptyProductMessage:g,productsCountLabel:b,getCategoryId:d,history:u})=>{let C=Gt(\"(max-width:768px)\"),[S,k]=A(!0),[y,W]=A([]),[I,c]=A(0),[B,Z]=A([]),[H,_]=A(!1),[te,G]=A(!0),x=Zt(()=>{let m=document.querySelectorAll('[data-testid*=\"spinner\"], .ns-spinner, [class*=\"spinner\"]');G(m.length===0)},[]);le(()=>{H&&x()},[H,x]),le(()=>{r().then(W)},[r]),le(()=>{if(y.length>0){let m=y[I]?.categoryId;d&&d(m),_(!0),n(m).then(Z).finally(()=>{_(!1),k(!1)})}},[y,I,n]);let w=y.map(m=>({label:m.label,content:\"\",categoryId:m.categoryId}));return Jt(Qe,{isMobile:C,children:[s&&(w.length>0?z(Ue,{isMobile:C,children:z(re,{itemArray:w,value:I,onChange:(m,R)=>c(R)})}):z(Je,{children:l})),z(Ke,{isMobile:C,children:H?z(Xe,{children:te&&z(Qt,{})}):z(U,{isInitialDataLoading:S,entries:B,allEntryLabel:e,allEntryLink:t,renderEntry:o?m=>o({...m,productStatusBadge:m.productStatusBadge}):void 0,settings:i,showControlButtons:a,categoryName:y[I]?.label,emptyProductMessage:g,productsCountLabel:b,history:u})})]})},Kt=Ut;import{useState as X,useEffect as pe,useMemo as oo}from\"react\";import{Typography as M,Box as E,useMediaQuery as io,Tooltip as ao}from\"@mui/material\";import{NsLink as no,NsImage as bt}from\"@nuskin/foundation-ui-components\";import{styled as N}from\"@nuskin/foundation-theme\";import{Box as q}from\"@mui/material\";import{jsx as de}from\"react/jsx-runtime\";var se=e=>({fontSize:\"12px\",fontStyle:\"normal\",fontWeight:\"600\",lineHeight:\"16px\",letterSpacing:\"0.12px\",color:e?\"#000000\":\"#FFFFFF\",\"& a\":{color:\"inherit\",textDecoration:\"none\",\"&:hover\":{textDecoration:\"underline\"}}}),tt=e=>({fontSize:\"12px\",fontStyle:\"normal\",fontWeight:\"700\",lineHeight:\"16px\",letterSpacing:\"0.48px\",color:e?\"#000000\":\"#FFFFFF\",textTransform:\"uppercase\",paddingLeft:\"5px\"}),ot=()=>({display:\"flex\",flexDirection:\"row\",gap:\"10px\",alignItems:\"center\"}),et=e=>({...se(e),paddingBottom:\"11px\",wordBreak:\"break-all\",overflowWrap:\"break-word\",paddingLeft:\"5px\",\"& a\":{color:\"inherit\",textDecoration:\"none\"},\"@media (max-width: 420px)\":{fontSize:\"11px\",lineHeight:\"15px\",paddingBottom:\"8px\"},\"@media (max-width: 400px)\":{fontSize:\"10px\",lineHeight:\"14px\",paddingBottom:\"6px\"},\"@media (max-width: 375px)\":{fontSize:\"8px\",lineHeight:\"12px\",paddingBottom:\"4px\"}}),Xt=e=>({...tt(e),marginBottom:\"11px\",transition:\"opacity 0.3s ease-out, transform 0.3s ease-out\",opacity:1,transform:\"translateY(0)\",\"@media (max-width: 420px)\":{fontSize:\"11px\",lineHeight:\"14px\",marginBottom:\"8px\"},\"@media (max-width: 400px)\":{fontSize:\"10px\",lineHeight:\"12px\",marginBottom:\"5px\"},\"@media (max-width: 375px)\":{fontSize:\"8px\",lineHeight:\"11px\",marginBottom:\"4px\"}}),it=N(e=>de(q,{...e}))(({bannerProps:e,isCircularImage:t,hasWhiteBackground:o})=>({backgroundClip:\"border-box\",display:\"flex\",background:e?.backgroundColor??\"#383838\",position:\"relative\",overflow:\"hidden\",width:\"100%\",height:\"auto\",flexDirection:\"row\",alignItems:\"center\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"transform, opacity\",transform:\"translateZ(0)\",backfaceVisibility:\"hidden\",\"&.scrolled\":{top:0,left:0,right:0,boxShadow:\"0 2px 8px rgba(0,0,0,0.2)\",\".content\":{paddingTop:\"0\",justifyContent:\"center\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".body-title\":{fontSize:\"26px\",lineHeight:\"34px\",marginBottom:\"0\",fontStyle:\"normal\",fontWeight:\"400\",fontFamily:e?.headlineFont??\"Lora\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".bg-image\":{width:\"90px\",height:\"90px\",padding:t?\"2px\":\"0px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",objectFit:\"cover\",objectPosition:\"center\"},\".placeholder-image\":{\"& > div\":{width:\"90px\",height:\"90px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"}}},\".content\":{width:\"70%\",height:\"100%\",marginLeft:\"2%\",marginRight:\"auto\",display:\"flex\",flexDirection:\"column\",position:\"relative\",boxSizing:\"border-box\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".bg-image\":{width:\"252px\",height:\"252px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"width, height, transform\",padding:t?\"3px\":\"0px\",objectFit:\"cover\",objectPosition:\"center\"},\".placeholder-image\":{transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"width, height, transform\",\"& > div\":{transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"}},\".body-title\":{fontSize:\"32px\",lineHeight:\"38px\",marginBottom:\"8px\",fontWeight:\"400\",color:o?\"#000000\":\"#FFFFFF\",overflow:\"hidden\",whiteSpace:\"nowrap\",textOverflow:\"ellipsis\",fontFamily:e?.headlineFont??\"Lora\",paddingLeft:\"5px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".body-text\":{fontSize:\"16px\",marginBottom:\"12px\",fontStyle:\"normal\",fontWeight:\"400\",lineHeight:\"22px\",color:o?\"#000000\":\"#FFFFFF\",fontFamily:e?.paragraphFont??\"inherit\",display:\"-webkit-box\",WebkitBoxOrient:\"vertical\",overflow:\"hidden\",WebkitLineClamp:3,textOverflow:\"ellipsis\",paddingLeft:\"5px\",transition:\"opacity 0.3s ease-out, transform 0.3s ease-out\",opacity:1,transform:\"translateY(0)\"},\".social-media\":{display:\"flex\",flexDirection:\"column\",transition:\"opacity 0.3s ease-out, transform 0.3s ease-out\",opacity:1,transform:\"translateY(0)\"},\".email-text\":se(o),\".phone-text\":se(o),\".social-title-text\":{...tt(o),marginBottom:\"8px\"},\".social-icons\":{...ot(),paddingBottom:\"8px\"}})),at=N(e=>de(q,{...e}))(({bannerProps:e,isCircularImage:t,hasWhiteBackground:o})=>({backgroundClip:\"border-box\",display:\"flex\",background:e?.backgroundColor??\"#383838\",position:\"relative\",overflow:\"hidden\",width:\"100%\",flexDirection:\"column\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"transform, opacity\",transform:\"translateZ(0)\",backfaceVisibility:\"hidden\",\"&.scrolled\":{top:0,left:0,right:0,boxShadow:\"0 2px 8px rgba(0,0,0,0.2)\",\".content-mobile\":{paddingTop:\"5px\",width:\"60%\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".body-title-mobile\":{fontSize:\"18px\",lineHeight:\"28px\",marginBottom:\"0\",fontStyle:\"normal\",fontWeight:\"400\",fontFamily:e?.headlineFont??\"Lora\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".bg-image-mobile\":{width:\"75px\",height:\"75px\",padding:t?\"2px\":\"0px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",objectFit:\"cover\",objectPosition:\"center\"},\".placeholder-image-mobile\":{\"& > div\":{width:\"75px !important\",height:\"75px !important\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"}}},\".image-content-mobile\":{display:\"flex\",flexDirection:\"row\",width:\"100%\",justifyContent:\"center\",alignItems:\"center\"},\".content-mobile\":{width:\"55%\",height:\"100%\",paddingTop:\"10px\",paddingRight:\"10px\",marginLeft:\"8px\",marginRight:\"auto\",display:\"flex\",flexDirection:\"column\",justifyContent:\"center\",position:\"relative\",boxSizing:\"border-box\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",\"@media (max-width: 420px)\":{paddingTop:\"8px\",width:\"100%\"},\"@media (max-width: 400px)\":{paddingTop:\"6px\",width:\"100%\",height:\"100%\"},\"@media (max-width: 375px)\":{paddingTop:\"4px\",width:\"100%\",height:\"100%\"}},\".bg-image-mobile\":{width:\"144px\",height:\"144px\",display:\"flex\",justifyContent:\"center\",alignItems:\"center\",objectFit:\"cover\",objectPosition:\"center\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"width, height, transform\",padding:t?\"2px\":\"0px\",\"@media (max-width: 420px)\":{width:\"120px\",height:\"120px\"},\"@media (max-width: 400px)\":{width:\"112px\",height:\"112px\"},\"@media (max-width: 375px)\":{width:\"90px\",height:\"90px\"}},\".placeholder-image-mobile\":{transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"width, height, transform\",\"& > div\":{transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",width:\"144px\",height:\"144px\",\"@media (max-width: 420px)\":{width:\"120px\",height:\"120px\"},\"@media (max-width: 400px)\":{width:\"110px !important\",height:\"110px !important\"},\"@media (max-width: 375px)\":{width:\"90px\",height:\"90px\"}}},\".body-title-mobile\":{fontSize:\"22px\",lineHeight:\"28px\",marginBottom:\"13px\",fontWeight:\"400\",color:o?\"#000000\":\"#FFFFFF\",fontStyle:\"normal\",overflow:\"hidden\",whiteSpace:\"nowrap\",textOverflow:\"ellipsis\",fontFamily:e?.headlineFont??\"Lora\",paddingLeft:\"5px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",\"@media (max-width: 420px)\":{fontSize:\"16px\",lineHeight:\"24px\",marginBottom:\"8px\"},\"@media (max-width: 400px)\":{fontSize:\"16px\",lineHeight:\"22px\",marginBottom:\"6px\"},\"@media (max-width: 375px)\":{fontSize:\"14px\",lineHeight:\"20px\",marginBottom:\"4px\"}},\".body-text-mobile\":{fontSize:\"14px\",padding:\"20px 25px 20px 25px\",fontStyle:\"normal\",fontWeight:\"400\",lineHeight:\"20px\",color:\"#252525\",backgroundColor:\"#E0E0E0\",fontFamily:e?.paragraphFont??\"inherit\",transition:\"all 0.25s cubic-bezier(0.4, 0, 0.2, 1)\",opacity:1,transform:\"translateY(0)\"},\".expandable-description-mobile\":{backgroundColor:\"#E0E0E0\",position:\"relative\"},\".description-content-mobile\":{fontSize:\"14px\",padding:\"10px 15px\",fontStyle:\"normal\",fontWeight:\"400\",lineHeight:\"20px\",color:\"#252525\",fontFamily:e?.paragraphFont??\"inherit\",transition:\"max-height 0.3s ease-in-out, opacity 0.3s ease-in-out\",overflow:\"hidden\",position:\"relative\",\"&.collapsed\":{maxHeight:\"50px\",display:\"-webkit-box\",WebkitLineClamp:2,WebkitBoxOrient:\"vertical\",\"&::after\":{content:'\"\"',position:\"absolute\",bottom:0,left:0,right:0,height:\"20px\",background:\"linear-gradient(transparent, rgba(224, 224, 224, 0.8), #E0E0E0)\",pointerEvents:\"none\"}},\"&.expanded\":{maxHeight:\"none\",whiteSpace:\"normal\",display:\"block\",\"&::after\":{display:\"none\"}}},\".email-text-mobile\":et(o),\".phone-text-mobile\":et(o),\".social-title-text-mobile\":Xt(o),\".social-icons-mobile\":{...ot(),paddingBottom:\"10px\",transition:\"opacity 0.3s ease-out, transform 0.3s ease-out\",opacity:1,transform:\"translateY(0)\",\"& img\":{width:\"24px\",height:\"24px\",\"@media (max-width: 400px)\":{width:\"20px\",height:\"20px\"},\"@media (max-width: 375px)\":{width:\"18px\",height:\"18px\"}},\"@media (max-width: 420px)\":{paddingBottom:\"8px\"},\"@media (max-width: 400px)\":{paddingBottom:\"4px\"},\"@media (max-width: 375px)\":{paddingBottom:\"3px\"}}})),nt=N(q)({display:\"flex\",gap:\"12px\",marginBottom:\"16px\",paddingLeft:\"5px\",\"&.mobile-badges\":{flexDirection:\"column\",gap:\"8px\",marginBottom:\"12px\"},\"&.tablet-badges\":{flexDirection:\"row\",gap:\"12px\",marginBottom:\"8px\"}}),rt=N(e=>de(q,{...e}))(({hasWhiteBackground:e})=>({backgroundColor:\"rgba(255, 255, 255, 0.2)\",backdropFilter:\"blur(10px)\",borderRadius:\"20px\",padding:\"8px 16px\",display:\"flex\",alignItems:\"center\",gap:\"4px\",border:\"1px solid rgba(255, 255, 255, 0.3)\",transition:\"all 0.3s ease\",\"&.mobile-badge\":{padding:\"6px 12px\",borderRadius:\"16px\",fontSize:\"12px\"},\"&.tablet-badge\":{padding:\"8px 16px\",borderRadius:\"20px\",fontSize:\"14px\"},\"&:hover\":{backgroundColor:\"rgba(255, 255, 255, 0.3)\",transform:\"translateY(-1px)\",boxShadow:\"0 4px 12px rgba(0, 0, 0, 0.1)\"},\".badge-text\":{color:e?\"#000000\":\"#FFFFFF\",fontWeight:\"400\",opacity:.9},\".badge-value\":{color:e?\"#000000\":\"#FFFFFF\",fontWeight:\"600\"}})),lt=N(\"button\")({backgroundColor:\"#E0E0E0\",border:\"1px solid #252525\",borderRadius:\"10px\",cursor:\"pointer\",width:\"40px\",height:\"20px\",display:\"flex\",alignItems:\"center\",justifyContent:\"center\",margin:\"10px auto 5px auto\",transition:\"all 0.2s ease\",\"& .arrow-icon-mobile\":{transition:\"transform 0.3s ease\",\"&.expanded\":{transform:\"rotate(180deg)\"}}}),st=N(q)`\n background: none;\n border: 2px solid transparent;\n cursor: pointer;\n padding: 2px;\n display: flex;\n align-items: center;\n border-radius: 8px;\n transition: all 0.3s ease;\n\n &:hover {\n transform: scale(1.1);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n }\n\n &:focus,\n &:focus-within {\n outline: none;\n border-color: #007bff;\n box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25);\n }\n\n &:hover svg {\n fill: #ffffff;\n }\n`,dt=N(\"span\")`\n line-height: 0.5;\n`,pt=N(\"a\")({fontSize:\"inherit\",fontFamily:\"inherit\",fontWeight:\"inherit\",lineHeight:\"inherit\",letterSpacing:\"inherit\",color:\"inherit\",textDecoration:\"none\",\"&:hover\":{textDecoration:\"underline\"}}),ct=N(\"span\")({});import{Box as eo}from\"@mui/material\";import{jsx as L,jsxs as to}from\"react/jsx-runtime\";var gt=({width:e,height:t,backgroundColor:o})=>L(eo,{sx:{width:e,height:t,display:\"flex\",justifyContent:\"center\",alignItems:\"center\",backgroundColor:o},\"data-testid\":\"placeholder-image\",children:L(\"svg\",{xmlns:\"http://www.w3.org/2000/svg\",width:\"128\",height:\"129\",viewBox:\"0 0 128 129\",fill:\"none\",children:to(\"g\",{id:\"ns_logomark\",children:[L(\"path\",{id:\"Vector\",d:\"M127.495 52.1946C125.663 47.9538 122.999 44.1171 119.661 40.9073C112.565 34.2835 102.562 31.7037 93.1175 34.0622C83.6733 36.4206 76.0882 43.3926 72.991 52.5619C71.4142 56.8414 70.6063 61.3627 70.6039 65.9196C70.6039 85.8227 70.6039 105.737 70.6039 125.662C70.6039 129.001 70.6039 129.001 66.9051 128.834C66.9051 128.2 66.9051 127.499 66.9051 126.831C66.9051 104.323 66.9051 81.8263 66.9051 59.3409C66.3415 45.3064 74.9302 32.5039 88.1888 27.6164C89.79 27.0612 91.4307 26.6259 93.0981 26.314C94.7114 25.98 96.4605 25.8465 98.0738 25.6461C96.0231 16.3291 78.9419 5.60953 65.0889 4.97504C50.3084 4.62252 36.6074 12.6365 29.7509 25.6461C31.331 25.8465 32.8779 25.9466 34.3569 26.2138C48.0999 28.544 58.7086 39.4998 60.5168 53.2298C60.8904 55.7285 61.0812 58.2508 61.0877 60.7769C61.0877 82.7507 61.0877 104.724 61.0877 126.697C61.0877 128.434 60.6842 129.169 58.8016 128.968C56.9183 128.768 57.1204 128.2 57.1204 126.965C57.1204 119.985 57.1204 113.006 57.1204 105.993C57.1204 92.1674 57.1204 78.3423 57.1204 64.5171C57.2385 56.3928 54.2457 48.5271 48.7477 42.5103C42.2429 35.5282 32.6539 32.2371 23.1959 33.7401C13.7379 35.243 5.66194 41.3411 1.67448 49.9906C1.23781 50.8254 0.867444 51.6937 0.262573 52.9293C5.79294 22.3996 32.4752 0.139867 63.7085 0.000656323C94.9411 -0.138555 121.824 21.8824 127.629 52.3616\",fill:\"#252525\"}),L(\"path\",{id:\"Vector_2\",d:\"M86.0995 124.927C86.0995 124.293 86.0995 123.858 86.0995 123.425C86.0995 111.669 86.0995 100.049 86.0995 88.1269C85.8836 82.4231 88.0775 76.89 92.1523 72.8653C97.3131 67.9567 104.984 66.7091 111.452 69.7263C117.892 72.1185 122.166 78.225 122.178 85.0541C122.372 92.1747 119.781 99.0921 114.949 104.356C107.882 113.237 98.6134 120.141 88.05 124.392C87.4217 124.616 86.782 124.805 86.1335 124.96\",fill:\"#252525\"}),L(\"path\",{id:\"Vector_3\",d:\"M41.8183 125.395C37.6149 123.224 33.6477 121.487 29.9828 119.25C21.5405 114.299 14.4778 107.331 9.43828 98.9796C6.53442 94.3985 5.34408 88.9493 6.07591 83.5852C7.056 75.2882 13.8859 68.8841 22.2829 68.3905C31.1231 67.2473 39.3527 73.0751 41.1455 81.7484C41.76 84.263 42.0762 86.8411 42.0868 89.4287C42.0868 100.516 42.0868 111.636 42.0868 122.823C42.0868 123.457 42.0867 124.059 41.8854 125.294\",fill:\"#252525\"}),L(\"path\",{id:\"Vector_4\",d:\"M51.3337 127.431C47.9713 127.431 47.6681 127.198 47.6681 124.326V76.6386C48.1096 67.937 42.9747 59.906 34.8574 56.602C25.8992 52.8557 15.5485 54.8615 8.66523 61.6779C4.28638 66.6086 1.89197 72.9696 1.94049 79.5438C1.95423 80.2444 1.78037 80.9357 1.43588 81.5476C1.06552 79.9446 0.62885 78.2081 0.426687 76.7387C-0.724024 70.4463 0.471163 63.9529 3.78906 58.472C6.09291 54.6111 9.65016 51.6434 13.8762 50.0567C22.8587 46.555 32.9393 47.1785 41.4148 51.7598C47.6592 54.8694 51.5262 61.2882 51.3337 68.2232C51.5019 87.6249 51.3337 107.027 51.3337 126.396C51.3337 126.797 51.3337 127.164 51.3337 127.532\",fill:\"#252525\"}),L(\"path\",{id:\"Vector_5\",d:\"M76.287 127.499V125.094C76.287 107.196 76.4883 89.2963 76.287 71.3966C76.0848 56.9034 84.2554 50.6588 95.7553 48.3545C101.535 47.2005 107.524 47.6393 113.071 49.6235C122.914 53.3319 128.994 63.1725 127.866 73.5672C127.631 76.2831 127.17 78.975 126.487 81.6151C125.916 78.2758 125.68 74.9364 124.772 71.597C122.808 64.3002 117.377 58.4174 110.228 55.8421C103.078 53.2668 95.1132 54.3239 88.8955 58.6734C83.0441 62.6207 79.7011 69.3237 80.086 76.3389C80.086 92.2349 80.086 108.131 80.086 124.026C80.086 127.366 80.086 127.366 76.2198 127.366\",fill:\"#252525\"})]})})});import{jsx as mt}from\"react/jsx-runtime\";var xt=({width:e=16,height:t=16,className:o=\"\"})=>mt(\"svg\",{width:e,height:t,viewBox:\"0 0 24 24\",fill:\"currentColor\",className:o,\"data-testid\":\"arrow-down-icon\",children:mt(\"path\",{d:\"M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z\"})});function J(e){if(typeof window>\"u\")return;let t=window.location.href,o={...e},i=t.includes(\"personal-offer\")?\"postorefront_\":\"mysite_\";o.event=i+e.event;try{window.dataLayer||(console.error(\"GTM dataLayer not available, but event logged\"),window.dataLayer=[]),window.dataLayer.push(o)}catch(a){console.error(\"Failed to track GTM event:\",a)}}import{Fragment as yt,jsx as p,jsxs as P}from\"react/jsx-runtime\";var ht=(e,t,o)=>{let i=o.includes(\"mobile\")?\"placeholder-image-mobile\":\"placeholder-image\";return e?.imageSrc?p(dt,{tabIndex:0,children:p(bt,{className:o,src:e.imageSrc,alt:e.imageAlt})}):p(E,{className:i,children:p(gt,{width:o.includes(\"mobile\")?\"144px\":\"246px\",height:o.includes(\"mobile\")?\"144px\":\"246px\",backgroundColor:t?.backgroundColor??\"#5F5F5F\"})})},ft=(e,t,o,i)=>!e||!t?null:p(nt,{className:o?\"mobile-badges\":\"tablet-badges\",children:t&&p(rt,{className:o?\"mobile-badge\":\"tablet-badge\",hasWhiteBackground:i,tabIndex:0,children:p(ct,{className:\"badge-value\",children:t})})}),ro=(e,t,o,i,a)=>{let{shopTitle:r,socialTitleText:n,email:s,showBadges:l,expirationDate:g,phone:b}=e;return P(E,{className:\"content-mobile\",children:[p(M,{tabIndex:0,className:\"body-title-mobile\",children:r}),!t&&P(yt,{children:[p(M,{tabIndex:0,className:\"social-title-text-mobile\",children:n}),ee(\"email\",s,\"email-text-mobile\"),ee(\"phone\",b,\"phone-text-mobile\"),p(E,{className:\"social-icons-mobile\",children:o}),ft(l,g??\"\",i,a)]})]})},lo=(e,t,o,i,a)=>{let{shopTitle:r,shopDescription:n,socialTitleText:s,email:l,phone:g,showBadges:b,expirationDate:d}=e;return P(E,{className:\"content\",children:[p(M,{tabIndex:0,className:\"body-title\",children:r}),!t&&P(yt,{children:[n?.length>480?p(ao,{title:n,arrow:!0,children:p(M,{tabIndex:0,className:\"body-text\",children:n})}):p(M,{tabIndex:0,className:\"body-text\",children:n}),P(E,{className:\"social-media\",children:[p(M,{tabIndex:0,className:\"social-title-text\",children:s}),P(E,{className:\"social-icons\",children:[o,ee(\"email\",l,\"email-text\"),ee(\"phone\",g,\"phone-text\")]})]}),ft(b,d??\"\",i,a)]})]})},so=e=>new Promise((t,o)=>{let i=new Image;i.crossOrigin=\"anonymous\",i.src=e,i.onload=()=>{let a=document.createElement(\"canvas\"),r=a.getContext(\"2d\");if(!r)return o(new Error(\"Canvas not supported\"));a.width=i.width,a.height=i.height,r.drawImage(i,0,0);let s=[r.getImageData(0,0,1,1).data,r.getImageData(i.width-1,0,1,1).data,r.getImageData(0,i.height-1,1,1).data,r.getImageData(i.width-1,i.height-1,1,1).data].every(l=>Array.prototype.slice.call(l)[3]<10);t(s)},i.onerror=()=>o(new Error(\"Failed to load image\"))}),po=e=>{if(!e)return!1;let t=e.replace(\"#\",\"\").toLowerCase();if(!/^[0-9a-f]{3,4}$|^[0-9a-f]{6}$|^[0-9a-f]{8}$/i.test(t))return!1;let o=t;(t.length===3||t.length===4)&&(o=t.split(\"\").map(s=>s+s).join(\"\"));let i=Number.parseInt(o.substring(0,2),16),a=Number.parseInt(o.substring(2,4),16),r=Number.parseInt(o.substring(4,6),16),n=220;return i>=n&&a>=n&&r>=n},co=(e,t)=>({onClick:()=>{J({event:\"contact_click\",contact_type:e,contact_value:t,click_element:`${e}_link`})},onKeyDown:o=>{(o.key===\"Enter\"||o.key===\" \")&&(o.preventDefault(),J({event:\"contact_click\",contact_type:e,contact_value:t,click_element:`${e}_link`}),globalThis.location.href=`${e===\"email\"?\"mailto\":\"tel\"}:${t}`)}}),ee=(e,t,o)=>{let i=e===\"email\"?\"mailto:\":\"tel:\",a=co(e,t);return p(M,{className:o,children:p(pt,{href:`${i}${t}`,...a,children:t})})};function ut({className:e,shopTitle:t,shopDescription:o,socialTitleText:i,imageDetails:a,email:r,phone:n,bannerProps:s,socialIcons:l,expirationDate:g,showBadges:b=!1}){let d=io(\"(max-width: 560px)\"),[u,C]=X(!1),[S,k]=X(!1),[y,W]=X(!1),[I,c]=X(!1),B=()=>{k(!S)};pe(()=>{(async()=>{if(a?.imageSrc){let w=await so(a.imageSrc);c(w)}else c(!1)})()},[a?.imageSrc]),pe(()=>{W(po(s?.backgroundColor))},[s?.backgroundColor]),pe(()=>{let x,w=window.scrollY,m=!1,R=!1,oe=0,ce=h=>{let Q=Date.now();if(m!==h&&!R){if(Q-oe<100)return;R=!0,m=h,oe=Q,h&&k(!1),clearTimeout(x),C(h),x=setTimeout(()=>{R=!1,h&&window.scrollY<15&&window.scrollTo({top:d?20:30,behavior:\"smooth\"})},300)}},wt=()=>{let h=window.scrollY;if(R){w=h;return}if(Math.abs(h-w)<.5)return;let O=h>w,kt=d?15:25,vt=d?8:12;O&&h>kt&&!m?ce(!0):!O&&h<vt&&m&&ce(!1),w=h},Ct=()=>{let h=window.scrollY,O=h>(d?5:10);m=O,C(O),w=h,oe=Date.now()},j=null,ge=0,me=()=>{j||Date.now()-ge<16||(j=requestAnimationFrame(()=>{wt(),ge=Date.now(),j=null}))};return Ct(),window.addEventListener(\"scroll\",me,{passive:!0}),()=>{window.removeEventListener(\"scroll\",me),j&&cancelAnimationFrame(j),clearTimeout(x)}},[d]);let Z=oo(()=>l?.map((x,w)=>p(st,{onClick:R=>{R.preventDefault(),J({event:\"social_click\",social_platform:x.type,social_url:x.url,click_element:\"social_icon\"}),window.open(x.url,\"_blank\")},children:p(no,{href:x.url,target:\"_blank\",children:p(bt,{src:`https://www.google.com/s2/favicons?domain=${x?.url}&sz=24`,alt:`${x.type} icon`,width:\"24\",height:\"24\"},x?.type+w)})},x?.type+w)),[l]),H=`${e} ${u?\"scrolled\":\"\"}`,_={shopTitle:t,shopDescription:o,socialTitleText:i,email:r,phone:n,showBadges:b,expirationDate:g},te=()=>window.innerWidth<=380?50:window.innerWidth<=415?56:window.innerWidth<=460?62:80,G=d&&o&&o.length>te();return d?P(at,{className:H,\"data-testid\":\"my-site-shop-header\",bannerProps:s,isCircularImage:I,hasWhiteBackground:y,children:[P(E,{className:\"image-content-mobile\",children:[ht(a,s??{},\"bg-image-mobile\"),ro(_,u,Z,d,y)]}),!u&&P(E,{className:\"expandable-description-mobile\",children:[p(M,{className:`description-content-mobile ${S||!G?\"expanded\":\"collapsed\"}`,children:o}),G&&p(lt,{onClick:B,children:p(xt,{width:16,height:16,className:`arrow-icon-mobile ${S?\"expanded\":\"\"}`})})]})]}):P(it,{className:H,\"data-testid\":\"my-site-shop-header\",bannerProps:s,isCircularImage:I,hasWhiteBackground:y,children:[ht(a,s??{},\"bg-image\"),lo(_,u,Z,d,y)]})}export{ut as MysiteHero,re as NsCategoryNavigation,ne as NsProductCard,U as ProductCarousel,Kt as ProductTabCarousel};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","import React, { ReactElement, useState } from 'react';\nimport { NsImage } from '@nuskin/foundation-ui-components';\nimport { ProductImageType } from '../types/image';\nimport {\n PriceComponent,\n ProductCardContainer,\n ImageContainer,\n DefaultImage,\n ProductTitle,\n ProductBadgeContainer,\n AddToCartButton,\n CartIcon,\n} from './styles/NsProductCard.Styled';\nimport { useMediaQuery } from '@mui/material';\nimport { NsCardButton } from './types';\n\ntype NsProductCardProps = {\n readonly productTitle: string;\n readonly imageDetails?: ProductImageType;\n readonly className?: string;\n readonly button?: NsCardButton & { disabled?: boolean };\n readonly onCardClick?: () => void;\n readonly productStatusBadge?: React.ReactNode;\n readonly directSellerBadge?: React.ReactNode;\n readonly mySitePriceComponent?: React.ReactNode;\n readonly testId?: string;\n};\n\nconst NsProductCard = ({\n productTitle,\n imageDetails,\n className,\n button,\n onCardClick,\n productStatusBadge,\n directSellerBadge,\n mySitePriceComponent,\n testId,\n}: NsProductCardProps): ReactElement => {\n const [isButtonHovered, setIsButtonHovered] = useState(false);\n const isMobile = useMediaQuery('(max-width: 560px)');\n\n const handleImageError = (e: React.SyntheticEvent<HTMLImageElement, Event>) => {\n const target = e.target as HTMLImageElement;\n const noImageFallback = imageDetails?.fallbackImage;\n if (noImageFallback && target.src !== noImageFallback) {\n target.src = noImageFallback;\n }\n };\n\n return (\n <ProductCardContainer\n className={className}\n onClick={onCardClick}\n tabIndex={0}\n data-testid=\"product-card\"\n isMobile={isMobile}\n >\n <ImageContainer bgColor={imageDetails?.bgColor} onError={handleImageError}>\n {imageDetails?.imageSrc ? (\n <NsImage\n data-testid={testId ?? 'test-product-image'}\n className={imageDetails.className ?? ''}\n src={imageDetails.imageSrc}\n alt={imageDetails.imageAlt}\n aria-label={imageDetails.areaLabel ?? imageDetails.imageAlt}\n width={'100%'}\n />\n ) : (\n <DefaultImage alt=\"\" />\n )}\n </ImageContainer>\n <ProductTitle title={productTitle} data-testid=\"product-title\">\n {productTitle}\n </ProductTitle>\n {directSellerBadge && <ProductBadgeContainer>{directSellerBadge}</ProductBadgeContainer>}\n <ProductBadgeContainer>{productStatusBadge}</ProductBadgeContainer>\n <PriceComponent>{mySitePriceComponent}</PriceComponent>\n {button?.showButton && (\n <AddToCartButton\n tabIndex={0}\n aria-roledescription=\":\"\n aria-label={button.buttonText || 'ADD TO CART'}\n data-testid=\"add-to-cart-button\"\n disabled={button?.disabled ?? false}\n isMobile={isMobile}\n isHovered={isButtonHovered}\n onClick={(e) => {\n e.stopPropagation();\n if (!button?.disabled) {\n button.onClick?.();\n }\n }}\n onMouseEnter={() => {\n if (!isMobile && !button?.disabled) {\n setIsButtonHovered(true);\n }\n }}\n onMouseLeave={() => {\n if (!isMobile) {\n setIsButtonHovered(false);\n }\n }}\n >\n <CartIcon className=\"cart-icon\" disabled={button?.disabled}>\n <svg width=\"24\" height=\"22\" viewBox=\"0 0 24 22\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M0 1.86358C0 1.26109 0.488416 0.772675 1.09091 0.772675H3.48173C4.51054 0.772675 5.39955 1.49136 5.61511 2.49733L5.71309 2.95456H22.9091C23.245 2.95456 23.5622 3.10933 23.7689 3.37411C23.9757 3.63889 24.0489 3.98415 23.9674 4.31005L22.4053 10.5583C21.9197 12.5009 20.1743 13.8636 18.172 13.8636H8.05068L8.28444 14.9546H20.7273C21.3298 14.9546 21.8182 15.443 21.8182 16.0455C21.8182 16.648 21.3298 17.1364 20.7273 17.1364H19.6364H8.18182H7.40252C6.88811 17.1364 6.4436 16.777 6.33582 16.274L3.76449 4.27405L3.48173 2.95449H1.09091C0.488416 2.95449 0 2.46608 0 1.86358ZM8.18182 17.1364C6.97683 17.1364 6 18.1132 6 19.3182C6 20.5232 6.97683 21.5 8.18182 21.5C9.3868 21.5 10.3636 20.5232 10.3636 19.3182C10.3636 18.1132 9.3868 17.1364 8.18182 17.1364ZM19.6364 17.1364C18.4314 17.1364 17.4545 18.1132 17.4545 19.3182C17.4545 20.5232 18.4314 21.5 19.6364 21.5C20.8413 21.5 21.8182 20.5232 21.8182 19.3182C21.8182 18.1132 20.8413 17.1364 19.6364 17.1364ZM7.58317 11.6818H18.172C19.1732 11.6818 20.0459 11.0005 20.2887 10.0292L21.5119 5.13638H6.18062L7.58317 11.6818Z\"\n fill={button?.disabled ? '#999' : '#ffffff'}\n />\n </svg>\n </CartIcon>\n {button.buttonText || 'ADD TO CART'}\n </AddToCartButton>\n )}\n </ProductCardContainer>\n );\n};\n\nexport default NsProductCard;\n","import { styled } from '@nuskin/foundation-theme';\n\nexport const PriceComponent = styled('div')`\n width: 200px;\n text-align: left;\n margin-bottom: 5px;\n`;\n\nexport const ProductCardContainer = styled('button')<{ isMobile: boolean }>`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: space-between;\n width: 240px;\n height: ${(props) => (props.isMobile ? '410px' : '513px')};\n overflow: hidden;\n cursor: pointer;\n border: 1px solid #ededed;\n background: var(--color-primary-n-10-primary-white, #fff);\n`;\n\nexport const ImageContainer = styled('div')<{\n bgColor?: string;\n}>`\n width: '240px';\n height: '240px';\n background: ${(props) => props.bgColor ?? '#f5f5f5'};\n border-radius: 8px;\n overflow: hidden;\n margin-bottom: 0;\n display: flex;\n align-items: normal;\n justify-content: center;\n position: relative;\n @media (max-width: 560px) {\n width: 200px;\n height: 200px;\n align-items: unset;\n }\n`;\n\nexport const DefaultImage = styled('img')`\n width: 100%;\n height: 100%;\n object-fit: cover;\n border-radius: 8px;\n display: block;\n`;\n\nexport const ProductTitle = styled('div')`\n width: 200px;\n margin-top: 16px;\n max-height: 66px;\n text-align: left;\n font-size: 16px;\n font-family: 'Inter', sans-serif;\n font-weight: 400;\n line-height: 22px;\n overflow: hidden;\n color: #666;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n text-overflow: ellipsis;\n @media (max-width: 560px) {\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n margin-top: 5px;\n max-height: 54px;\n line-height: 18px;\n }\n`;\n\nexport const ProductBadgeContainer = styled('div')`\n width: 200px;\n text-align: left;\n margin-bottom: 12px;\n @media (max-width: 560px) {\n margin-bottom: 8px;\n }\n`;\n\nexport const AddToCartButton = styled('button')<{\n disabled?: boolean;\n isMobile: boolean;\n isHovered: boolean;\n}>`\n width: 200px;\n height: 40px;\n border-radius: 4px;\n display: flex;\n align-items: center;\n gap: 10px;\n font-family: 'Inter', sans-serif;\n font-size: 14px;\n font-weight: 600;\n line-height: 20px;\n letter-spacing: 0.14px;\n text-transform: none;\n justify-content: flex-start;\n padding-left: 31px;\n overflow: hidden;\n white-space: normal;\n word-break: break-word;\n overflow-wrap: break-word;\n text-overflow: ellipsis;\n margin-top: 8px;\n margin-bottom: 10px;\n -webkit-appearance: none;\n -webkit-tap-highlight-color: transparent;\n\n color: ${(props) => (props.disabled ? '#999' : '#fff')};\n background-color: ${(props) => {\n if (props.disabled) return '#e0e0e0';\n if (!props.isMobile && props.isHovered) return '#888';\n return '#000';\n }};\n border: ${(props) => (props.disabled ? '1px solid #ccc' : 'none')};\n cursor: ${(props) => (props.disabled ? 'not-allowed' : 'pointer')};\n opacity: ${(props) => (props.disabled ? 0.6 : 1)};\n transition: ${(props) => (props.isMobile ? 'none' : 'all 0.3s ease')};\n\n @media (max-width: 560px) {\n margin: 5px 0;\n }\n`;\n\nexport const CartIcon = styled('span')<{ disabled?: boolean }>`\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n display: inline-block;\n background: none;\n transition: all 0.3s ease;\n opacity: ${(props) => (props.disabled ? 0.5 : 1)};\n`;\n","import React, { ReactElement, useCallback, ReactNode, useRef } from 'react';\nimport Slider from 'react-slick';\nimport useMediaQuery from '@mui/material/useMediaQuery';\nimport 'slick-carousel/slick/slick.css';\nimport { NsCardButton, NsCarouselControl } from '@nuskin/foundation-ui-components';\nimport { ProductImageType } from '../types/image';\nimport NsProductCard from '../card/NsProductCard';\nimport {\n SlickContainer,\n ControlsContainer,\n ControlsHeaderRow,\n ScrollableContainer,\n CardList,\n ViewAllWrapper,\n ProductCountWrapper,\n ArrowsWrapper,\n CustomTypography,\n ViewAllLink,\n ProductInfoWrapper,\n CategoryNameWrapper,\n EmptyProductCategories,\n} from './NsProductCarousel.styled';\n\nexport type ProductCardEntry = {\n readonly productTitle: string;\n readonly imageDetails?: ProductImageType;\n readonly button?: NsCardButton;\n readonly onCardClick?: () => void;\n readonly productStatusBadge?: React.ReactNode;\n readonly directSeller?: React.ReactNode;\n readonly mySitePriceComponent?: React.ReactNode;\n};\n\ninterface SlickSettings {\n dots?: boolean;\n infinite?: boolean;\n speed?: number;\n slidesToShow?: number;\n slidesToScroll?: number;\n swipe?: boolean;\n draggable?: boolean;\n arrows?: boolean;\n responsive?: Array<{\n breakpoint: number;\n settings: {\n slidesToShow?: number;\n slidesToScroll?: number;\n arrows?: boolean;\n };\n }>;\n}\n\ninterface ProductCardCarouselProps<T = ProductCardEntry> {\n readonly entries: T[];\n readonly settings?: SlickSettings;\n readonly showControlButtons?: boolean;\n readonly renderEntry?: (entry: T, index: number) => ReactNode;\n readonly allEntryLabel?: string;\n readonly allEntryLink?: string;\n readonly categoryName?: string;\n readonly emptyProductMessage?: string;\n readonly productsCountLabel?: string;\n readonly isInitialDataLoading?: boolean;\n readonly history?: {\n push: (path: string) => void;\n };\n}\n\nexport default function ProductCardCarousel({\n entries,\n renderEntry,\n settings = {},\n showControlButtons = true,\n allEntryLabel = 'View All',\n allEntryLink = '',\n categoryName,\n emptyProductMessage = 'No Products Available For The Selected Category',\n productsCountLabel = 'Products',\n isInitialDataLoading,\n history,\n}: ProductCardCarouselProps): ReactElement {\n const sliderRef = useRef<Slider>(null);\n const isMobile = useMediaQuery('(max-width: 560px)');\n\n const prev = useCallback(() => {\n sliderRef.current?.slickPrev();\n }, []);\n\n const next = useCallback(() => {\n sliderRef.current?.slickNext();\n }, []);\n\n const renderProductEntry =\n renderEntry ??\n ((entry: ProductCardEntry, index: number) => (\n <NsProductCard\n key={`${entry.productTitle}-${index}`}\n productTitle={entry.productTitle}\n imageDetails={entry.imageDetails}\n button={entry.button}\n onCardClick={entry.onCardClick}\n productStatusBadge={entry.productStatusBadge}\n directSellerBadge={entry.directSeller}\n mySitePriceComponent={entry.mySitePriceComponent}\n />\n ));\n\n const sliderSettings = {\n dots: true,\n infinite: true,\n speed: 500,\n slidesToShow: Math.min(entries?.length ?? 0, 4),\n slidesToScroll: 4,\n swipe: true,\n draggable: true,\n arrows: true,\n responsive: [\n {\n breakpoint: 1320,\n settings: {\n slidesToShow: Math.min(entries?.length ?? 0, 3),\n slidesToScroll: 3,\n },\n },\n {\n breakpoint: 900,\n settings: {\n slidesToShow: Math.min(entries?.length ?? 0, 2),\n slidesToScroll: 2,\n },\n },\n {\n breakpoint: 600,\n settings: {\n slidesToShow: 1,\n slidesToScroll: 1,\n arrows: false,\n },\n },\n ],\n ...settings,\n };\n\n const shouldShowNavigation = (entries?.length ?? 0) > sliderSettings.slidesToShow;\n\n const renderCarouselContent = () => {\n if (entries?.length === 0 && !isInitialDataLoading) {\n return <EmptyProductCategories>{emptyProductMessage}</EmptyProductCategories>;\n }\n\n if (isMobile) {\n return (\n <ScrollableContainer>\n <CardList>{entries.map((entry, index) => entry && renderProductEntry(entry, index))}</CardList>\n </ScrollableContainer>\n );\n }\n\n return (\n <Slider {...sliderSettings} ref={sliderRef}>\n {entries.map((entry, index) => entry && renderProductEntry(entry, index))}\n </Slider>\n );\n };\n\n return (\n <SlickContainer>\n {showControlButtons && (\n <ControlsContainer>\n <ControlsHeaderRow>\n <ProductInfoWrapper>\n <ProductCountWrapper>\n <CustomTypography variant=\"body-m\">\n {entries?.length ?? 0} {productsCountLabel}\n </CustomTypography>\n </ProductCountWrapper>\n {!isMobile && categoryName && <CategoryNameWrapper>{categoryName}</CategoryNameWrapper>}\n </ProductInfoWrapper>\n <ViewAllWrapper $isMobile={isMobile}>\n <ViewAllLink\n onClick={(e) => {\n if (history) {\n e.preventDefault();\n history.push(allEntryLink);\n }\n }}\n >\n {allEntryLabel}\n </ViewAllLink>\n </ViewAllWrapper>\n </ControlsHeaderRow>\n {!isMobile && (\n <ArrowsWrapper $isDisabled={!shouldShowNavigation}>\n <NsCarouselControl prev={prev} next={next} viewAllLabel={''} viewAllUrl={''} />\n </ArrowsWrapper>\n )}\n </ControlsContainer>\n )}\n {renderCarouselContent()}\n </SlickContainer>\n );\n}\n","import React from 'react';\nimport { styled } from '@nuskin/foundation-theme';\nimport Box, { BoxProps } from '@mui/material/Box';\nimport { NsTypography } from '@nuskin/foundation-ui-components';\n\nexport const SlickContainer: React.ComponentType<BoxProps> = styled(Box)`\n padding: 30px 0 60px;\n width: 100%;\n margin: auto;\n margin-top: 50px;\n position: relative;\n\n .slick-list {\n padding-left: 24px;\n padding-right: 24px;\n }\n .slick-slide {\n display: flex;\n justify-content: center;\n padding: 0 12px;\n box-sizing: border-box;\n }\n .slick-prev,\n .slick-next {\n display: none !important;\n }\n\n @media (max-width: 1200px) {\n max-width: 1024px;\n .slick-list {\n padding-left: 12px;\n padding-right: 12px;\n }\n .slick-slide {\n padding: 0 6px;\n }\n }\n @media (max-width: 700px) {\n max-width: 100vw;\n padding: 10px 0 50px;\n .slick-list {\n padding-left: 4px;\n padding-right: 4px;\n }\n .slick-slide {\n padding: 0 2px;\n }\n }\n @media (max-width: 560px) {\n padding: 10px 0 10px;\n margin-top: 25px;\n }\n`;\nexport const ScrollableContainer = styled('div')`\n overflow-x: auto;\n display: flex;\n scroll-snap-type: x mandatory;\n -webkit-overflow-scrolling: touch;\n gap: 16px;\n padding: 0 8px 16px;\n width: 100%;\n box-sizing: border-box;\n\n &::-webkit-scrollbar {\n height: 6px;\n }\n\n &::-webkit-scrollbar-thumb {\n background: #007bff;\n border-radius: 10px;\n }\n`;\n\nexport const CardList = styled('div')`\n display: flex;\n scroll-snap-align: start;\n justify-content: center;\n gap: 15px;\n`;\n\nexport const ControlsContainer: React.ComponentType<BoxProps> = styled(Box)`\n position: absolute;\n bottom: calc(100% + 1px);\n right: 1px;\n width: 100%;\n display: flex;\n justify-content: space-between;\n align-items: center;\n box-sizing: border-box;\n`;\n\nexport const ViewAllWrapper: React.ComponentType<BoxProps & { $isMobile?: boolean }> = styled(Box)<{\n $isMobile?: boolean;\n}>`\n display: flex;\n align-items: center;\n margin-left: auto;\n margin-right: ${({ $isMobile }) => ($isMobile ? 0 : '24px')};\n\n @media (max-width: 560px) {\n margin-left: 0;\n order: 2;\n }\n`;\n\nexport const ProductCountWrapper: React.ComponentType<BoxProps> = styled(Box)`\n display: none;\n\n @media (max-width: 560px) {\n color: #666666;\n font-family: Inter;\n font-size: 14px !important;\n font-style: normal;\n font-weight: 600;\n line-height: 18px;\n display: flex;\n align-items: center;\n order: 1;\n }\n`;\n\nexport const ArrowsWrapper: React.ComponentType<BoxProps & { $isDisabled?: boolean }> = styled(Box)<{\n $isDisabled?: boolean;\n}>`\n display: flex;\n align-items: center;\n opacity: ${({ $isDisabled }) => ($isDisabled ? 0.3 : 1)};\n pointer-events: ${({ $isDisabled }) => ($isDisabled ? 'none' : 'auto')};\n transition: opacity 0.3s ease;\n\n .carousal-prev-button,\n .carousal-next-button {\n transition: all 0.3s ease;\n border: 2px solid #000000;\n border-radius: 3px;\n padding: 9px;\n cursor: pointer;\n\n svg {\n transition: all 0.3s ease;\n }\n\n svg polyline {\n stroke: #000000;\n fill: none;\n }\n\n &:hover {\n background-color: #f5f5f5;\n border: 2px solid #ddd;\n\n svg {\n opacity: 0.5;\n }\n\n svg polyline {\n stroke: #000000;\n fill: none;\n }\n }\n }\n\n @media (max-width: 560px) {\n display: none;\n }\n`;\nexport const Scrollablewrapper = styled('div')`\n @media (max-width: 560px) {\n overflow-y: hidden;\n scrollbar-width: thin;\n scrollbar-color: #007bff #eee;\n &::-webkit-scrollbar {\n width: 8px;\n }\n &::-webkit-scrollbar-track {\n background: #eee;\n }\n &::-webkit-scrollbar-thumb {\n background-color: red;\n border-radius: 8px;\n border: 2px solid #eee;\n }\n }\n`;\nexport const CustomTypography = styled(NsTypography)`\n color: #666666;\n font-family: Inter;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 22px;\n @media (max-width: 560px) {\n margin: 0 3px;\n }\n`;\n\nexport const ViewAllLink = styled('a')`\n color: #000000;\n font-family: Inter, sans-serif;\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 22px;\n text-decoration: none;\n border-bottom: 1px solid #000000;\n padding-bottom: 4px;\n transition: all 0.3s ease;\n cursor: pointer;\n\n @media (max-width: 560px) {\n font-size: 14px;\n line-height: 18px;\n }\n\n &:hover {\n color: #666666;\n border-bottom: 1px solid #666666;\n cursor: pointer;\n }\n`;\n\nexport const EmptyProductCategories = styled('div')`\n padding-top: 20px;\n font-size: 20px;\n text-align: center;\n`;\nexport const ControlsHeaderRow = styled('div')`\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n`;\n\nexport const ProductInfoWrapper = styled('div')`\n display: flex;\n align-items: center;\n flex: 1;\n min-width: 0;\n`;\n\nexport const CategoryNameWrapper = styled('div')`\n font-family: 'Lora';\n font-weight: 400;\n font-size: 22px;\n margin-left: 16px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n margin-bottom: 13px;\n`;\n","import React, { useState, useEffect, useCallback } from 'react';\nimport { useMediaQuery } from '@mui/material';\n\nimport { NsCategoryNavigation } from '../Nav-Category-Navigation';\nimport { NsSpinner } from '@nuskin/foundation-ui-components';\nimport ProductCardCarousel, { ProductCardEntry } from './NsProductCarousel';\nimport {\n ProductTabCarouselContainer,\n TabsContainer,\n ContentContainer,\n NoTabsContainer,\n SpinnerContainer,\n} from './ProductTabCarousel.styled';\n\ninterface Category {\n label: string;\n categoryId: string;\n}\n\ninterface SlickSettings {\n dots?: boolean;\n infinite?: boolean;\n speed?: number;\n slidesToShow?: number;\n slidesToScroll?: number;\n swipe?: boolean;\n draggable?: boolean;\n arrows?: boolean;\n responsive?: Array<{\n breakpoint: number;\n settings: {\n slidesToShow?: number;\n slidesToScroll?: number;\n arrows?: boolean;\n };\n }>;\n}\n\ninterface ProductTabCarouselProps {\n readonly allEntryLabel?: string;\n readonly allEntryLink?: string;\n readonly renderEntry?: (entry: ProductCardEntry) => React.ReactNode;\n readonly settings?: SlickSettings;\n readonly showControlButtons?: boolean;\n readonly fetchCategories: () => Promise<Category[]>;\n readonly fetchProducts: (categoryId: string) => Promise<ProductCardEntry[]>;\n readonly emptyProductTabs?: string;\n readonly emptyProductMessage?: string;\n readonly showCustomCategory?: boolean;\n readonly productsCountLabel?: string;\n readonly getCategoryId: (categoryId: string) => Promise<Category[]>;\n readonly history?: {\n push: (path: string) => void;\n };\n}\n\nconst ProductTabCarousel: React.FC<ProductTabCarouselProps> = ({\n allEntryLabel,\n allEntryLink,\n renderEntry,\n settings,\n showControlButtons = true,\n fetchCategories,\n fetchProducts,\n showCustomCategory = false,\n emptyProductTabs = 'No tabs available',\n emptyProductMessage,\n productsCountLabel,\n getCategoryId,\n history,\n}) => {\n const isMobile = useMediaQuery('(max-width:768px)');\n const [isLoadingInitialData, setIsLoadingInitialData] = useState(true);\n const [categories, setCategories] = useState<Category[]>([]);\n const [selectedTab, setSelectedTab] = useState(0);\n const [products, setProducts] = useState<ProductCardEntry[]>([]);\n const [loading, setLoading] = useState(false);\n const [shouldShowSpinner, setShouldShowSpinner] = useState(true);\n\n const checkForExistingSpinners = useCallback(() => {\n const existingSpinners = document.querySelectorAll('[data-testid*=\"spinner\"], .ns-spinner, [class*=\"spinner\"]');\n setShouldShowSpinner(existingSpinners.length === 0);\n }, []);\n\n useEffect(() => {\n if (loading) {\n checkForExistingSpinners();\n }\n }, [loading, checkForExistingSpinners]);\n\n useEffect(() => {\n fetchCategories().then(setCategories);\n }, [fetchCategories]);\n\n useEffect(() => {\n if (categories.length > 0) {\n const categoryId = categories[selectedTab]?.categoryId;\n if (getCategoryId) {\n getCategoryId(categoryId);\n }\n\n setLoading(true);\n fetchProducts(categoryId)\n .then(setProducts)\n .finally(() => {\n setLoading(false);\n setIsLoadingInitialData(false);\n });\n }\n }, [categories, selectedTab, fetchProducts]);\n\n const itemArray = categories.map((cat) => ({\n label: cat.label,\n content: '',\n categoryId: cat.categoryId,\n }));\n\n return (\n <ProductTabCarouselContainer isMobile={isMobile}>\n {showCustomCategory &&\n (itemArray.length > 0 ? (\n <TabsContainer isMobile={isMobile}>\n <NsCategoryNavigation\n itemArray={itemArray}\n value={selectedTab}\n onChange={(_, newValue) => setSelectedTab(newValue)}\n />\n </TabsContainer>\n ) : (\n <NoTabsContainer>{emptyProductTabs}</NoTabsContainer>\n ))}\n <ContentContainer isMobile={isMobile}>\n {loading ? (\n <SpinnerContainer>{shouldShowSpinner && <NsSpinner />}</SpinnerContainer>\n ) : (\n <ProductCardCarousel\n isInitialDataLoading={isLoadingInitialData}\n entries={products}\n allEntryLabel={allEntryLabel}\n allEntryLink={allEntryLink}\n renderEntry={\n renderEntry\n ? (entry) => renderEntry({ ...entry, productStatusBadge: entry.productStatusBadge })\n : undefined\n }\n settings={settings}\n showControlButtons={showControlButtons}\n categoryName={categories[selectedTab]?.label}\n emptyProductMessage={emptyProductMessage}\n productsCountLabel={productsCountLabel}\n history={history}\n />\n )}\n </ContentContainer>\n </ProductTabCarouselContainer>\n );\n};\n\nexport default ProductTabCarousel;\n","import * as React from 'react';\nimport Tabs from '@mui/material/Tabs';\nimport Tab from '@mui/material/Tab';\nimport Box from '@mui/material/Box';\nimport PropTypes from 'prop-types';\nimport { NsCategoryNavigationContainer } from './NsCategoryNavigation.styled';\nimport { useMediaQuery } from '@mui/material';\n\nfunction TabPanel(\n props: Readonly<{\n children?: React.ReactNode;\n value: number;\n index: number;\n [key: string]: unknown;\n }>,\n) {\n const { children, value, index, ...other } = props;\n return (\n <div\n role=\"tabpanel\"\n hidden={value !== index}\n id={`vertical-tabpanel-${index}`}\n aria-labelledby={`vertical-tab-${index}`}\n {...other}\n >\n {value === index && <Box className=\"tabPanel\">{children}</Box>}\n </div>\n );\n}\nTabPanel.propTypes = {\n children: PropTypes.node,\n index: PropTypes.number.isRequired,\n value: PropTypes.number.isRequired,\n};\n\ninterface NsCategoryNavigationProps {\n itemArray: { label: string; content: React.ReactNode; categoryId: string }[];\n value?: number;\n onChange?: (event: React.SyntheticEvent, newValue: number) => void;\n}\n\nexport const NsCategoryNavigation: React.FC<Readonly<NsCategoryNavigationProps>> = ({\n itemArray,\n value: controlledValue,\n onChange,\n}) => {\n const [internalValue, setInternalValue] = React.useState(0);\n const isMobile = useMediaQuery('(max-width:768px)');\n const value = controlledValue ?? internalValue;\n const handleChange = (event: React.SyntheticEvent, newValue: number) => {\n if (onChange) {\n onChange(event, newValue);\n } else {\n setInternalValue(newValue);\n }\n };\n\n return (\n <NsCategoryNavigationContainer>\n <Box className=\"tabContainer\">\n <Tabs\n orientation={isMobile ? 'horizontal' : 'vertical'}\n variant=\"scrollable\"\n value={value}\n onChange={handleChange}\n aria-label=\"Vertical tabs example\"\n className=\"tabsStyle\"\n >\n {itemArray.map((item) => (\n <Tab key={item.categoryId} label={item.label} className=\"tabStyle\" />\n ))}\n </Tabs>\n {itemArray.map((item) => (\n <TabPanel\n key={item.categoryId}\n value={value}\n index={itemArray.findIndex((i) => i.categoryId === item.categoryId)}\n >\n {item.content}\n </TabPanel>\n ))}\n </Box>\n </NsCategoryNavigationContainer>\n );\n};\n","import { styled } from '@nuskin/foundation-theme';\nexport const NsCategoryNavigationContainer = styled.div`\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: flex-start;\n width: 100%;\n height: 100%;\n background-color: #fff;\n .tabsStyle {\n display: flex;\n padding-top: 8.533px;\n flex-direction: column;\n align-items: flex-start;\n gap: 12.8px;\n border-right: 1px;\n border-color: divider;\n width: 200px;\n & .Mui-selected {\n font-weight: 700;\n font-size: 14px;\n font-family: 'inter', sans-serif;\n font-style: normal;\n font-height: 20px;\n border-radius: 4px;\n }\n & .MuiTabs-indicator {\n left: 0;\n background-color: #5b81a5;\n color: #5b81a5;\n\n @media (max-width: 768px) {\n display: none;\n }\n }\n }\n\n .tabContainer {\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: flex-start;\n min-width: 100%;\n background-color: #fff;\n @media (max-width: 768px) {\n flex-direction: column;\n justify-content: center;\n align-items: center;\n }\n }\n\n .tabStyle {\n align-items: flex-start;\n display: flex;\n text-align: left;\n font-size: 14px;\n font-family: 'inter' sans-serif;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n min-height: 20px;\n padding: 1px;\n padding-left: 10px;\n margin-bottom: 10px;\n cursor: pointer;\n text-transform: none;\n }\n @media (max-width: 768px) {\n flex-direction: row;\n\n .tabsStyle {\n width: 100%;\n border-right: none;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding-top: 0px;\n }\n\n .tabStyle {\n display: flex;\n align-items: center;\n gap: 10px;\n font-size: 14px;\n border: 1px solid #ccc;\n border-radius: 70px;\n padding: 8px 16px;\n text-align: center;\n margin: 4px;\n background-color: #fff;\n cursor: pointer;\n color: black;\n font-family: Inter;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .tabStyle.Mui-selected {\n background-color: #5b81a5;\n color: #ffffff !important;\n font-weight: 700;\n border-radius: 70px;\n }\n }\n .tabPanel {\n padding: 8px;\n text-align: left;\n }\n`;\n","import { styled } from '@nuskin/foundation-theme';\n\nexport const ProductTabCarouselContainer = styled('div')<{ isMobile?: boolean }>`\n display: flex;\n flex-direction: ${({ isMobile }) => (isMobile ? 'column' : 'row')};\n align-items: ${({ isMobile }) => (isMobile ? 'stretch' : 'flex-start')};\n width: 100%;\n max-width: 1920px;\n min-height: ${({ isMobile }) => (isMobile ? 'auto' : '800px')};\n margin: 0 auto;\n box-sizing: border-box;\n overflow: visible;\n background: #fff;\n padding: ${({ isMobile }) => (isMobile ? '10px 16px 0px 16px' : '50px 60px 0px 60px')};\n\n @media (max-width: 768px) {\n padding: 10px 16px 0px 16px;\n min-height: auto;\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n padding: 30px 40px 0px 40px;\n gap: 20px;\n }\n\n transform: translateZ(0);\n will-change: auto;\n`;\n\nexport const TabsContainer = styled('div')<{ isMobile?: boolean }>`\n min-width: ${({ isMobile }) => (isMobile ? '100%' : 'auto')};\n height: ${({ isMobile }) => (isMobile ? 'auto' : '100%')};\n flex-shrink: 0;\n\n @media (max-width: 768px) {\n width: 100%;\n height: auto;\n\n overflow-x: auto;\n overflow-y: visible;\n -webkit-overflow-scrolling: touch;\n scrollbar-width: none;\n -ms-overflow-style: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n min-width: 200px;\n margin-right: 20px;\n }\n`;\n\nexport const ContentContainer = styled('div')<{ isMobile?: boolean }>`\n flex: 1;\n min-width: 0;\n height: ${({ isMobile }) => (isMobile ? 'auto' : '100%')};\n\n @media (max-width: 768px) {\n width: 100%;\n height: auto;\n min-height: 300px;\n\n -webkit-overflow-scrolling: touch;\n overflow-x: hidden;\n overflow-y: auto;\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n min-height: 400px;\n }\n\n contain: layout style paint;\n transform: translateZ(0);\n`;\n\nexport const LoadingContainer = styled('div')`\n display: flex;\n justify-content: center;\n align-items: center;\n min-height: 200px;\n padding: 20px;\n\n @media (max-width: 768px) {\n min-height: 150px;\n padding: 16px;\n }\n`;\n\nexport const NoTabsContainer = styled('div')`\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 40px 20px;\n color: #666;\n font-size: 16px;\n\n @media (max-width: 768px) {\n padding: 20px 16px;\n font-size: 14px;\n }\n`;\nexport const SpinnerContainer = styled('div')`\n padding: 10px;\n display: flex;\n justify-content: center;\n`;\n","import React, { ReactElement, useState, useEffect, useMemo } from 'react';\nimport { Typography, Box, useMediaQuery, Tooltip } from '@mui/material';\nimport { NsLink, NsImage } from '@nuskin/foundation-ui-components';\nimport {\n MysiteHeroContainer,\n MysiteHeroContainerMobile,\n BadgeContainer,\n Badge,\n ToggleButtonMobile,\n StyledSpan,\n ImgTabIndex,\n ContactLink,\n BadgeValue,\n} from '@/common/headers/MysiteHero.styled';\nimport { PlaceholderImage } from '../icon/icons/PlaceholderImage';\nimport { ArrowDownIcon } from '../icon/icons/ArrowDownIcon';\nimport { trackGTMEvent } from '../utils/gtmTracking';\n\ntype MysiteHeroProps = {\n readonly imageDetails?: {\n imageSrc: string;\n imageAlt: string;\n bgColor: string;\n };\n readonly shopTitle: string;\n readonly shopDescription: string;\n readonly socialTitleText: string;\n readonly email: string;\n readonly phone: string;\n readonly className?: string;\n readonly bannerProps?: {\n backgroundColor?: string;\n headlineFont?: string;\n paragraphFont?: string;\n };\n readonly socialIcons?: {\n type: string;\n url: string;\n }[];\n readonly expirationDate?: string;\n readonly showBadges?: boolean;\n};\n\ntype ImageDetails = {\n imageSrc: string;\n imageAlt: string;\n bgColor: string;\n};\n\ntype BannerProps = {\n backgroundColor?: string;\n headlineFont?: string;\n paragraphFont?: string;\n};\n\ntype ContentProps = {\n shopTitle: string;\n shopDescription: string;\n socialTitleText: string;\n email: string;\n phone: string;\n showBadges: boolean;\n expirationDate?: string;\n};\n\nconst renderImageContent = (imageDetails: ImageDetails | undefined, bannerProps: BannerProps, className: string) => {\n const placeholderClass = className.includes('mobile') ? 'placeholder-image-mobile' : 'placeholder-image';\n return imageDetails?.imageSrc ? (\n <ImgTabIndex tabIndex={0}>\n <NsImage className={className} src={imageDetails.imageSrc} alt={imageDetails.imageAlt} />\n </ImgTabIndex>\n ) : (\n <Box className={placeholderClass}>\n <PlaceholderImage\n width={className.includes('mobile') ? '144px' : '246px'}\n height={className.includes('mobile') ? '144px' : '246px'}\n backgroundColor={bannerProps?.backgroundColor ?? '#5F5F5F'}\n />\n </Box>\n );\n};\n\nconst renderBadges = (showBadges: boolean, expirationDate: string, isMobile: boolean, hasWhiteBackground: boolean) => {\n if (!showBadges || !expirationDate) return null;\n\n const badgeClass = isMobile ? 'mobile-badge' : 'tablet-badge';\n const containerClass = isMobile ? 'mobile-badges' : 'tablet-badges';\n\n return (\n <BadgeContainer className={containerClass}>\n {expirationDate && (\n <Badge className={badgeClass} hasWhiteBackground={hasWhiteBackground} tabIndex={0}>\n <BadgeValue className=\"badge-value\">{expirationDate}</BadgeValue>\n </Badge>\n )}\n </BadgeContainer>\n );\n};\n\nconst renderMobileContent = (\n props: ContentProps,\n isScrolled: boolean,\n renderSocialMediaIcons: React.ReactNode,\n isMobile: boolean,\n hasWhiteBackground: boolean,\n) => {\n const { shopTitle, socialTitleText, email, showBadges, expirationDate, phone } = props;\n\n return (\n <Box className=\"content-mobile\">\n <Typography tabIndex={0} className=\"body-title-mobile\">\n {shopTitle}\n </Typography>\n {!isScrolled && (\n <>\n <Typography tabIndex={0} className=\"social-title-text-mobile\">\n {socialTitleText}\n </Typography>\n {renderContactLink('email', email, 'email-text-mobile')}\n {renderContactLink('phone', phone, 'phone-text-mobile')}\n <Box className=\"social-icons-mobile\">{renderSocialMediaIcons}</Box>\n {renderBadges(showBadges, expirationDate ?? '', isMobile, hasWhiteBackground)}\n </>\n )}\n </Box>\n );\n};\n\nconst renderDesktopContent = (\n props: ContentProps,\n isScrolled: boolean,\n renderSocialMediaIcons: React.ReactNode,\n isMobile: boolean,\n hasWhiteBackground: boolean,\n) => {\n const { shopTitle, shopDescription, socialTitleText, email, phone, showBadges, expirationDate } = props;\n\n return (\n <Box className=\"content\">\n <Typography tabIndex={0} className=\"body-title\">\n {shopTitle}\n </Typography>\n {!isScrolled && (\n <>\n {shopDescription?.length > 480 ? (\n <Tooltip title={shopDescription} arrow>\n <Typography tabIndex={0} className=\"body-text\">\n {shopDescription}\n </Typography>\n </Tooltip>\n ) : (\n <Typography tabIndex={0} className=\"body-text\">\n {shopDescription}\n </Typography>\n )}\n <Box className=\"social-media\">\n <Typography tabIndex={0} className=\"social-title-text\">\n {socialTitleText}\n </Typography>\n <Box className=\"social-icons\">\n {renderSocialMediaIcons}\n {renderContactLink('email', email, 'email-text')}\n {renderContactLink('phone', phone, 'phone-text')}\n </Box>\n </Box>\n {renderBadges(showBadges, expirationDate ?? '', isMobile, hasWhiteBackground)}\n </>\n )}\n </Box>\n );\n};\n\nconst checkIfImageIsCircular = (url: string): Promise<boolean> => {\n return new Promise((resolve, reject) => {\n const imageContext = new Image();\n imageContext.crossOrigin = 'anonymous';\n imageContext.src = url;\n\n imageContext.onload = () => {\n const canvas = document.createElement('canvas');\n const context = canvas.getContext('2d');\n if (!context) return reject(new Error('Canvas not supported'));\n\n canvas.width = imageContext.width;\n canvas.height = imageContext.height;\n\n context.drawImage(imageContext, 0, 0);\n\n const corners = [\n context.getImageData(0, 0, 1, 1).data,\n context.getImageData(imageContext.width - 1, 0, 1, 1).data,\n context.getImageData(0, imageContext.height - 1, 1, 1).data,\n context.getImageData(imageContext.width - 1, imageContext.height - 1, 1, 1).data,\n ];\n\n const isCircular = corners.every((corner) => {\n const imageArray = Array.prototype.slice.call(corner);\n const alpha = imageArray[3];\n return alpha < 10;\n });\n resolve(isCircular);\n };\n imageContext.onerror = () => reject(new Error('Failed to load image'));\n });\n};\n\nconst isWhiteOrNearWhite = (color: string | undefined): boolean => {\n if (!color) return false;\n\n const hex = color.replace('#', '').toLowerCase();\n\n /* regex pattern for hex color format: 3 chars (#fff), 4 chars (#ffff), 6 chars (#ffffff), or 8 chars (#ffffffff)*/\n if (!/^[0-9a-f]{3,4}$|^[0-9a-f]{6}$|^[0-9a-f]{8}$/i.test(hex)) return false;\n\n let fullHex = hex;\n if (hex.length === 3 || hex.length === 4) {\n fullHex = hex\n .split('')\n .map((char) => char + char)\n .join('');\n }\n\n const r = Number.parseInt(fullHex.substring(0, 2), 16);\n const g = Number.parseInt(fullHex.substring(2, 4), 16);\n const b = Number.parseInt(fullHex.substring(4, 6), 16);\n\n const threshold = 220;\n return r >= threshold && g >= threshold && b >= threshold;\n};\n\nconst createContactClickHandler = (contactType: 'email' | 'phone', contactValue: string) => ({\n onClick: () => {\n trackGTMEvent({\n event: 'contact_click',\n contact_type: contactType,\n contact_value: contactValue,\n click_element: `${contactType}_link`,\n });\n },\n onKeyDown: (e: React.KeyboardEvent<HTMLAnchorElement>) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n trackGTMEvent({\n event: 'contact_click',\n contact_type: contactType,\n contact_value: contactValue,\n click_element: `${contactType}_link`,\n });\n globalThis.location.href = `${contactType === 'email' ? 'mailto' : 'tel'}:${contactValue}`;\n }\n },\n});\n\nconst renderContactLink = (contactType: 'email' | 'phone', contactValue: string, className: string) => {\n const protocol = contactType === 'email' ? 'mailto:' : 'tel:';\n const handlers = createContactClickHandler(contactType, contactValue);\n\n return (\n <Typography className={className}>\n <ContactLink href={`${protocol}${contactValue}`} {...handlers}>\n {contactValue}\n </ContactLink>\n </Typography>\n );\n};\nexport default function MysiteHero({\n className,\n shopTitle,\n shopDescription,\n socialTitleText,\n imageDetails,\n email,\n phone,\n bannerProps,\n socialIcons,\n expirationDate,\n showBadges = false,\n}: MysiteHeroProps): ReactElement {\n const isMobile = useMediaQuery('(max-width: 560px)');\n const [isScrolled, setIsScrolled] = useState(false);\n const [isDescriptionExpanded, setIsDescriptionExpanded] = useState(false);\n const [hasWhiteBackground, setHasWhiteBackground] = useState(false);\n const [isImageCircular, setIsImageCircular] = useState(false);\n\n const toggleDescription = () => {\n setIsDescriptionExpanded(!isDescriptionExpanded);\n };\n\n useEffect(() => {\n const checkImage = async () => {\n if (imageDetails?.imageSrc) {\n const isCircular = await checkIfImageIsCircular(imageDetails.imageSrc);\n setIsImageCircular(isCircular);\n } else {\n setIsImageCircular(false);\n }\n };\n\n checkImage();\n }, [imageDetails?.imageSrc]);\n\n useEffect(() => {\n setHasWhiteBackground(isWhiteOrNearWhite(bannerProps?.backgroundColor));\n }, [bannerProps?.backgroundColor]);\n\n useEffect(() => {\n let debounceTimeout: ReturnType<typeof setTimeout>;\n let lastScrollY = window.scrollY;\n let currentScrollState = false;\n let isTransitioning = false;\n let lastUpdateTime = 0;\n\n const updateScrollState = (newState: boolean) => {\n const now = Date.now();\n\n if (currentScrollState !== newState && !isTransitioning) {\n if (now - lastUpdateTime < 100) {\n return;\n }\n\n isTransitioning = true;\n currentScrollState = newState;\n lastUpdateTime = now;\n\n if (newState) {\n setIsDescriptionExpanded(false);\n }\n\n clearTimeout(debounceTimeout);\n setIsScrolled(newState);\n\n debounceTimeout = setTimeout(() => {\n isTransitioning = false;\n\n if (newState && window.scrollY < 15) {\n window.scrollTo({\n top: isMobile ? 20 : 30,\n behavior: 'smooth',\n });\n }\n }, 300);\n }\n };\n\n const handleScroll = () => {\n const currentScrollY = window.scrollY;\n\n if (isTransitioning) {\n lastScrollY = currentScrollY;\n return;\n }\n\n const scrollDelta = Math.abs(currentScrollY - lastScrollY);\n\n if (scrollDelta < 0.5) {\n return;\n }\n\n const scrollingDown = currentScrollY > lastScrollY;\n\n const scrollDownThreshold = isMobile ? 15 : 25;\n const scrollUpThreshold = isMobile ? 8 : 12;\n\n if (scrollingDown && currentScrollY > scrollDownThreshold && !currentScrollState) {\n updateScrollState(true);\n } else if (!scrollingDown && currentScrollY < scrollUpThreshold && currentScrollState) {\n updateScrollState(false);\n }\n\n lastScrollY = currentScrollY;\n };\n\n const initializeState = () => {\n const initialScrollY = window.scrollY;\n const scrollThreshold = isMobile ? 5 : 10;\n const shouldStartCompact = initialScrollY > scrollThreshold;\n\n currentScrollState = shouldStartCompact;\n setIsScrolled(shouldStartCompact);\n lastScrollY = initialScrollY;\n lastUpdateTime = Date.now();\n };\n\n let rafId: number | null = null;\n let lastRafTime = 0;\n const throttledScrollHandler = () => {\n if (rafId) return;\n\n const now = Date.now();\n if (now - lastRafTime < 16) {\n return;\n }\n\n rafId = requestAnimationFrame(() => {\n handleScroll();\n lastRafTime = Date.now();\n rafId = null;\n });\n };\n\n initializeState();\n window.addEventListener('scroll', throttledScrollHandler, { passive: true });\n\n return () => {\n window.removeEventListener('scroll', throttledScrollHandler);\n if (rafId) cancelAnimationFrame(rafId);\n clearTimeout(debounceTimeout);\n };\n }, [isMobile]);\n\n const renderSocialMediaIcons = useMemo(() => {\n return socialIcons?.map((icon, index) => {\n const handleSocialClick = (e: React.MouseEvent) => {\n e.preventDefault();\n trackGTMEvent({\n event: 'social_click',\n social_platform: icon.type,\n social_url: icon.url,\n click_element: 'social_icon',\n });\n window.open(icon.url, '_blank');\n };\n\n return (\n <StyledSpan key={icon?.type + index} onClick={handleSocialClick}>\n <NsLink href={icon.url} target=\"_blank\">\n <NsImage\n key={icon?.type + index}\n src={`https://www.google.com/s2/favicons?domain=${icon?.url}&sz=24`}\n alt={`${icon.type} icon`}\n width=\"24\"\n height=\"24\"\n />\n </NsLink>\n </StyledSpan>\n );\n });\n }, [socialIcons]);\n\n const containerClass = `${className} ${isScrolled ? 'scrolled' : ''}`;\n const props = { shopTitle, shopDescription, socialTitleText, email, phone, showBadges, expirationDate };\n\n const getCharacterLimit = () => {\n if (window.innerWidth <= 380) return 50;\n if (window.innerWidth <= 415) return 56;\n if (window.innerWidth <= 460) return 62;\n return 80;\n };\n\n const shouldShowToggle = isMobile && shopDescription && shopDescription.length > getCharacterLimit();\n\n return isMobile ? (\n <MysiteHeroContainerMobile\n className={containerClass}\n data-testid=\"my-site-shop-header\"\n bannerProps={bannerProps}\n isCircularImage={isImageCircular}\n hasWhiteBackground={hasWhiteBackground}\n >\n <Box className=\"image-content-mobile\">\n {renderImageContent(imageDetails, bannerProps ?? {}, 'bg-image-mobile')}\n {renderMobileContent(props, isScrolled, renderSocialMediaIcons, isMobile, hasWhiteBackground)}\n </Box>\n {!isScrolled && (\n <Box className=\"expandable-description-mobile\">\n <Typography\n className={`description-content-mobile ${isDescriptionExpanded || !shouldShowToggle ? 'expanded' : 'collapsed'}`}\n >\n {shopDescription}\n </Typography>\n {shouldShowToggle && (\n <ToggleButtonMobile onClick={toggleDescription}>\n <ArrowDownIcon\n width={16}\n height={16}\n className={`arrow-icon-mobile ${isDescriptionExpanded ? 'expanded' : ''}`}\n />\n </ToggleButtonMobile>\n )}\n </Box>\n )}\n </MysiteHeroContainerMobile>\n ) : (\n <MysiteHeroContainer\n className={containerClass}\n data-testid=\"my-site-shop-header\"\n bannerProps={bannerProps}\n isCircularImage={isImageCircular}\n hasWhiteBackground={hasWhiteBackground}\n >\n {renderImageContent(imageDetails, bannerProps ?? {}, 'bg-image')}\n {renderDesktopContent(props, isScrolled, renderSocialMediaIcons, isMobile, hasWhiteBackground)}\n </MysiteHeroContainer>\n );\n}\n","import React from 'react';\nimport { styled } from '@nuskin/foundation-theme';\nimport { Box, BoxProps } from '@mui/material';\n\ninterface StyledBoxProps extends BoxProps {\n bannerProps?: {\n backgroundColor?: string;\n headlineFont?: string;\n paragraphFont?: string;\n };\n isCircularImage?: boolean;\n hasWhiteBackground?: boolean;\n}\n\ninterface BadgeProps extends BoxProps {\n hasWhiteBackground?: boolean;\n}\n\nconst getContactTextStyles = (hasWhiteBackground: boolean | undefined) => ({\n fontSize: '12px',\n fontStyle: 'normal' as const,\n fontWeight: '600',\n lineHeight: '16px',\n letterSpacing: '0.12px',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n '& a': {\n color: 'inherit',\n textDecoration: 'none',\n '&:hover': {\n textDecoration: 'underline',\n },\n },\n});\n\nconst getSocialTitleStyles = (hasWhiteBackground: boolean | undefined) => ({\n fontSize: '12px',\n fontStyle: 'normal' as const,\n fontWeight: '700',\n lineHeight: '16px',\n letterSpacing: '0.48px',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n textTransform: 'uppercase' as const,\n paddingLeft: '5px',\n});\n\nconst getSocialIconsStyles = () => ({\n display: 'flex',\n flexDirection: 'row' as const,\n gap: '10px',\n alignItems: 'center',\n});\n\nconst getContactTextMobileStyles = (hasWhiteBackground: boolean | undefined) => ({\n ...getContactTextStyles(hasWhiteBackground),\n paddingBottom: '11px',\n wordBreak: 'break-all' as const,\n overflowWrap: 'break-word' as const,\n paddingLeft: '5px',\n '& a': {\n color: 'inherit',\n textDecoration: 'none',\n },\n '@media (max-width: 420px)': {\n fontSize: '11px',\n lineHeight: '15px',\n paddingBottom: '8px',\n },\n '@media (max-width: 400px)': {\n fontSize: '10px',\n lineHeight: '14px',\n paddingBottom: '6px',\n },\n '@media (max-width: 375px)': {\n fontSize: '8px',\n lineHeight: '12px',\n paddingBottom: '4px',\n },\n});\n\nconst getSocialTitleMobileStyles = (hasWhiteBackground: boolean | undefined) => ({\n ...getSocialTitleStyles(hasWhiteBackground),\n marginBottom: '11px',\n transition: 'opacity 0.3s ease-out, transform 0.3s ease-out',\n opacity: 1,\n transform: 'translateY(0)',\n '@media (max-width: 420px)': {\n fontSize: '11px',\n lineHeight: '14px',\n marginBottom: '8px',\n },\n '@media (max-width: 400px)': {\n fontSize: '10px',\n lineHeight: '12px',\n marginBottom: '5px',\n },\n '@media (max-width: 375px)': {\n fontSize: '8px',\n lineHeight: '11px',\n marginBottom: '4px',\n },\n});\n\nexport const MysiteHeroContainer = styled((props: StyledBoxProps) => <Box {...props} />)(\n ({ bannerProps, isCircularImage, hasWhiteBackground }) => ({\n backgroundClip: 'border-box',\n display: 'flex',\n background: bannerProps?.backgroundColor ?? '#383838',\n position: 'relative',\n overflow: 'hidden',\n width: '100%',\n height: 'auto',\n flexDirection: 'row',\n alignItems: 'center',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'transform, opacity',\n transform: 'translateZ(0)',\n backfaceVisibility: 'hidden',\n '&.scrolled': {\n top: 0,\n left: 0,\n right: 0,\n boxShadow: '0 2px 8px rgba(0,0,0,0.2)',\n '.content': {\n paddingTop: '0',\n justifyContent: 'center',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.body-title': {\n fontSize: '26px',\n lineHeight: '34px',\n marginBottom: '0',\n fontStyle: 'normal',\n fontWeight: '400',\n fontFamily: bannerProps?.headlineFont ?? 'Lora',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n\n '.bg-image': {\n width: '90px',\n height: '90px',\n padding: isCircularImage ? '2px' : '0px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n objectFit: 'cover',\n objectPosition: 'center',\n },\n '.placeholder-image': {\n '& > div': {\n width: '90px',\n height: '90px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n },\n },\n '.content': {\n width: '70%',\n height: '100%',\n marginLeft: '2%',\n marginRight: 'auto',\n display: 'flex',\n flexDirection: 'column',\n position: 'relative',\n boxSizing: 'border-box',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.bg-image': {\n width: '252px',\n height: '252px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'width, height, transform',\n padding: isCircularImage ? '3px' : '0px',\n objectFit: 'cover',\n objectPosition: 'center',\n },\n '.placeholder-image': {\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'width, height, transform',\n '& > div': {\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n },\n '.body-title': {\n fontSize: '32px',\n lineHeight: '38px',\n marginBottom: '8px',\n fontWeight: '400',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n fontFamily: bannerProps?.headlineFont ?? 'Lora',\n paddingLeft: '5px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.body-text': {\n fontSize: '16px',\n marginBottom: '12px',\n fontStyle: 'normal',\n fontWeight: '400',\n lineHeight: '22px',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n fontFamily: bannerProps?.paragraphFont ?? 'inherit',\n display: '-webkit-box',\n WebkitBoxOrient: 'vertical',\n overflow: 'hidden',\n WebkitLineClamp: 3,\n textOverflow: 'ellipsis',\n paddingLeft: '5px',\n transition: 'opacity 0.3s ease-out, transform 0.3s ease-out',\n opacity: 1,\n transform: 'translateY(0)',\n },\n '.social-media': {\n display: 'flex',\n flexDirection: 'column',\n transition: 'opacity 0.3s ease-out, transform 0.3s ease-out',\n opacity: 1,\n transform: 'translateY(0)',\n },\n '.email-text': getContactTextStyles(hasWhiteBackground),\n '.phone-text': getContactTextStyles(hasWhiteBackground),\n '.social-title-text': {\n ...getSocialTitleStyles(hasWhiteBackground),\n marginBottom: '8px',\n },\n '.social-icons': {\n ...getSocialIconsStyles(),\n paddingBottom: '8px',\n },\n }),\n);\n\nexport const MysiteHeroContainerMobile = styled((props: StyledBoxProps) => <Box {...props} />)(\n ({ bannerProps, isCircularImage, hasWhiteBackground }) => ({\n backgroundClip: 'border-box',\n display: 'flex',\n background: bannerProps?.backgroundColor ?? '#383838',\n position: 'relative',\n overflow: 'hidden',\n width: '100%',\n flexDirection: 'column',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'transform, opacity',\n transform: 'translateZ(0)',\n backfaceVisibility: 'hidden',\n '&.scrolled': {\n top: 0,\n left: 0,\n right: 0,\n boxShadow: '0 2px 8px rgba(0,0,0,0.2)',\n '.content-mobile': {\n paddingTop: '5px',\n width: '60%',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.body-title-mobile': {\n fontSize: '18px',\n lineHeight: '28px',\n marginBottom: '0',\n fontStyle: 'normal',\n fontWeight: '400',\n fontFamily: bannerProps?.headlineFont ?? 'Lora',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.bg-image-mobile': {\n width: '75px',\n height: '75px',\n padding: isCircularImage ? '2px' : '0px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n objectFit: 'cover',\n objectPosition: 'center',\n },\n '.placeholder-image-mobile': {\n '& > div': {\n width: '75px !important',\n height: '75px !important',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n },\n },\n '.image-content-mobile': {\n display: 'flex',\n flexDirection: 'row',\n width: '100%',\n justifyContent: 'center',\n alignItems: 'center',\n },\n '.content-mobile': {\n width: '55%',\n height: '100%',\n paddingTop: '10px',\n paddingRight: '10px',\n marginLeft: '8px',\n marginRight: 'auto',\n display: 'flex',\n flexDirection: 'column',\n justifyContent: 'center',\n position: 'relative',\n boxSizing: 'border-box',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n '@media (max-width: 420px)': {\n paddingTop: '8px',\n width: '100%',\n },\n '@media (max-width: 400px)': {\n paddingTop: '6px',\n width: '100%',\n height: '100%',\n },\n '@media (max-width: 375px)': {\n paddingTop: '4px',\n width: '100%',\n height: '100%',\n },\n },\n '.bg-image-mobile': {\n width: '144px',\n height: '144px',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n objectFit: 'cover',\n objectPosition: 'center',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'width, height, transform',\n padding: isCircularImage ? '2px' : '0px',\n '@media (max-width: 420px)': {\n width: '120px',\n height: '120px',\n },\n '@media (max-width: 400px)': {\n width: '112px',\n height: '112px',\n },\n '@media (max-width: 375px)': {\n width: '90px',\n height: '90px',\n },\n },\n '.placeholder-image-mobile': {\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'width, height, transform',\n '& > div': {\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n width: '144px',\n height: '144px',\n '@media (max-width: 420px)': {\n width: '120px',\n height: '120px',\n },\n '@media (max-width: 400px)': {\n width: '110px !important',\n height: '110px !important',\n },\n '@media (max-width: 375px)': {\n width: '90px',\n height: '90px',\n },\n },\n },\n '.body-title-mobile': {\n fontSize: '22px',\n lineHeight: '28px',\n marginBottom: '13px',\n fontWeight: '400',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n fontStyle: 'normal',\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n fontFamily: bannerProps?.headlineFont ?? 'Lora',\n paddingLeft: '5px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n '@media (max-width: 420px)': {\n fontSize: '16px',\n lineHeight: '24px',\n marginBottom: '8px',\n },\n '@media (max-width: 400px)': {\n fontSize: '16px',\n lineHeight: '22px',\n marginBottom: '6px',\n },\n '@media (max-width: 375px)': {\n fontSize: '14px',\n lineHeight: '20px',\n marginBottom: '4px',\n },\n },\n '.body-text-mobile': {\n fontSize: '14px',\n padding: '20px 25px 20px 25px',\n fontStyle: 'normal',\n fontWeight: '400',\n lineHeight: '20px',\n color: '#252525',\n backgroundColor: '#E0E0E0',\n fontFamily: bannerProps?.paragraphFont ?? 'inherit',\n transition: 'all 0.25s cubic-bezier(0.4, 0, 0.2, 1)',\n opacity: 1,\n transform: 'translateY(0)',\n },\n '.expandable-description-mobile': {\n backgroundColor: '#E0E0E0',\n position: 'relative',\n },\n '.description-content-mobile': {\n fontSize: '14px',\n padding: '10px 15px',\n fontStyle: 'normal',\n fontWeight: '400',\n lineHeight: '20px',\n color: '#252525',\n fontFamily: bannerProps?.paragraphFont ?? 'inherit',\n transition: 'max-height 0.3s ease-in-out, opacity 0.3s ease-in-out',\n overflow: 'hidden',\n position: 'relative',\n '&.collapsed': {\n maxHeight: '50px',\n display: '-webkit-box',\n WebkitLineClamp: 2,\n WebkitBoxOrient: 'vertical',\n '&::after': {\n content: '\"\"',\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n height: '20px',\n background: 'linear-gradient(transparent, rgba(224, 224, 224, 0.8), #E0E0E0)',\n pointerEvents: 'none',\n },\n },\n '&.expanded': {\n maxHeight: 'none',\n whiteSpace: 'normal',\n display: 'block',\n '&::after': {\n display: 'none',\n },\n },\n },\n '.email-text-mobile': getContactTextMobileStyles(hasWhiteBackground),\n '.phone-text-mobile': getContactTextMobileStyles(hasWhiteBackground),\n '.social-title-text-mobile': getSocialTitleMobileStyles(hasWhiteBackground),\n '.social-icons-mobile': {\n ...getSocialIconsStyles(),\n paddingBottom: '10px',\n transition: 'opacity 0.3s ease-out, transform 0.3s ease-out',\n opacity: 1,\n transform: 'translateY(0)',\n '& img': {\n width: '24px',\n height: '24px',\n '@media (max-width: 400px)': {\n width: '20px',\n height: '20px',\n },\n '@media (max-width: 375px)': {\n width: '18px',\n height: '18px',\n },\n },\n '@media (max-width: 420px)': {\n paddingBottom: '8px',\n },\n '@media (max-width: 400px)': {\n paddingBottom: '4px',\n },\n '@media (max-width: 375px)': {\n paddingBottom: '3px',\n },\n },\n }),\n);\n\nexport const BadgeContainer = styled(Box)({\n display: 'flex',\n gap: '12px',\n marginBottom: '16px',\n paddingLeft: '5px',\n\n '&.mobile-badges': {\n flexDirection: 'column',\n gap: '8px',\n marginBottom: '12px',\n },\n\n '&.tablet-badges': {\n flexDirection: 'row',\n gap: '12px',\n marginBottom: '8px',\n },\n});\n\nexport const Badge = styled((props: BadgeProps) => <Box {...props} />)(({ hasWhiteBackground }) => ({\n backgroundColor: 'rgba(255, 255, 255, 0.2)',\n backdropFilter: 'blur(10px)',\n borderRadius: '20px',\n padding: '8px 16px',\n display: 'flex',\n alignItems: 'center',\n gap: '4px',\n border: '1px solid rgba(255, 255, 255, 0.3)',\n transition: 'all 0.3s ease',\n\n '&.mobile-badge': {\n padding: '6px 12px',\n borderRadius: '16px',\n fontSize: '12px',\n },\n\n '&.tablet-badge': {\n padding: '8px 16px',\n borderRadius: '20px',\n fontSize: '14px',\n },\n\n '&:hover': {\n backgroundColor: 'rgba(255, 255, 255, 0.3)',\n transform: 'translateY(-1px)',\n boxShadow: '0 4px 12px rgba(0, 0, 0, 0.1)',\n },\n\n '.badge-text': {\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n fontWeight: '400',\n opacity: 0.9,\n },\n\n '.badge-value': {\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n fontWeight: '600',\n },\n}));\nexport const ToggleButtonMobile = styled('button')({\n backgroundColor: '#E0E0E0',\n border: '1px solid #252525',\n borderRadius: '10px',\n cursor: 'pointer',\n width: '40px',\n height: '20px',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n margin: '10px auto 5px auto',\n transition: 'all 0.2s ease',\n '& .arrow-icon-mobile': {\n transition: 'transform 0.3s ease',\n '&.expanded': {\n transform: 'rotate(180deg)',\n },\n },\n});\nexport const StyledSpan = styled(Box)`\n background: none;\n border: 2px solid transparent;\n cursor: pointer;\n padding: 2px;\n display: flex;\n align-items: center;\n border-radius: 8px;\n transition: all 0.3s ease;\n\n &:hover {\n transform: scale(1.1);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n }\n\n &:focus,\n &:focus-within {\n outline: none;\n border-color: #007bff;\n box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25);\n }\n\n &:hover svg {\n fill: #ffffff;\n }\n`;\nexport const ImgTabIndex = styled('span')`\n line-height: 0.5;\n`;\n\nexport const ContactLink = styled('a')({\n fontSize: 'inherit',\n fontFamily: 'inherit',\n fontWeight: 'inherit',\n lineHeight: 'inherit',\n letterSpacing: 'inherit',\n color: 'inherit',\n textDecoration: 'none',\n '&:hover': {\n textDecoration: 'underline',\n },\n});\n\nexport const BadgeValue = styled('span')({});\n","import React from 'react';\nimport { Box } from '@mui/material';\n\ntype PlaceholderImageProps = {\n readonly width: string | number;\n readonly height: string | number;\n readonly backgroundColor: string;\n};\n\nexport const PlaceholderImage: React.FC<PlaceholderImageProps> = ({ width, height, backgroundColor }) => {\n return (\n <Box\n sx={{\n width,\n height,\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n backgroundColor,\n }}\n data-testid=\"placeholder-image\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"128\" height=\"129\" viewBox=\"0 0 128 129\" fill=\"none\">\n <g id=\"ns_logomark\">\n <path\n id=\"Vector\"\n d=\"M127.495 52.1946C125.663 47.9538 122.999 44.1171 119.661 40.9073C112.565 34.2835 102.562 31.7037 93.1175 34.0622C83.6733 36.4206 76.0882 43.3926 72.991 52.5619C71.4142 56.8414 70.6063 61.3627 70.6039 65.9196C70.6039 85.8227 70.6039 105.737 70.6039 125.662C70.6039 129.001 70.6039 129.001 66.9051 128.834C66.9051 128.2 66.9051 127.499 66.9051 126.831C66.9051 104.323 66.9051 81.8263 66.9051 59.3409C66.3415 45.3064 74.9302 32.5039 88.1888 27.6164C89.79 27.0612 91.4307 26.6259 93.0981 26.314C94.7114 25.98 96.4605 25.8465 98.0738 25.6461C96.0231 16.3291 78.9419 5.60953 65.0889 4.97504C50.3084 4.62252 36.6074 12.6365 29.7509 25.6461C31.331 25.8465 32.8779 25.9466 34.3569 26.2138C48.0999 28.544 58.7086 39.4998 60.5168 53.2298C60.8904 55.7285 61.0812 58.2508 61.0877 60.7769C61.0877 82.7507 61.0877 104.724 61.0877 126.697C61.0877 128.434 60.6842 129.169 58.8016 128.968C56.9183 128.768 57.1204 128.2 57.1204 126.965C57.1204 119.985 57.1204 113.006 57.1204 105.993C57.1204 92.1674 57.1204 78.3423 57.1204 64.5171C57.2385 56.3928 54.2457 48.5271 48.7477 42.5103C42.2429 35.5282 32.6539 32.2371 23.1959 33.7401C13.7379 35.243 5.66194 41.3411 1.67448 49.9906C1.23781 50.8254 0.867444 51.6937 0.262573 52.9293C5.79294 22.3996 32.4752 0.139867 63.7085 0.000656323C94.9411 -0.138555 121.824 21.8824 127.629 52.3616\"\n fill=\"#252525\"\n />\n <path\n id=\"Vector_2\"\n d=\"M86.0995 124.927C86.0995 124.293 86.0995 123.858 86.0995 123.425C86.0995 111.669 86.0995 100.049 86.0995 88.1269C85.8836 82.4231 88.0775 76.89 92.1523 72.8653C97.3131 67.9567 104.984 66.7091 111.452 69.7263C117.892 72.1185 122.166 78.225 122.178 85.0541C122.372 92.1747 119.781 99.0921 114.949 104.356C107.882 113.237 98.6134 120.141 88.05 124.392C87.4217 124.616 86.782 124.805 86.1335 124.96\"\n fill=\"#252525\"\n />\n <path\n id=\"Vector_3\"\n d=\"M41.8183 125.395C37.6149 123.224 33.6477 121.487 29.9828 119.25C21.5405 114.299 14.4778 107.331 9.43828 98.9796C6.53442 94.3985 5.34408 88.9493 6.07591 83.5852C7.056 75.2882 13.8859 68.8841 22.2829 68.3905C31.1231 67.2473 39.3527 73.0751 41.1455 81.7484C41.76 84.263 42.0762 86.8411 42.0868 89.4287C42.0868 100.516 42.0868 111.636 42.0868 122.823C42.0868 123.457 42.0867 124.059 41.8854 125.294\"\n fill=\"#252525\"\n />\n <path\n id=\"Vector_4\"\n d=\"M51.3337 127.431C47.9713 127.431 47.6681 127.198 47.6681 124.326V76.6386C48.1096 67.937 42.9747 59.906 34.8574 56.602C25.8992 52.8557 15.5485 54.8615 8.66523 61.6779C4.28638 66.6086 1.89197 72.9696 1.94049 79.5438C1.95423 80.2444 1.78037 80.9357 1.43588 81.5476C1.06552 79.9446 0.62885 78.2081 0.426687 76.7387C-0.724024 70.4463 0.471163 63.9529 3.78906 58.472C6.09291 54.6111 9.65016 51.6434 13.8762 50.0567C22.8587 46.555 32.9393 47.1785 41.4148 51.7598C47.6592 54.8694 51.5262 61.2882 51.3337 68.2232C51.5019 87.6249 51.3337 107.027 51.3337 126.396C51.3337 126.797 51.3337 127.164 51.3337 127.532\"\n fill=\"#252525\"\n />\n <path\n id=\"Vector_5\"\n d=\"M76.287 127.499V125.094C76.287 107.196 76.4883 89.2963 76.287 71.3966C76.0848 56.9034 84.2554 50.6588 95.7553 48.3545C101.535 47.2005 107.524 47.6393 113.071 49.6235C122.914 53.3319 128.994 63.1725 127.866 73.5672C127.631 76.2831 127.17 78.975 126.487 81.6151C125.916 78.2758 125.68 74.9364 124.772 71.597C122.808 64.3002 117.377 58.4174 110.228 55.8421C103.078 53.2668 95.1132 54.3239 88.8955 58.6734C83.0441 62.6207 79.7011 69.3237 80.086 76.3389C80.086 92.2349 80.086 108.131 80.086 124.026C80.086 127.366 80.086 127.366 76.2198 127.366\"\n fill=\"#252525\"\n />\n </g>\n </svg>\n </Box>\n );\n};\n","import React from 'react';\n\ntype ArrowDownIconProps = {\n readonly width?: string | number;\n readonly height?: string | number;\n readonly className?: string;\n};\n\nexport const ArrowDownIcon: React.FC<ArrowDownIconProps> = ({ width = 16, height = 16, className = '' }) => {\n return (\n <svg\n width={width}\n height={height}\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className={className}\n data-testid=\"arrow-down-icon\"\n >\n <path d=\"M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z\" />\n </svg>\n );\n};\n","export interface GTMEvent {\n event: string;\n\n [key: string]: unknown;\n}\n\ndeclare global {\n interface Window {\n dataLayer: unknown[];\n }\n}\n\nexport function trackGTMEvent(eventData: GTMEvent): void {\n if (typeof window === 'undefined') {\n return;\n }\n\n const url = window.location.href;\n const updatedEventData = { ...eventData };\n\n const prefix = url.includes('personal-offer') ? 'postorefront_' : 'mysite_';\n updatedEventData.event = prefix + eventData.event;\n\n try {\n if (window.dataLayer) {\n window.dataLayer.push(updatedEventData);\n } else {\n console.error('GTM dataLayer not available, but event logged');\n window.dataLayer = [];\n window.dataLayer.push(updatedEventData);\n }\n } catch (error) {\n console.error('Failed to track GTM event:', error);\n }\n}\n"]}
1
+ {"version":3,"sources":["/gitlab-runner-data/builds/nextgen-development/mysite/npm/react-mysite-elements/dist/index.mjs","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/@babel/runtime/helpers/interopRequireDefault.js","../node_modules/@mui/icons-material/utils/createSvgIcon.js","../node_modules/@mui/icons-material/CalendarToday.js","../node_modules/@mui/icons-material/Public.js","../node_modules/@mui/icons-material/TrendingUp.js","../node_modules/@mui/icons-material/TrendingDown.js","../node_modules/@mui/icons-material/Remove.js","../node_modules/@mui/icons-material/ShoppingCart.js","../node_modules/@mui/icons-material/MoreVert.js","../node_modules/@mui/icons-material/Visibility.js","../node_modules/@mui/icons-material/ArrowBack.js","../node_modules/@mui/icons-material/Language.js","../node_modules/@mui/icons-material/ArrowUpward.js","../node_modules/@mui/icons-material/ArrowDownward.js","../node_modules/@mui/icons-material/ChevronLeft.js","../node_modules/@mui/icons-material/ChevronRight.js","../src/common/card/NsProductCard.tsx","../src/common/card/styles/NsProductCard.Styled.tsx","../src/common/carousel/NsProductCarousel.tsx","../src/common/carousel/NsProductCarousel.styled.ts","../src/common/carousel/ProductTabCarousel.tsx","../src/common/Nav-Category-Navigation/NsCategoryNavigation.tsx","../src/common/Nav-Category-Navigation/NsCategoryNavigation.styled.tsx","../src/common/carousel/ProductTabCarousel.styled.tsx","../src/common/headers/MysiteHero.tsx","../src/common/headers/MysiteHero.styled.tsx","../src/common/icon/icons/PlaceholderImage.tsx","../src/common/icon/icons/ArrowDownIcon.tsx","../src/common/utils/gtmTracking.ts","../src/common/shopping-dashboard/ShoppingDashboard.styled.tsx","../src/common/shopping-dashboard/shared/DashboardHeader.tsx","../src/common/shopping-dashboard/shared/DashboardHeader.styled.tsx","../src/common/shopping-dashboard/TranslationKeys/ShoppingDashboardTranslationKeys.ts","../src/common/shopping-dashboard/shared/StatsCard.tsx","../src/common/shopping-dashboard/utils/trendUtils.tsx","../src/common/shopping-dashboard/shared/StatsCard.styled.tsx","../src/common/shopping-dashboard/shared/LoadingSkeletons.tsx","../src/common/shopping-dashboard/shared/LoadingSkeletons.styled.tsx","../src/common/shopping-dashboard/shared/TopProducts/TopSellingProductsList.tsx","../src/common/shopping-dashboard/shared/TopProducts/TopSellingProductsList.styled.tsx","../src/common/shopping-dashboard/shared/WidgetMenu.tsx","../src/common/shopping-dashboard/shared/WidgetMenu.styled.tsx","../src/common/shopping-dashboard/shared/ConversionRate/ConversionRateChart.tsx","../src/common/shopping-dashboard/shared/ConversionRate/ConversionRateChart.styled.tsx","../src/common/shopping-dashboard/shared/Signups/SignupsChart.tsx","../src/common/shopping-dashboard/shared/Signups/SignupsChart.styled.tsx","../src/common/shopping-dashboard/shared/TopCategories/TopCategoriesPieChart.tsx","../src/common/shopping-dashboard/shared/TopCategories/TopCategoriesPieChart.styled.tsx","../src/common/shopping-dashboard/ShoppingDashboard.tsx","../src/common/shopping-dashboard/MysiteDashboardWithNavigation.tsx","../src/common/shopping-dashboard/shared/TopProducts/ProductsFullView.tsx","../src/common/shopping-dashboard/shared/PageHeader.tsx","../src/common/shopping-dashboard/shared/PageHeader.styled.tsx","../src/common/shopping-dashboard/shared/DataTable.tsx","../src/common/shopping-dashboard/shared/DataTable.styled.tsx","../src/common/shopping-dashboard/shared/Pagination.tsx","../src/common/shopping-dashboard/shared/Pagination.styled.tsx","../src/common/shopping-dashboard/utils/dataUtils.ts","../src/common/shopping-dashboard/utils/dateConstants.ts","../src/common/shopping-dashboard/utils/dateFormat.ts","../src/common/shopping-dashboard/shared/FullViewComponents.styled.tsx","../src/common/shopping-dashboard/shared/TopProducts/ProductsFullView.styled.tsx","../src/common/shopping-dashboard/shared/useViewport.ts","../src/common/shopping-dashboard/shared/ConversionRate/ConversionRateFullView.tsx","../src/common/shopping-dashboard/shared/ConversionRate/ConversionRateFullView.styled.tsx","../src/common/shopping-dashboard/shared/Signups/SignupsFullView.tsx","../src/common/shopping-dashboard/shared/Signups/SignupsFullView.styled.tsx","../src/common/shopping-dashboard/shared/TopCategories/CategoriesFullView.tsx","../src/common/shopping-dashboard/shared/TopCategories/CategoriesFullView.styled.tsx","../src/common/shopping-dashboard/ProductOfferDashboard.styled.tsx","../src/common/shopping-dashboard/shared/TopPerformingOffers/TopPerformingOffersPieChart.tsx","../src/common/shopping-dashboard/TranslationKeys/ProductOfferDashboardTranslationKeys.ts","../src/common/shopping-dashboard/ProductOfferDashboard.tsx","../src/common/shopping-dashboard/PoDashboardWithNavigation.tsx","../src/common/shopping-dashboard/shared/TopPerformingOffers/TopPerformingOffersFullView.tsx","../src/common/shopping-dashboard/shared/TopPerformingOffers/TopPerformingOffersFullView.styled.tsx","../src/common/shopping-dashboard/shared/FilterBar.styled.tsx","../src/common/shopping-dashboard/shared/FilterBar.tsx","../src/common/shopping-dashboard/fixtures/mockDashboardData.ts","../src/common/shopping-dashboard/fixtures/mockProductOfferData.ts","../src/common/shopping-dashboard/utils/marketConstants.ts"],"names":["Cp","Object","create","di","defineProperty","vp","getOwnPropertyDescriptor","kp","getOwnPropertyNames","Sp","getPrototypeOf","Dp","prototype","hasOwnProperty","ve","e","require","Proxy","get","t","r","apply","arguments","Error","ie","exports","Tp","i","n","call","enumerable","te","__esModule","value","require_ReactPropTypesSecret","__commonJSMin","module","ReactPropTypesSecret","require_factoryWithThrowingShims","emptyFunction","emptyFunctionWithReset","$i","resetWarningCache","shim","props","propName","componentName","location","propFullName","secret","err","name","isRequired","getShim","ReactPropTypes","array","bigint","bool","func","number","object","string","symbol","any","arrayOf","element","elementType","instanceOf","node","objectOf","oneOf","oneOfType","shape","exact","checkPropTypes","PropTypes","require_prop_types","Ai","ReactIs","throwOnDirectAccess","require_interopRequireDefault","_interopRequireDefault","default","require_createSvgIcon","_utils","createSvgIcon","require_CalendarToday","ke","_createSvgIcon","Se","_jsxRuntime","_default","jsx","d","require_Public","require_TrendingUp","require_TrendingDown","require_Remove","require_ShoppingCart","require_MoreVert","require_Visibility","require_ArrowBack","require_Language","require_ArrowUpward","require_ArrowDownward","require_ChevronLeft","require_ChevronRight","useState","NsImage","styled","PriceComponent","ProductCardContainer","isMobile","ImageContainer","bgColor","DefaultImage","ProductTitle","ProductBadgeContainer","AddToCartButton","disabled","isHovered","CartIcon","useMediaQuery","jsxs","NsProductCard","productTitle","imageDetails","className","button","onCardClick","productStatusBadge","directSellerBadge","mySitePriceComponent","testId","isButtonHovered","setIsButtonHovered","handleImageError","target","noImageFallback","fallbackImage","src","onClick","tabIndex","children","onError","imageSrc","alt","imageAlt","areaLabel","width","title","showButton","buttonText","stopPropagation","onMouseEnter","onMouseLeave","height","viewBox","fill","xmlns","fillRule","clipRule","NsProductCard_default","useCallback","useRef","Slider","NsCarouselControl","Box","NsTypography","SlickContainer","ScrollableContainer","CardList","ControlsContainer","ViewAllWrapper","$isMobile","ProductCountWrapper","ArrowsWrapper","$isDisabled","Scrollablewrapper","CustomTypography","ViewAllLink","EmptyProductCategories","ControlsHeaderRow","ProductInfoWrapper","CategoryNameWrapper","ProductCardCarousel","entries","renderEntry","settings","showControlButtons","allEntryLabel","allEntryLink","categoryName","emptyProductMessage","productsCountLabel","isInitialDataLoading","history","sliderRef","prev","current","slickPrev","next","slickNext","renderProductEntry","entry","index","directSeller","sliderSettings","dots","infinite","speed","slidesToShow","Math","min","length","slidesToScroll","swipe","draggable","arrows","responsive","breakpoint","shouldShowNavigation","renderCarouselContent","map","ref","variant","preventDefault","push","viewAllLabel","viewAllUrl","useEffect","import_prop_types","Bi","React","Tabs","Tab","NsCategoryNavigationContainer","div","TabPanel","other","role","hidden","id","propTypes","Jo","NsCategoryNavigation","itemArray","controlledValue","onChange","Hi","internalValue","setInternalValue","orientation","event","newValue","item","label","categoryId","findIndex","content","NsSpinner","ProductTabCarouselContainer","TabsContainer","ContentContainer","LoadingContainer","NoTabsContainer","SpinnerContainer","ProductTabCarousel","fetchCategories","fetchProducts","showCustomCategory","emptyProductTabs","getCategoryId","categories","isLoadingInitialData","setIsLoadingInitialData","setCategories","selectedTab","setSelectedTab","products","setProducts","loading","setLoading","shouldShowSpinner","setShouldShowSpinner","checkForExistingSpinners","existingSpinners","document","querySelectorAll","then","finally","cat","_","ProductTabCarousel_default","useMemo","Typography","Tooltip","NsLink","getContactTextStyles","hasWhiteBackground","fontSize","fontStyle","fontWeight","lineHeight","letterSpacing","color","textDecoration","getSocialTitleStyles","textTransform","paddingLeft","getSocialIconsStyles","display","flexDirection","gap","alignItems","getContactTextMobileStyles","paddingBottom","wordBreak","overflowWrap","getSocialTitleMobileStyles","marginBottom","transition","opacity","transform","MysiteHeroContainer","bannerProps","isCircularImage","backgroundClip","background","backgroundColor","position","overflow","willChange","backfaceVisibility","top","left","right","boxShadow","paddingTop","justifyContent","fontFamily","headlineFont","padding","objectFit","objectPosition","marginLeft","marginRight","boxSizing","whiteSpace","textOverflow","paragraphFont","WebkitBoxOrient","WebkitLineClamp","MysiteHeroContainerMobile","paddingRight","maxHeight","bottom","pointerEvents","BadgeContainer","Badge","backdropFilter","borderRadius","border","ToggleButtonMobile","cursor","margin","StyledSpan","ImgTabIndex","ContactLink","BadgeValue","PlaceholderImage","sx","ArrowDownIcon","trackGTMEvent","eventData","window","url","href","updatedEventData","prefix","includes","dataLayer","console","error","Fragment","renderImageContent","placeholderClass","renderBadges","showBadges","expirationDate","renderMobileContent","isScrolled","renderSocialMediaIcons","shopTitle","socialTitleText","email","phone","renderContactLink","renderDesktopContent","shopDescription","arrow","checkIfImageIsCircular","Promise","resolve","reject","imageContext","Image","crossOrigin","onload","canvas","createElement","context","getContext","drawImage","isCircular","getImageData","data","every","corner","Array","slice","onerror","isWhiteOrNearWhite","hex","replace","toLowerCase","test","fullHex","split","char","join","Number","parseInt","substring","g","b","threshold","createContactClickHandler","contactType","contactValue","contact_type","contact_value","click_element","onKeyDown","key","globalThis","protocol","handlers","MysiteHero","socialIcons","setIsScrolled","isDescriptionExpanded","setIsDescriptionExpanded","setHasWhiteBackground","isImageCircular","setIsImageCircular","toggleDescription","debounceTimeout","lastScrollY","scrollY","currentScrollState","isTransitioning","lastUpdateTime","updateScrollState","newState","now","Date","clearTimeout","setTimeout","scrollTo","behavior","handleScroll","currentScrollY","abs","scrollingDown","scrollDownThreshold","scrollUpThreshold","initializeState","initialScrollY","shouldStartCompact","rafId","lastRafTime","throttledScrollHandler","requestAnimationFrame","addEventListener","passive","removeEventListener","cancelAnimationFrame","icon","social_platform","type","social_url","open","containerClass","getCharacterLimit","innerWidth","shouldShowToggle","DashboardContainer","StatsRow","WidgetContainer","TwoColumnGrid","ErrorContainer","import_CalendarToday","Pr","import_Public","yn","ColorUtils","getGenomeColor","HeaderContainer","theme","TitleSection","ShopTitle","DateRangeLabel","FiltersSection","FilterDropdownContainer","FilterLabel","StyledSelect","FilterIcon","LoadingIndicatorContainer","DesktopFiltersContainer","StyledCircularProgress","ShoppingDashboardTranslationKeys","fallback","stats","revenue","volume","visits","subtitle","dcSv","conversionRate","trend","increased","decreased","unchanged","details","filter","dateRange","last7days","last30days","last90days","thisMonth","dateRangeLabel","market","all","us","ca","jp","kr","au","nz","marketLabel","productSort","units","byUnits","byRevenue","byVolume","signupView","members","retail","brandAffiliates","showAll","showMembers","showRetail","showBrandAffiliates","categorySort","widget","topProducts","viewAll","empty","ariaLabel","titleAriaLabel","sortAriaLabel","noImageAriaLabel","unitsSuffix","revenueSuffix","dcSvSuffix","rank","formula","comparison","chartAriaLabel","filterAriaLabel","noData","noChange","tooltipOrders","tooltipVisits","ordersPerSiteVisits","signups","total","totalSignupsInPeriod","noTrendData","topCategories","menu","fullView","navigation","backToDashboard","backAriaLabel","dashboard","statsRow","dashboardFilters","loadingDashboard","dateRangeFilter","marketFilter","filterSuffix","columns","date","status","detailsTitle","orderId","customer","items","bv","orderTotal","totalSv","orderDetailsTitle","notAvailable","product","unitsSold","skuPrefix","noProducts","category","percentOfTotal","allCategoriesTitle","noCategoryData","dataTable","noDataAvailable","sortableColumn","pagination","previousPage","nextPage","goToPage","of","defaults","zeroTrend","noValue","getTranslation","DashboardHeader","dateRangeLabelProp","isLoading","onDateRangeChange","onMarketChange","handleDateRangeChange","newDateRange","handleMarketChange","newMarket","handleFilterKeyDown","blur","getDateRangeLabelText","as","htmlFor","Pn","CalendarTodayIcon","Rn","PublicIcon","import_TrendingUp","aa","import_TrendingDown","ia","import_Remove","Mn","getTrendIcon","direction","On","TrendingUpIcon","Ln","TrendingDownIcon","Vn","RemoveIcon","getTrendColor","StatsCardContainer","StatsTitle","StatsValueContainer","StatsValue","StatsSubtitle","TrendContainer","TrendIcon","TrendText","StatsCardHeader","Skeleton","SkeletonCard","SkeletonHeader","SkeletonRow","StatsCardWrapper","StatsCardHeaderRow","StatsCardBody","StatsCardSubtitle","ProductRowInfo","ProductRowMetrics","ChartMetricRow","ChartMetricTrend","ChartAreaSkeleton","PieChartLayout","PieCircleSkeleton","LegendList","LegendRowWrapper","LegendRowInfo","DashboardLayout","DashboardHeaderRow","DashboardFilterGroup","StatsGrid","WidgetGrid","FullViewLayout","FullViewMetricCard","FullViewMetricCenter","FullViewChartArea","FullViewTableCard","FullViewTableRow","SummaryCardsGrid","StatsCardSkeleton","ProductRowSkeleton","ProductsListSkeleton","rowKey","ChartWidgetSkeleton","LegendRowSkeleton","CategoriesPieChartSkeleton","FullViewChartSkeleton","FullViewTableSkeleton","StatsCardComponent","trendDirection","trendValue","getTrendAriaLabel","directionText","StatsCard","memo","displayName","import_ShoppingCart","sl","ProductsListContainer","WidgetHeader","HeaderActionsContainer","WidgetTitle","SortDropdown","ProductsList","ProductItem","ProductRank","ProductImage","ProductImagePlaceholder","ProductInfo","ProductName","ProductSubtitle","ProductMetrics","ProductValue","ProductTrend","EmptyState","EmptyStateText","import_MoreVert","Sl","import_Visibility","Dl","Menu","MenuItem","ListItemIcon","ListItemText","IconButton","StyledIconButton","WidgetMenu","widgetId","onFullView","anchorEl","setAnchorEl","handleClick","currentTarget","handleClose","handleFullView","size","Rl","MoreVertIcon","onClose","MenuListProps","anchorOrigin","vertical","horizontal","transformOrigin","Ml","VisibilityIcon","TopSellingProductsListComponent","maxProducts","onSortChange","onTitleClick","handleSortChange","newSort","formatValue","sortBy","toLocaleString","getSubtitle","getTrendValue","getTrendDirection","startsWith","displayedProducts","rankLabel","trendLabel","getTrendDirectionLabel","Ol","ShoppingCartIcon","imageUrl","toUpperCase","TopSellingProductsList","LineChart","Line","XAxis","YAxis","CartesianGrid","ResponsiveContainer","ConversionRateContainer","ChartHeader","TitleRow","ChartTitle","FilterDropdown","MetricDisplay","MetricValue","MetricTrend","FormulaDisplay","ChartContainer","TooltipContainer","TooltipLabel","TooltipValue","TooltipDetails","MONTH_MAP","Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec","CHART_MARGIN","AXIS_TICK","LINE_DOT","ACTIVE_DOT","rateTickFormatter","formatShortDate","dateStr","parts","CustomTooltip","active","payload","rate","toFixed","orders","siteVisits","ConversionRateChartComponent","conversionData","conversionFilter","onFilterChange","handleFilterChange","newFilter","noDataText","noChangeText","currentRate","trendInfo","latestRate","previousRate","change","percentageChange","formattedChange","formattedData","shortDate","minHeight","strokeDasharray","dataKey","tick","tickLine","interval","tickFormatter","domain","stroke","strokeWidth","dot","activeDot","ConversionRateChart","SignupsContainer","Legend","LegendItem","LegendColor","LegendLabel","SERIES_COLORS","SignupsChartComponent","signupData","onViewChange","handleViewChange","newView","totalSignups","latestTotal","previousTotal","totalLabel","membersLabel","retailLabel","brandAffiliatesLabel","SignupsChart","PieChart","Pie","Cell","CategoriesContainer","ChartAndLegendContainer","ChartWrapper","DonutCenterOverlay","DonutCenterLabel","DonutCenterValue","DonutCenterTrend","LegendContainer","LegendInfo","LegendName","LegendValue","LegendPercentage","parseTrendPercent","cleanedValue","trim","parsedValue","isFinite","tooltipFormatter","TopCategoriesPieChartComponent","nextSortedCategories","sort","a","percentage","nextTotalRevenue","reduce","sum","weightedRevenueTrend","accumulator","weightedSum","weight","averageRevenueTrend","nextTrendDirection","nextFormattedTrend","sortedCategories","totalRevenue","formattedTrend","cx","cy","innerRadius","outerRadius","nameKey","paddingAngle","formatter","TopCategoriesPieChart","EMPTY_TOP_PRODUCTS","EMPTY_CONVERSION_DATA","EMPTY_SIGNUP_DATA","EMPTY_CATEGORIES","ShoppingDashboard","onProductSortChange","onSignupViewChange","onConversionFilterChange","onCategorySortChange","onProductsTitleClick","onConversionTitleClick","onSignupsTitleClick","onCategoriesToTitleClick","resolvedTopProducts","resolvedConversionData","resolvedSignupData","resolvedCategories","metrics","import_ArrowBack","os","import_Language","PageHeaderWrapper","BackButtonWrapper","BackButton","LeftSection","Title","DateRange","MobileDateRange","FilterWrapper","MobileTitleWrapper","MobileTitle","PageHeader","onBack","filters","renderFilterIcon","iconType","ys","ws","LanguageIcon","xs","ArrowBackIcon","options","option","import_ArrowUpward","Cs","import_ArrowDownward","vs","TableContainer","Table","TableHeader","TableHeaderCell","sortable","TableBody","TableRow","TableCell","EmptyTableCell","SortIconContainer","isActive","DataTable","onSort","sortColumn","sortDirection","getRowKey","handleSort","columnKey","handleKeyDown","getAriaSort","column","Vs","ArrowDownwardIcon","Ls","ArrowUpwardIcon","colSpan","row","rowIndex","render","import_ChevronLeft","$s","import_ChevronRight","Fs","PaginationContainer","PageButton","PageInfo","NavButton","Pagination","currentPage","totalPages","onPageChange","itemsPerPage","totalItems","handlePrevious","handleNext","action","pageNumbers","from","pages","startItem","endItem","goToPageLabel","As","ChevronLeftIcon","page","zs","ChevronRightIcon","calculateTotalPages","ceil","paginateItems","startIndex","endIndex","sortByNumericProperty","aVal","bVal","calculatePercentage","decimalPlaces","DAYS_MAP","DATE_RANGE_LABELS","getDaysFromDateRange","getDateRangeLabel","formatDateRangeLabel","getMonth","getDate","formatDisplayDate","formatDateRange","start","end","formatISODate","toISOString","PageContainer","MetricChartCardSection","shadows","MetricSection","palette","text","primary","success","main","secondary","ComparisonText","ChartSection","TableSection","withCard","MobileCardName","MobileCardSubtext","MobileCardDetail","MobileCardStatus","warning","ProductImageCell","ProductSku","MobileCardsContainer","DesktopTableContainer","MobileProductCard","divider","MobileCardHeader","MobileProductRank","MobileProductImage","MobileProductDetails","MobileProductName","MobileProductSku","MobileMetricsGrid","MobileMetricItem","MobileMetricLabel","MobileMetricValue","MOBILE_VIEWPORT_QUERY","useIsMobileViewport","noSsr","mapProductToRow","sku","padStart","image","ProductsFullView","setCurrentPage","setSortColumn","setSortDirection","isMobileView","handleBack","productRows","sortedRows","paginatedRows","MobileOrderCard","MobileOrderHeader","MobileCustomerInfo","MobileCustomerName","MobileOrderDate","MobileOrderId","MobileOrderMetrics","MobileOrdersContainer","ComparisonTextMobile","ConversionRateFullView","firstRate","getConversionFilterLabel","conversionFilterLabel","paginatedOrders","getChartColor","xd","yd","order","customerName","MobileSignupsContainer","MobileSignupCard","SignupTrendChartContainer","toNumeric","parsed","SignupsFullView","normalizedSignupData","point","rawPoint","brandAffiliate","brand_affiliates","brand_affiliate","signupTotal","first","last","hasSignupTrendData","paginatedSignups","Dd","Td","connectNulls","signup","muiStyled","SummaryItemRow","SummaryItemInfo","SummaryItemName","SummaryItemSubtext","SummaryItemPercentage","TopSection","SummaryContainer","SummaryItem","ColorDot","dotColor","SummaryInfo","SummaryName","SummaryValue","SummaryPercentage","MobileCategoriesContainer","MobileCategoryCard","CategoriesFullView","totalRevenueTrendDirection","totalRevenueTrend","paginatedCategories","DEFAULT_HISTORY_STATE_KEY","EMPTY_ORDERS","EMPTY_SIGNUPS","isRecord","isMysiteDashboardView","readViewFromState","state","stateKey","view","buildStateWithView","buildLocationWithState","pathname","search","hash","MysiteDashboardWithNavigation","initialDateRange","initialMarket","initialProductSort","initialSignupView","initialConversionFilter","initialCategorySort","historyAdapter","historyStateKey","resetToDashboardOnMount","currentView","setCurrentView","hasIntraDashboardHistoryRef","setDateRange","setMarket","setProductSort","setSignupView","setConversionFilter","setCategorySort","resolvedOrders","resolvedSignups","updateView","readCurrentView","writeCurrentView","mode","nextState","nextLocation","replaceState","pushState","listen","nextView","handlePopState","handleOpenFullView","goBack","back","nextDateRange","nextMarket","handleProductSortChange","nextProductSort","handleSignupViewChange","nextSignupView","handleConversionFilterChange","nextFilter","handleCategorySortChange","nextSort","handleProductsTitleClick","handleConversionTitleClick","handleSignupsTitleClick","handleCategoriesTitleClick","PoDashboardContainer","TopChartsRow","StatsCardStack","BottomChartsRow","ProductOfferDashboardTranslationKeys","offersPurchased","trendUp","trendDown","trendNeutral","comparedTo","offerSort","overall","emptyState","topPerformingOffers","statsCard","conversionChart","topOffers","widgetMenu","filterDateRange","filterMarket","backButton","columnName","columnRevenue","columnPercentage","columnTrend","trendZero","TopPerformingOffersPieChartComponent","offers","nextSortedOffers","offer","sortedOffers","TopPerformingOffersPieChart","EMPTY_TOP_OFFERS","ProductOfferDashboard","dashboardTitle","onOfferSortChange","onOffersTitleClick","resolvedTopOffers","selectedMarket","MobileOffersContainer","MobileOfferCard","TopPerformingOffersFullView","paginatedOffers","isProductOfferDashboardView","PoDashboardWithNavigation","allProducts","allOffers","initialOfferSort","setOfferSort","resolvedAllProducts","resolvedAllOffers","handleOfferSortChange","handleOffersTitleClick","FilterContainer","FilterBar","mockStats","mockTopProducts","mockConversionData","setDate","mockSignupData","months","floor","mockCategories","mockOrders","firstNames","lastNames","String","toLocaleDateString","month","day","year","customerType","mockSignupDetails","types","mockProductOfferStats","mockProductOfferStatsPositiveTrend","mockProductOfferStatsNegativeTrend","mockProductOfferStatsNeutralTrend","mockProductOfferStatsZeroOffers","mockTopOffers","MARKET_MULTIPLIERS","getMarketMultiplier","applyMarketMultiplier","round","getMarketDisplayName","Zr","po","zo","Es","Bs","Ro","Ge","zf","xp","df","fn","yr","xr","se","Je","If","Yo","ProductCarousel","ei","R","qp","Io","Hr","o","ba","Yr","ft","Na","oi","gr","so","Ke","Hf","ug","Ze","fg","de","Ur","mg","Hs","Kr","gg","_f","yp","Tc","ut","hp","ni","li","yo","mp","bp","fp","Ef","ii","Qe","cg"],"mappings":"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","sourcesContent":["var Cp=Object.create;var di=Object.defineProperty;var vp=Object.getOwnPropertyDescriptor;var kp=Object.getOwnPropertyNames;var Sp=Object.getPrototypeOf,Dp=Object.prototype.hasOwnProperty;var ve=(e=>typeof require<\"u\"?require:typeof Proxy<\"u\"?new Proxy(e,{get:(t,r)=>(typeof require<\"u\"?require:t)[r]}):e)(function(e){if(typeof require<\"u\")return require.apply(this,arguments);throw Error('Dynamic require of \"'+e+'\" is not supported')});var ie=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var Tp=(e,t,r,i)=>{if(t&&typeof t==\"object\"||typeof t==\"function\")for(let n of kp(t))!Dp.call(e,n)&&n!==r&&di(e,n,{get:()=>t[n],enumerable:!(i=vp(t,n))||i.enumerable});return e};var te=(e,t,r)=>(r=e!=null?Cp(Sp(e)):{},Tp(t||!e||!e.__esModule?di(r,\"default\",{value:e,enumerable:!0}):r,e));var $i=ie((km,Vi)=>{\"use strict\";var Ip=\"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED\";Vi.exports=Ip});var Ai=ie((Sm,Ii)=>{\"use strict\";var Ap=$i();function Fi(){}function Ni(){}Ni.resetWarningCache=Fi;Ii.exports=function(){function e(i,n,s,u,m,w){if(w!==Ap){var k=new Error(\"Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types\");throw k.name=\"Invariant Violation\",k}}e.isRequired=e;function t(){return e}var r={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:Ni,resetWarningCache:Fi};return r.PropTypes=r,r}});var Bi=ie((Pm,zi)=>{\"use strict\";zi.exports=Ai()();var Dm,Tm});var ke=ie((Ph,Po)=>{\"use strict\";function lc(e){return e&&e.__esModule?e:{default:e}}Po.exports=lc,Po.exports.__esModule=!0,Po.exports.default=Po.exports});var Se=ie(Tr=>{\"use strict\";\"use client\";Object.defineProperty(Tr,\"__esModule\",{value:!0});Object.defineProperty(Tr,\"default\",{enumerable:!0,get:function(){return sc.createSvgIcon}});var sc=ve(\"@mui/material/utils\")});var Pr=ie(ea=>{\"use strict\";\"use client\";var dc=ke();Object.defineProperty(ea,\"__esModule\",{value:!0});ea.default=void 0;var pc=dc(Se()),cc=ve(\"react/jsx-runtime\"),Mh=ea.default=(0,pc.default)((0,cc.jsx)(\"path\",{d:\"M20 3h-1V1h-2v2H7V1H5v2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2m0 18H4V8h16z\"}),\"CalendarToday\")});var yn=ie(ta=>{\"use strict\";\"use client\";var uc=ke();Object.defineProperty(ta,\"__esModule\",{value:!0});ta.default=void 0;var gc=uc(Se()),fc=ve(\"react/jsx-runtime\"),Lh=ta.default=(0,gc.default)((0,fc.jsx)(\"path\",{d:\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m-1 17.93c-3.95-.49-7-3.85-7-7.93 0-.62.08-1.21.21-1.79L9 15v1c0 1.1.9 2 2 2zm6.9-2.54c-.26-.81-1-1.39-1.9-1.39h-1v-3c0-.55-.45-1-1-1H8v-2h2c.55 0 1-.45 1-1V7h2c1.1 0 2-.9 2-2v-.41c2.93 1.19 5 4.06 5 7.41 0 2.08-.8 3.97-2.1 5.39\"}),\"Public\")});var aa=ie(oa=>{\"use strict\";\"use client\";var bc=ke();Object.defineProperty(oa,\"__esModule\",{value:!0});oa.default=void 0;var xc=bc(Se()),yc=ve(\"react/jsx-runtime\"),_h=oa.default=(0,xc.default)((0,yc.jsx)(\"path\",{d:\"m16 6 2.29 2.29-4.88 4.88-4-4L2 16.59 3.41 18l6-6 4 4 6.3-6.29L22 12V6z\"}),\"TrendingUp\")});var ia=ie(ra=>{\"use strict\";\"use client\";var wc=ke();Object.defineProperty(ra,\"__esModule\",{value:!0});ra.default=void 0;var Cc=wc(Se()),vc=ve(\"react/jsx-runtime\"),jh=ra.default=(0,Cc.default)((0,vc.jsx)(\"path\",{d:\"m16 18 2.29-2.29-4.88-4.88-4 4L2 7.41 3.41 6l6 6 4-4 6.3 6.29L22 12v6z\"}),\"TrendingDown\")});var Mn=ie(na=>{\"use strict\";\"use client\";var kc=ke();Object.defineProperty(na,\"__esModule\",{value:!0});na.default=void 0;var Sc=kc(Se()),Dc=ve(\"react/jsx-runtime\"),Uh=na.default=(0,Sc.default)((0,Dc.jsx)(\"path\",{d:\"M19 13H5v-2h14z\"}),\"Remove\")});var sl=ie(ga=>{\"use strict\";\"use client\";var Ac=ke();Object.defineProperty(ga,\"__esModule\",{value:!0});ga.default=void 0;var zc=Ac(Se()),Bc=ve(\"react/jsx-runtime\"),ub=ga.default=(0,zc.default)((0,Bc.jsx)(\"path\",{d:\"M7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2M1 2v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H5.21l-.94-2zm16 16c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2\"}),\"ShoppingCart\")});var Sl=ie(ma=>{\"use strict\";\"use client\";var Hc=ke();Object.defineProperty(ma,\"__esModule\",{value:!0});ma.default=void 0;var _c=Hc(Se()),Wc=ve(\"react/jsx-runtime\"),hb=ma.default=(0,_c.default)((0,Wc.jsx)(\"path\",{d:\"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2m0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2\"}),\"MoreVert\")});var Dl=ie(ha=>{\"use strict\";\"use client\";var jc=ke();Object.defineProperty(ha,\"__esModule\",{value:!0});ha.default=void 0;var Kc=jc(Se()),Uc=ve(\"react/jsx-runtime\"),xb=ha.default=(0,Kc.default)((0,Uc.jsx)(\"path\",{d:\"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5M12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5m0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3\"}),\"Visibility\")});var os=ie(Ia=>{\"use strict\";\"use client\";var ju=ke();Object.defineProperty(Ia,\"__esModule\",{value:!0});Ia.default=void 0;var Ku=ju(Se()),Uu=ve(\"react/jsx-runtime\"),Mx=Ia.default=(0,Ku.default)((0,Uu.jsx)(\"path\",{d:\"M20 11H7.83l5.59-5.59L12 4l-8 8 8 8 1.41-1.41L7.83 13H20z\"}),\"ArrowBack\")});var as=ie(Aa=>{\"use strict\";\"use client\";var qu=ke();Object.defineProperty(Aa,\"__esModule\",{value:!0});Aa.default=void 0;var Gu=qu(Se()),Yu=ve(\"react/jsx-runtime\"),Lx=Aa.default=(0,Gu.default)((0,Yu.jsx)(\"path\",{d:\"M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2m6.93 6h-2.95c-.32-1.25-.78-2.45-1.38-3.56 1.84.63 3.37 1.91 4.33 3.56M12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96M4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2 0 .68.06 1.34.14 2zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56-1.84-.63-3.37-1.9-4.33-3.56m2.95-8H5.08c.96-1.66 2.49-2.93 4.33-3.56C8.81 5.55 8.35 6.75 8.03 8M12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96M14.34 14H9.66c-.09-.66-.16-1.32-.16-2 0-.68.07-1.35.16-2h4.68c.09.65.16 1.32.16 2 0 .68-.07 1.34-.16 2m.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95c-.96 1.65-2.49 2.93-4.33 3.56M16.36 14c.08-.66.14-1.32.14-2 0-.68-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2z\"}),\"Language\")});var Cs=ie(za=>{\"use strict\";\"use client\";var Zu=ke();Object.defineProperty(za,\"__esModule\",{value:!0});za.default=void 0;var Qu=Zu(Se()),Xu=ve(\"react/jsx-runtime\"),Bx=za.default=(0,Qu.default)((0,Xu.jsx)(\"path\",{d:\"m4 12 1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8z\"}),\"ArrowUpward\")});var vs=ie(Ba=>{\"use strict\";\"use client\";var eg=ke();Object.defineProperty(Ba,\"__esModule\",{value:!0});Ba.default=void 0;var tg=eg(Se()),og=ve(\"react/jsx-runtime\"),Hx=Ba.default=(0,tg.default)((0,og.jsx)(\"path\",{d:\"m20 12-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8z\"}),\"ArrowDownward\")});var $s=ie(Ea=>{\"use strict\";\"use client\";var rg=ke();Object.defineProperty(Ea,\"__esModule\",{value:!0});Ea.default=void 0;var ig=rg(Se()),ng=ve(\"react/jsx-runtime\"),Yx=Ea.default=(0,ig.default)((0,ng.jsx)(\"path\",{d:\"M15.41 7.41 14 6l-6 6 6 6 1.41-1.41L10.83 12z\"}),\"ChevronLeft\")});var Fs=ie(Ha=>{\"use strict\";\"use client\";var lg=ke();Object.defineProperty(Ha,\"__esModule\",{value:!0});Ha.default=void 0;var sg=lg(Se()),dg=ve(\"react/jsx-runtime\"),Zx=Ha.default=(0,sg.default)((0,dg.jsx)(\"path\",{d:\"M10 6 8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z\"}),\"ChevronRight\")});import{useState as Pp}from\"react\";import{NsImage as Rp}from\"@nuskin/foundation-ui-components\";import{styled as Rt}from\"@nuskin/foundation-theme\";var pi=Rt(\"div\")`\n width: 200px;\n text-align: left;\n margin-bottom: 5px;\n`,ci=Rt(\"button\")`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: space-between;\n width: 240px;\n height: ${e=>e.isMobile?\"410px\":\"513px\"};\n overflow: hidden;\n cursor: pointer;\n border: 1px solid #ededed;\n background: var(--color-primary-n-10-primary-white, #fff);\n`,ui=Rt(\"div\")`\n width: '240px';\n height: '240px';\n background: ${e=>e.bgColor??\"#f5f5f5\"};\n border-radius: 8px;\n overflow: hidden;\n margin-bottom: 0;\n display: flex;\n align-items: normal;\n justify-content: center;\n position: relative;\n @media (max-width: 560px) {\n width: 200px;\n height: 200px;\n align-items: unset;\n }\n`,gi=Rt(\"img\")`\n width: 100%;\n height: 100%;\n object-fit: cover;\n border-radius: 8px;\n display: block;\n`,fi=Rt(\"div\")`\n width: 200px;\n margin-top: 16px;\n max-height: 66px;\n text-align: left;\n font-size: 16px;\n font-family: 'Inter', sans-serif;\n font-weight: 400;\n line-height: 22px;\n overflow: hidden;\n color: #666;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n text-overflow: ellipsis;\n @media (max-width: 560px) {\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n margin-top: 5px;\n max-height: 54px;\n line-height: 18px;\n }\n`,br=Rt(\"div\")`\n width: 200px;\n text-align: left;\n margin-bottom: 12px;\n @media (max-width: 560px) {\n margin-bottom: 8px;\n }\n`,mi=Rt(\"button\")`\n width: 200px;\n height: 40px;\n border-radius: 4px;\n display: flex;\n align-items: center;\n gap: 10px;\n font-family: 'Inter', sans-serif;\n font-size: 14px;\n font-weight: 600;\n line-height: 20px;\n letter-spacing: 0.14px;\n text-transform: none;\n justify-content: flex-start;\n padding-left: 31px;\n overflow: hidden;\n white-space: normal;\n word-break: break-word;\n overflow-wrap: break-word;\n text-overflow: ellipsis;\n margin-top: 8px;\n margin-bottom: 10px;\n -webkit-appearance: none;\n -webkit-tap-highlight-color: transparent;\n\n color: ${e=>e.disabled?\"#999\":\"#fff\"};\n background-color: ${e=>e.disabled?\"#e0e0e0\":!e.isMobile&&e.isHovered?\"#888\":\"#000\"};\n border: ${e=>e.disabled?\"1px solid #ccc\":\"none\"};\n cursor: ${e=>e.disabled?\"not-allowed\":\"pointer\"};\n opacity: ${e=>e.disabled?.6:1};\n transition: ${e=>e.isMobile?\"none\":\"all 0.3s ease\"};\n\n @media (max-width: 560px) {\n margin: 5px 0;\n }\n`,hi=Rt(\"span\")`\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n display: inline-block;\n background: none;\n transition: all 0.3s ease;\n opacity: ${e=>e.disabled?.5:1};\n`;import{useMediaQuery as Mp}from\"@mui/material\";import{jsx as ot,jsxs as bi}from\"react/jsx-runtime\";var Op=({productTitle:e,imageDetails:t,className:r,button:i,onCardClick:n,productStatusBadge:s,directSellerBadge:u,mySitePriceComponent:m,testId:w})=>{let[k,g]=Pp(!1),d=Mp(\"(max-width: 560px)\"),b=x=>{let S=x.target,p=t?.fallbackImage;p&&S.src!==p&&(S.src=p)};return bi(ci,{className:r,onClick:n,tabIndex:0,\"data-testid\":\"product-card\",isMobile:d,children:[ot(ui,{bgColor:t?.bgColor,onError:b,children:t?.imageSrc?ot(Rp,{\"data-testid\":w??\"test-product-image\",className:t.className??\"\",src:t.imageSrc,alt:t.imageAlt,\"aria-label\":t.areaLabel??t.imageAlt,width:\"100%\"}):ot(gi,{alt:\"\"})}),ot(fi,{title:e,\"data-testid\":\"product-title\",children:e}),u&&ot(br,{children:u}),ot(br,{children:s}),ot(pi,{children:m}),i?.showButton&&bi(mi,{tabIndex:0,\"aria-roledescription\":\":\",\"aria-label\":i.buttonText||\"ADD TO CART\",\"data-testid\":\"add-to-cart-button\",disabled:i?.disabled??!1,isMobile:d,isHovered:k,onClick:x=>{x.stopPropagation(),i?.disabled||i.onClick?.()},onMouseEnter:()=>{!d&&!i?.disabled&&g(!0)},onMouseLeave:()=>{d||g(!1)},children:[ot(hi,{className:\"cart-icon\",disabled:i?.disabled,children:ot(\"svg\",{width:\"24\",height:\"22\",viewBox:\"0 0 24 22\",fill:\"none\",xmlns:\"http://www.w3.org/2000/svg\",children:ot(\"path\",{fillRule:\"evenodd\",clipRule:\"evenodd\",d:\"M0 1.86358C0 1.26109 0.488416 0.772675 1.09091 0.772675H3.48173C4.51054 0.772675 5.39955 1.49136 5.61511 2.49733L5.71309 2.95456H22.9091C23.245 2.95456 23.5622 3.10933 23.7689 3.37411C23.9757 3.63889 24.0489 3.98415 23.9674 4.31005L22.4053 10.5583C21.9197 12.5009 20.1743 13.8636 18.172 13.8636H8.05068L8.28444 14.9546H20.7273C21.3298 14.9546 21.8182 15.443 21.8182 16.0455C21.8182 16.648 21.3298 17.1364 20.7273 17.1364H19.6364H8.18182H7.40252C6.88811 17.1364 6.4436 16.777 6.33582 16.274L3.76449 4.27405L3.48173 2.95449H1.09091C0.488416 2.95449 0 2.46608 0 1.86358ZM8.18182 17.1364C6.97683 17.1364 6 18.1132 6 19.3182C6 20.5232 6.97683 21.5 8.18182 21.5C9.3868 21.5 10.3636 20.5232 10.3636 19.3182C10.3636 18.1132 9.3868 17.1364 8.18182 17.1364ZM19.6364 17.1364C18.4314 17.1364 17.4545 18.1132 17.4545 19.3182C17.4545 20.5232 18.4314 21.5 19.6364 21.5C20.8413 21.5 21.8182 20.5232 21.8182 19.3182C21.8182 18.1132 20.8413 17.1364 19.6364 17.1364ZM7.58317 11.6818H18.172C19.1732 11.6818 20.0459 11.0005 20.2887 10.0292L21.5119 5.13638H6.18062L7.58317 11.6818Z\",fill:i?.disabled?\"#999\":\"#ffffff\"})})}),i.buttonText||\"ADD TO CART\"]})]})},xr=Op;import{useCallback as Li,useRef as Vp}from\"react\";import $p from\"react-slick\";import Fp from\"@mui/material/useMediaQuery\";import{NsCarouselControl as Np}from\"@nuskin/foundation-ui-components\";import{styled as Pe}from\"@nuskin/foundation-theme\";import ko from\"@mui/material/Box\";import{NsTypography as Lp}from\"@nuskin/foundation-ui-components\";var xi=Pe(ko)`\n padding: 30px 0 60px;\n width: 100%;\n margin: auto;\n margin-top: 50px;\n position: relative;\n\n .slick-list {\n padding-left: 24px;\n padding-right: 24px;\n }\n .slick-slide {\n display: flex;\n justify-content: center;\n padding: 0 12px;\n box-sizing: border-box;\n }\n .slick-prev,\n .slick-next {\n display: none !important;\n }\n\n @media (max-width: 1200px) {\n max-width: 1024px;\n .slick-list {\n padding-left: 12px;\n padding-right: 12px;\n }\n .slick-slide {\n padding: 0 6px;\n }\n }\n @media (max-width: 700px) {\n max-width: 100vw;\n padding: 10px 0 50px;\n .slick-list {\n padding-left: 4px;\n padding-right: 4px;\n }\n .slick-slide {\n padding: 0 2px;\n }\n }\n @media (max-width: 560px) {\n padding: 10px 0 10px;\n margin-top: 25px;\n }\n`,yi=Pe(\"div\")`\n overflow-x: auto;\n display: flex;\n scroll-snap-type: x mandatory;\n -webkit-overflow-scrolling: touch;\n gap: 16px;\n padding: 0 8px 16px;\n width: 100%;\n box-sizing: border-box;\n\n &::-webkit-scrollbar {\n height: 6px;\n }\n\n &::-webkit-scrollbar-thumb {\n background: #007bff;\n border-radius: 10px;\n }\n`,wi=Pe(\"div\")`\n display: flex;\n scroll-snap-align: start;\n justify-content: center;\n gap: 15px;\n`,Ci=Pe(ko)`\n position: absolute;\n bottom: calc(100% + 1px);\n right: 1px;\n width: 100%;\n display: flex;\n justify-content: space-between;\n align-items: center;\n box-sizing: border-box;\n`,vi=Pe(ko)`\n display: flex;\n align-items: center;\n margin-left: auto;\n margin-right: ${({$isMobile:e})=>e?0:\"24px\"};\n\n @media (max-width: 560px) {\n margin-left: 0;\n order: 2;\n }\n`,ki=Pe(ko)`\n display: none;\n\n @media (max-width: 560px) {\n color: #666666;\n font-family: Inter;\n font-size: 14px !important;\n font-style: normal;\n font-weight: 600;\n line-height: 18px;\n display: flex;\n align-items: center;\n order: 1;\n }\n`,Si=Pe(ko)`\n display: flex;\n align-items: center;\n opacity: ${({$isDisabled:e})=>e?.3:1};\n pointer-events: ${({$isDisabled:e})=>e?\"none\":\"auto\"};\n transition: opacity 0.3s ease;\n\n .carousal-prev-button,\n .carousal-next-button {\n transition: all 0.3s ease;\n border: 2px solid #000000;\n border-radius: 3px;\n padding: 9px;\n cursor: pointer;\n\n svg {\n transition: all 0.3s ease;\n }\n\n svg polyline {\n stroke: #000000;\n fill: none;\n }\n\n &:hover {\n background-color: #f5f5f5;\n border: 2px solid #ddd;\n\n svg {\n opacity: 0.5;\n }\n\n svg polyline {\n stroke: #000000;\n fill: none;\n }\n }\n }\n\n @media (max-width: 560px) {\n display: none;\n }\n`,sm=Pe(\"div\")`\n @media (max-width: 560px) {\n overflow-y: hidden;\n scrollbar-width: thin;\n scrollbar-color: #007bff #eee;\n &::-webkit-scrollbar {\n width: 8px;\n }\n &::-webkit-scrollbar-track {\n background: #eee;\n }\n &::-webkit-scrollbar-thumb {\n background-color: red;\n border-radius: 8px;\n border: 2px solid #eee;\n }\n }\n`,Di=Pe(Lp)`\n color: #666666;\n font-family: Inter;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 22px;\n @media (max-width: 560px) {\n margin: 0 3px;\n }\n`,Ti=Pe(\"a\")`\n color: #000000;\n font-family: Inter, sans-serif;\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 22px;\n text-decoration: none;\n border-bottom: 1px solid #000000;\n padding-bottom: 4px;\n transition: all 0.3s ease;\n cursor: pointer;\n\n @media (max-width: 560px) {\n font-size: 14px;\n line-height: 18px;\n }\n\n &:hover {\n color: #666666;\n border-bottom: 1px solid #666666;\n cursor: pointer;\n }\n`,Pi=Pe(\"div\")`\n padding-top: 20px;\n font-size: 20px;\n text-align: center;\n`,Ri=Pe(\"div\")`\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n`,Mi=Pe(\"div\")`\n display: flex;\n align-items: center;\n flex: 1;\n min-width: 0;\n`,Oi=Pe(\"div\")`\n font-family: 'Lora';\n font-weight: 400;\n font-size: 22px;\n margin-left: 16px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n margin-bottom: 13px;\n`;import{jsx as We,jsxs as So}from\"react/jsx-runtime\";function Yo({entries:e,renderEntry:t,settings:r={},showControlButtons:i=!0,allEntryLabel:n=\"View All\",allEntryLink:s=\"\",categoryName:u,emptyProductMessage:m=\"No Products Available For The Selected Category\",productsCountLabel:w=\"Products\",isInitialDataLoading:k,history:g}){let d=Vp(null),b=Fp(\"(max-width: 560px)\"),x=Li(()=>{d.current?.slickPrev()},[]),S=Li(()=>{d.current?.slickNext()},[]),p=t??((C,T)=>We(xr,{productTitle:C.productTitle,imageDetails:C.imageDetails,button:C.button,onCardClick:C.onCardClick,productStatusBadge:C.productStatusBadge,directSellerBadge:C.directSeller,mySitePriceComponent:C.mySitePriceComponent},`${C.productTitle}-${T}`)),f={dots:!0,infinite:!0,speed:500,slidesToShow:Math.min(e?.length??0,4),slidesToScroll:4,swipe:!0,draggable:!0,arrows:!0,responsive:[{breakpoint:1320,settings:{slidesToShow:Math.min(e?.length??0,3),slidesToScroll:3}},{breakpoint:900,settings:{slidesToShow:Math.min(e?.length??0,2),slidesToScroll:2}},{breakpoint:600,settings:{slidesToShow:1,slidesToScroll:1,arrows:!1}}],...r},h=(e?.length??0)>f.slidesToShow,v=()=>e?.length===0&&!k?We(Pi,{children:m}):b?We(yi,{children:We(wi,{children:e.map((C,T)=>C&&p(C,T))})}):We($p,{...f,ref:d,children:e.map((C,T)=>C&&p(C,T))});return So(xi,{children:[i&&So(Ci,{children:[So(Ri,{children:[So(Mi,{children:[We(ki,{children:So(Di,{variant:\"body-m\",children:[e?.length??0,\" \",w]})}),!b&&u&&We(Oi,{children:u})]}),We(vi,{$isMobile:b,children:We(Ti,{onClick:C=>{g&&(C.preventDefault(),g.push(s))},children:n})})]}),!b&&We(Si,{$isDisabled:!h,children:We(Np,{prev:x,next:S,viewAllLabel:\"\",viewAllUrl:\"\"})})]}),v()]})}import{useState as io,useEffect as wr,useCallback as Wp}from\"react\";import{useMediaQuery as jp}from\"@mui/material\";var Jo=te(Bi());import*as Hi from\"react\";import Bp from\"@mui/material/Tabs\";import Ep from\"@mui/material/Tab\";import _i from\"@mui/material/Box\";import{styled as zp}from\"@nuskin/foundation-theme\";var Ei=zp.div`\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: flex-start;\n width: 100%;\n height: 100%;\n background-color: #fff;\n .tabsStyle {\n display: flex;\n padding-top: 8.533px;\n flex-direction: column;\n align-items: flex-start;\n gap: 12.8px;\n border-right: 1px;\n border-color: divider;\n width: 200px;\n & .Mui-selected {\n font-weight: 700;\n font-size: 14px;\n font-family: 'inter', sans-serif;\n font-style: normal;\n font-height: 20px;\n border-radius: 4px;\n }\n & .MuiTabs-indicator {\n left: 0;\n background-color: #5b81a5;\n color: #5b81a5;\n\n @media (max-width: 768px) {\n display: none;\n }\n }\n }\n\n .tabContainer {\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: flex-start;\n min-width: 100%;\n background-color: #fff;\n @media (max-width: 768px) {\n flex-direction: column;\n justify-content: center;\n align-items: center;\n }\n }\n\n .tabStyle {\n align-items: flex-start;\n display: flex;\n text-align: left;\n font-size: 14px;\n font-family: 'inter' sans-serif;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n min-height: 20px;\n padding: 1px;\n padding-left: 10px;\n margin-bottom: 10px;\n cursor: pointer;\n text-transform: none;\n }\n @media (max-width: 768px) {\n flex-direction: row;\n\n .tabsStyle {\n width: 100%;\n border-right: none;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding-top: 0px;\n }\n\n .tabStyle {\n display: flex;\n align-items: center;\n gap: 10px;\n font-size: 14px;\n border: 1px solid #ccc;\n border-radius: 70px;\n padding: 8px 16px;\n text-align: center;\n margin: 4px;\n background-color: #fff;\n cursor: pointer;\n color: black;\n font-family: Inter;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .tabStyle.Mui-selected {\n background-color: #5b81a5;\n color: #ffffff !important;\n font-weight: 700;\n border-radius: 70px;\n }\n }\n .tabPanel {\n padding: 8px;\n text-align: left;\n }\n`;import{useMediaQuery as Hp}from\"@mui/material\";import{jsx as ao,jsxs as _p}from\"react/jsx-runtime\";function Wi(e){let{children:t,value:r,index:i,...n}=e;return ao(\"div\",{role:\"tabpanel\",hidden:r!==i,id:`vertical-tabpanel-${i}`,\"aria-labelledby\":`vertical-tab-${i}`,...n,children:r===i&&ao(_i,{className:\"tabPanel\",children:t})})}Wi.propTypes={children:Jo.default.node,index:Jo.default.number.isRequired,value:Jo.default.number.isRequired};var yr=({itemArray:e,value:t,onChange:r})=>{let[i,n]=Hi.useState(0),s=Hp(\"(max-width:768px)\"),u=t??i;return ao(Ei,{children:_p(_i,{className:\"tabContainer\",children:[ao(Bp,{orientation:s?\"horizontal\":\"vertical\",variant:\"scrollable\",value:u,onChange:(w,k)=>{r?r(w,k):n(k)},\"aria-label\":\"Vertical tabs example\",className:\"tabsStyle\",children:e.map(w=>ao(Ep,{label:w.label,className:\"tabStyle\"},w.categoryId))}),e.map(w=>ao(Wi,{value:u,index:e.findIndex(k=>k.categoryId===w.categoryId),children:w.content},w.categoryId))]})})};import{NsSpinner as Kp}from\"@nuskin/foundation-ui-components\";import{styled as ro}from\"@nuskin/foundation-theme\";var ji=ro(\"div\")`\n display: flex;\n flex-direction: ${({isMobile:e})=>e?\"column\":\"row\"};\n align-items: ${({isMobile:e})=>e?\"stretch\":\"flex-start\"};\n width: 100%;\n max-width: 1920px;\n min-height: ${({isMobile:e})=>e?\"auto\":\"800px\"};\n margin: 0 auto;\n box-sizing: border-box;\n overflow: visible;\n background: #fff;\n padding: ${({isMobile:e})=>e?\"10px 16px 0px 16px\":\"50px 60px 0px 60px\"};\n\n @media (max-width: 768px) {\n padding: 10px 16px 0px 16px;\n min-height: auto;\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n padding: 30px 40px 0px 40px;\n gap: 20px;\n }\n\n transform: translateZ(0);\n will-change: auto;\n`,Ki=ro(\"div\")`\n min-width: ${({isMobile:e})=>e?\"100%\":\"auto\"};\n height: ${({isMobile:e})=>e?\"auto\":\"100%\"};\n flex-shrink: 0;\n\n @media (max-width: 768px) {\n width: 100%;\n height: auto;\n\n overflow-x: auto;\n overflow-y: visible;\n -webkit-overflow-scrolling: touch;\n scrollbar-width: none;\n -ms-overflow-style: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n min-width: 200px;\n margin-right: 20px;\n }\n`,Ui=ro(\"div\")`\n flex: 1;\n min-width: 0;\n height: ${({isMobile:e})=>e?\"auto\":\"100%\"};\n\n @media (max-width: 768px) {\n width: 100%;\n height: auto;\n min-height: 300px;\n\n -webkit-overflow-scrolling: touch;\n overflow-x: hidden;\n overflow-y: auto;\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n min-height: 400px;\n }\n\n contain: layout style paint;\n transform: translateZ(0);\n`,Em=ro(\"div\")`\n display: flex;\n justify-content: center;\n align-items: center;\n min-height: 200px;\n padding: 20px;\n\n @media (max-width: 768px) {\n min-height: 150px;\n padding: 16px;\n }\n`,qi=ro(\"div\")`\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 40px 20px;\n color: #666;\n font-size: 16px;\n\n @media (max-width: 768px) {\n padding: 20px 16px;\n font-size: 14px;\n }\n`,Gi=ro(\"div\")`\n padding: 10px;\n display: flex;\n justify-content: center;\n`;import{jsx as jt,jsxs as Gp}from\"react/jsx-runtime\";var Up=({allEntryLabel:e,allEntryLink:t,renderEntry:r,settings:i,showControlButtons:n=!0,fetchCategories:s,fetchProducts:u,showCustomCategory:m=!1,emptyProductTabs:w=\"No tabs available\",emptyProductMessage:k,productsCountLabel:g,getCategoryId:d,history:b})=>{let x=jp(\"(max-width:768px)\"),[S,p]=io(!0),[f,h]=io([]),[v,C]=io(0),[T,$]=io([]),[L,_]=io(!1),[l,c]=io(!0),y=Wp(()=>{let M=document.querySelectorAll('[data-testid*=\"spinner\"], .ns-spinner, [class*=\"spinner\"]');c(M.length===0)},[]);wr(()=>{L&&y()},[L,y]),wr(()=>{s().then(h)},[s]),wr(()=>{if(f.length>0){let M=f[v]?.categoryId;d&&d(M),_(!0),u(M).then($).finally(()=>{_(!1),p(!1)})}},[f,v,u]);let D=f.map(M=>({label:M.label,content:\"\",categoryId:M.categoryId}));return Gp(ji,{isMobile:x,children:[m&&(D.length>0?jt(Ki,{isMobile:x,children:jt(yr,{itemArray:D,value:v,onChange:(M,F)=>C(F)})}):jt(qi,{children:w})),jt(Ui,{isMobile:x,children:L?jt(Gi,{children:l&&jt(Kp,{})}):jt(Yo,{isInitialDataLoading:S,entries:T,allEntryLabel:e,allEntryLink:t,renderEntry:r?M=>r({...M,productStatusBadge:M.productStatusBadge}):void 0,settings:i,showControlButtons:n,categoryName:f[v]?.label,emptyProductMessage:k,productsCountLabel:g,history:b})})]})},qp=Up;import{useState as Qo,useEffect as kr,useMemo as Qp}from\"react\";import{Typography as Mt,Box as Ot,useMediaQuery as Xp,Tooltip as ec}from\"@mui/material\";import{NsLink as tc,NsImage as un}from\"@nuskin/foundation-ui-components\";import{styled as ct}from\"@nuskin/foundation-theme\";import{Box as Do}from\"@mui/material\";import{jsx as vr}from\"react/jsx-runtime\";var Cr=e=>({fontSize:\"12px\",fontStyle:\"normal\",fontWeight:\"600\",lineHeight:\"16px\",letterSpacing:\"0.12px\",color:e?\"#000000\":\"#FFFFFF\",\"& a\":{color:\"inherit\",textDecoration:\"none\",\"&:hover\":{textDecoration:\"underline\"}}}),Ji=e=>({fontSize:\"12px\",fontStyle:\"normal\",fontWeight:\"700\",lineHeight:\"16px\",letterSpacing:\"0.48px\",color:e?\"#000000\":\"#FFFFFF\",textTransform:\"uppercase\",paddingLeft:\"5px\"}),Zi=()=>({display:\"flex\",flexDirection:\"row\",gap:\"10px\",alignItems:\"center\"}),Yi=e=>({...Cr(e),paddingBottom:\"11px\",wordBreak:\"break-all\",overflowWrap:\"break-word\",paddingLeft:\"5px\",\"& a\":{color:\"inherit\",textDecoration:\"none\"},\"@media (max-width: 420px)\":{fontSize:\"11px\",lineHeight:\"15px\",paddingBottom:\"8px\"},\"@media (max-width: 400px)\":{fontSize:\"10px\",lineHeight:\"14px\",paddingBottom:\"6px\"},\"@media (max-width: 375px)\":{fontSize:\"8px\",lineHeight:\"12px\",paddingBottom:\"4px\"}}),Yp=e=>({...Ji(e),marginBottom:\"11px\",transition:\"opacity 0.3s ease-out, transform 0.3s ease-out\",opacity:1,transform:\"translateY(0)\",\"@media (max-width: 420px)\":{fontSize:\"11px\",lineHeight:\"14px\",marginBottom:\"8px\"},\"@media (max-width: 400px)\":{fontSize:\"10px\",lineHeight:\"12px\",marginBottom:\"5px\"},\"@media (max-width: 375px)\":{fontSize:\"8px\",lineHeight:\"11px\",marginBottom:\"4px\"}}),Qi=ct(e=>vr(Do,{...e}))(({bannerProps:e,isCircularImage:t,hasWhiteBackground:r})=>({backgroundClip:\"border-box\",display:\"flex\",background:e?.backgroundColor??\"#383838\",position:\"relative\",overflow:\"hidden\",width:\"100%\",height:\"auto\",flexDirection:\"row\",alignItems:\"center\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"transform, opacity\",transform:\"translateZ(0)\",backfaceVisibility:\"hidden\",\"&.scrolled\":{top:0,left:0,right:0,boxShadow:\"0 2px 8px rgba(0,0,0,0.2)\",\".content\":{paddingTop:\"0\",justifyContent:\"center\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".body-title\":{fontSize:\"26px\",lineHeight:\"34px\",marginBottom:\"0\",fontStyle:\"normal\",fontWeight:\"400\",fontFamily:e?.headlineFont??\"Lora\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".bg-image\":{width:\"90px\",height:\"90px\",padding:t?\"2px\":\"0px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",objectFit:\"cover\",objectPosition:\"center\"},\".placeholder-image\":{\"& > div\":{width:\"90px\",height:\"90px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"}}},\".content\":{width:\"70%\",height:\"100%\",marginLeft:\"2%\",marginRight:\"auto\",display:\"flex\",flexDirection:\"column\",position:\"relative\",boxSizing:\"border-box\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".bg-image\":{width:\"252px\",height:\"252px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"width, height, transform\",padding:t?\"3px\":\"0px\",objectFit:\"cover\",objectPosition:\"center\"},\".placeholder-image\":{transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"width, height, transform\",\"& > div\":{transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"}},\".body-title\":{fontSize:\"32px\",lineHeight:\"38px\",marginBottom:\"8px\",fontWeight:\"400\",color:r?\"#000000\":\"#FFFFFF\",overflow:\"hidden\",whiteSpace:\"nowrap\",textOverflow:\"ellipsis\",fontFamily:e?.headlineFont??\"Lora\",paddingLeft:\"5px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".body-text\":{fontSize:\"16px\",marginBottom:\"12px\",fontStyle:\"normal\",fontWeight:\"400\",lineHeight:\"22px\",color:r?\"#000000\":\"#FFFFFF\",fontFamily:e?.paragraphFont??\"inherit\",display:\"-webkit-box\",WebkitBoxOrient:\"vertical\",overflow:\"hidden\",WebkitLineClamp:3,textOverflow:\"ellipsis\",paddingLeft:\"5px\",transition:\"opacity 0.3s ease-out, transform 0.3s ease-out\",opacity:1,transform:\"translateY(0)\"},\".social-media\":{display:\"flex\",flexDirection:\"column\",transition:\"opacity 0.3s ease-out, transform 0.3s ease-out\",opacity:1,transform:\"translateY(0)\"},\".email-text\":Cr(r),\".phone-text\":Cr(r),\".social-title-text\":{...Ji(r),marginBottom:\"8px\"},\".social-icons\":{...Zi(),paddingBottom:\"8px\"}})),Xi=ct(e=>vr(Do,{...e}))(({bannerProps:e,isCircularImage:t,hasWhiteBackground:r})=>({backgroundClip:\"border-box\",display:\"flex\",background:e?.backgroundColor??\"#383838\",position:\"relative\",overflow:\"hidden\",width:\"100%\",flexDirection:\"column\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"transform, opacity\",transform:\"translateZ(0)\",backfaceVisibility:\"hidden\",\"&.scrolled\":{top:0,left:0,right:0,boxShadow:\"0 2px 8px rgba(0,0,0,0.2)\",\".content-mobile\":{paddingTop:\"5px\",width:\"60%\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".body-title-mobile\":{fontSize:\"18px\",lineHeight:\"28px\",marginBottom:\"0\",fontStyle:\"normal\",fontWeight:\"400\",fontFamily:e?.headlineFont??\"Lora\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"},\".bg-image-mobile\":{width:\"75px\",height:\"75px\",padding:t?\"2px\":\"0px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",objectFit:\"cover\",objectPosition:\"center\"},\".placeholder-image-mobile\":{\"& > div\":{width:\"75px !important\",height:\"75px !important\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\"}}},\".image-content-mobile\":{display:\"flex\",flexDirection:\"row\",width:\"100%\",justifyContent:\"center\",alignItems:\"center\"},\".content-mobile\":{width:\"55%\",height:\"100%\",paddingTop:\"10px\",paddingRight:\"10px\",marginLeft:\"8px\",marginRight:\"auto\",display:\"flex\",flexDirection:\"column\",justifyContent:\"center\",position:\"relative\",boxSizing:\"border-box\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",\"@media (max-width: 420px)\":{paddingTop:\"8px\",width:\"100%\"},\"@media (max-width: 400px)\":{paddingTop:\"6px\",width:\"100%\",height:\"100%\"},\"@media (max-width: 375px)\":{paddingTop:\"4px\",width:\"100%\",height:\"100%\"}},\".bg-image-mobile\":{width:\"144px\",height:\"144px\",display:\"flex\",justifyContent:\"center\",alignItems:\"center\",objectFit:\"cover\",objectPosition:\"center\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"width, height, transform\",padding:t?\"2px\":\"0px\",\"@media (max-width: 420px)\":{width:\"120px\",height:\"120px\"},\"@media (max-width: 400px)\":{width:\"112px\",height:\"112px\"},\"@media (max-width: 375px)\":{width:\"90px\",height:\"90px\"}},\".placeholder-image-mobile\":{transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",willChange:\"width, height, transform\",\"& > div\":{transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",width:\"144px\",height:\"144px\",\"@media (max-width: 420px)\":{width:\"120px\",height:\"120px\"},\"@media (max-width: 400px)\":{width:\"110px !important\",height:\"110px !important\"},\"@media (max-width: 375px)\":{width:\"90px\",height:\"90px\"}}},\".body-title-mobile\":{fontSize:\"22px\",lineHeight:\"28px\",marginBottom:\"13px\",fontWeight:\"400\",color:r?\"#000000\":\"#FFFFFF\",fontStyle:\"normal\",overflow:\"hidden\",whiteSpace:\"nowrap\",textOverflow:\"ellipsis\",fontFamily:e?.headlineFont??\"Lora\",paddingLeft:\"5px\",transition:\"all 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",\"@media (max-width: 420px)\":{fontSize:\"16px\",lineHeight:\"24px\",marginBottom:\"8px\"},\"@media (max-width: 400px)\":{fontSize:\"16px\",lineHeight:\"22px\",marginBottom:\"6px\"},\"@media (max-width: 375px)\":{fontSize:\"14px\",lineHeight:\"20px\",marginBottom:\"4px\"}},\".body-text-mobile\":{fontSize:\"14px\",padding:\"20px 25px 20px 25px\",fontStyle:\"normal\",fontWeight:\"400\",lineHeight:\"20px\",color:\"#252525\",backgroundColor:\"#E0E0E0\",fontFamily:e?.paragraphFont??\"inherit\",transition:\"all 0.25s cubic-bezier(0.4, 0, 0.2, 1)\",opacity:1,transform:\"translateY(0)\"},\".expandable-description-mobile\":{backgroundColor:\"#E0E0E0\",position:\"relative\"},\".description-content-mobile\":{fontSize:\"14px\",padding:\"10px 15px\",fontStyle:\"normal\",fontWeight:\"400\",lineHeight:\"20px\",color:\"#252525\",fontFamily:e?.paragraphFont??\"inherit\",transition:\"max-height 0.3s ease-in-out, opacity 0.3s ease-in-out\",overflow:\"hidden\",position:\"relative\",\"&.collapsed\":{maxHeight:\"50px\",display:\"-webkit-box\",WebkitLineClamp:2,WebkitBoxOrient:\"vertical\",\"&::after\":{content:'\"\"',position:\"absolute\",bottom:0,left:0,right:0,height:\"20px\",background:\"linear-gradient(transparent, rgba(224, 224, 224, 0.8), #E0E0E0)\",pointerEvents:\"none\"}},\"&.expanded\":{maxHeight:\"none\",whiteSpace:\"normal\",display:\"block\",\"&::after\":{display:\"none\"}}},\".email-text-mobile\":Yi(r),\".phone-text-mobile\":Yi(r),\".social-title-text-mobile\":Yp(r),\".social-icons-mobile\":{...Zi(),paddingBottom:\"10px\",transition:\"opacity 0.3s ease-out, transform 0.3s ease-out\",opacity:1,transform:\"translateY(0)\",\"& img\":{width:\"24px\",height:\"24px\",\"@media (max-width: 400px)\":{width:\"20px\",height:\"20px\"},\"@media (max-width: 375px)\":{width:\"18px\",height:\"18px\"}},\"@media (max-width: 420px)\":{paddingBottom:\"8px\"},\"@media (max-width: 400px)\":{paddingBottom:\"4px\"},\"@media (max-width: 375px)\":{paddingBottom:\"3px\"}}})),en=ct(Do)({display:\"flex\",gap:\"12px\",marginBottom:\"16px\",paddingLeft:\"5px\",\"&.mobile-badges\":{flexDirection:\"column\",gap:\"8px\",marginBottom:\"12px\"},\"&.tablet-badges\":{flexDirection:\"row\",gap:\"12px\",marginBottom:\"8px\"}}),tn=ct(e=>vr(Do,{...e}))(({hasWhiteBackground:e})=>({backgroundColor:\"rgba(255, 255, 255, 0.2)\",backdropFilter:\"blur(10px)\",borderRadius:\"20px\",padding:\"8px 16px\",display:\"flex\",alignItems:\"center\",gap:\"4px\",border:\"1px solid rgba(255, 255, 255, 0.3)\",transition:\"all 0.3s ease\",\"&.mobile-badge\":{padding:\"6px 12px\",borderRadius:\"16px\",fontSize:\"12px\"},\"&.tablet-badge\":{padding:\"8px 16px\",borderRadius:\"20px\",fontSize:\"14px\"},\"&:hover\":{backgroundColor:\"rgba(255, 255, 255, 0.3)\",transform:\"translateY(-1px)\",boxShadow:\"0 4px 12px rgba(0, 0, 0, 0.1)\"},\".badge-text\":{color:e?\"#000000\":\"#FFFFFF\",fontWeight:\"400\",opacity:.9},\".badge-value\":{color:e?\"#000000\":\"#FFFFFF\",fontWeight:\"600\"}})),on=ct(\"button\")({backgroundColor:\"#E0E0E0\",border:\"1px solid #252525\",borderRadius:\"10px\",cursor:\"pointer\",width:\"40px\",height:\"20px\",display:\"flex\",alignItems:\"center\",justifyContent:\"center\",margin:\"10px auto 5px auto\",transition:\"all 0.2s ease\",\"& .arrow-icon-mobile\":{transition:\"transform 0.3s ease\",\"&.expanded\":{transform:\"rotate(180deg)\"}}}),an=ct(Do)`\n background: none;\n border: 2px solid transparent;\n cursor: pointer;\n padding: 2px;\n display: flex;\n align-items: center;\n border-radius: 8px;\n transition: all 0.3s ease;\n\n &:hover {\n transform: scale(1.1);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n }\n\n &:focus,\n &:focus-within {\n outline: none;\n border-color: #007bff;\n box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25);\n }\n\n &:hover svg {\n fill: #ffffff;\n }\n`,rn=ct(\"span\")`\n line-height: 0.5;\n`,nn=ct(\"a\")({fontSize:\"inherit\",fontFamily:\"inherit\",fontWeight:\"inherit\",lineHeight:\"inherit\",letterSpacing:\"inherit\",color:\"inherit\",textDecoration:\"none\",\"&:hover\":{textDecoration:\"underline\"}}),ln=ct(\"span\")({});import{Box as Jp}from\"@mui/material\";import{jsx as Kt,jsxs as Zp}from\"react/jsx-runtime\";var sn=({width:e,height:t,backgroundColor:r})=>Kt(Jp,{sx:{width:e,height:t,display:\"flex\",justifyContent:\"center\",alignItems:\"center\",backgroundColor:r},\"data-testid\":\"placeholder-image\",children:Kt(\"svg\",{xmlns:\"http://www.w3.org/2000/svg\",width:\"128\",height:\"129\",viewBox:\"0 0 128 129\",fill:\"none\",children:Zp(\"g\",{id:\"ns_logomark\",children:[Kt(\"path\",{id:\"Vector\",d:\"M127.495 52.1946C125.663 47.9538 122.999 44.1171 119.661 40.9073C112.565 34.2835 102.562 31.7037 93.1175 34.0622C83.6733 36.4206 76.0882 43.3926 72.991 52.5619C71.4142 56.8414 70.6063 61.3627 70.6039 65.9196C70.6039 85.8227 70.6039 105.737 70.6039 125.662C70.6039 129.001 70.6039 129.001 66.9051 128.834C66.9051 128.2 66.9051 127.499 66.9051 126.831C66.9051 104.323 66.9051 81.8263 66.9051 59.3409C66.3415 45.3064 74.9302 32.5039 88.1888 27.6164C89.79 27.0612 91.4307 26.6259 93.0981 26.314C94.7114 25.98 96.4605 25.8465 98.0738 25.6461C96.0231 16.3291 78.9419 5.60953 65.0889 4.97504C50.3084 4.62252 36.6074 12.6365 29.7509 25.6461C31.331 25.8465 32.8779 25.9466 34.3569 26.2138C48.0999 28.544 58.7086 39.4998 60.5168 53.2298C60.8904 55.7285 61.0812 58.2508 61.0877 60.7769C61.0877 82.7507 61.0877 104.724 61.0877 126.697C61.0877 128.434 60.6842 129.169 58.8016 128.968C56.9183 128.768 57.1204 128.2 57.1204 126.965C57.1204 119.985 57.1204 113.006 57.1204 105.993C57.1204 92.1674 57.1204 78.3423 57.1204 64.5171C57.2385 56.3928 54.2457 48.5271 48.7477 42.5103C42.2429 35.5282 32.6539 32.2371 23.1959 33.7401C13.7379 35.243 5.66194 41.3411 1.67448 49.9906C1.23781 50.8254 0.867444 51.6937 0.262573 52.9293C5.79294 22.3996 32.4752 0.139867 63.7085 0.000656323C94.9411 -0.138555 121.824 21.8824 127.629 52.3616\",fill:\"#252525\"}),Kt(\"path\",{id:\"Vector_2\",d:\"M86.0995 124.927C86.0995 124.293 86.0995 123.858 86.0995 123.425C86.0995 111.669 86.0995 100.049 86.0995 88.1269C85.8836 82.4231 88.0775 76.89 92.1523 72.8653C97.3131 67.9567 104.984 66.7091 111.452 69.7263C117.892 72.1185 122.166 78.225 122.178 85.0541C122.372 92.1747 119.781 99.0921 114.949 104.356C107.882 113.237 98.6134 120.141 88.05 124.392C87.4217 124.616 86.782 124.805 86.1335 124.96\",fill:\"#252525\"}),Kt(\"path\",{id:\"Vector_3\",d:\"M41.8183 125.395C37.6149 123.224 33.6477 121.487 29.9828 119.25C21.5405 114.299 14.4778 107.331 9.43828 98.9796C6.53442 94.3985 5.34408 88.9493 6.07591 83.5852C7.056 75.2882 13.8859 68.8841 22.2829 68.3905C31.1231 67.2473 39.3527 73.0751 41.1455 81.7484C41.76 84.263 42.0762 86.8411 42.0868 89.4287C42.0868 100.516 42.0868 111.636 42.0868 122.823C42.0868 123.457 42.0867 124.059 41.8854 125.294\",fill:\"#252525\"}),Kt(\"path\",{id:\"Vector_4\",d:\"M51.3337 127.431C47.9713 127.431 47.6681 127.198 47.6681 124.326V76.6386C48.1096 67.937 42.9747 59.906 34.8574 56.602C25.8992 52.8557 15.5485 54.8615 8.66523 61.6779C4.28638 66.6086 1.89197 72.9696 1.94049 79.5438C1.95423 80.2444 1.78037 80.9357 1.43588 81.5476C1.06552 79.9446 0.62885 78.2081 0.426687 76.7387C-0.724024 70.4463 0.471163 63.9529 3.78906 58.472C6.09291 54.6111 9.65016 51.6434 13.8762 50.0567C22.8587 46.555 32.9393 47.1785 41.4148 51.7598C47.6592 54.8694 51.5262 61.2882 51.3337 68.2232C51.5019 87.6249 51.3337 107.027 51.3337 126.396C51.3337 126.797 51.3337 127.164 51.3337 127.532\",fill:\"#252525\"}),Kt(\"path\",{id:\"Vector_5\",d:\"M76.287 127.499V125.094C76.287 107.196 76.4883 89.2963 76.287 71.3966C76.0848 56.9034 84.2554 50.6588 95.7553 48.3545C101.535 47.2005 107.524 47.6393 113.071 49.6235C122.914 53.3319 128.994 63.1725 127.866 73.5672C127.631 76.2831 127.17 78.975 126.487 81.6151C125.916 78.2758 125.68 74.9364 124.772 71.597C122.808 64.3002 117.377 58.4174 110.228 55.8421C103.078 53.2668 95.1132 54.3239 88.8955 58.6734C83.0441 62.6207 79.7011 69.3237 80.086 76.3389C80.086 92.2349 80.086 108.131 80.086 124.026C80.086 127.366 80.086 127.366 76.2198 127.366\",fill:\"#252525\"})]})})});import{jsx as dn}from\"react/jsx-runtime\";var pn=({width:e=16,height:t=16,className:r=\"\"})=>dn(\"svg\",{width:e,height:t,viewBox:\"0 0 24 24\",fill:\"currentColor\",className:r,\"data-testid\":\"arrow-down-icon\",children:dn(\"path\",{d:\"M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z\"})});function Zo(e){if(typeof window>\"u\")return;let t=window.location.href,r={...e},i=t.includes(\"personal-offer\")?\"postorefront_\":\"mysite_\";r.event=i+e.event;try{window.dataLayer||(console.error(\"GTM dataLayer not available, but event logged\"),window.dataLayer=[]),window.dataLayer.push(r)}catch(n){console.error(\"Failed to track GTM event:\",n)}}import{Fragment as mn,jsx as U,jsxs as at}from\"react/jsx-runtime\";var cn=(e,t,r)=>{let i=r.includes(\"mobile\")?\"placeholder-image-mobile\":\"placeholder-image\";return e?.imageSrc?U(rn,{tabIndex:0,children:U(un,{className:r,src:e.imageSrc,alt:e.imageAlt})}):U(Ot,{className:i,children:U(sn,{width:r.includes(\"mobile\")?\"144px\":\"246px\",height:r.includes(\"mobile\")?\"144px\":\"246px\",backgroundColor:t?.backgroundColor??\"#5F5F5F\"})})},gn=(e,t,r,i)=>!e||!t?null:U(en,{className:r?\"mobile-badges\":\"tablet-badges\",children:t&&U(tn,{className:r?\"mobile-badge\":\"tablet-badge\",hasWhiteBackground:i,tabIndex:0,children:U(ln,{className:\"badge-value\",children:t})})}),oc=(e,t,r,i,n)=>{let{shopTitle:s,socialTitleText:u,email:m,showBadges:w,expirationDate:k,phone:g}=e;return at(Ot,{className:\"content-mobile\",children:[U(Mt,{tabIndex:0,className:\"body-title-mobile\",children:s}),!t&&at(mn,{children:[U(Mt,{tabIndex:0,className:\"social-title-text-mobile\",children:u}),Xo(\"email\",m,\"email-text-mobile\"),Xo(\"phone\",g,\"phone-text-mobile\"),U(Ot,{className:\"social-icons-mobile\",children:r}),gn(w,k??\"\",i,n)]})]})},ac=(e,t,r,i,n)=>{let{shopTitle:s,shopDescription:u,socialTitleText:m,email:w,phone:k,showBadges:g,expirationDate:d}=e;return at(Ot,{className:\"content\",children:[U(Mt,{tabIndex:0,className:\"body-title\",children:s}),!t&&at(mn,{children:[u?.length>480?U(ec,{title:u,arrow:!0,children:U(Mt,{tabIndex:0,className:\"body-text\",children:u})}):U(Mt,{tabIndex:0,className:\"body-text\",children:u}),at(Ot,{className:\"social-media\",children:[U(Mt,{tabIndex:0,className:\"social-title-text\",children:m}),at(Ot,{className:\"social-icons\",children:[r,Xo(\"email\",w,\"email-text\"),Xo(\"phone\",k,\"phone-text\")]})]}),gn(g,d??\"\",i,n)]})]})},rc=e=>new Promise((t,r)=>{let i=new Image;i.crossOrigin=\"anonymous\",i.src=e,i.onload=()=>{let n=document.createElement(\"canvas\"),s=n.getContext(\"2d\");if(!s)return r(new Error(\"Canvas not supported\"));n.width=i.width,n.height=i.height,s.drawImage(i,0,0);let m=[s.getImageData(0,0,1,1).data,s.getImageData(i.width-1,0,1,1).data,s.getImageData(0,i.height-1,1,1).data,s.getImageData(i.width-1,i.height-1,1,1).data].every(w=>Array.prototype.slice.call(w)[3]<10);t(m)},i.onerror=()=>r(new Error(\"Failed to load image\"))}),ic=e=>{if(!e)return!1;let t=e.replace(\"#\",\"\").toLowerCase();if(!/^[0-9a-f]{3,4}$|^[0-9a-f]{6}$|^[0-9a-f]{8}$/i.test(t))return!1;let r=t;(t.length===3||t.length===4)&&(r=t.split(\"\").map(m=>m+m).join(\"\"));let i=Number.parseInt(r.substring(0,2),16),n=Number.parseInt(r.substring(2,4),16),s=Number.parseInt(r.substring(4,6),16),u=220;return i>=u&&n>=u&&s>=u},nc=(e,t)=>({onClick:()=>{Zo({event:\"contact_click\",contact_type:e,contact_value:t,click_element:`${e}_link`})},onKeyDown:r=>{(r.key===\"Enter\"||r.key===\" \")&&(r.preventDefault(),Zo({event:\"contact_click\",contact_type:e,contact_value:t,click_element:`${e}_link`}),globalThis.location.href=`${e===\"email\"?\"mailto\":\"tel\"}:${t}`)}}),Xo=(e,t,r)=>{let i=e===\"email\"?\"mailto:\":\"tel:\",n=nc(e,t);return U(Mt,{className:r,children:U(nn,{href:`${i}${t}`,...n,children:t})})};function fn({className:e,shopTitle:t,shopDescription:r,socialTitleText:i,imageDetails:n,email:s,phone:u,bannerProps:m,socialIcons:w,expirationDate:k,showBadges:g=!1}){let d=Xp(\"(max-width: 560px)\"),[b,x]=Qo(!1),[S,p]=Qo(!1),[f,h]=Qo(!1),[v,C]=Qo(!1),T=()=>{p(!S)};kr(()=>{(async()=>{if(n?.imageSrc){let D=await rc(n.imageSrc);C(D)}else C(!1)})()},[n?.imageSrc]),kr(()=>{h(ic(m?.backgroundColor))},[m?.backgroundColor]),kr(()=>{let y,D=window.scrollY,M=!1,F=!1,I=0,fe=ee=>{let et=Date.now();if(M!==ee&&!F){if(et-I<100)return;F=!0,M=ee,I=et,ee&&p(!1),clearTimeout(y),x(ee),y=setTimeout(()=>{F=!1,ee&&window.scrollY<15&&window.scrollTo({top:d?20:30,behavior:\"smooth\"})},300)}},xe=()=>{let ee=window.scrollY;if(F){D=ee;return}if(Math.abs(ee-D)<.5)return;let tt=ee>D,Bt=d?15:25,Co=d?8:12;tt&&ee>Bt&&!M?fe(!0):!tt&&ee<Co&&M&&fe(!1),D=ee},wo=()=>{let ee=window.scrollY,tt=ee>(d?5:10);M=tt,x(tt),D=ee,I=Date.now()},Ee=null,eo=0,St=()=>{Ee||Date.now()-eo<16||(Ee=requestAnimationFrame(()=>{xe(),eo=Date.now(),Ee=null}))};return wo(),window.addEventListener(\"scroll\",St,{passive:!0}),()=>{window.removeEventListener(\"scroll\",St),Ee&&cancelAnimationFrame(Ee),clearTimeout(y)}},[d]);let $=Qp(()=>w?.map((y,D)=>U(an,{onClick:F=>{F.preventDefault(),Zo({event:\"social_click\",social_platform:y.type,social_url:y.url,click_element:\"social_icon\"}),window.open(y.url,\"_blank\")},children:U(tc,{href:y.url,target:\"_blank\",children:U(un,{src:`https://www.google.com/s2/favicons?domain=${y?.url}&sz=24`,alt:`${y.type} icon`,width:\"24\",height:\"24\"},y?.type+D)})},y?.type+D)),[w]),L=`${e} ${b?\"scrolled\":\"\"}`,_={shopTitle:t,shopDescription:r,socialTitleText:i,email:s,phone:u,showBadges:g,expirationDate:k},l=()=>window.innerWidth<=380?50:window.innerWidth<=415?56:window.innerWidth<=460?62:80,c=d&&r&&r.length>l();return d?at(Xi,{className:L,\"data-testid\":\"my-site-shop-header\",bannerProps:m,isCircularImage:v,hasWhiteBackground:f,children:[at(Ot,{className:\"image-content-mobile\",children:[cn(n,m??{},\"bg-image-mobile\"),oc(_,b,$,d,f)]}),!b&&at(Ot,{className:\"expandable-description-mobile\",children:[U(Mt,{className:`description-content-mobile ${S||!c?\"expanded\":\"collapsed\"}`,children:r}),c&&U(on,{onClick:T,children:U(pn,{width:16,height:16,className:`arrow-icon-mobile ${S?\"expanded\":\"\"}`})})]})]}):at(Qi,{className:L,\"data-testid\":\"my-site-shop-header\",bannerProps:m,isCircularImage:v,hasWhiteBackground:f,children:[cn(n,m??{},\"bg-image\"),ac(_,b,$,d,f)]})}import{styled as To}from\"@nuskin/foundation-theme\";var Sr=To(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 24px;\n padding: 16px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 24px;\n gap: 32px;\n }\n\n @media (min-width: 1080px) {\n padding: 32px;\n gap: 40px;\n }\n`,hn=To(\"div\")`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 768px) {\n grid-template-columns: repeat(3, 1fr);\n gap: 20px;\n }\n\n @media (min-width: 1080px) {\n gap: 24px;\n }\n`,bn=To(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 768px) {\n gap: 20px;\n }\n\n @media (min-width: 1080px) {\n gap: 24px;\n }\n`,Dr=To(\"div\")`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 1080px) {\n grid-template-columns: repeat(2, 1fr);\n gap: 24px;\n }\n`,xn=To(\"div\")`\n padding: 24px;\n text-align: center;\n color: #d32f2f;\n background-color: #ffebee;\n border-radius: 8px;\n`;var Pn=te(Pr()),Rn=te(yn());import{NsSpinner as hc}from\"@nuskin/foundation-ui-components\";import{ColorUtils as mc,styled as Be}from\"@nuskin/foundation-theme\";var{getGenomeColor:je}=mc,wn=Be(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 12px;\n padding: 16px;\n background-color: ${({theme:e})=>je(e,\"N20\")};\n border-radius: 12px;\n min-height: 64px;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n padding: 24px;\n }\n\n @media (min-width: 1080px) {\n padding: 24px 32px;\n }\n`,Cn=Be(\"div\")`\n display: flex;\n flex-direction: row;\n align-items: baseline;\n gap: 12px;\n flex-wrap: wrap;\n`,vn=Be(\"h1\")`\n font-size: 20px;\n font-weight: 600;\n line-height: 1.3;\n color: ${({theme:e})=>je(e,\"N100\")};\n margin: 0;\n\n @media (min-width: 768px) {\n font-size: 24px;\n }\n\n @media (min-width: 1080px) {\n font-size: 28px;\n }\n`,kn=Be(\"div\")`\n font-size: 13px;\n font-weight: 400;\n line-height: 1.4;\n color: ${({theme:e})=>je(e,\"N70\")};\n\n @media (min-width: 768px) {\n font-size: 14px;\n }\n`,Sn=Be(\"div\")`\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-items: center;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 768px) {\n width: auto;\n }\n`,Rr=Be(\"div\")`\n display: flex;\n align-items: center;\n gap: 8px;\n position: relative;\n`,Mr=Be(\"label\")`\n font-size: 14px;\n font-weight: 500;\n line-height: 1.4;\n color: ${({theme:e})=>je(e,\"N80\")};\n white-space: nowrap;\n display: none;\n\n @media (min-width: 1080px) {\n display: block;\n }\n`,Or=Be(\"select\")`\n display: flex;\n align-items: center;\n gap: 12px;\n height: 40px;\n padding: 8px 12px;\n background-color: transparent;\n border: none;\n border-radius: 4px;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n color: ${({theme:e})=>je(e,\"N70\")};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n appearance: none;\n background-image: url('data:image/svg+xml;charset=UTF-8,%3csvg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3e%3cpath d=\"M5.625 7.3125L9 10.6875L12.375 7.3125\" stroke=\"%235f5f5f\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/%3e%3c/svg%3e');\n background-repeat: no-repeat;\n background-position: right 8px center;\n padding-right: 32px;\n min-width: auto;\n\n &:hover {\n background-color: ${({theme:e})=>je(e,\"N30\")};\n }\n\n &:focus {\n border-color: ${({theme:e})=>je(e,\"A70\")};\n box-shadow: 0 0 0 3px ${({theme:e})=>je(e,\"A20\")};\n }\n\n &:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n @media (min-width: 768px) {\n min-width: 160px;\n }\n\n @media (min-width: 1080px) {\n background-color: ${({theme:e})=>je(e,\"N10\")};\n border: 1px solid ${({theme:e})=>je(e,\"N40\")};\n border-radius: 8px;\n min-width: 180px;\n }\n`,Lr=Be(\"span\")`\n display: inline-flex;\n align-items: center;\n justify-content: center;\n color: ${({theme:e})=>je(e,\"N70\")};\n\n svg {\n width: 16px;\n height: 16px;\n }\n`,Dn=Be(\"div\")`\n display: flex;\n align-items: center;\n justify-content: center;\n width: 28px;\n height: 28px;\n overflow: hidden;\n\n svg,\n img,\n > * {\n width: 28px !important;\n height: 28px !important;\n max-width: 28px;\n max-height: 28px;\n }\n`,Tn=Be(\"div\")`\n display: flex;\n flex-wrap: wrap;\n gap: 16px;\n align-items: center;\n width: 100%;\n\n @media (min-width: 768px) {\n width: auto;\n }\n`,Fh=Be(\"div\")`\n display: flex;\n align-items: center;\n justify-content: center;\n`;var o={title:{key:\"shoppingDashboard.title\",fallback:\"Shop Performance\"},error:{key:\"shoppingDashboard.error\",fallback:\"Error loading dashboard\"},stats:{revenue:{key:\"shoppingDashboard.stats.revenue\",fallback:\"Total Revenue\"},volume:{key:\"shoppingDashboard.stats.volume\",fallback:\"Volume\"},visits:{key:\"shoppingDashboard.stats.visits\",fallback:\"Site Visits\"},subtitle:{dcSv:{key:\"shoppingDashboard.stats.subtitle.dcSv\",fallback:\"DC-SV\"},conversionRate:{key:\"shoppingDashboard.stats.subtitle.conversionRate\",fallback:\"Conversion Rate\"}},trend:{increased:{key:\"shoppingDashboard.stats.trend.increased\",fallback:\"increased\"},decreased:{key:\"shoppingDashboard.stats.trend.decreased\",fallback:\"decreased\"},unchanged:{key:\"shoppingDashboard.stats.trend.unchanged\",fallback:\"unchanged\"}},details:{key:\"shoppingDashboard.stats.details\",fallback:\"details\"}},filter:{dateRange:{label:{key:\"shoppingDashboard.filter.dateRange.label\",fallback:\"Date Range\"},last7days:{key:\"shoppingDashboard.filter.dateRange.last7days\",fallback:\"Last 7 Days\"},last30days:{key:\"shoppingDashboard.filter.dateRange.last30days\",fallback:\"Last 30 Days\"},last90days:{key:\"shoppingDashboard.filter.dateRange.last90days\",fallback:\"Last 90 Days\"},thisMonth:{key:\"shoppingDashboard.filter.dateRange.thisMonth\",fallback:\"This Month\"}},dateRangeLabel:{key:\"shoppingDashboard.filter.dateRangeLabel\",fallback:\"Date Range\"},market:{label:{key:\"shoppingDashboard.filter.market.label\",fallback:\"Market\"},all:{key:\"shoppingDashboard.filter.market.all\",fallback:\"All Markets\"},us:{key:\"shoppingDashboard.filter.market.us\",fallback:\"United States\"},ca:{key:\"shoppingDashboard.filter.market.ca\",fallback:\"Canada\"},jp:{key:\"shoppingDashboard.filter.market.jp\",fallback:\"Japan\"},kr:{key:\"shoppingDashboard.filter.market.kr\",fallback:\"Korea\"},au:{key:\"shoppingDashboard.filter.market.au\",fallback:\"Australia\"},nz:{key:\"shoppingDashboard.filter.market.nz\",fallback:\"New Zealand\"}},marketLabel:{key:\"shoppingDashboard.filter.marketLabel\",fallback:\"Market\"},productSort:{label:{key:\"shoppingDashboard.filter.productSort.label\",fallback:\"Sort By\"},units:{key:\"shoppingDashboard.filter.productSort.units\",fallback:\"Units\"},revenue:{key:\"shoppingDashboard.filter.productSort.revenue\",fallback:\"Revenue\"},volume:{key:\"shoppingDashboard.filter.productSort.volume\",fallback:\"Volume\"},byUnits:{key:\"shoppingDashboard.filter.productSort.byUnits\",fallback:\"By: Units\"},byRevenue:{key:\"shoppingDashboard.filter.productSort.byRevenue\",fallback:\"By: Revenue\"},byVolume:{key:\"shoppingDashboard.filter.productSort.byVolume\",fallback:\"By: Volume\"}},signupView:{label:{key:\"shoppingDashboard.filter.signupView.label\",fallback:\"Show\"},all:{key:\"shoppingDashboard.filter.signupView.all\",fallback:\"All\"},members:{key:\"shoppingDashboard.filter.signupView.members\",fallback:\"Members\"},retail:{key:\"shoppingDashboard.filter.signupView.retail\",fallback:\"Retail\"},brandAffiliates:{key:\"shoppingDashboard.filter.signupView.brandAffiliates\",fallback:\"Brand Affiliates\"},showAll:{key:\"shoppingDashboard.filter.signupView.showAll\",fallback:\"Show: All\"},showMembers:{key:\"shoppingDashboard.filter.signupView.showMembers\",fallback:\"Show: Members\"},showRetail:{key:\"shoppingDashboard.filter.signupView.showRetail\",fallback:\"Show: Retail\"},showBrandAffiliates:{key:\"shoppingDashboard.filter.signupView.showBrandAffiliates\",fallback:\"Show: Brand Affiliates\"}},categorySort:{byRevenue:{key:\"shoppingDashboard.filter.categorySort.byRevenue\",fallback:\"By: Revenue\"},byUnits:{key:\"shoppingDashboard.filter.categorySort.byUnits\",fallback:\"By: Units\"}}},widget:{topProducts:{title:{key:\"shoppingDashboard.widget.topProducts.title\",fallback:\"Top Selling Products\"},viewAll:{key:\"shoppingDashboard.widget.topProducts.viewAll\",fallback:\"View All Products\"},units:{key:\"shoppingDashboard.widget.topProducts.units\",fallback:\"Units\"},revenue:{key:\"shoppingDashboard.widget.topProducts.revenue\",fallback:\"Revenue\"},loading:{key:\"shoppingDashboard.widget.topProducts.loading\",fallback:\"Loading products...\"},empty:{key:\"shoppingDashboard.widget.topProducts.empty\",fallback:\"No products available\"},ariaLabel:{key:\"shoppingDashboard.widget.topProducts.ariaLabel\",fallback:\"Top Selling Products widget\"},titleAriaLabel:{key:\"shoppingDashboard.widget.topProducts.titleAriaLabel\",fallback:\"Click to view full top products details page\"},sortAriaLabel:{key:\"shoppingDashboard.widget.topProducts.sortAriaLabel\",fallback:\"Sort products by\"},noImageAriaLabel:{key:\"shoppingDashboard.widget.topProducts.noImageAriaLabel\",fallback:\"No image available\"},unitsSuffix:{key:\"shoppingDashboard.widget.topProducts.unitsSuffix\",fallback:\"units\"},revenueSuffix:{key:\"shoppingDashboard.widget.topProducts.revenueSuffix\",fallback:\"revenue\"},dcSvSuffix:{key:\"shoppingDashboard.widget.topProducts.dcSvSuffix\",fallback:\"DC-SV\"},rank:{key:\"shoppingDashboard.widget.topProducts.rank\",fallback:\"Rank\"},trend:{key:\"shoppingDashboard.widget.topProducts.trend\",fallback:\"Trend\"}},conversionRate:{title:{key:\"shoppingDashboard.widget.conversionRate.title\",fallback:\"Conversion Rate\"},formula:{key:\"shoppingDashboard.widget.conversionRate.formula\",fallback:\"Orders \\xF7 Site visits\"},comparison:{key:\"shoppingDashboard.widget.conversionRate.comparison\",fallback:\"compared to this time last month\"},chartAriaLabel:{key:\"shoppingDashboard.widget.conversionRate.chartAriaLabel\",fallback:\"Conversion Rate chart showing daily rates\"},titleAriaLabel:{key:\"shoppingDashboard.widget.conversionRate.titleAriaLabel\",fallback:\"Click to view full conversion rate details page\"},filterAriaLabel:{key:\"shoppingDashboard.widget.conversionRate.filterAriaLabel\",fallback:\"Filter conversion rate by customer type\"},noData:{key:\"shoppingDashboard.widget.conversionRate.noData\",fallback:\"No data\"},noChange:{key:\"shoppingDashboard.widget.conversionRate.noChange\",fallback:\"No change\"},tooltipOrders:{key:\"shoppingDashboard.widget.conversionRate.tooltipOrders\",fallback:\"orders\"},tooltipVisits:{key:\"shoppingDashboard.widget.conversionRate.tooltipVisits\",fallback:\"visits\"},ordersPerSiteVisits:{key:\"shoppingDashboard.widget.conversionRate.ordersPerSiteVisits\",fallback:\"Orders / Site Visits\"}},signups:{title:{key:\"shoppingDashboard.widget.signups.title\",fallback:\"Sign-ups\"},total:{key:\"shoppingDashboard.widget.signups.total\",fallback:\"Total\"},members:{key:\"shoppingDashboard.widget.signups.members\",fallback:\"Members\"},retail:{key:\"shoppingDashboard.widget.signups.retail\",fallback:\"Retail\"},brandAffiliates:{key:\"shoppingDashboard.widget.signups.brandAffiliates\",fallback:\"Brand Affiliates\"},chartAriaLabel:{key:\"shoppingDashboard.widget.signups.chartAriaLabel\",fallback:\"Signups multi-line chart showing Total, Members, Retail, and Brand Affiliates\"},titleAriaLabel:{key:\"shoppingDashboard.widget.signups.titleAriaLabel\",fallback:\"Click to view full signups details page\"},filterAriaLabel:{key:\"shoppingDashboard.widget.signups.filterAriaLabel\",fallback:\"Filter signups view\"},noData:{key:\"shoppingDashboard.widget.signups.noData\",fallback:\"No data\"},noChange:{key:\"shoppingDashboard.widget.signups.noChange\",fallback:\"No change\"},totalSignupsInPeriod:{key:\"shoppingDashboard.widget.signups.totalSignupsInPeriod\",fallback:\"Total sign-ups in period\"},noTrendData:{key:\"shoppingDashboard.widget.signups.noTrendData\",fallback:\"No sign-up trend data available.\"}},topCategories:{title:{key:\"shoppingDashboard.widget.topCategories.title\",fallback:\"Top Categories\"},revenue:{key:\"shoppingDashboard.widget.topCategories.revenue\",fallback:\"Revenue\"},units:{key:\"shoppingDashboard.widget.topCategories.units\",fallback:\"Units\"},empty:{key:\"shoppingDashboard.widget.topCategories.empty\",fallback:\"No category data available\"},chartAriaLabel:{key:\"shoppingDashboard.widget.topCategories.chartAriaLabel\",fallback:\"Top Categories donut chart showing revenue distribution by category\"},titleAriaLabel:{key:\"shoppingDashboard.widget.topCategories.titleAriaLabel\",fallback:\"Click to view full categories details page\"},sortAriaLabel:{key:\"shoppingDashboard.widget.topCategories.sortAriaLabel\",fallback:\"Sort categories by\"}},menu:{ariaLabel:{key:\"shoppingDashboard.widget.menu.ariaLabel\",fallback:\"widget options\"},fullView:{key:\"shoppingDashboard.widget.menu.fullView\",fallback:\"Full View\"}}},navigation:{backToDashboard:{key:\"shoppingDashboard.navigation.backToDashboard\",fallback:\"Back to Dashboard\"},backAriaLabel:{key:\"shoppingDashboard.navigation.backAriaLabel\",fallback:\"Back to dashboard\"}},ariaLabel:{dashboard:{key:\"shoppingDashboard.ariaLabel.dashboard\",fallback:\"Shopping Dashboard\"},statsRow:{key:\"shoppingDashboard.ariaLabel.statsRow\",fallback:\"Key performance metrics\"},dashboardFilters:{key:\"shoppingDashboard.ariaLabel.dashboardFilters\",fallback:\"Dashboard filters\"},loadingDashboard:{key:\"shoppingDashboard.ariaLabel.loadingDashboard\",fallback:\"Loading dashboard data\"},dateRangeFilter:{key:\"shoppingDashboard.ariaLabel.dateRangeFilter\",fallback:\"Date range filter, currently selected:\"},marketFilter:{key:\"shoppingDashboard.ariaLabel.marketFilter\",fallback:\"Market filter, currently selected:\"},filterSuffix:{key:\"shoppingDashboard.ariaLabel.filterSuffix\",fallback:\"filter\"}},fullView:{signups:{columns:{id:{key:\"shoppingDashboard.fullView.signups.columns.id\",fallback:\"ID\"},name:{key:\"shoppingDashboard.fullView.signups.columns.name\",fallback:\"Name\"},date:{key:\"shoppingDashboard.fullView.signups.columns.date\",fallback:\"Date\"},type:{key:\"shoppingDashboard.fullView.signups.columns.type\",fallback:\"Type\"},email:{key:\"shoppingDashboard.fullView.signups.columns.email\",fallback:\"Email\"},status:{key:\"shoppingDashboard.fullView.signups.columns.status\",fallback:\"Status\"}},detailsTitle:{key:\"shoppingDashboard.fullView.signups.detailsTitle\",fallback:\"Signup Details\"}},conversionRate:{columns:{orderId:{key:\"shoppingDashboard.fullView.conversionRate.columns.orderId\",fallback:\"Order ID\"},date:{key:\"shoppingDashboard.fullView.conversionRate.columns.date\",fallback:\"Date\"},customer:{key:\"shoppingDashboard.fullView.conversionRate.columns.customer\",fallback:\"Customer\"},type:{key:\"shoppingDashboard.fullView.conversionRate.columns.type\",fallback:\"Type\"},items:{key:\"shoppingDashboard.fullView.conversionRate.columns.items\",fallback:\"Items\"},total:{key:\"shoppingDashboard.fullView.conversionRate.columns.total\",fallback:\"Total\"},bv:{key:\"shoppingDashboard.fullView.conversionRate.columns.bv\",fallback:\"BV\"},orderTotal:{key:\"shoppingDashboard.fullView.conversionRate.columns.orderTotal\",fallback:\"Order Total\"},totalSv:{key:\"shoppingDashboard.fullView.conversionRate.columns.totalSv\",fallback:\"Total SV\"}},orderDetailsTitle:{key:\"shoppingDashboard.fullView.conversionRate.orderDetailsTitle\",fallback:\"Order Details\"},notAvailable:{key:\"shoppingDashboard.fullView.conversionRate.notAvailable\",fallback:\"N/A\"}},products:{columns:{rank:{key:\"shoppingDashboard.fullView.products.columns.rank\",fallback:\"#\"},product:{key:\"shoppingDashboard.fullView.products.columns.product\",fallback:\"Product\"},unitsSold:{key:\"shoppingDashboard.fullView.products.columns.unitsSold\",fallback:\"Units Sold\"},revenue:{key:\"shoppingDashboard.fullView.products.columns.revenue\",fallback:\"Revenue\"},volume:{key:\"shoppingDashboard.fullView.products.columns.volume\",fallback:\"Volume (DC-SV)\"}},skuPrefix:{key:\"shoppingDashboard.fullView.products.skuPrefix\",fallback:\"SKU\"},noProducts:{key:\"shoppingDashboard.fullView.products.noProducts\",fallback:\"No products available.\"}},categories:{columns:{category:{key:\"shoppingDashboard.fullView.categories.columns.category\",fallback:\"Category\"},revenue:{key:\"shoppingDashboard.fullView.categories.columns.revenue\",fallback:\"Revenue\"},percentOfTotal:{key:\"shoppingDashboard.fullView.categories.columns.percentOfTotal\",fallback:\"% of Total\"},trend:{key:\"shoppingDashboard.fullView.categories.columns.trend\",fallback:\"Trend\"}},allCategoriesTitle:{key:\"shoppingDashboard.fullView.categories.allCategoriesTitle\",fallback:\"All Categories\"},noCategoryData:{key:\"shoppingDashboard.fullView.categories.noCategoryData\",fallback:\"No category data available.\"}}},dataTable:{noDataAvailable:{key:\"shoppingDashboard.dataTable.noDataAvailable\",fallback:\"No data available\"},sortableColumn:{key:\"shoppingDashboard.dataTable.sortableColumn\",fallback:\", sortable column\"}},pagination:{previousPage:{key:\"shoppingDashboard.pagination.previousPage\",fallback:\"Previous page\"},nextPage:{key:\"shoppingDashboard.pagination.nextPage\",fallback:\"Next page\"},goToPage:{key:\"shoppingDashboard.pagination.goToPage\",fallback:\"Go to page\"},of:{key:\"shoppingDashboard.pagination.of\",fallback:\"of\"}},defaults:{zeroTrend:{key:\"shoppingDashboard.defaults.zeroTrend\",fallback:\"+0%\"},noValue:{key:\"shoppingDashboard.defaults.noValue\",fallback:\"--\"}}};function a(e){return e.fallback}import{jsx as q,jsxs as Ut}from\"react/jsx-runtime\";var Ro=({shopTitle:e,dateRange:t,market:r,dateRangeLabel:i,isLoading:n=!1,stats:s,onDateRangeChange:u,onMarketChange:m})=>{let w=b=>{let x=b.target.value;u?.(x)},k=b=>{let x=b.target.value;m?.(x)},g=b=>{b.key===\"Escape\"&&b.target.blur()},d=()=>i||(s?.dateRange?s.dateRange.label:a(o.filter.dateRange.last30days));return Ut(wn,{as:\"header\",\"data-testid\":\"dashboard-header\",children:[Ut(Cn,{children:[q(vn,{\"data-testid\":\"dashboard-shop-title\",children:e??s?.shopTitle??a(o.title)}),q(kn,{\"aria-live\":\"polite\",\"data-testid\":\"dashboard-date-range-label\",children:d()})]}),q(Sn,{\"aria-label\":a(o.ariaLabel.dashboardFilters),\"data-testid\":\"dashboard-filters-section\",children:Ut(Tn,{children:[n&&q(Dn,{as:\"output\",\"aria-live\":\"polite\",\"aria-label\":a(o.ariaLabel.loadingDashboard),\"data-testid\":\"dashboard-loading-indicator\",children:q(hc,{})}),Ut(Rr,{children:[q(Mr,{htmlFor:\"filter-date-range\",children:a(o.filter.dateRangeLabel)}),q(Lr,{\"aria-hidden\":\"true\",children:q(Pn.default,{})}),Ut(Or,{id:\"filter-date-range\",\"data-testid\":\"filter-date-range\",value:t,onChange:w,onKeyDown:g,disabled:n,\"aria-label\":`${a(o.ariaLabel.dateRangeFilter)} ${a(o.filter.dateRange[t])}`,children:[q(\"option\",{value:\"last7days\",children:a(o.filter.dateRange.last7days)}),q(\"option\",{value:\"last30days\",children:a(o.filter.dateRange.last30days)}),q(\"option\",{value:\"last90days\",children:a(o.filter.dateRange.last90days)}),q(\"option\",{value:\"thisMonth\",children:a(o.filter.dateRange.thisMonth)})]})]}),Ut(Rr,{children:[q(Mr,{htmlFor:\"filter-market\",children:a(o.filter.marketLabel)}),q(Lr,{\"aria-hidden\":\"true\",children:q(Rn.default,{})}),Ut(Or,{id:\"filter-market\",\"data-testid\":\"filter-market\",value:r,onChange:k,onKeyDown:g,disabled:n,\"aria-label\":`${a(o.ariaLabel.marketFilter)} ${a(o.filter.market[r])}`,children:[q(\"option\",{value:\"all\",children:a(o.filter.market.all)}),q(\"option\",{value:\"us\",children:a(o.filter.market.us)}),q(\"option\",{value:\"ca\",children:a(o.filter.market.ca)}),q(\"option\",{value:\"jp\",children:a(o.filter.market.jp)}),q(\"option\",{value:\"kr\",children:a(o.filter.market.kr)}),q(\"option\",{value:\"au\",children:a(o.filter.market.au)}),q(\"option\",{value:\"nz\",children:a(o.filter.market.nz)})]})]})]})})]})};import Nc from\"react\";var On=te(aa()),Ln=te(ia()),Vn=te(Mn());import{jsx as Vr}from\"react/jsx-runtime\";function ut(e){switch(e){case\"up\":return Vr(On.default,{});case\"down\":return Vr(Ln.default,{});case\"neutral\":default:return Vr(Vn.default,{})}}function Tc(e){switch(e){case\"up\":return\"#4caf50\";case\"down\":return\"#f44336\";case\"neutral\":default:return\"#757575\"}}import{ColorUtils as Pc,styled as gt}from\"@nuskin/foundation-theme\";var{getGenomeColor:no}=Pc,$r=gt(\"div\")`\n display: flex;\n flex-direction: column;\n padding: 12px;\n background-color: ${({theme:e})=>no(e,\"N20\")};\n border: 1px solid ${({theme:e})=>no(e,\"N30\")};\n border-radius: 8px;\n min-height: 120px;\n transition: box-shadow 0.2s ease;\n\n &:hover {\n box-shadow: 0px 2px 8px rgba(0, 0, 0, 0.08);\n }\n\n @media (min-width: 768px) {\n padding: 20px;\n min-height: 140px;\n }\n\n @media (min-width: 1080px) {\n padding: 24px;\n min-height: 160px;\n }\n`,$n=gt(\"div\")`\n font-size: 12px;\n font-weight: 400;\n line-height: 1.4;\n color: ${({theme:e})=>no(e,\"N70\")};\n margin-bottom: 4px;\n text-transform: capitalize;\n\n @media (min-width: 768px) {\n font-size: 13px;\n margin-bottom: 6px;\n }\n\n @media (min-width: 1080px) {\n font-size: 14px;\n }\n`,Fn=gt(\"div\")`\n display: flex;\n flex-direction: row;\n align-items: flex-end;\n gap: 8px;\n margin-top: 8px;\n`,Nn=gt(\"div\")`\n font-size: 24px;\n font-weight: 700;\n line-height: 1.2;\n color: ${({theme:e})=>no(e,\"N100\")};\n\n @media (min-width: 768px) {\n font-size: 28px;\n }\n\n @media (min-width: 1080px) {\n font-size: 32px;\n }\n`,In=gt(\"div\")`\n font-size: 16px;\n font-weight: 400;\n line-height: normal;\n color: ${({theme:e})=>no(e,\"N70\")};\n padding-bottom: 2px;\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`,An=gt(\"div\")`\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: 12px;\n font-weight: 500;\n line-height: 1;\n flex-shrink: 0;\n color: ${({theme:e,direction:t})=>t===\"up\"?\"#22C55E\":t===\"down\"?\"#DC2626\":no(e,\"N70\")};\n\n svg {\n width: 14px;\n height: 14px;\n }\n\n @media (min-width: 768px) {\n font-size: 14px;\n margin-top: 12px;\n\n svg {\n width: 18px;\n height: 18px;\n }\n }\n`,zn=gt(\"span\")`\n display: flex;\n align-items: center;\n justify-content: center;\n`,Bn=gt(\"span\")`\n white-space: nowrap;\n`,En=gt(\"div\")`\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n`;import E from\"@mui/material/Skeleton\";import{styled as B}from\"@nuskin/foundation-theme\";import Mo from\"@mui/material/Skeleton\";var la=B(\"div\")`\n display: flex;\n flex-direction: column;\n padding: 16px;\n border-radius: 12px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 20px;\n }\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`,sa=B(\"div\")`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 16px;\n padding-bottom: 12px;\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`,Hn=B(\"div\")`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 12px 0;\n\n @media (min-width: 768px) {\n gap: 14px;\n padding: 14px 0;\n }\n`,_n=B(\"div\")`\n display: flex;\n flex-direction: column;\n padding: 12px;\n border-radius: 8px;\n min-height: 120px;\n\n @media (min-width: 600px) {\n padding: 20px;\n min-height: 140px;\n }\n @media (min-width: 900px) {\n padding: 24px;\n min-height: 160px;\n }\n`,Wn=B(\"div\")`\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n`,jn=B(\"div\")`\n margin-top: 8px;\n`,Kn=B(Mo)`\n margin-top: 4px;\n`,Un=B(\"div\")`\n flex: 1;\n min-width: 0;\n`,qn=B(\"div\")`\n display: flex;\n flex-direction: column;\n align-items: flex-end;\n gap: 4px;\n`,Gn=B(\"div\")`\n display: flex;\n align-items: flex-start;\n gap: 8px;\n margin-bottom: 16px;\n`,Yn=B(\"div\")`\n padding-top: 4px;\n`,Jn=B(Mo)`\n border-radius: 8px;\n height: 220px;\n\n @media (min-width: 600px) {\n height: 280px;\n }\n @media (min-width: 900px) {\n height: 340px;\n }\n`,Zn=B(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 16px;\n\n @media (min-width: 600px) {\n flex-direction: row;\n gap: 24px;\n }\n`,Qn=B(Mo)`\n width: 100%;\n height: 200px;\n border-radius: 8px;\n flex-shrink: 0;\n\n @media (min-width: 600px) {\n width: 200px;\n border-radius: 50%;\n }\n`,Xn=B(\"div\")`\n flex: 1;\n display: flex;\n flex-direction: column;\n gap: 4px;\n`,el=B(\"div\")`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 8px;\n`,tl=B(\"div\")`\n flex: 1;\n`,Rc=B(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 24px;\n\n @media (min-width: 600px) {\n gap: 32px;\n }\n @media (min-width: 900px) {\n gap: 40px;\n }\n`,Mc=B(\"div\")`\n display: flex;\n justify-content: space-between;\n align-items: center;\n flex-wrap: wrap;\n gap: 16px;\n`,Oc=B(\"div\")`\n display: flex;\n gap: 16px;\n`,Lc=B(\"div\")`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n\n @media (min-width: 600px) {\n grid-template-columns: repeat(3, 1fr);\n gap: 20px;\n }\n @media (min-width: 900px) {\n gap: 24px;\n }\n`,Vc=B(\"div\")`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n\n @media (min-width: 900px) {\n grid-template-columns: repeat(2, 1fr);\n gap: 24px;\n }\n`,Fr=B(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 24px;\n`,ol=B(\"div\")`\n padding: 24px;\n border-radius: 8px;\n display: flex;\n flex-direction: column;\n gap: 24px;\n`,al=B(\"div\")`\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 16px 0;\n gap: 8px;\n`,rl=B(Mo)`\n border-radius: 8px;\n height: 260px;\n\n @media (min-width: 600px) {\n height: 320px;\n }\n @media (min-width: 900px) {\n height: 400px;\n }\n`,Nr=B(\"div\")`\n padding: 20px;\n border-radius: 8px;\n display: flex;\n flex-direction: column;\n gap: 16px;\n`,da=B(Mo)`\n border-radius: 4px;\n`,il=B(\"div\")`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n\n @media (min-width: 600px) {\n grid-template-columns: repeat(3, 1fr);\n }\n`;import{jsx as P,jsxs as j}from\"react/jsx-runtime\";var Oo=()=>j(_n,{\"data-testid\":\"skeleton-stats-card\",children:[j(Wn,{children:[P(E,{variant:\"text\",width:80,height:18}),P(E,{variant:\"text\",width:48,height:16})]}),j(jn,{children:[P(E,{variant:\"text\",width:120,height:36}),P(Kn,{variant:\"text\",width:100,height:16})]})]}),$c=()=>j(Hn,{children:[P(E,{variant:\"rounded\",width:28,height:28}),P(E,{variant:\"rounded\",width:50,height:50}),j(Un,{children:[P(E,{variant:\"text\",width:\"70%\",height:18}),P(E,{variant:\"text\",width:\"50%\",height:14})]}),j(qn,{children:[P(E,{variant:\"text\",width:80,height:18}),P(E,{variant:\"text\",width:48,height:14})]})]}),nl=()=>j(la,{\"data-testid\":\"skeleton-products-list\",children:[j(sa,{children:[P(E,{variant:\"text\",width:160,height:22}),P(E,{variant:\"rounded\",width:100,height:32})]}),[\"product-1\",\"product-2\",\"product-3\",\"product-4\",\"product-5\"].map(e=>P($c,{},e))]}),pa=()=>j(la,{\"data-testid\":\"skeleton-chart-widget\",children:[j(sa,{children:[P(E,{variant:\"text\",width:140,height:22}),P(E,{variant:\"rounded\",width:110,height:32})]}),j(Gn,{children:[P(E,{variant:\"text\",width:100,height:36}),j(Yn,{children:[P(E,{variant:\"text\",width:60,height:18}),P(E,{variant:\"text\",width:140,height:14})]})]}),P(Jn,{variant:\"rounded\",width:\"100%\"})]}),Fc=()=>j(el,{children:[P(E,{variant:\"circular\",width:12,height:12}),j(tl,{children:[P(E,{variant:\"text\",width:\"60%\",height:16}),P(E,{variant:\"text\",width:\"40%\",height:14})]}),P(E,{variant:\"text\",width:36,height:18})]}),ca=()=>j(la,{\"data-testid\":\"skeleton-categories-pie\",children:[j(sa,{children:[P(E,{variant:\"text\",width:140,height:22}),P(E,{variant:\"rounded\",width:100,height:32})]}),j(Zn,{children:[P(Qn,{variant:\"circular\"}),P(Xn,{children:[\"legend-1\",\"legend-2\",\"legend-3\",\"legend-4\",\"legend-5\"].map(e=>P(Fc,{},e))})]})]});var Lt=()=>j(Fr,{\"data-testid\":\"skeleton-fullview-chart\",children:[j(ol,{children:[j(al,{children:[P(E,{variant:\"text\",width:140,height:52}),P(E,{variant:\"text\",width:80,height:24}),P(E,{variant:\"text\",width:160,height:16})]}),P(rl,{variant:\"rounded\",width:\"100%\"})]}),j(Nr,{children:[P(E,{variant:\"text\",width:200,height:24}),[\"table-row-1\",\"table-row-2\",\"table-row-3\",\"table-row-4\",\"table-row-5\"].map(e=>P(da,{variant:\"rounded\",width:\"100%\",height:44},e))]})]}),ll=()=>j(Fr,{\"data-testid\":\"skeleton-fullview-table\",children:[j(il,{children:[P(Oo,{}),P(Oo,{}),P(Oo,{})]}),j(Nr,{children:[P(E,{variant:\"text\",width:200,height:24}),P(da,{variant:\"rounded\",width:\"100%\",height:40}),[\"summary-row-1\",\"summary-row-2\",\"summary-row-3\",\"summary-row-4\",\"summary-row-5\",\"summary-row-6\",\"summary-row-7\",\"summary-row-8\"].map(e=>P(da,{variant:\"rounded\",width:\"100%\",height:44},e))]})]});import{jsx as qt,jsxs as ua}from\"react/jsx-runtime\";var Ic=({title:e,value:t,subtitle:r,trendDirection:i=\"neutral\",trendValue:n,testId:s,isLoading:u=!1})=>{if(u)return qt($r,{\"data-testid\":s,children:qt(Oo,{})});let m=()=>{let w=a(o.stats.trend.unchanged);return i===\"up\"?w=a(o.stats.trend.increased):i===\"down\"&&(w=a(o.stats.trend.decreased)),`${e} ${w} ${n??\"\"}`};return ua($r,{as:\"article\",\"aria-label\":`${e}: ${t}`,\"data-testid\":s,children:[ua(En,{children:[qt($n,{id:`stats-title-${s}`,children:e}),n&&ua(An,{as:\"output\",direction:i,\"aria-live\":\"polite\",\"aria-label\":m(),\"data-testid\":`stats-trend-${s}`,children:[qt(zn,{\"aria-hidden\":\"true\",children:ut(i)}),qt(Bn,{children:n})]})]}),ua(Fn,{children:[qt(Nn,{\"aria-describedby\":`stats-title-${s}`,\"data-testid\":`stats-value-${s}`,children:t}),r&&qt(In,{\"aria-label\":`${e} ${a(o.stats.details)}: ${r}`,\"data-testid\":`stats-subtitle-${s}`,children:r})]})]})},ft=Nc.memo(Ic);ft.displayName=\"StatsCard\";var Ol=te(sl());import tu from\"react\";import{ColorUtils as Ec,styled as me}from\"@nuskin/foundation-theme\";var{getGenomeColor:W}=Ec,fa=me(\"div\")`\n display: flex;\n flex-direction: column;\n padding: 16px;\n background-color: ${({theme:e})=>W(e,\"N20\")};\n border: 1px solid ${({theme:e})=>W(e,\"N30\")};\n border-radius: 12px;\n min-height: 320px;\n width: 100%;\n box-sizing: border-box;\n overflow: hidden;\n\n @media (min-width: 768px) {\n padding: 20px;\n min-height: 400px;\n }\n\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`,Ir=me(\"div\")`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 16px;\n padding-bottom: 12px;\n border-bottom: 1px solid ${({theme:e})=>W(e,\"N40\")};\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`,dl=me(\"div\")`\n display: flex;\n align-items: center;\n gap: 8px;\n`,Ar=me(\"h2\")`\n font-size: 16px;\n font-weight: 600;\n line-height: 1.4;\n color: ${({theme:e})=>W(e,\"N100\")};\n margin: 0;\n cursor: pointer;\n transition: all 0.2s ease-in-out;\n border: 0;\n background: transparent;\n padding: 0;\n text-align: left;\n\n &:hover {\n text-decoration: underline;\n color: ${({theme:e})=>W(e,\"A80\")};\n }\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`,pl=me(\"select\")`\n height: 32px;\n padding: 4px 8px;\n background-color: ${({theme:e})=>W(e,\"N20\")};\n border: 1px solid ${({theme:e})=>W(e,\"N40\")};\n border-radius: 6px;\n font-size: 12px;\n font-weight: 400;\n color: ${({theme:e})=>W(e,\"N100\")};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>W(e,\"N30\")};\n }\n\n &:focus {\n border-color: ${({theme:e})=>W(e,\"A70\")};\n box-shadow: 0 0 0 3px ${({theme:e})=>W(e,\"A20\")};\n }\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`,cl=me(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 12px;\n width: 100%;\n overflow: hidden;\n list-style: none;\n margin: 0;\n padding: 0;\n\n @media (min-width: 768px) {\n gap: 14px;\n }\n`,ul=me(\"div\")`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 12px;\n background-color: ${({theme:e})=>W(e,\"N20\")};\n border-radius: 8px;\n transition:\n background-color 0.2s ease,\n box-shadow 0.2s ease;\n cursor: pointer;\n width: 100%;\n box-sizing: border-box;\n overflow: hidden;\n list-style: none;\n\n &:not(:last-child) {\n border-bottom: 1px solid ${({theme:e})=>W(e,\"N40\")};\n }\n\n &:hover {\n background-color: ${({theme:e})=>W(e,\"N30\")};\n box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.06);\n }\n\n @media (min-width: 768px) {\n padding: 14px;\n gap: 14px;\n }\n`,gl=me(\"div\")`\n display: flex;\n align-items: center;\n justify-content: center;\n min-width: 24px;\n height: 24px;\n background-color: ${({theme:e})=>W(e,\"A10\")};\n color: ${({theme:e})=>W(e,\"A80\")};\n border-radius: 4px;\n font-size: 12px;\n font-weight: 600;\n\n @media (min-width: 768px) {\n min-width: 28px;\n height: 28px;\n font-size: 13px;\n }\n`,fl=me(\"img\")`\n width: 40px;\n height: 40px;\n border-radius: 8px;\n object-fit: cover;\n flex-shrink: 0;\n\n @media (min-width: 768px) {\n width: 50px;\n height: 50px;\n }\n`,ml=me(\"div\")`\n width: 40px;\n height: 40px;\n border-radius: 8px;\n background-color: ${({theme:e})=>W(e,\"N40\")};\n display: flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n color: ${({theme:e})=>W(e,\"N70\")};\n font-size: 10px;\n font-weight: 500;\n\n @media (min-width: 768px) {\n width: 50px;\n height: 50px;\n font-size: 11px;\n }\n`,hl=me(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex-grow: 1;\n min-width: 0;\n`,bl=me(\"div\")`\n font-size: 13px;\n font-weight: 500;\n line-height: 1.3;\n color: ${({theme:e})=>W(e,\"N100\")};\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n max-width: 18ch;\n\n @media (min-width: 768px) {\n font-size: 14px;\n max-width: none;\n }\n`,xl=me(\"div\")`\n font-size: 11px;\n font-weight: 400;\n line-height: 1.3;\n color: ${({theme:e})=>W(e,\"N70\")};\n\n @media (min-width: 768px) {\n font-size: 12px;\n }\n`,yl=me(\"div\")`\n display: flex;\n flex-direction: column;\n align-items: flex-end;\n gap: 4px;\n flex-shrink: 0;\n`,wl=me(\"div\")`\n font-size: 14px;\n font-weight: 600;\n line-height: 1.2;\n color: ${({theme:e})=>W(e,\"N100\")};\n white-space: nowrap;\n\n @media (min-width: 768px) {\n font-size: 16px;\n }\n`,Cl=me(\"div\")`\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: 11px;\n font-weight: 500;\n color: ${({theme:e,direction:t})=>t===\"up\"?\"#22C55E\":t===\"down\"?\"#DC2626\":W(e,\"N70\")};\n\n svg {\n width: 14px;\n height: 14px;\n }\n\n @media (min-width: 768px) {\n font-size: 12px;\n\n svg {\n width: 16px;\n height: 16px;\n }\n }\n`,vl=me(\"div\")`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n gap: 12px;\n padding: 40px 20px;\n text-align: center;\n color: ${({theme:e})=>W(e,\"N70\")};\n\n svg {\n width: 48px;\n height: 48px;\n color: ${({theme:e})=>W(e,\"N50\")};\n }\n`,kl=me(\"div\")`\n font-size: 14px;\n font-weight: 400;\n line-height: 1.4;\n color: ${({theme:e})=>W(e,\"N70\")};\n`;var Rl=te(Sl()),Ml=te(Dl());import{useState as Yc}from\"react\";import Jc from\"@mui/material/Menu\";import Zc from\"@mui/material/MenuItem\";import Qc from\"@mui/material/ListItemIcon\";import Xc from\"@mui/material/ListItemText\";import qc from\"@mui/material/IconButton\";import{styled as Gc}from\"@nuskin/foundation-theme\";var Tl=Gc(qc)(()=>({padding:\"4px\"}));import{Fragment as eu,jsx as lo,jsxs as Pl}from\"react/jsx-runtime\";var Ke=({widgetId:e,onFullView:t})=>{let[r,i]=Yc(null),n=!!r,s=w=>{i(w.currentTarget)},u=()=>{i(null)},m=()=>{u(),t&&t()};return Pl(eu,{children:[lo(Tl,{\"data-testid\":`widget-menu-button-${e}`,\"aria-label\":a(o.widget.menu.ariaLabel),\"aria-controls\":n?\"widget-menu\":void 0,\"aria-haspopup\":\"true\",\"aria-expanded\":n?\"true\":void 0,onClick:s,size:\"small\",children:lo(Rl.default,{fontSize:\"small\"})}),lo(Jc,{id:\"widget-menu\",\"data-testid\":`widget-menu-${e}`,anchorEl:r,open:n,onClose:u,MenuListProps:{\"aria-labelledby\":\"widget-options-button\"},anchorOrigin:{vertical:\"bottom\",horizontal:\"right\"},transformOrigin:{vertical:\"top\",horizontal:\"right\"},children:Pl(Zc,{onClick:m,\"data-testid\":\"widget-menu-item-fullview\",children:[lo(Qc,{children:lo(Ml.default,{fontSize:\"small\"})}),lo(Xc,{children:a(o.widget.menu.fullView)})]})})]})};import{jsx as oe,jsxs as rt}from\"react/jsx-runtime\";var ou=({products:e,productSort:t,isLoading:r=!1,maxProducts:i=5,onSortChange:n,onTitleClick:s})=>{let u=p=>{let f=p.target.value;n?.(f)},m=(p,f)=>{switch(f){case\"units\":return`${p.unitsSold.toLocaleString()} ${a(o.widget.topProducts.unitsSuffix)}`;case\"revenue\":return`$${p.revenue.toLocaleString()}`;case\"volume\":return`${p.volume.toLocaleString()} ${a(o.widget.topProducts.dcSvSuffix)}`;default:return`${p.unitsSold.toLocaleString()} ${a(o.widget.topProducts.unitsSuffix)}`}},w=(p,f)=>{switch(f){case\"units\":return`$${p.revenue.toLocaleString()} ${a(o.widget.topProducts.revenueSuffix)}`;case\"revenue\":return`${p.unitsSold.toLocaleString()} ${a(o.widget.topProducts.unitsSuffix)}`;case\"volume\":return`$${p.revenue.toLocaleString()} ${a(o.widget.topProducts.revenueSuffix)}`;default:return`$${p.revenue.toLocaleString()} ${a(o.widget.topProducts.revenueSuffix)}`}},k=(p,f)=>{let h=p.trend;if(!h)return\"\";switch(f){case\"units\":return h.units??\"\";case\"revenue\":return h.revenue??\"\";case\"volume\":return h.volume??\"\";default:return h.units??\"\"}},g=(p,f)=>{let h=k(p,f);return h?h.startsWith(\"+\")?\"up\":h.startsWith(\"-\")?\"down\":\"neutral\":\"neutral\"},d=e.slice(0,i),b=a(o.widget.topProducts.rank),x=a(o.widget.topProducts.trend),S=p=>p===\"up\"?a(o.stats.trend.increased):p===\"down\"?a(o.stats.trend.decreased):a(o.stats.trend.unchanged);return r&&e.length===0?oe(fa,{\"data-testid\":\"widget-top-products\",children:oe(nl,{})}):e.length===0?rt(fa,{\"data-testid\":\"widget-top-products\",children:[oe(Ir,{children:oe(Ar,{children:a(o.widget.topProducts.title)})}),rt(vl,{\"data-testid\":\"products-empty-state\",children:[oe(Ol.default,{}),oe(kl,{children:a(o.widget.topProducts.empty)})]})]}):rt(fa,{as:\"section\",\"data-testid\":\"widget-top-products\",\"aria-label\":a(o.widget.topProducts.ariaLabel),children:[rt(Ir,{children:[oe(Ar,{as:\"button\",onClick:s,\"aria-label\":a(o.widget.topProducts.titleAriaLabel),\"data-testid\":\"widget-title-top-products\",children:a(o.widget.topProducts.title)}),rt(dl,{children:[rt(pl,{id:\"product-sort\",\"data-testid\":\"product-sort-dropdown\",value:t,onChange:u,disabled:r,\"aria-label\":a(o.widget.topProducts.sortAriaLabel),children:[oe(\"option\",{value:\"units\",children:a(o.filter.productSort.byUnits)}),oe(\"option\",{value:\"revenue\",children:a(o.filter.productSort.byRevenue)}),oe(\"option\",{value:\"volume\",children:a(o.filter.productSort.byVolume)})]}),oe(Ke,{widgetId:\"top-products\",onFullView:s})]})]}),oe(cl,{as:\"ul\",\"data-testid\":\"products-list\",children:d.map((p,f)=>{let h=g(p,t),v=k(p,t);return rt(ul,{as:\"li\",\"data-testid\":`product-item-${f}`,\"aria-label\":`${b} ${p.rank}: ${p.name}, ${m(p,t)}`,children:[oe(gl,{\"aria-label\":`${b} ${p.rank}`,children:p.rank}),p.imageUrl?oe(fl,{src:p.imageUrl,alt:p.name,loading:\"lazy\",onError:C=>{C.currentTarget.hidden=!0}}):oe(ml,{\"aria-label\":a(o.widget.topProducts.noImageAriaLabel),children:p.name.substring(0,2).toUpperCase()}),rt(hl,{children:[oe(bl,{title:p.name,children:p.name}),oe(xl,{children:w(p,t)})]}),rt(yl,{children:[oe(wl,{children:m(p,t)}),v&&rt(Cl,{as:\"output\",direction:h,\"aria-live\":\"polite\",\"aria-label\":`${x}: ${S(h)} ${v}`,children:[oe(\"span\",{\"aria-hidden\":\"true\",children:ut(h)}),oe(\"span\",{children:v})]})]})]},p.id)})})]})},so=tu.memo(ou);so.displayName=\"TopSellingProductsList\";import Lo from\"react\";import{LineChart as ru,Line as iu,XAxis as nu,YAxis as lu,CartesianGrid as su,Tooltip as du,ResponsiveContainer as pu}from\"recharts\";import{ColorUtils as au,styled as De}from\"@nuskin/foundation-theme\";var{getGenomeColor:G}=au,zr=De(\"div\")`\n display: flex;\n flex-direction: column;\n padding: 16px;\n background-color: ${({theme:e})=>G(e,\"N20\")};\n border: 1px solid ${({theme:e})=>G(e,\"N30\")};\n border-radius: 12px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 20px;\n }\n\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`,Ll=De(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 8px;\n margin-bottom: 16px;\n padding-bottom: 12px;\n border-bottom: 1px solid ${({theme:e})=>G(e,\"N40\")};\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`,Vl=De(\"div\")`\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n`,$l=De(\"div\")`\n display: flex;\n align-items: center;\n gap: 8px;\n`,Fl=De(\"h2\")`\n font-size: 16px;\n font-weight: 600;\n line-height: 1.4;\n color: ${({theme:e})=>G(e,\"N100\")};\n margin: 0;\n cursor: pointer;\n transition: all 0.2s ease-in-out;\n border: 0;\n background: transparent;\n padding: 0;\n text-align: left;\n\n &:hover {\n text-decoration: underline;\n color: ${({theme:e})=>G(e,\"A80\")};\n }\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`,Nl=De(\"select\")`\n height: 32px;\n padding: 4px 8px;\n background-color: ${({theme:e})=>G(e,\"N20\")};\n border: 1px solid ${({theme:e})=>G(e,\"N40\")};\n border-radius: 6px;\n font-size: 12px;\n font-weight: 400;\n color: ${({theme:e})=>G(e,\"N100\")};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>G(e,\"N30\")};\n }\n\n &:focus {\n border-color: ${({theme:e})=>G(e,\"A70\")};\n box-shadow: 0 0 0 3px ${({theme:e})=>G(e,\"A20\")};\n }\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`,Il=De(\"div\")`\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n gap: 10px;\n margin-bottom: 8px;\n`,Al=De(\"div\")`\n font-size: 28px;\n font-weight: 700;\n line-height: 1.2;\n color: ${({theme:e})=>G(e,\"N100\")};\n\n @media (min-width: 768px) {\n font-size: 32px;\n }\n`,zl=De(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 2px;\n padding-top: 4px;\n\n .trend-line {\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: 14px;\n color: ${({theme:e,direction:t})=>t===\"up\"?\"#066100\":t===\"down\"?\"#DC2626\":G(e,\"N70\")};\n\n svg {\n width: 16px;\n height: 16px;\n }\n\n .change-value {\n font-weight: 600;\n line-height: 20px;\n }\n\n .change-percent {\n font-weight: 400;\n line-height: 20px;\n }\n }\n\n .comparison-text {\n font-size: 12px;\n font-weight: 400;\n line-height: 16px;\n color: ${({theme:e})=>G(e,\"N70\")};\n letter-spacing: 0.12px;\n }\n`,Bl=De(\"div\")`\n font-size: 12px;\n font-weight: 400;\n line-height: 16px;\n color: ${({theme:e})=>G(e,\"N100\")};\n margin-bottom: 16px;\n letter-spacing: 0.12px;\n`,El=De(\"div\")`\n width: 100%;\n height: 220px;\n margin-top: 16px;\n\n @media (min-width: 768px) {\n height: 280px;\n }\n\n @media (min-width: 1080px) {\n height: 340px;\n }\n\n .recharts-cartesian-grid-horizontal line,\n .recharts-cartesian-grid-vertical line {\n stroke: ${({theme:e})=>G(e,\"N40\")};\n stroke-width: 1px;\n }\n\n .recharts-text {\n fill: ${({theme:e})=>G(e,\"N70\")};\n font-size: 10px;\n }\n\n .recharts-tooltip-wrapper {\n z-index: 100;\n }\n`,Hl=De(\"div\")`\n background-color: ${({theme:e})=>G(e,\"N100\")};\n border: 1px solid ${({theme:e})=>G(e,\"N40\")};\n border-radius: 6px;\n padding: 8px 12px;\n box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.15);\n`,_l=De(\"div\")`\n font-size: 11px;\n font-weight: 600;\n color: ${({theme:e})=>G(e,\"N10\")};\n margin-bottom: 4px;\n`,Wl=De(\"div\")`\n font-size: 13px;\n font-weight: 700;\n color: ${({theme:e})=>G(e,\"A10\")};\n`,jl=De(\"div\")`\n font-size: 10px;\n font-weight: 400;\n color: ${({theme:e})=>G(e,\"N30\")};\n margin-top: 2px;\n`;import{jsx as Q,jsxs as $e}from\"react/jsx-runtime\";var cu={Jan:\"1\",Feb:\"2\",Mar:\"3\",Apr:\"4\",May:\"5\",Jun:\"6\",Jul:\"7\",Aug:\"8\",Sep:\"9\",Oct:\"10\",Nov:\"11\",Dec:\"12\"},uu={top:5,right:10,left:-10,bottom:5},Kl={fontSize:10},gu={r:3,fill:\"#3B82F6\"},fu={r:5},mu=e=>`${e}%`;function hu(e){let t=e.split(\" \");return t.length!==2?e:`${cu[t[0]]||t[0]}/${t[1]}`}var bu=({active:e,payload:t})=>{if(!e||!t?.length)return null;let r=t[0].payload;return $e(Hl,{children:[Q(_l,{children:r.date}),$e(Wl,{children:[r.rate.toFixed(2),\"%\"]}),$e(jl,{children:[r.orders,\" \",a(o.widget.conversionRate.tooltipOrders),\" /\",\" \",r.siteVisits.toLocaleString(),\" \",a(o.widget.conversionRate.tooltipVisits)]})]})},xu=({conversionData:e,conversionFilter:t,isLoading:r=!1,title:i,onFilterChange:n,onTitleClick:s})=>{let u=Lo.useCallback(S=>{let p=S.target.value;n?.(p)},[n]),m=a(o.widget.conversionRate.noData),w=a(o.widget.conversionRate.noChange),k=Lo.useMemo(()=>e.length===0?0:e[e.length-1].rate,[e]),g=Lo.useMemo(()=>{if(e.length<2)return{direction:\"neutral\",value:m};let S=e[e.length-1].rate,p=e[0].rate,f=S-p,h=f/p*100;if(Math.abs(h)<.1)return{direction:\"neutral\",value:w};let v=f>0?\"up\":\"down\",C=`${f>0?\"+\":\"\"}${f.toFixed(2)}%`;return{direction:v,value:C}},[e,w,m]),d=Lo.useMemo(()=>e.map(S=>({...S,shortDate:hu(S.date)})),[e]),b=S=>S===\"up\"?a(o.stats.trend.increased):S===\"down\"?a(o.stats.trend.decreased):a(o.stats.trend.unchanged);if(r&&e.length===0)return Q(zr,{\"data-testid\":\"widget-conversion-rate\",children:Q(pa,{})});let x=a(o.widget.conversionRate.chartAriaLabel);return $e(zr,{as:\"section\",\"data-testid\":\"widget-conversion-rate\",\"aria-label\":x,children:[$e(Ll,{children:[$e(Vl,{children:[Q(Fl,{as:\"button\",onClick:s,\"aria-label\":a(o.widget.conversionRate.titleAriaLabel),\"data-testid\":\"widget-title-conversion-rate\",children:i??a(o.widget.conversionRate.title)}),$e($l,{children:[$e(Nl,{id:\"conversion-filter\",\"data-testid\":\"conversion-filter-dropdown\",value:t,onChange:u,disabled:r,\"aria-label\":a(o.widget.conversionRate.filterAriaLabel),children:[Q(\"option\",{value:\"all\",children:a(o.filter.signupView.all)}),Q(\"option\",{value:\"members\",children:a(o.filter.signupView.members)}),Q(\"option\",{value:\"retail\",children:a(o.filter.signupView.retail)}),Q(\"option\",{value:\"brandAffiliates\",children:a(o.filter.signupView.brandAffiliates)})]}),Q(Ke,{widgetId:\"conversion-rate\",onFullView:s})]})]}),Q(Bl,{\"data-testid\":\"conversion-formula\",children:a(o.widget.conversionRate.formula)})]}),$e(Il,{children:[$e(Al,{\"aria-label\":`${a(o.widget.conversionRate.title)}: ${k.toFixed(2)}%`,\"data-testid\":\"conversion-metric-value\",children:[k.toFixed(2),\"%\"]}),g.value!==m&&$e(zl,{as:\"output\",direction:g.direction,\"aria-live\":\"polite\",\"aria-label\":`${b(g.direction)} ${g.value}`,\"data-testid\":\"conversion-metric-trend\",children:[$e(\"div\",{className:\"trend-line\",children:[Q(\"span\",{\"aria-hidden\":\"true\",children:ut(g.direction)}),Q(\"span\",{className:\"change-value\",children:g.value.replace(\"%\",\"\")}),Q(\"span\",{className:\"change-percent\",children:\"%\"})]}),Q(\"div\",{className:\"comparison-text\",children:a(o.widget.conversionRate.comparison)})]})]}),Q(El,{\"data-testid\":\"conversion-chart\",children:Q(pu,{width:\"100%\",height:\"100%\",minHeight:200,children:$e(ru,{data:d,margin:uu,children:[Q(su,{strokeDasharray:\"3 3\"}),Q(nu,{dataKey:\"shortDate\",tick:Kl,tickLine:!1,interval:\"preserveStartEnd\"}),Q(lu,{tick:Kl,tickLine:!1,tickFormatter:mu,domain:[\"dataMin - 0.5\",\"dataMax + 0.5\"]}),Q(du,{content:bu}),Q(iu,{type:\"monotone\",dataKey:\"rate\",stroke:\"#3B82F6\",strokeWidth:2,dot:gu,activeDot:fu})]})})})]})},po=Lo.memo(xu);po.displayName=\"ConversionRateChart\";import No from\"react\";import{LineChart as wu,Line as co,XAxis as Cu,YAxis as vu,CartesianGrid as ku,Tooltip as Su,ResponsiveContainer as Du}from\"recharts\";import{ColorUtils as yu,styled as Fe}from\"@nuskin/foundation-theme\";var{getGenomeColor:ne}=yu,Br=Fe(\"div\")`\n display: flex;\n flex-direction: column;\n padding: 16px;\n background-color: ${({theme:e})=>ne(e,\"N20\")};\n border: 1px solid ${({theme:e})=>ne(e,\"N30\")};\n border-radius: 12px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 20px;\n }\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`,Ul=Fe(\"div\")`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 16px;\n padding-bottom: 12px;\n border-bottom: 1px solid ${({theme:e})=>ne(e,\"N40\")};\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`,ql=Fe(\"div\")`\n display: flex;\n align-items: center;\n gap: 8px;\n`,Gl=Fe(\"h2\")`\n font-size: 16px;\n font-weight: 600;\n line-height: 1.4;\n color: ${({theme:e})=>ne(e,\"N100\")};\n margin: 0;\n cursor: pointer;\n transition: all 0.2s ease-in-out;\n border: 0;\n background: transparent;\n padding: 0;\n text-align: left;\n\n &:hover {\n text-decoration: underline;\n color: ${({theme:e})=>ne(e,\"A80\")};\n }\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`,Yl=Fe(\"select\")`\n height: 32px;\n padding: 4px 8px;\n background-color: ${({theme:e})=>ne(e,\"N20\")};\n border: 1px solid ${({theme:e})=>ne(e,\"N40\")};\n border-radius: 6px;\n font-size: 12px;\n font-weight: 400;\n color: ${({theme:e})=>ne(e,\"N100\")};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>ne(e,\"N30\")};\n }\n &:focus {\n border-color: ${({theme:e})=>ne(e,\"A70\")};\n box-shadow: 0 0 0 3px ${({theme:e})=>ne(e,\"A20\")};\n }\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`,Jl=Fe(\"div\")`\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n gap: 10px;\n margin-bottom: 16px;\n`,Zl=Fe(\"div\")`\n font-size: 28px;\n font-weight: 700;\n line-height: 1.2;\n color: ${({theme:e})=>ne(e,\"N100\")};\n\n @media (min-width: 768px) {\n font-size: 32px;\n }\n`,Ql=Fe(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 2px;\n padding-top: 4px;\n\n .trend-line {\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: 14px;\n color: ${({theme:e,direction:t})=>t===\"up\"?\"#066100\":t===\"down\"?\"#DC2626\":ne(e,\"N70\")};\n\n svg {\n width: 16px;\n height: 16px;\n }\n .change-value {\n font-weight: 600;\n line-height: 20px;\n }\n .change-percent {\n font-weight: 400;\n line-height: 20px;\n }\n }\n\n .comparison-text {\n font-size: 12px;\n font-weight: 400;\n line-height: 16px;\n color: ${({theme:e})=>ne(e,\"N70\")};\n letter-spacing: 0.12px;\n }\n`,Xl=Fe(\"div\")`\n width: 100%;\n height: 220px;\n margin-top: 16px;\n\n @media (min-width: 768px) {\n height: 280px;\n }\n @media (min-width: 1080px) {\n height: 340px;\n }\n\n .recharts-cartesian-grid-horizontal line,\n .recharts-cartesian-grid-vertical line {\n stroke: ${({theme:e})=>ne(e,\"N40\")};\n stroke-width: 1px;\n }\n .recharts-text {\n fill: ${({theme:e})=>ne(e,\"N70\")};\n font-size: 10px;\n }\n`,es=Fe(\"div\")`\n display: flex;\n flex-wrap: wrap;\n gap: 16px;\n margin-top: 16px;\n padding-top: 12px;\n border-top: 1px solid ${({theme:e})=>ne(e,\"N40\")};\n`,Vo=Fe(\"div\")`\n display: flex;\n align-items: center;\n gap: 8px;\n cursor: pointer;\n padding: 4px 8px;\n border-radius: 4px;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>ne(e,\"N30\")};\n }\n`,$o=Fe(\"div\")`\n width: 12px;\n height: 12px;\n border-radius: 50%;\n background-color: ${({color:e})=>e};\n flex-shrink: 0;\n`,Fo=Fe(\"span\")`\n font-size: 12px;\n font-weight: 400;\n color: ${({theme:e})=>ne(e,\"N70\")};\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`;import{Fragment as Ou,jsx as V,jsxs as Re}from\"react/jsx-runtime\";var Ue={total:\"#3B82F6\",members:\"#7B92A8\",retail:\"#A3B5C7\",brandAffiliates:\"#CBD6E0\"},Tu={Jan:\"1\",Feb:\"2\",Mar:\"3\",Apr:\"4\",May:\"5\",Jun:\"6\",Jul:\"7\",Aug:\"8\",Sep:\"9\",Oct:\"10\",Nov:\"11\",Dec:\"12\"},Pu={top:5,right:10,left:-10,bottom:5},ts={fontSize:10},uo={r:2};function Ru(e){let t=e.split(\" \");return t.length!==2?e:`${Tu[t[0]]||t[0]}/${t[1]}`}var Mu=({signupData:e,signupView:t,isLoading:r=!1,title:i,onViewChange:n,onTitleClick:s})=>{let u=No.useCallback(h=>{let v=h.target.value;n?.(v)},[n]),m=a(o.widget.signups.noData),w=a(o.widget.signups.noChange),k=No.useMemo(()=>e.length===0?0:e[e.length-1].total,[e]),g=No.useMemo(()=>{if(e.length<2)return{direction:\"neutral\",value:m};let h=e[e.length-1].total,v=e[0].total,C=h-v,T=C/v*100;if(Math.abs(T)<.1)return{direction:\"neutral\",value:w};let $=C>0?\"up\":\"down\",L=`${C>0?\"+\":\"\"}${C} (${T.toFixed(1)}%)`;return{direction:$,value:L}},[w,m,e]),d=No.useMemo(()=>e.map(h=>({...h,shortDate:Ru(h.date)})),[e]),b=a(o.widget.signups.total),x=a(o.widget.signups.members),S=a(o.widget.signups.retail),p=a(o.widget.signups.brandAffiliates),f=h=>h===\"up\"?a(o.stats.trend.increased):h===\"down\"?a(o.stats.trend.decreased):a(o.stats.trend.unchanged);return r&&e.length===0?V(Br,{\"data-testid\":\"widget-signups\",children:V(pa,{})}):Re(Br,{as:\"section\",\"data-testid\":\"widget-signups\",\"aria-label\":a(o.widget.signups.chartAriaLabel),children:[Re(Ul,{children:[V(Gl,{as:\"button\",onClick:s,\"aria-label\":a(o.widget.signups.titleAriaLabel),\"data-testid\":\"widget-title-signups\",children:i??a(o.widget.signups.title)}),Re(ql,{children:[Re(Yl,{id:\"signup-view\",\"data-testid\":\"signup-view-dropdown\",value:t,onChange:u,disabled:r,\"aria-label\":a(o.widget.signups.filterAriaLabel),children:[V(\"option\",{value:\"all\",children:a(o.filter.signupView.showAll)}),V(\"option\",{value:\"members\",children:a(o.filter.signupView.showMembers)}),V(\"option\",{value:\"retail\",children:a(o.filter.signupView.showRetail)}),V(\"option\",{value:\"brandAffiliates\",children:a(o.filter.signupView.showBrandAffiliates)})]}),V(Ke,{widgetId:\"signups\",onFullView:s})]})]}),Re(Jl,{\"data-testid\":\"signups-metric-display\",children:[V(Zl,{\"data-testid\":\"signups-metric-value\",\"aria-label\":`${b}: ${k.toLocaleString()}`,children:k.toLocaleString()}),g.value!==m&&Re(Ql,{as:\"output\",\"data-testid\":\"signups-metric-trend\",direction:g.direction,\"aria-live\":\"polite\",\"aria-label\":`${f(g.direction)} ${g.value}`,children:[Re(\"div\",{className:\"trend-line\",children:[V(\"span\",{\"aria-hidden\":\"true\",children:ut(g.direction)}),V(\"span\",{className:\"change-value\",children:g.value.split(\" \")[0]}),V(\"span\",{className:\"change-percent\",children:g.value.split(\" \")[1]})]}),V(\"div\",{className:\"comparison-text\",children:a(o.widget.conversionRate.comparison)})]})]}),V(Xl,{\"data-testid\":\"signups-chart\",children:V(Du,{width:\"100%\",height:\"100%\",minHeight:200,children:Re(wu,{data:d,margin:Pu,children:[V(ku,{strokeDasharray:\"3 3\"}),V(Cu,{dataKey:\"shortDate\",tick:ts,tickLine:!1,interval:\"preserveStartEnd\"}),V(vu,{tick:ts,tickLine:!1}),V(Su,{}),(t===\"all\"||t===\"members\")&&V(co,{type:\"monotone\",dataKey:t===\"all\"?\"total\":\"members\",stroke:t===\"all\"?Ue.total:Ue.members,strokeWidth:2,dot:uo,name:t===\"all\"?b:x}),t===\"all\"&&Re(Ou,{children:[V(co,{type:\"monotone\",dataKey:\"members\",stroke:Ue.members,strokeWidth:2,dot:uo,name:x}),V(co,{type:\"monotone\",dataKey:\"retail\",stroke:Ue.retail,strokeWidth:2,dot:uo,name:S}),V(co,{type:\"monotone\",dataKey:\"brandAffiliates\",stroke:Ue.brandAffiliates,strokeWidth:2,dot:uo,name:p})]}),t===\"retail\"&&V(co,{type:\"monotone\",dataKey:\"retail\",stroke:Ue.retail,strokeWidth:2,dot:uo,name:S}),t===\"brandAffiliates\"&&V(co,{type:\"monotone\",dataKey:\"brandAffiliates\",stroke:Ue.brandAffiliates,strokeWidth:2,dot:uo,name:p})]})})}),t===\"all\"&&Re(es,{\"data-testid\":\"signups-legend\",children:[Re(Vo,{\"data-testid\":\"legend-total\",children:[V($o,{color:Ue.total}),V(Fo,{children:b})]}),Re(Vo,{\"data-testid\":\"legend-members\",children:[V($o,{color:Ue.members}),V(Fo,{children:x})]}),Re(Vo,{\"data-testid\":\"legend-retail\",children:[V($o,{color:Ue.retail}),V(Fo,{children:S})]}),Re(Vo,{\"data-testid\":\"legend-brandAffiliates\",children:[V($o,{color:Ue.brandAffiliates}),V(Fo,{children:p})]})]})]})},ba=No.memo(Mu);ba.displayName=\"SignupsChart\";import Er from\"react\";import{PieChart as Vu,Pie as $u,Cell as Fu,ResponsiveContainer as Nu,Tooltip as Iu}from\"recharts\";import{ColorUtils as Lu,styled as re}from\"@nuskin/foundation-theme\";var{getGenomeColor:ae}=Lu,Vt=re(\"div\")`\n display: flex;\n flex-direction: column;\n padding: 16px;\n background-color: ${({theme:e})=>ae(e,\"N20\")};\n border: 1px solid ${({theme:e})=>ae(e,\"N30\")};\n border-radius: 12px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 20px;\n }\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`,go=re(\"div\")`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 16px;\n padding-bottom: 12px;\n border-bottom: 1px solid ${({theme:e})=>ae(e,\"N40\")};\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`,xa=re(\"div\")`\n display: flex;\n align-items: center;\n gap: 8px;\n`,fo=re(\"h2\")`\n font-size: 16px;\n font-weight: 600;\n line-height: 1.4;\n color: ${({theme:e})=>ae(e,\"N100\")};\n margin: 0;\n cursor: pointer;\n transition: all 0.2s ease-in-out;\n border: 0;\n background: transparent;\n padding: 0;\n text-align: left;\n\n &:hover {\n text-decoration: underline;\n color: ${({theme:e})=>ae(e,\"A80\")};\n }\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`,ya=re(\"select\")`\n height: 32px;\n padding: 4px 8px;\n background-color: ${({theme:e})=>ae(e,\"N20\")};\n border: 1px solid ${({theme:e})=>ae(e,\"N40\")};\n border-radius: 6px;\n font-size: 12px;\n font-weight: 400;\n color: ${({theme:e})=>ae(e,\"N100\")};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>ae(e,\"N30\")};\n }\n &:focus {\n border-color: ${({theme:e})=>ae(e,\"A70\")};\n box-shadow: 0 0 0 3px ${({theme:e})=>ae(e,\"A20\")};\n }\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`,wa=re(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 16px;\n\n @media (min-width: 768px) {\n flex-direction: row;\n gap: 24px;\n }\n`,Ca=re(\"div\")`\n position: relative;\n width: 100%;\n height: 200px;\n flex-shrink: 0;\n\n @media (min-width: 768px) {\n width: 200px;\n height: 200px;\n }\n`,va=re(\"div\")`\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n pointer-events: none;\n z-index: 1;\n width: 96px;\n`,ka=re(\"div\")`\n font-size: 10px;\n line-height: 1.2;\n font-weight: 500;\n color: ${({theme:e})=>ae(e,\"N70\")};\n`,Sa=re(\"div\")`\n margin-top: 2px;\n font-size: 16px;\n line-height: 1.2;\n font-weight: 700;\n color: ${({theme:e})=>ae(e,\"N100\")};\n`,Da=re(\"div\")`\n margin-top: 2px;\n font-size: 11px;\n line-height: 1.2;\n font-weight: 600;\n color: ${({direction:e,theme:t})=>e===\"up\"?\"#2e7d32\":e===\"down\"?\"#d32f2f\":ae(t,\"N70\")};\n`,Ta=re(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 8px;\n flex: 1;\n`,Pa=re(\"div\")`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 8px;\n border-radius: 6px;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>ae(e,\"N30\")};\n }\n`,Ra=re(\"div\")`\n width: 12px;\n height: 12px;\n border-radius: 50%;\n background-color: ${({color:e})=>e};\n flex-shrink: 0;\n`,Ma=re(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex: 1;\n min-width: 0;\n`,Oa=re(\"div\")`\n font-size: 13px;\n font-weight: 500;\n color: ${({theme:e})=>ae(e,\"N100\")};\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n\n @media (min-width: 768px) {\n font-size: 14px;\n }\n`,La=re(\"div\")`\n font-size: 11px;\n font-weight: 400;\n color: ${({theme:e})=>ae(e,\"N70\")};\n\n @media (min-width: 768px) {\n font-size: 12px;\n }\n`,Va=re(\"div\")`\n font-size: 14px;\n font-weight: 600;\n color: ${({theme:e})=>ae(e,\"N100\")};\n flex-shrink: 0;\n\n @media (min-width: 768px) {\n font-size: 16px;\n }\n`,$a=re(\"div\")`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n gap: 12px;\n padding: 40px 20px;\n text-align: center;\n color: ${({theme:e})=>ae(e,\"N70\")};\n`,Fa=re(\"div\")`\n font-size: 14px;\n font-weight: 400;\n line-height: 1.4;\n color: ${({theme:e})=>ae(e,\"N70\")};\n`;import{jsx as le,jsxs as Me}from\"react/jsx-runtime\";function Au(e){if(!e)return null;let t=e.replace(\"%\",\"\").trim(),r=Number(t);return Number.isFinite(r)?r:null}var zu=e=>`$${e.toLocaleString()}`,Bu=({categories:e,categorySort:t,isLoading:r=!1,title:i,onSortChange:n,onTitleClick:s})=>{let u=Er.useCallback(d=>{let b=d.target.value;n?.(b)},[n]),{sortedCategories:m,totalRevenue:w,trendDirection:k,formattedTrend:g}=Er.useMemo(()=>{let d=[...e].sort((v,C)=>t===\"revenue\"?C.revenue-v.revenue:C.percentage-v.percentage),b=d.reduce((v,C)=>v+C.revenue,0),x=d.reduce((v,C)=>{let T=Au(C.trend?.revenue);return T===null?v:{weightedSum:v.weightedSum+T*C.revenue,weight:v.weight+C.revenue}},{weightedSum:0,weight:0}),S=x.weight>0?x.weightedSum/x.weight:0,p=\"neutral\";S>0?p=\"up\":S<0&&(p=\"down\");let h=`${S>0?\"+\":\"\"}${S.toFixed(1)}%`;return{sortedCategories:d,totalRevenue:b,trendDirection:p,formattedTrend:h}},[e,t]);return r&&e.length===0?le(Vt,{\"data-testid\":\"widget-top-categories\",children:le(ca,{})}):e.length===0?Me(Vt,{\"data-testid\":\"widget-top-categories\",children:[le(go,{children:le(fo,{children:i??a(o.widget.topCategories.title)})}),le($a,{\"data-testid\":\"categories-empty-state\",children:le(Fa,{children:a(o.widget.topCategories.empty)})})]}):Me(Vt,{as:\"section\",\"data-testid\":\"widget-top-categories\",\"aria-label\":a(o.widget.topCategories.chartAriaLabel),children:[Me(go,{children:[le(fo,{as:\"button\",onClick:s,\"aria-label\":a(o.widget.topCategories.titleAriaLabel),\"data-testid\":\"widget-title-top-categories\",children:i??a(o.widget.topCategories.title)}),Me(xa,{children:[Me(ya,{id:\"category-sort\",\"data-testid\":\"category-sort-dropdown\",value:t,onChange:u,disabled:r,\"aria-label\":a(o.widget.topCategories.sortAriaLabel),children:[le(\"option\",{value:\"revenue\",children:a(o.filter.categorySort.byRevenue)}),le(\"option\",{value:\"units\",children:a(o.filter.categorySort.byUnits)})]}),le(Ke,{widgetId:\"top-categories\",onFullView:s})]})]}),Me(wa,{children:[Me(Ca,{\"data-testid\":\"categories-chart\",children:[le(Nu,{width:\"100%\",height:\"100%\",children:Me(Vu,{children:[le($u,{data:m,cx:\"50%\",cy:\"50%\",innerRadius:\"55%\",outerRadius:\"85%\",dataKey:\"revenue\",nameKey:\"name\",paddingAngle:2,children:m.map(d=>le(Fu,{fill:d.color},`cell-${d.id}`))}),le(Iu,{formatter:zu})]})}),Me(va,{\"data-testid\":\"categories-donut-center\",children:[le(ka,{children:a(o.stats.revenue)}),Me(Sa,{children:[\"$\",w.toLocaleString()]}),le(Da,{direction:k,children:g})]})]}),le(Ta,{\"data-testid\":\"categories-legend-container\",children:m.map((d,b)=>Me(Pa,{\"data-testid\":`category-legend-${b}`,children:[le(Ra,{color:d.color}),Me(Ma,{children:[le(Oa,{children:d.name}),Me(La,{children:[\"$\",d.revenue.toLocaleString()]})]}),Me(Va,{children:[d.percentage,\"%\"]})]},d.id))})]})]})},Na=Er.memo(Bu);Na.displayName=\"TopCategoriesPieChart\";import{jsx as mt,jsxs as Gt}from\"react/jsx-runtime\";var Eu=[],Hu=[],_u=[],Wu=[],Hr=({stats:e,topProducts:t,conversionData:r,signupData:i,categories:n,isLoading:s=!1,error:u,shopTitle:m,className:w,dateRange:k=\"last30days\",market:g=\"all\",productSort:d=\"units\",signupView:b=\"all\",conversionFilter:x=\"all\",categorySort:S=\"revenue\",onDateRangeChange:p,onMarketChange:f,onProductSortChange:h,onSignupViewChange:v,onConversionFilterChange:C,onCategorySortChange:T,onProductsTitleClick:$,onConversionTitleClick:L,onSignupsTitleClick:_,onCategoriesToTitleClick:l})=>{let c=t??Eu,y=r??Hu,D=i??_u,M=n??Wu;if(u)return mt(Sr,{as:\"main\",className:w,\"aria-label\":a(o.ariaLabel.dashboard),children:Gt(xn,{\"data-testid\":\"dashboard-error\",role:\"alert\",\"aria-live\":\"assertive\",children:[Gt(\"strong\",{children:[a(o.error),\":\"]}),\" \",u]})});let F=I=>I?I.startsWith(\"+\")?\"up\":I.startsWith(\"-\")?\"down\":\"neutral\":\"neutral\";return Gt(Sr,{as:\"main\",className:w,\"data-testid\":\"shopping-dashboard\",\"aria-label\":a(o.ariaLabel.dashboard),\"aria-busy\":s,children:[mt(Ro,{shopTitle:m,dateRange:k,market:g,isLoading:s,stats:e,onDateRangeChange:p,onMarketChange:f}),Gt(hn,{as:\"section\",\"data-testid\":\"stats-row\",\"aria-label\":a(o.ariaLabel.statsRow),children:[mt(ft,{title:a(o.stats.revenue),value:e?.metrics?.revenue??\"$0\",trendDirection:F(e?.trend?.revenue),trendValue:e?.trend?.revenue,testId:\"stats-card-revenue\",isLoading:s}),mt(ft,{title:a(o.stats.volume),value:e?.metrics?.volume??\"0\",subtitle:a(o.stats.subtitle.dcSv),trendDirection:F(e?.trend?.volume),trendValue:e?.trend?.volume,testId:\"stats-card-volume\",isLoading:s}),mt(ft,{title:a(o.stats.visits),value:e?.metrics?.siteVisits??\"0\",subtitle:`${e?.metrics?.conversionRate??\"0%\"} ${a(o.stats.subtitle.conversionRate)}`,trendDirection:F(e?.trend?.siteVisits),trendValue:e?.trend?.siteVisits,testId:\"stats-card-visits\",isLoading:s})]}),Gt(bn,{\"data-testid\":\"widget-container\",children:[Gt(Dr,{\"data-testid\":\"widget-row-1\",children:[mt(so,{products:c,productSort:d,isLoading:s,maxProducts:5,onSortChange:h,onTitleClick:$}),mt(ba,{signupData:D,signupView:b,isLoading:s,onViewChange:v,onTitleClick:_})]}),Gt(Dr,{\"data-testid\":\"widget-row-2\",children:[mt(po,{conversionData:y,conversionFilter:x,isLoading:s,onFilterChange:C,onTitleClick:L}),mt(Na,{categories:M,categorySort:S,isLoading:s,onSortChange:T,onTitleClick:l})]})]})]})};import K from\"react\";import wt,{useState as qr}from\"react\";var xs=te(os()),ys=te(Pr()),ws=te(as());import{ColorUtils as Ju,styled as Oe}from\"@nuskin/foundation-theme\";var{getGenomeColor:Ne}=Ju,rs=Oe(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 16px;\n margin-bottom: 24px;\n`,is=Oe(\"div\")`\n display: flex;\n align-items: center;\n`,ns=Oe(\"button\")`\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 0;\n border: none;\n background-color: transparent;\n color: ${({theme:e})=>Ne(e,\"N70\")};\n cursor: pointer;\n transition: color 0.2s ease;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n\n &:hover {\n color: ${({theme:e})=>Ne(e,\"N100\")};\n }\n\n &:focus {\n outline: 2px solid ${({theme:e})=>Ne(e,\"A70\")};\n outline-offset: 2px;\n border-radius: 4px;\n }\n\n svg {\n font-size: 16px;\n }\n\n span {\n line-height: 1;\n }\n`,ls=Oe(\"div\")`\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding-bottom: 16px;\n border-bottom: 1px solid ${({theme:e})=>Ne(e,\"N30\")};\n gap: 24px;\n\n @media (max-width: 767px) {\n align-items: flex-end;\n gap: 16px;\n }\n`,ss=Oe(\"div\")`\n display: flex;\n align-items: center;\n gap: 16px;\n flex: 1;\n\n @media (max-width: 767px) {\n display: none;\n }\n`,ds=Oe(\"h1\")`\n font-size: 16px;\n font-weight: 600;\n line-height: 22px;\n color: ${({theme:e})=>Ne(e,\"N100\")};\n margin: 0;\n white-space: nowrap;\n\n @media (max-width: 767px) {\n display: block;\n margin-bottom: 16px;\n }\n`,ps=Oe(\"p\")`\n font-size: 16px;\n font-weight: 400;\n line-height: 22px;\n color: ${({theme:e})=>Ne(e,\"N100\")};\n margin: 0;\n white-space: nowrap;\n`,cs=Oe(\"p\")`\n display: none;\n font-size: 16px;\n font-weight: 400;\n line-height: 22px;\n color: ${({theme:e})=>Ne(e,\"N100\")};\n margin: 0;\n white-space: nowrap;\n\n @media (max-width: 767px) {\n display: block;\n flex-shrink: 0;\n }\n`,us=Oe(\"div\")`\n display: flex;\n gap: 24px;\n align-items: center;\n flex-shrink: 0;\n\n @media (max-width: 767px) {\n flex-direction: column;\n align-items: flex-start;\n gap: 8px;\n }\n`,gs=Oe(\"div\")`\n display: flex;\n align-items: center;\n gap: 8px;\n`,fs=Oe(\"span\")`\n display: flex;\n align-items: center;\n justify-content: center;\n color: ${({theme:e})=>Ne(e,\"N70\")};\n\n svg {\n font-size: 16px;\n }\n`,ms=Oe(\"select\")`\n min-width: 120px;\n height: 32px;\n padding: 6px 8px;\n padding-right: 24px;\n background-color: transparent;\n border: none;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n color: ${({theme:e})=>Ne(e,\"N100\")};\n cursor: pointer;\n outline: none;\n transition: background-color 0.2s ease;\n appearance: none;\n background-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"><path fill=\"%23667085\" d=\"M6 8L2 4h8L6 8z\"/></svg>');\n background-repeat: no-repeat;\n background-position: right 4px center;\n\n &:hover {\n background-color: ${({theme:e})=>Ne(e,\"N20\")};\n border-radius: 4px;\n }\n\n &:focus {\n background-color: ${({theme:e})=>Ne(e,\"N20\")};\n border-radius: 4px;\n outline: 2px solid ${({theme:e})=>Ne(e,\"A70\")};\n outline-offset: 2px;\n }\n\n &:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n\n @media (max-width: 767px) {\n min-width: auto;\n width: auto;\n flex: none;\n padding-right: 24px;\n background-position: right 8px center;\n }\n`,hs=Oe(\"div\")`\n display: none;\n\n @media (max-width: 767px) {\n display: block;\n margin-bottom: 16px;\n }\n`,bs=Oe(\"h1\")`\n font-size: 16px;\n font-weight: 600;\n line-height: 22px;\n color: ${({theme:e})=>Ne(e,\"N100\")};\n margin: 0;\n`;import{jsx as Ie,jsxs as mo}from\"react/jsx-runtime\";var se=({title:e,dateRange:t,onBack:r,filters:i,onFilterChange:n})=>{let s=u=>u?mo(fs,{children:[u===\"calendar\"&&Ie(ys.default,{}),u===\"globe\"&&Ie(ws.default,{})]}):null;return mo(rs,{\"data-testid\":\"page-header\",children:[Ie(is,{children:mo(ns,{onClick:r,\"aria-label\":a(o.navigation.backAriaLabel),\"data-testid\":\"page-back-button\",type:\"button\",children:[Ie(xs.default,{}),Ie(\"span\",{children:a(o.navigation.backToDashboard)})]})}),Ie(hs,{children:Ie(bs,{children:e})}),mo(ls,{children:[mo(ss,{children:[Ie(ds,{\"data-testid\":\"page-header-title\",children:e}),Ie(ps,{\"data-testid\":\"page-header-date-range\",children:t})]}),i&&i.length>0&&n&&Ie(us,{\"data-testid\":\"page-header-filters\",children:i.map(u=>mo(gs,{children:[s(u.icon),Ie(ms,{id:`filter-${u.key}`,value:u.value,onChange:m=>n(u.key,m.target.value),disabled:u.disabled,\"aria-label\":`${u.label} ${a(o.ariaLabel.filterSuffix)}`,\"data-testid\":`filter-dropdown-${u.key}`,children:u.options.map(m=>Ie(\"option\",{value:m.value,children:u.label&&u.key===\"customerType\"?`${u.label} ${m.label}`:m.label},m.value))})]},u.key))}),Ie(cs,{children:t})]})]})};var Ls=te(Cs()),Vs=te(vs());import{ColorUtils as ag,styled as bt}from\"@nuskin/foundation-theme\";var{getGenomeColor:ht}=ag,ks=bt(\"div\")`\n width: 100%;\n overflow-x: auto;\n border-radius: 8px;\n border: 1px solid ${({theme:e})=>ht(e,\"N30\")};\n`,Ss=bt(\"table\")`\n width: 100%;\n border-collapse: collapse;\n`,Ds=bt(\"thead\")`\n background-color: ${({theme:e})=>ht(e,\"N20\")};\n border-bottom: 2px solid ${({theme:e})=>ht(e,\"N40\")};\n`,Ts=bt(\"th\")`\n padding: 12px 16px;\n font-size: 14px;\n font-weight: 600;\n color: ${({theme:e})=>ht(e,\"N100\")};\n text-align: left;\n cursor: ${({sortable:e})=>e?\"pointer\":\"default\"};\n user-select: none;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e,sortable:t})=>t?ht(e,\"N30\"):\"transparent\"};\n }\n\n &:focus {\n outline: 2px solid ${({theme:e})=>ht(e,\"A70\")};\n outline-offset: -2px;\n }\n`,Ps=bt(\"tbody\")``,_r=bt(\"tr\")`\n border-bottom: 1px solid ${({theme:e})=>ht(e,\"N30\")};\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>ht(e,\"N20\")};\n }\n\n &:last-child {\n border-bottom: none;\n }\n`,Wr=bt(\"td\")`\n padding: 12px 16px;\n font-size: 14px;\n font-weight: 400;\n color: ${({theme:e})=>ht(e,\"N100\")};\n text-align: left;\n`,Rs=bt(Wr)`\n text-align: center;\n`,Ms=bt(\"span\")`\n display: inline-flex;\n margin-left: 6px;\n opacity: ${({isActive:e})=>e?1:.4};\n transition: opacity 0.2s ease;\n\n svg {\n font-size: 16px;\n }\n`;import{jsx as qe,jsxs as Os}from\"react/jsx-runtime\";var Ge=({columns:e,data:t,sortable:r=!1,onSort:i,sortColumn:n,sortDirection:s=\"asc\",getRowKey:u})=>{let m=g=>{if(!r||!i)return;i(g,n===g&&s===\"asc\"?\"desc\":\"asc\")},w=(g,d)=>{(g.key===\"Enter\"||g.key===\" \")&&(g.preventDefault(),m(d))},k=g=>{if(n===g)return s===\"asc\"?\"ascending\":\"descending\"};return qe(ks,{\"data-testid\":\"data-table\",children:Os(Ss,{children:[qe(Ds,{children:qe(\"tr\",{children:e.map(g=>Os(Ts,{sortable:r&&g.sortable,onClick:()=>g.sortable&&m(g.key),onKeyDown:d=>g.sortable&&w(d,g.key),tabIndex:r&&g.sortable?0:-1,\"aria-sort\":k(g.key),\"aria-label\":`${g.label}${g.sortable?a(o.dataTable.sortableColumn):\"\"}`,\"data-testid\":`table-header-${g.key}`,children:[g.label,r&&g.sortable&&qe(Ms,{isActive:n===g.key,children:n===g.key&&s===\"desc\"?qe(Vs.default,{}):qe(Ls.default,{})})]},g.key))})}),qe(Ps,{children:t.length===0?qe(_r,{\"data-testid\":\"table-empty-row\",children:qe(Rs,{colSpan:e.length,children:a(o.dataTable.noDataAvailable)})}):t.map((g,d)=>qe(_r,{\"data-testid\":`table-row-${d}`,children:e.map(b=>qe(Wr,{\"data-testid\":`table-cell-${b.key}`,children:b.render?b.render(g[b.key],g):g[b.key]},b.key))},u?u(g,d):d))})]})})};var As=te($s()),zs=te(Fs());import{ColorUtils as pg,styled as _a}from\"@nuskin/foundation-theme\";var{getGenomeColor:Ye}=pg,Ns=_a(\"div\")`\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 8px;\n margin-top: 24px;\n`,Wa=_a(\"button\")`\n width: 32px;\n height: 32px;\n border-radius: 4px;\n border: none;\n background-color: ${({theme:e,isActive:t})=>t?Ye(e,\"A80\"):Ye(e,\"N20\")};\n color: ${({theme:e,isActive:t})=>t?\"#ffffff\":Ye(e,\"N100\")};\n font-size: 14px;\n font-weight: 500;\n cursor: pointer;\n transition: all 0.2s ease;\n\n &:hover:not(:disabled) {\n background-color: ${({theme:e,isActive:t})=>t?Ye(e,\"A70\"):Ye(e,\"N30\")};\n }\n\n &:focus {\n outline: 2px solid ${({theme:e})=>Ye(e,\"A70\")};\n outline-offset: 2px;\n }\n\n &:disabled {\n opacity: 0.4;\n cursor: not-allowed;\n }\n`,ja=_a(\"span\")`\n font-size: 14px;\n font-weight: 400;\n color: ${({theme:e})=>Ye(e,\"N70\")};\n margin: 0 8px;\n`,jr=_a(\"button\")`\n width: 32px;\n height: 32px;\n border-radius: 4px;\n border: none;\n background-color: ${({theme:e})=>Ye(e,\"N20\")};\n color: ${({theme:e})=>Ye(e,\"N100\")};\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n transition: background-color 0.2s ease;\n\n &:hover:not(:disabled) {\n background-color: ${({theme:e})=>Ye(e,\"N30\")};\n }\n\n &:focus {\n outline: 2px solid ${({theme:e})=>Ye(e,\"A70\")};\n outline-offset: 2px;\n }\n\n &:disabled {\n opacity: 0.4;\n cursor: not-allowed;\n }\n\n svg {\n font-size: 18px;\n }\n`;import{Fragment as Is,jsx as xt,jsxs as Ka}from\"react/jsx-runtime\";var Je=({currentPage:e,totalPages:t,onPageChange:r,itemsPerPage:i,totalItems:n})=>{let s=()=>{e>1&&r(e-1)},u=()=>{e<t&&r(e+1)},m=(x,S)=>{(x.key===\"Enter\"||x.key===\" \")&&(x.preventDefault(),S())},k=(()=>{if(t<=7)return Array.from({length:t},(S,p)=>p+1);let x=[];return e<=4?x.push(1,2,3,4,5):e>=t-3?x.push(t-4,t-3,t-2,t-1,t):x.push(e-1,e,e+1),x})(),g=i?(e-1)*i+1:null,d=i?Math.min(e*i,n??1/0):null,b=a(o.pagination.goToPage);return Ka(Ns,{\"data-testid\":\"pagination\",children:[xt(jr,{onClick:s,onKeyDown:x=>m(x,s),disabled:e===1,\"aria-label\":a(o.pagination.previousPage),\"data-testid\":\"pagination-previous\",type:\"button\",children:xt(As.default,{})}),t>7&&e>4&&Ka(Is,{children:[xt(Wa,{onClick:()=>r(1),isActive:!1,\"aria-label\":`${b} 1`,\"data-testid\":\"pagination-page-1\",type:\"button\",children:\"1\"}),xt(ja,{children:\"...\"})]}),k.map(x=>xt(Wa,{onClick:()=>r(x),isActive:e===x,\"aria-label\":`${b} ${x}`,\"aria-current\":e===x?\"page\":void 0,\"data-testid\":`pagination-page-${x}`,type:\"button\",children:x},x)),t>7&&e<t-3&&Ka(Is,{children:[xt(ja,{children:\"...\"}),xt(Wa,{onClick:()=>r(t),isActive:!1,\"aria-label\":`${b} ${t}`,\"data-testid\":`pagination-page-${t}`,type:\"button\",children:t})]}),xt(jr,{onClick:u,onKeyDown:x=>m(x,u),disabled:e===t,\"aria-label\":a(o.pagination.nextPage),\"data-testid\":\"pagination-next\",type:\"button\",children:xt(zs.default,{})}),i&&n&&Ka(ja,{as:\"output\",\"aria-live\":\"polite\",\"data-testid\":\"pagination-page-info\",children:[g,\"-\",d,\" \",a(o.pagination.of),\" \",n]})]})};function Ze(e,t){return Math.ceil(e.length/t)}function Qe(e,t,r){let i=(t-1)*r,n=i+r;return e.slice(i,n)}function cg(e,t,r=\"desc\"){return[...e].sort((i,n)=>{let s=i[t],u=n[t];return r===\"asc\"?s-u:u-s})}function ug(e,t,r=1){return t===0?\"0.0\":(e/t*100).toFixed(r)}var Bs={last7days:7,last30days:30,last90days:90,thisMonth:31},Es={last7days:\"Last 7 Days\",last30days:\"Last 30 Days\",last90days:\"Last 90 Days\",thisMonth:\"This Month\"};function gg(e){return Bs[e]??30}function Kr(e){return Es[e]??\"Last 30 Days\"}function de(e){return Kr(e)}function Hs(e){return`${[\"Jan\",\"Feb\",\"Mar\",\"Apr\",\"May\",\"Jun\",\"Jul\",\"Aug\",\"Sep\",\"Oct\",\"Nov\",\"Dec\"][e.getMonth()]} ${e.getDate()}`}function Ur(e){let t=new Date(e);return Hs(t)}function fg(e,t){return`${Ur(e)} - ${Ur(t)}`}function mg(e){return e.toISOString().split(\"T\")[0]}import{styled as ye}from\"@mui/material/styles\";import{Box as $t,Typography as Ft}from\"@mui/material\";import{ColorUtils as hg}from\"@nuskin/foundation-theme\";var{getGenomeColor:_s}=hg,he=ye($t)`\n display: flex;\n flex-direction: column;\n gap: 24px;\n padding: 24px;\n max-width: 1400px;\n margin: 0 auto;\n\n @media (max-width: 767px) {\n padding: 16px;\n gap: 16px;\n }\n`,Ua=ye($t)`\n display: flex;\n flex-direction: column;\n gap: 24px;\n padding: 24px;\n background-color: ${({theme:e})=>_s(e,\"N20\")};\n border-radius: 8px;\n box-shadow: ${({theme:e})=>e.shadows[1]};\n\n @media (max-width: 767px) {\n padding: 16px;\n gap: 16px;\n }\n`,qa=ye($t)`\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 16px 0;\n\n @media (max-width: 767px) {\n padding: 8px 0;\n }\n`,Ga=ye(Ft)`\n font-size: 3rem;\n font-weight: 600;\n color: ${({theme:e})=>e.palette.text.primary};\n line-height: 1.2;\n\n @media (max-width: 767px) {\n font-size: 2.5rem;\n }\n`,Ya=ye($t)`\n display: flex;\n align-items: center;\n gap: 4px;\n margin-top: 8px;\n font-size: 1.25rem;\n font-weight: 500;\n color: ${({theme:e,direction:t})=>t===\"up\"?e.palette.success.main:t===\"down\"?e.palette.error.main:e.palette.text.secondary};\n\n svg {\n font-size: 1.5rem;\n }\n\n @media (max-width: 767px) {\n font-size: 1rem;\n\n svg {\n font-size: 1.25rem;\n }\n }\n`,u0=ye(Ft)`\n margin-top: 4px;\n font-size: 0.875rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n\n @media (max-width: 767px) {\n font-size: 0.8125rem;\n }\n`,Ja=ye($t)`\n display: flex;\n flex-direction: column;\n gap: 12px;\n padding: 0;\n\n @media (max-width: 767px) {\n gap: 8px;\n }\n`,Nt=ye(Ft)`\n font-size: 1.25rem;\n font-weight: 600;\n color: ${({theme:e})=>e.palette.text.primary};\n\n @media (max-width: 767px) {\n font-size: 1.125rem;\n }\n`,Za=ye($t)`\n width: 100%;\n height: 400px;\n\n @media (max-width: 767px) {\n height: 200px;\n }\n`,It=ye($t)`\n display: flex;\n flex-direction: column;\n gap: 16px;\n\n ${({withCard:e=!0,theme:t})=>e&&`\n padding: 20px;\n background-color: ${_s(t,\"N20\")};\n border-radius: 8px;\n box-shadow: ${t.shadows[1]};\n\n @media (max-width: 767px) {\n padding: 16px;\n }\n `}\n`,g0=ye($t)`\n display: flex;\n justify-content: center;\n align-items: center;\n min-height: 400px;\n`,At=ye(Ft)`\n text-align: center;\n color: ${({theme:e})=>e.palette.text.secondary};\n font-size: 1rem;\n padding: 40px 20px;\n\n @media (max-width: 767px) {\n font-size: 0.875rem;\n padding: 32px 16px;\n }\n`,Ws=ye(Ft)`\n font-weight: 600;\n font-size: 14px;\n`,js=ye(Ft)`\n font-size: 13px;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,Ks=ye(Ft)`\n font-size: 13px;\n`,Us=ye(Ft)`\n font-size: 13px;\n color: ${({theme:e,status:t})=>t===\"Active\"?e.palette.success.main:e.palette.warning.main};\n`;import{styled as pe}from\"@mui/material/styles\";import{Box as yt,Typography as zt}from\"@mui/material\";import{ColorUtils as bg}from\"@nuskin/foundation-theme\";var{getGenomeColor:xg}=bg,qs=pe(yt)`\n display: flex;\n align-items: center;\n gap: 12px;\n`,Gs=pe(\"img\")`\n width: 40px;\n height: 40px;\n border-radius: 8px;\n object-fit: cover;\n`,Ys=pe(yt)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n`,Js=pe(zt)`\n font-size: 0.875rem;\n font-weight: 500;\n color: ${({theme:e})=>e.palette.text.primary};\n`,Zs=pe(zt)`\n font-size: 0.75rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,Qa=pe(zt)`\n font-size: 0.875rem;\n font-weight: 500;\n`,Qs=pe(yt)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`,Xs=pe(yt)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`,ed=pe(yt)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 16px;\n background-color: ${({theme:e})=>xg(e,\"N20\")};\n border: 1px solid ${({theme:e})=>e.palette.divider};\n border-radius: 8px;\n`,td=pe(yt)`\n display: flex;\n align-items: center;\n gap: 12px;\n flex: 1;\n`,od=pe(zt)`\n font-size: 1rem;\n font-weight: 700;\n color: ${({theme:e})=>e.palette.primary.main};\n min-width: 24px;\n`,ad=pe(\"img\")`\n width: 48px;\n height: 48px;\n border-radius: 8px;\n object-fit: cover;\n`,rd=pe(yt)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex: 1;\n`,id=pe(zt)`\n font-size: 0.875rem;\n font-weight: 600;\n`,nd=pe(zt)`\n font-size: 0.75rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,ld=pe(yt)`\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n gap: 8px;\n margin-top: 8px;\n padding-top: 8px;\n border-top: 1px solid ${({theme:e})=>e.palette.divider};\n`,Xa=pe(yt)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n text-align: center;\n`,er=pe(zt)`\n font-size: 0.625rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n text-transform: uppercase;\n`,tr=pe(zt)`\n font-size: 0.875rem;\n font-weight: 500;\n`;import yg from\"@mui/material/useMediaQuery\";var wg=\"(max-width:767px)\";function it(){return yg(wg,{noSsr:!0})}import{jsx as Y,jsxs as Te}from\"react/jsx-runtime\";function Cg(e){return{rank:e.rank,name:e.name,sku:`${a(o.fullView.products.skuPrefix)}-${e.id.replace(\"prod-\",\"\").padStart(3,\"0\")}`,image:e.imageUrl,units:e.unitsSold,revenue:e.revenue,volume:e.volume}}var Io=({products:e,dateRange:t,market:r,productSort:i,isLoading:n=!1,onBack:s,onDateRangeChange:u,onMarketChange:m,onProductSortChange:w})=>{let[k,g]=qr(1),[d,b]=qr(i===\"revenue\"?\"revenue\":\"units\"),[x,S]=qr(\"desc\"),p=10,f=it(),h=wt.useCallback(()=>s?.(),[s]),v=wt.useMemo(()=>[{key:\"dateRange\",label:a(o.filter.dateRange.label),value:t,icon:\"calendar\",options:[{value:\"last7days\",label:a(o.filter.dateRange.last7days)},{value:\"last30days\",label:a(o.filter.dateRange.last30days)},{value:\"last90days\",label:a(o.filter.dateRange.last90days)},{value:\"thisMonth\",label:a(o.filter.dateRange.thisMonth)}]},{key:\"market\",label:a(o.filter.market.label),value:r,icon:\"globe\",options:[{value:\"all\",label:a(o.filter.market.all)},{value:\"us\",label:a(o.filter.market.us)},{value:\"ca\",label:a(o.filter.market.ca)},{value:\"jp\",label:a(o.filter.market.jp)},{value:\"kr\",label:a(o.filter.market.kr)},{value:\"au\",label:a(o.filter.market.au)},{value:\"nz\",label:a(o.filter.market.nz)}]},{key:\"sort\",label:a(o.filter.productSort.label),value:i,options:[{value:\"units\",label:a(o.filter.productSort.units)},{value:\"revenue\",label:a(o.filter.productSort.revenue)},{value:\"volume\",label:a(o.filter.productSort.volume)}]}],[t,r,i]),C=wt.useCallback((y,D)=>{y===\"dateRange\"?u?.(D):y===\"market\"?m?.(D):y===\"sort\"&&(w?.(D),g(1))},[u,m,w]),T=wt.useCallback((y,D)=>{b(y),S(D),g(1)},[]),$=wt.useMemo(()=>e.map(Cg),[e]),L=wt.useMemo(()=>[...$].sort((y,D)=>{let M=y[d],F=D[d];return x===\"asc\"?M-F:F-M}),[$,d,x]),_=wt.useMemo(()=>Ze(L,p),[p,L]),l=wt.useMemo(()=>Qe(L,k,p),[k,p,L]),c=wt.useMemo(()=>[{key:\"rank\",label:a(o.fullView.products.columns.rank),sortable:!0},{key:\"name\",label:a(o.fullView.products.columns.product),sortable:!0,render:(y,D)=>Te(qs,{children:[D.image&&Y(Gs,{src:D.image,alt:D.name}),Te(Ys,{children:[Y(Js,{children:D.name}),Y(Zs,{children:D.sku})]})]})},{key:\"units\",label:a(o.fullView.products.columns.unitsSold),sortable:!0,render:y=>Y(Qa,{children:Number(y).toLocaleString()})},{key:\"revenue\",label:a(o.fullView.products.columns.revenue),sortable:!0,render:y=>Te(Qa,{children:[\"$\",Number(y).toLocaleString()]})},{key:\"volume\",label:a(o.fullView.products.columns.volume),sortable:!0,render:y=>Y(Qa,{children:Number(y).toLocaleString()})}],[]);return n?Te(he,{\"data-testid\":\"products-full-view\",children:[Y(se,{title:a(o.widget.topProducts.title),dateRange:de(t),onBack:h,filters:v,onFilterChange:C}),Y(ll,{})]}):e.length===0?Te(he,{\"data-testid\":\"products-full-view\",children:[Y(se,{title:a(o.widget.topProducts.title),dateRange:de(t),onBack:h,filters:v,onFilterChange:C}),Y(At,{\"data-testid\":\"products-fullview-empty\",children:a(o.fullView.products.noProducts)})]}):Te(he,{\"data-testid\":\"products-full-view\",children:[Y(se,{title:a(o.widget.topProducts.title),dateRange:de(t),onBack:h,filters:v,onFilterChange:C}),f?Y(Qs,{\"data-testid\":\"products-fullview-mobile-cards\",children:l.map(y=>Te(ed,{children:[Te(td,{children:[Te(od,{children:[\"#\",y.rank]}),y.image&&Y(ad,{src:y.image,alt:y.name}),Te(rd,{children:[Y(id,{children:y.name}),Y(nd,{children:y.sku})]})]}),Te(ld,{children:[Te(Xa,{children:[Y(er,{children:a(o.widget.topProducts.units)}),Y(tr,{children:y.units.toLocaleString()})]}),Te(Xa,{children:[Y(er,{children:a(o.widget.topProducts.revenue)}),Te(tr,{children:[\"$\",y.revenue.toLocaleString()]})]}),Te(Xa,{children:[Y(er,{children:a(o.filter.productSort.volume)}),Y(tr,{children:y.volume.toLocaleString()})]})]})]},y.rank))}):Y(Xs,{\"data-testid\":\"products-fullview-desktop-table\",children:Y(Ge,{columns:c,data:l,sortable:!0,onSort:T,sortColumn:d,sortDirection:x,getRowKey:y=>y.rank})}),_>1&&Y(Je,{currentPage:k,totalPages:_,onPageChange:g,itemsPerPage:p,totalItems:L.length})]})};var xd=te(aa()),yd=te(ia());import Xe,{useState as Sg}from\"react\";import{LineChart as Dg,Line as Tg,XAxis as Pg,YAxis as Rg,CartesianGrid as Mg,Tooltip as Og,ResponsiveContainer as Lg,Legend as Vg}from\"recharts\";import{styled as Ae}from\"@mui/material/styles\";import{Box as Yt,Typography as Ao}from\"@mui/material\";import{ColorUtils as vg}from\"@nuskin/foundation-theme\";var{getGenomeColor:kg}=vg,sd=Ae(Yt)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n padding: 16px;\n background-color: ${({theme:e})=>kg(e,\"N20\")};\n border: 1px solid ${({theme:e})=>e.palette.divider};\n border-radius: 8px;\n }\n`,dd=Ae(Yt)`\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n`,pd=Ae(Yt)`\n display: flex;\n flex-direction: column;\n gap: 4px;\n`,cd=Ae(Ao)`\n font-size: 1rem;\n font-weight: 600;\n`,ud=Ae(Ao)`\n font-size: 0.875rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,gd=Ae(\"a\")`\n font-size: 0.875rem;\n color: ${({theme:e})=>e.palette.primary.main};\n text-decoration: none;\n cursor: pointer;\n &:hover {\n text-decoration: underline;\n }\n`,fd=Ae(Yt)`\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n gap: 16px;\n padding-top: 12px;\n border-top: 1px solid ${({theme:e})=>e.palette.divider};\n`,or=Ae(Yt)`\n display: flex;\n flex-direction: column;\n gap: 4px;\n text-align: center;\n`,ar=Ae(Ao)`\n font-size: 0.75rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,rr=Ae(Ao)`\n font-size: 0.875rem;\n font-weight: 500;\n`,md=Ae(Yt)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`,hd=Ae(Yt)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`,bd=Ae(Ao)`\n margin-top: 4px;\n font-size: 0.875rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n @media (max-width: 767px) {\n font-size: 0.75rem;\n }\n`;import{jsx as H,jsxs as be}from\"react/jsx-runtime\";var zo=({conversionData:e,orders:t,dateRange:r,market:i,conversionFilter:n,isLoading:s=!1,onBack:u,onDateRangeChange:m,onMarketChange:w,onConversionFilterChange:k})=>{let[g,d]=Sg(1),b=10,x=it(),S=Xe.useCallback(()=>u?.(),[u]),p=Xe.useMemo(()=>e.length===0?0:e[e.length-1]?.rate||0,[e]),f=Xe.useMemo(()=>{if(e.length<2)return{direction:\"neutral\",value:a(o.defaults.zeroTrend)};let c=e[0].rate,D=((e[e.length-1]?.rate||0)-c)/c*100,M=\"neutral\";return D>0?M=\"up\":D<0&&(M=\"down\"),{direction:M,value:`${D>=0?\"+\":\"\"}${D.toFixed(1)}%`}},[e]),h=Xe.useCallback(c=>c===\"members\"?a(o.filter.signupView.members):c===\"retail\"?a(o.filter.signupView.retail):c===\"brandAffiliates\"?a(o.filter.signupView.brandAffiliates):a(o.filter.signupView.all),[]),v=Xe.useMemo(()=>h(n),[n,h]),C=Xe.useMemo(()=>[{key:\"dateRange\",label:a(o.filter.dateRange.label),value:r,icon:\"calendar\",options:[{value:\"last7days\",label:a(o.filter.dateRange.last7days)},{value:\"last30days\",label:a(o.filter.dateRange.last30days)},{value:\"last90days\",label:a(o.filter.dateRange.last90days)},{value:\"thisMonth\",label:a(o.filter.dateRange.thisMonth)}]},{key:\"market\",label:a(o.filter.market.label),value:i,icon:\"globe\",options:[{value:\"all\",label:a(o.filter.market.all)},{value:\"us\",label:a(o.filter.market.us)},{value:\"ca\",label:a(o.filter.market.ca)},{value:\"jp\",label:a(o.filter.market.jp)},{value:\"kr\",label:a(o.filter.market.kr)},{value:\"au\",label:a(o.filter.market.au)},{value:\"nz\",label:a(o.filter.market.nz)}]},{key:\"customerType\",label:a(o.filter.signupView.label),value:n,options:[{value:\"all\",label:a(o.filter.signupView.all)},{value:\"members\",label:a(o.filter.signupView.members)},{value:\"retail\",label:a(o.filter.signupView.retail)}]}],[n,r,i]),T=Xe.useCallback((c,y)=>{c===\"dateRange\"?m?.(y):c===\"market\"?w?.(y):c===\"customerType\"&&(k?.(y),d(1))},[k,m,w]),$=Xe.useMemo(()=>Ze(t,b),[b,t]),L=Xe.useMemo(()=>Qe(t,g,b),[g,b,t]),_=Xe.useMemo(()=>[{key:\"orderId\",label:a(o.fullView.conversionRate.columns.orderId),sortable:!0},{key:\"date\",label:a(o.fullView.conversionRate.columns.date),sortable:!0},{key:\"customerName\",label:a(o.fullView.conversionRate.columns.customer),sortable:!0},{key:\"customerType\",label:a(o.fullView.conversionRate.columns.type),sortable:!0},{key:\"items\",label:a(o.fullView.conversionRate.columns.items),sortable:!0},{key:\"total\",label:a(o.fullView.conversionRate.columns.total),sortable:!0,render:c=>`$${Number(c).toFixed(2)}`},{key:\"bv\",label:a(o.fullView.conversionRate.columns.bv),sortable:!0}],[]),l=Xe.useCallback(()=>n===\"members\"?\"#2e7d32\":n===\"retail\"?\"#ed6c02\":\"#1976d2\",[n]);return s?be(he,{\"data-testid\":\"conversion-rate-full-view\",children:[H(se,{title:a(o.widget.conversionRate.title),dateRange:de(r),onBack:S,filters:C,onFilterChange:T}),H(Lt,{})]}):be(he,{\"data-testid\":\"conversion-rate-full-view\",children:[H(se,{title:a(o.widget.conversionRate.title),dateRange:de(r),onBack:S,filters:C,onFilterChange:T}),be(Ua,{\"data-testid\":\"conversion-fullview-metric-chart\",children:[be(qa,{children:[be(Ga,{\"data-testid\":\"conversion-rate-value\",children:[p.toFixed(1),\"%\"]}),be(Ya,{direction:f.direction,\"data-testid\":\"conversion-rate-trend\",children:[f.direction===\"up\"&&H(xd.default,{}),f.direction===\"down\"&&H(yd.default,{}),f.value]}),H(bd,{children:a(o.widget.conversionRate.ordersPerSiteVisits)})]}),H(Ja,{children:H(Za,{\"data-testid\":\"conversion-fullview-chart\",children:H(Lg,{width:\"100%\",height:\"100%\",children:be(Dg,{data:e,children:[H(Mg,{strokeDasharray:\"3 3\"}),H(Pg,{dataKey:\"date\"}),H(Rg,{tickFormatter:c=>`${c}%`,domain:[0,\"auto\"]}),H(Og,{formatter:c=>typeof c==\"number\"?`${c.toFixed(2)}%`:typeof c==\"string\"?c:a(o.fullView.conversionRate.notAvailable)}),H(Vg,{}),H(Tg,{type:\"monotone\",dataKey:\"rate\",stroke:l(),strokeWidth:2,name:`${a(o.widget.conversionRate.title)} (${v})`,dot:!1})]})})})})]}),be(It,{\"data-testid\":\"conversion-fullview-table-section\",children:[be(Nt,{\"data-testid\":\"conversion-fullview-table-title\",children:[a(o.fullView.conversionRate.orderDetailsTitle),\" (\",t.length,\")\"]}),x?H(md,{\"data-testid\":\"conversion-fullview-mobile-orders\",children:L.map(c=>be(sd,{children:[be(dd,{children:[be(pd,{children:[H(cd,{children:c.customerName}),H(ud,{children:c.date})]}),H(gd,{children:c.orderId})]}),be(fd,{children:[be(or,{children:[H(ar,{children:a(o.fullView.conversionRate.columns.items)}),H(rr,{children:c.items})]}),be(or,{children:[H(ar,{children:a(o.fullView.conversionRate.columns.orderTotal)}),be(rr,{children:[\"$\",c.total.toFixed(2)]})]}),be(or,{children:[H(ar,{children:a(o.fullView.conversionRate.columns.totalSv)}),H(rr,{children:c.bv})]})]})]},c.orderId))}):H(hd,{\"data-testid\":\"conversion-fullview-desktop-table\",children:H(Ge,{columns:_,data:L,sortable:!0,getRowKey:c=>c.orderId})}),$>1&&H(Je,{currentPage:g,totalPages:$,onPageChange:d,itemsPerPage:b,totalItems:t.length})]})]})};var Dd=te(aa()),Td=te(ia());import Ct,{useState as Ig}from\"react\";import{LineChart as Ag,Line as Jt,XAxis as zg,YAxis as Bg,CartesianGrid as Eg,Tooltip as Hg,ResponsiveContainer as _g,Legend as Wg}from\"recharts\";import{styled as Bo}from\"@mui/material/styles\";import{Box as Gr,Typography as $g}from\"@mui/material\";import{ColorUtils as Fg}from\"@nuskin/foundation-theme\";var{getGenomeColor:Ng}=Fg,wd=Bo(Gr)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`,Cd=Bo(Gr)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`,vd=Bo(Gr)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 8px;\n padding: 16px;\n background-color: ${({theme:e})=>Ng(e,\"N20\")};\n border: 1px solid ${({theme:e})=>e.palette.divider};\n border-radius: 8px;\n }\n`,kd=Bo(Za)`\n min-height: 320px;\n\n @media (max-width: 767px) {\n min-height: 260px;\n height: 260px;\n }\n`,Sd=Bo($g)`\n margin-top: 4px;\n font-size: 0.875rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n`;import{Fragment as jg,jsx as N,jsxs as nt}from\"react/jsx-runtime\";var Zt={total:\"#3B82F6\",members:\"#7B92A8\",retail:\"#A3B5C7\",brandAffiliates:\"#5F7388\"};function ir(e){if(typeof e==\"number\")return Number.isFinite(e)?e:0;if(typeof e==\"string\"){let t=Number(e.replace(/,/g,\"\"));return Number.isFinite(t)?t:0}return 0}var Yr=({signupData:e,signups:t,dateRange:r,market:i,signupView:n,isLoading:s=!1,onBack:u,onDateRangeChange:m,onMarketChange:w,onSignupViewChange:k})=>{let[g,d]=Ig(1),b=10,x=it(),S=Ct.useCallback(()=>u?.(),[u]),p=Ct.useMemo(()=>e.map(l=>{let c=l,y=ir(c.members),D=ir(c.retail),M=ir(c.brandAffiliates??c.brandAffiliate??c.brand_affiliates??c.brand_affiliate),F=ir(c.total??c.all??c.signupTotal??c.value);return{...l,total:F>0?F:y+D+M,members:y,retail:D,brandAffiliates:M}}),[e]),f=Ct.useMemo(()=>p.length===0?0:p[p.length-1].total,[p]),h=Ct.useMemo(()=>{if(p.length<2)return{direction:\"neutral\",value:a(o.defaults.zeroTrend)};let l=p[0].total,c=p[p.length-1].total;if(l<=0)return{direction:\"neutral\",value:a(o.defaults.zeroTrend)};let y=(c-l)/l*100,D=\"neutral\";return y>0?D=\"up\":y<0&&(D=\"down\"),{direction:D,value:`${y>=0?\"+\":\"\"}${y.toFixed(1)}%`}},[p]),v=p.length>0,C=Ct.useMemo(()=>[{key:\"dateRange\",label:a(o.filter.dateRange.label),value:r,icon:\"calendar\",options:[{value:\"last7days\",label:a(o.filter.dateRange.last7days)},{value:\"last30days\",label:a(o.filter.dateRange.last30days)},{value:\"last90days\",label:a(o.filter.dateRange.last90days)},{value:\"thisMonth\",label:a(o.filter.dateRange.thisMonth)}]},{key:\"market\",label:a(o.filter.market.label),value:i,icon:\"globe\",options:[{value:\"all\",label:a(o.filter.market.all)},{value:\"us\",label:a(o.filter.market.us)},{value:\"ca\",label:a(o.filter.market.ca)},{value:\"jp\",label:a(o.filter.market.jp)},{value:\"kr\",label:a(o.filter.market.kr)},{value:\"au\",label:a(o.filter.market.au)},{value:\"nz\",label:a(o.filter.market.nz)}]},{key:\"signupView\",label:a(o.filter.signupView.label),value:n,options:[{value:\"all\",label:a(o.filter.signupView.all)},{value:\"members\",label:a(o.filter.signupView.members)},{value:\"retail\",label:a(o.filter.signupView.retail)},{value:\"brandAffiliates\",label:a(o.filter.signupView.brandAffiliates)}]}],[r,i,n]),T=Ct.useCallback((l,c)=>{l===\"dateRange\"?m?.(c):l===\"market\"?w?.(c):l===\"signupView\"&&(k?.(c),d(1))},[m,w,k]),$=Ct.useMemo(()=>Ze(t,b),[t,b]),L=Ct.useMemo(()=>Qe(t,g,b),[g,b,t]),_=Ct.useMemo(()=>[{key:\"id\",label:a(o.fullView.signups.columns.id),sortable:!0},{key:\"name\",label:a(o.fullView.signups.columns.name),sortable:!0},{key:\"date\",label:a(o.fullView.signups.columns.date),sortable:!0},{key:\"type\",label:a(o.fullView.signups.columns.type),sortable:!0},{key:\"email\",label:a(o.fullView.signups.columns.email),sortable:!0},{key:\"status\",label:a(o.fullView.signups.columns.status),sortable:!0}],[]);return s?nt(he,{\"data-testid\":\"signups-full-view\",children:[N(se,{title:a(o.widget.signups.title),dateRange:de(r),onBack:S,filters:C,onFilterChange:T}),N(Lt,{})]}):nt(he,{\"data-testid\":\"signups-full-view\",children:[N(se,{title:a(o.widget.signups.title),dateRange:de(r),onBack:S,filters:C,onFilterChange:T}),nt(Ua,{\"data-testid\":\"signups-fullview-metric-chart\",children:[nt(qa,{children:[N(Ga,{\"data-testid\":\"signups-total\",children:f.toLocaleString()}),nt(Ya,{direction:h.direction,children:[h.direction===\"up\"&&N(Dd.default,{}),h.direction===\"down\"&&N(Td.default,{}),h.value]}),N(Sd,{children:a(o.widget.signups.totalSignupsInPeriod)})]}),N(Ja,{children:v?N(kd,{\"data-testid\":\"signups-fullview-chart\",children:N(_g,{width:\"100%\",height:\"100%\",minHeight:240,children:nt(Ag,{data:p,children:[N(Eg,{strokeDasharray:\"3 3\"}),N(zg,{dataKey:\"date\"}),N(Bg,{}),N(Hg,{}),N(Wg,{}),n===\"all\"&&nt(jg,{children:[N(Jt,{type:\"monotone\",dataKey:\"total\",stroke:Zt.total,strokeWidth:2,name:a(o.widget.signups.total),dot:{r:2},connectNulls:!0}),N(Jt,{type:\"monotone\",dataKey:\"members\",stroke:Zt.members,strokeWidth:2,name:a(o.widget.signups.members),dot:{r:2},connectNulls:!0}),N(Jt,{type:\"monotone\",dataKey:\"retail\",stroke:Zt.retail,strokeWidth:2,name:a(o.widget.signups.retail),dot:{r:2},connectNulls:!0}),N(Jt,{type:\"monotone\",dataKey:\"brandAffiliates\",stroke:Zt.brandAffiliates,strokeWidth:2,name:a(o.widget.signups.brandAffiliates),dot:{r:2},connectNulls:!0})]}),n===\"members\"&&N(Jt,{type:\"monotone\",dataKey:\"members\",stroke:Zt.members,strokeWidth:2,name:a(o.widget.signups.members),dot:{r:2},connectNulls:!0}),n===\"retail\"&&N(Jt,{type:\"monotone\",dataKey:\"retail\",stroke:Zt.retail,strokeWidth:2,name:a(o.widget.signups.retail),dot:{r:2},connectNulls:!0}),n===\"brandAffiliates\"&&N(Jt,{type:\"monotone\",dataKey:\"brandAffiliates\",stroke:Zt.brandAffiliates,strokeWidth:2,name:a(o.widget.signups.brandAffiliates),dot:{r:2},connectNulls:!0})]})})}):N(At,{\"data-testid\":\"signups-fullview-chart-empty\",children:a(o.widget.signups.noTrendData)})})]}),nt(It,{\"data-testid\":\"signups-fullview-table-section\",children:[N(Nt,{\"data-testid\":\"signups-fullview-table-title\",children:`${a(o.fullView.signups.detailsTitle)} (${t.length})`}),x?N(wd,{\"data-testid\":\"signups-fullview-mobile-cards\",children:L.map(l=>nt(vd,{children:[N(Ws,{children:l.name}),nt(js,{children:[l.date,\" - \",l.type]}),N(Ks,{children:l.email}),N(Us,{status:l.status,children:l.status})]},l.id))}):N(Cd,{\"data-testid\":\"signups-fullview-desktop-table\",children:N(Ge,{columns:_,data:L,sortable:!0,getRowKey:l=>l.id})}),$>1&&N(Je,{currentPage:g,totalPages:$,onPageChange:d,itemsPerPage:b,totalItems:t.length})]})]})};import vt,{useState as Ug}from\"react\";import{PieChart as qg,Pie as Gg,Cell as Yg,ResponsiveContainer as Jg,Tooltip as Zg}from\"recharts\";import{styled as Eo}from\"@nuskin/foundation-theme\";import{styled as we}from\"@mui/material/styles\";import{Box as lt,Typography as ho}from\"@mui/material\";import{ColorUtils as Kg}from\"@nuskin/foundation-theme\";var{getGenomeColor:Jr}=Kg,nr=Eo(\"div\")`\n display: flex;\n align-items: center;\n gap: 8px;\n`,lr=Eo(\"div\")`\n flex: 1;\n`,sr=Eo(\"span\")`\n font-weight: 600;\n`,dr=Eo(\"span\")`\n font-size: 0.875rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,pr=Eo(\"span\")`\n font-weight: 600;\n`,Pd=we(lt)`\n display: flex;\n gap: 24px;\n padding: 24px;\n background-color: ${({theme:e})=>Jr(e,\"N20\")};\n border-radius: 8px;\n box-shadow: ${({theme:e})=>e.shadows[1]};\n\n @media (max-width: 767px) {\n flex-direction: column;\n padding: 16px;\n gap: 16px;\n }\n`,Rd=we(lt)`\n position: relative;\n width: 280px;\n height: 280px;\n flex-shrink: 0;\n\n @media (max-width: 767px) {\n width: 100%;\n height: 220px;\n }\n`,Md=we(lt)`\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n pointer-events: none;\n z-index: 1;\n width: 120px;\n`,Od=we(ho)`\n font-size: 0.75rem;\n line-height: 1.2;\n font-weight: 500;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,Ld=we(ho)`\n margin-top: 2px;\n font-size: 1.25rem;\n line-height: 1.2;\n font-weight: 700;\n color: ${({theme:e})=>e.palette.text.primary};\n`,Vd=we(ho)`\n margin-top: 2px;\n font-size: 0.875rem;\n line-height: 1.2;\n font-weight: 600;\n color: ${({direction:e,theme:t})=>e===\"up\"?t.palette.success.main:e===\"down\"?t.palette.error.main:t.palette.text.secondary};\n`,$d=we(lt)`\n display: flex;\n flex-direction: column;\n gap: 12px;\n flex: 1;\n`,Fd=we(lt)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 8px 12px;\n border-radius: 6px;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>Jr(e,\"N30\")};\n }\n`,cr=we(lt)`\n width: 12px;\n height: 12px;\n border-radius: 50%;\n background-color: ${({dotColor:e})=>e};\n flex-shrink: 0;\n`,Nd=we(lt)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex: 1;\n`,Id=we(ho)`\n font-size: 0.875rem;\n font-weight: 500;\n`,Ad=we(ho)`\n font-size: 0.75rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,zd=we(ho)`\n font-size: 1rem;\n font-weight: 600;\n flex-shrink: 0;\n`,Bd=we(lt)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`,Ed=we(lt)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`,Hd=we(lt)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 16px;\n background-color: ${({theme:e})=>Jr(e,\"N20\")};\n border: 1px solid ${({theme:e})=>e.palette.divider};\n border-radius: 8px;\n`;import{jsx as J,jsxs as ce}from\"react/jsx-runtime\";function Qg(e){if(!e)return null;let t=e.replace(\"%\",\"\").trim(),r=Number(t);return Number.isFinite(r)?r:null}var Zr=({categories:e,dateRange:t,market:r,categorySort:i,isLoading:n=!1,onBack:s,onDateRangeChange:u,onMarketChange:m,onCategorySortChange:w})=>{let[k,g]=Ug(1),d=10,b=it(),x=vt.useCallback(()=>s?.(),[s]),S=vt.useMemo(()=>[{key:\"dateRange\",label:a(o.filter.dateRange.label),value:t,icon:\"calendar\",options:[{value:\"last7days\",label:a(o.filter.dateRange.last7days)},{value:\"last30days\",label:a(o.filter.dateRange.last30days)},{value:\"last90days\",label:a(o.filter.dateRange.last90days)},{value:\"thisMonth\",label:a(o.filter.dateRange.thisMonth)}]},{key:\"market\",label:a(o.filter.market.label),value:r,icon:\"globe\",options:[{value:\"all\",label:a(o.filter.market.all)},{value:\"us\",label:a(o.filter.market.us)},{value:\"ca\",label:a(o.filter.market.ca)},{value:\"jp\",label:a(o.filter.market.jp)},{value:\"kr\",label:a(o.filter.market.kr)},{value:\"au\",label:a(o.filter.market.au)},{value:\"nz\",label:a(o.filter.market.nz)}]},{key:\"sort\",label:a(o.filter.productSort.label),value:i,options:[{value:\"revenue\",label:a(o.filter.productSort.revenue)},{value:\"units\",label:a(o.filter.productSort.units)}]}],[i,t,r]),p=vt.useCallback((l,c)=>{l===\"dateRange\"?u?.(c):l===\"market\"?m?.(c):l===\"sort\"&&(w?.(c),g(1))},[w,u,m]),f=vt.useMemo(()=>[...e].sort((l,c)=>i===\"revenue\"?c.revenue-l.revenue:c.percentage-l.percentage),[e,i]),{totalRevenue:h,totalRevenueTrendDirection:v,totalRevenueTrend:C}=vt.useMemo(()=>{let l=f.reduce((I,fe)=>I+fe.revenue,0),c=f.reduce((I,fe)=>{let xe=Qg(fe.trend?.revenue);return xe===null?I:{weightedSum:I.weightedSum+xe*fe.revenue,weight:I.weight+fe.revenue}},{weightedSum:0,weight:0}),y=c.weight>0?c.weightedSum/c.weight:0,D=\"neutral\";y>0?D=\"up\":y<0&&(D=\"down\");let F=`${y>0?\"+\":\"\"}${y.toFixed(1)}%`;return{totalRevenue:l,totalRevenueTrendDirection:D,totalRevenueTrend:F}},[f]),T=vt.useMemo(()=>f.slice(0,5),[f]),$=vt.useMemo(()=>Ze(f,d),[d,f]),L=vt.useMemo(()=>Qe(f,k,d),[k,d,f]),_=vt.useMemo(()=>[{key:\"name\",label:a(o.fullView.categories.columns.category),sortable:!0,render:(l,c)=>ce(nr,{children:[J(cr,{dotColor:c.color}),J(\"span\",{children:c.name})]})},{key:\"revenue\",label:a(o.fullView.categories.columns.revenue),sortable:!0,render:l=>`$${Number(l).toLocaleString()}`},{key:\"percentage\",label:a(o.fullView.categories.columns.percentOfTotal),sortable:!0,render:l=>`${Number(l)}%`},{key:\"trend\",label:a(o.fullView.categories.columns.trend),render:(l,c)=>c.trend?.revenue??a(o.defaults.noValue)}],[]);return n?ce(he,{\"data-testid\":\"categories-full-view\",children:[J(se,{title:a(o.widget.topCategories.title),dateRange:de(t),onBack:x,filters:S,onFilterChange:p}),J(Lt,{})]}):e.length===0?ce(he,{\"data-testid\":\"categories-full-view\",children:[J(se,{title:a(o.widget.topCategories.title),dateRange:de(t),onBack:x,filters:S,onFilterChange:p}),J(At,{\"data-testid\":\"categories-fullview-empty\",children:a(o.fullView.categories.noCategoryData)})]}):ce(he,{\"data-testid\":\"categories-full-view\",children:[J(se,{title:a(o.widget.topCategories.title),dateRange:de(t),onBack:x,filters:S,onFilterChange:p}),ce(Pd,{\"data-testid\":\"categories-fullview-top-section\",children:[ce(Rd,{\"data-testid\":\"categories-fullview-chart\",children:[J(Jg,{width:\"100%\",height:\"100%\",children:ce(qg,{children:[J(Gg,{data:f,cx:\"50%\",cy:\"50%\",innerRadius:\"50%\",outerRadius:\"85%\",dataKey:\"revenue\",nameKey:\"name\",paddingAngle:2,children:f.map(l=>J(Yg,{fill:l.color},`cell-${l.id}`))}),J(Zg,{formatter:l=>`$${l.toLocaleString()}`})]})}),ce(Md,{\"data-testid\":\"categories-fullview-donut-center\",children:[J(Od,{children:a(o.stats.revenue)}),ce(Ld,{children:[\"$\",h.toLocaleString()]}),J(Vd,{direction:v,children:C})]})]}),J($d,{\"data-testid\":\"categories-fullview-summary\",children:T.map(l=>ce(Fd,{children:[J(cr,{dotColor:l.color}),ce(Nd,{children:[J(Id,{children:l.name}),ce(Ad,{children:[\"$\",l.revenue.toLocaleString()]})]}),ce(zd,{children:[l.percentage,\"%\"]})]},l.id))})]}),ce(It,{\"data-testid\":\"categories-fullview-table-section\",children:[ce(Nt,{\"data-testid\":\"categories-fullview-table-title\",children:[a(o.fullView.categories.allCategoriesTitle),\" (\",f.length,\")\"]}),b?J(Ed,{children:L.map(l=>ce(Hd,{children:[J(cr,{dotColor:l.color}),ce(lr,{children:[J(sr,{children:l.name}),ce(dr,{children:[\"$\",l.revenue.toLocaleString()]})]}),ce(pr,{children:[l.percentage,\"%\"]})]},l.id))}):J(Bd,{children:J(Ge,{columns:_,data:L,sortable:!0,getRowKey:l=>l.id})}),$>1&&J(Je,{currentPage:k,totalPages:$,onPageChange:g,itemsPerPage:d,totalItems:f.length})]})]})};import{jsx as Ho}from\"react/jsx-runtime\";var Xg=\"shoppingDashboardView\",ef=[],tf=[],of=[],af=[],rf=[],nf=[];function Wd(e){return typeof e==\"object\"&&e!==null}function lf(e){return e===\"dashboard\"||e===\"products\"||e===\"conversion-rate\"||e===\"signups\"||e===\"categories\"}function ur(e,t){if(!Wd(e))return\"dashboard\";let r=e[t];return lf(r)?r:\"dashboard\"}function _d(e,t,r){return{...Wd(e)?e:{},[t]:r}}function sf(e,t){return{pathname:e?.pathname,search:e?.search,hash:e?.hash,state:t}}var df=({stats:e,topProducts:t,conversionData:r,signupData:i,categories:n,orders:s,signups:u,isLoading:m=!1,error:w,shopTitle:k,className:g,initialDateRange:d=\"last30days\",initialMarket:b=\"all\",initialProductSort:x=\"units\",initialSignupView:S=\"all\",initialConversionFilter:p=\"all\",initialCategorySort:f=\"revenue\",historyAdapter:h,historyStateKey:v=Xg,resetToDashboardOnMount:C=!0,onDateRangeChange:T,onMarketChange:$,onProductSortChange:L,onSignupViewChange:_,onConversionFilterChange:l,onCategorySortChange:c,onViewChange:y})=>{let[D,M]=K.useState(\"dashboard\"),F=K.useRef(!1),[I,fe]=K.useState(d),[xe,wo]=K.useState(b),[Ee,eo]=K.useState(x),[St,ee]=K.useState(S),[et,tt]=K.useState(p),[Bt,Co]=K.useState(f),Wo=t??ef,jo=r??tf,ze=i??of,vo=n??af,Dt=s??rf,Tt=u??nf,Ve=K.useCallback(z=>{M(z),y?.(z)},[y]),Et=K.useCallback(()=>h?ur(h.location?.state,v):typeof window>\"u\"?\"dashboard\":ur(window.history.state,v),[h,v]),He=K.useCallback((z,oo)=>{if(h){let Go=_d(h.location?.state,v,z),si=sf(h.location,Go);if(oo===\"replace\"){h.replace(si);return}h.push(si);return}if(typeof window>\"u\")return;let Wt=_d(window.history.state,v,z);if(oo===\"replace\"){window.history.replaceState(Wt,\"\");return}window.history.pushState(Wt,\"\")},[h,v]);K.useEffect(()=>{if(C?(He(\"dashboard\",\"replace\"),F.current=!1,Ve(\"dashboard\")):Ve(Et()),h)return h.listen((oo,Wt)=>{if(Wt===\"POP\"){let Go=ur(oo.state,v);F.current=Go!==\"dashboard\",Ve(Go)}});let z=oo=>{let Wt=ur(oo.state,v);F.current=Wt!==\"dashboard\",Ve(Wt)};return window.addEventListener(\"popstate\",z),()=>{window.removeEventListener(\"popstate\",z)}},[h,v,Et,C,Ve,He]);let _e=K.useCallback(z=>{F.current=!0,He(z,\"push\"),Ve(z)},[Ve,He]),Ht=K.useCallback(()=>{if(D!==\"dashboard\"&&F.current){if(h){h.goBack();return}typeof window<\"u\"&&window.history.back();return}F.current=!1,He(\"dashboard\",\"replace\"),Ve(\"dashboard\")},[D,h,Ve,He]),Pt=K.useCallback(z=>{fe(z),T?.(z)},[T]),_t=K.useCallback(z=>{wo(z),$?.(z)},[$]),Ko=K.useCallback(z=>{eo(z),L?.(z)},[L]),Uo=K.useCallback(z=>{ee(z),_?.(z)},[_]),A=K.useCallback(z=>{tt(z),l?.(z)},[l]),dt=K.useCallback(z=>{Co(z),c?.(z)},[c]),pt=K.useCallback(()=>{_e(\"products\")},[_e]),to=K.useCallback(()=>{_e(\"conversion-rate\")},[_e]),qo=K.useCallback(()=>{_e(\"signups\")},[_e]),wp=K.useCallback(()=>{_e(\"categories\")},[_e]);return D===\"products\"?Ho(Io,{products:Wo,dateRange:I,market:xe,productSort:Ee,isLoading:m,onBack:Ht,onDateRangeChange:Pt,onMarketChange:_t,onProductSortChange:Ko}):D===\"conversion-rate\"?Ho(zo,{conversionData:jo,orders:Dt,dateRange:I,market:xe,conversionFilter:et,isLoading:m,onBack:Ht,onDateRangeChange:Pt,onMarketChange:_t,onConversionFilterChange:A}):D===\"signups\"?Ho(Yr,{signupData:ze,signups:Tt,dateRange:I,market:xe,signupView:St,isLoading:m,onBack:Ht,onDateRangeChange:Pt,onMarketChange:_t,onSignupViewChange:Uo}):D===\"categories\"?Ho(Zr,{categories:vo,dateRange:I,market:xe,categorySort:Bt,isLoading:m,onBack:Ht,onDateRangeChange:Pt,onMarketChange:_t,onCategorySortChange:dt}):Ho(Hr,{stats:e,topProducts:Wo,conversionData:jo,signupData:ze,categories:vo,isLoading:m,error:w,shopTitle:k,className:g,dateRange:I,market:xe,productSort:Ee,signupView:St,conversionFilter:et,categorySort:Bt,onDateRangeChange:Pt,onMarketChange:_t,onProductSortChange:Ko,onSignupViewChange:Uo,onConversionFilterChange:A,onCategorySortChange:dt,onProductsTitleClick:pt,onConversionTitleClick:to,onSignupsTitleClick:qo,onCategoriesToTitleClick:wp})};import{styled as _o}from\"@nuskin/foundation-theme\";var Qr=_o(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 16px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n gap: 24px;\n }\n\n @media (min-width: 1080px) {\n gap: 24px;\n }\n`,jd=_o(\"div\")`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 1080px) {\n grid-template-columns: 1fr 1fr;\n gap: 24px;\n }\n`,Kd=_o(\"div\")`\n display: flex;\n flex-direction: column;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 1080px) {\n gap: 24px;\n justify-content: stretch;\n }\n\n & > * {\n flex: 1;\n }\n`,Ud=_o(\"div\")`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 1080px) {\n grid-template-columns: 1fr 1fr;\n gap: 24px;\n }\n`,qd=_o(\"div\")`\n padding: 24px;\n text-align: center;\n color: #d32f2f;\n background-color: #ffebee;\n border-radius: 8px;\n`;import Xr from\"react\";import{PieChart as pf,Pie as cf,Cell as uf,ResponsiveContainer as gf,Tooltip as ff}from\"recharts\";var R={title:{key:\"productOfferDashboard.title\",fallback:\"Performance Overview\"},error:{key:\"productOfferDashboard.error\",fallback:\"Failed to load dashboard data. Please try again.\"},stats:{revenue:{key:\"productOfferDashboard.stats.revenue\",fallback:\"Total Revenue\"},offersPurchased:{key:\"productOfferDashboard.stats.offersPurchased\",fallback:\"Offers Purchased\"},conversionRate:{key:\"productOfferDashboard.stats.conversionRate\",fallback:\"Conversion Rate\"},trendUp:{key:\"productOfferDashboard.stats.trendUp\",fallback:\"Trending up\"},trendDown:{key:\"productOfferDashboard.stats.trendDown\",fallback:\"Trending down\"},trendNeutral:{key:\"productOfferDashboard.stats.trendNeutral\",fallback:\"No change\"},comparedTo:{key:\"productOfferDashboard.stats.comparedTo\",fallback:\"compared to this time last month\"}},filter:{dateRange:{label:{key:\"productOfferDashboard.filter.dateRange.label\",fallback:\"Date Range\"},last7days:{key:\"productOfferDashboard.filter.dateRange.last7days\",fallback:\"Last 7 Days\"},last30days:{key:\"productOfferDashboard.filter.dateRange.last30days\",fallback:\"Last 30 Days\"},last90days:{key:\"productOfferDashboard.filter.dateRange.last90days\",fallback:\"Last 90 Days\"},thisMonth:{key:\"productOfferDashboard.filter.dateRange.thisMonth\",fallback:\"This Month\"}},market:{label:{key:\"productOfferDashboard.filter.market.label\",fallback:\"Market\"},all:{key:\"productOfferDashboard.filter.market.all\",fallback:\"All Markets\"}},offerSort:{byRevenue:{key:\"productOfferDashboard.filter.offerSort.byRevenue\",fallback:\"Revenue\"},byUnits:{key:\"productOfferDashboard.filter.offerSort.byUnits\",fallback:\"Units\"}},productSort:{byUnits:{key:\"productOfferDashboard.filter.productSort.byUnits\",fallback:\"Units\"},byRevenue:{key:\"productOfferDashboard.filter.productSort.byRevenue\",fallback:\"Revenue\"},byVolume:{key:\"productOfferDashboard.filter.productSort.byVolume\",fallback:\"Volume\"}},conversionFilter:{overall:{key:\"productOfferDashboard.filter.conversionFilter.overall\",fallback:\"Overall\"}}},widget:{topProducts:{title:{key:\"productOfferDashboard.widget.topProducts.title\",fallback:\"Top Selling Products\"},emptyState:{key:\"productOfferDashboard.widget.topProducts.emptyState\",fallback:\"No products data available\"}},conversionRate:{title:{key:\"productOfferDashboard.widget.conversionRate.title\",fallback:\"Conversion Rate\"},subtitle:{key:\"productOfferDashboard.widget.conversionRate.subtitle\",fallback:\"Orders \\xF7 Site visits\"}},topPerformingOffers:{title:{key:\"productOfferDashboard.widget.topPerformingOffers.title\",fallback:\"Top Performing Offers\"},totalRevenue:{key:\"productOfferDashboard.widget.topPerformingOffers.totalRevenue\",fallback:\"Total revenue\"},emptyState:{key:\"productOfferDashboard.widget.topPerformingOffers.emptyState\",fallback:\"No offers data available\"}},menu:{fullView:{key:\"productOfferDashboard.widget.menu.fullView\",fallback:\"Full View\"}}},navigation:{back:{key:\"productOfferDashboard.navigation.back\",fallback:\"Back to Dashboard\"}},ariaLabel:{dashboard:{key:\"productOfferDashboard.ariaLabel.dashboard\",fallback:\"Product Offer Performance Dashboard\"},statsCard:{key:\"productOfferDashboard.ariaLabel.statsCard\",fallback:\"Performance metric\"},conversionChart:{key:\"productOfferDashboard.ariaLabel.conversionChart\",fallback:\"Conversion rate chart\"},topProducts:{key:\"productOfferDashboard.ariaLabel.topProducts\",fallback:\"Top selling products\"},topOffers:{key:\"productOfferDashboard.ariaLabel.topOffers\",fallback:\"Top performing offers chart\"},widgetMenu:{key:\"productOfferDashboard.ariaLabel.widgetMenu\",fallback:\"Widget options menu\"},filterDateRange:{key:\"productOfferDashboard.ariaLabel.filterDateRange\",fallback:\"Filter by date range\"},filterMarket:{key:\"productOfferDashboard.ariaLabel.filterMarket\",fallback:\"Filter by market\"},backButton:{key:\"productOfferDashboard.ariaLabel.backButton\",fallback:\"Back to dashboard overview\"}},fullView:{topOffers:{title:{key:\"productOfferDashboard.fullView.topOffers.title\",fallback:\"Top Performing Offers\"},columnName:{key:\"productOfferDashboard.fullView.topOffers.columnName\",fallback:\"Offer Name\"},columnRevenue:{key:\"productOfferDashboard.fullView.topOffers.columnRevenue\",fallback:\"Revenue\"},columnPercentage:{key:\"productOfferDashboard.fullView.topOffers.columnPercentage\",fallback:\"Share\"},columnTrend:{key:\"productOfferDashboard.fullView.topOffers.columnTrend\",fallback:\"Trend\"}}},defaults:{trendZero:{key:\"productOfferDashboard.defaults.trendZero\",fallback:\"+0%\"},noData:{key:\"productOfferDashboard.defaults.noData\",fallback:\"--\"}}};function O(e){return e.fallback}import{jsx as ue,jsxs as Le}from\"react/jsx-runtime\";function mf(e){if(!e)return null;let t=e.replace(\"%\",\"\").trim(),r=Number(t);return Number.isFinite(r)?r:null}var hf=e=>`$${e.toLocaleString()}`,bf=({offers:e,offerSort:t,isLoading:r=!1,title:i,onSortChange:n,onTitleClick:s})=>{let u=Xr.useCallback(d=>{let b=d.target.value;n?.(b)},[n]),{sortedOffers:m,totalRevenue:w,trendDirection:k,formattedTrend:g}=Xr.useMemo(()=>{let d=[...e].sort((v,C)=>t===\"revenue\"?C.revenue-v.revenue:C.percentage-v.percentage),b=d.reduce((v,C)=>v+C.revenue,0),x=d.reduce((v,C)=>{let T=mf(C.trend?.revenue);return T===null?v:{weightedSum:v.weightedSum+T*C.revenue,weight:v.weight+C.revenue}},{weightedSum:0,weight:0}),S=x.weight>0?x.weightedSum/x.weight:0,p=\"neutral\";S>0?p=\"up\":S<0&&(p=\"down\");let h=`${S>0?\"+\":\"\"}${S.toFixed(1)}%`;return{sortedOffers:d,totalRevenue:b,trendDirection:p,formattedTrend:h}},[e,t]);return r&&e.length===0?ue(Vt,{\"data-testid\":\"widget-top-offers\",children:ue(ca,{})}):e.length===0?Le(Vt,{\"data-testid\":\"widget-top-offers\",children:[ue(go,{children:ue(fo,{children:i??O(R.widget.topPerformingOffers.title)})}),ue($a,{\"data-testid\":\"top-offers-empty-state\",children:ue(Fa,{children:O(R.widget.topPerformingOffers.emptyState)})})]}):Le(Vt,{as:\"section\",\"data-testid\":\"widget-top-offers\",\"aria-label\":O(R.ariaLabel.topOffers),children:[Le(go,{children:[ue(fo,{as:\"button\",onClick:s,\"aria-label\":O(R.ariaLabel.topOffers),\"data-testid\":\"widget-title-top-offers\",children:i??O(R.widget.topPerformingOffers.title)}),Le(xa,{children:[Le(ya,{id:\"offer-sort\",\"data-testid\":\"offer-sort-dropdown\",value:t,onChange:u,disabled:r,\"aria-label\":O(R.ariaLabel.topOffers),children:[ue(\"option\",{value:\"revenue\",children:O(R.filter.offerSort.byRevenue)}),ue(\"option\",{value:\"units\",children:O(R.filter.offerSort.byUnits)})]}),ue(Ke,{widgetId:\"top-offers\",onFullView:s})]})]}),Le(wa,{children:[Le(Ca,{\"data-testid\":\"top-offers-chart\",children:[ue(gf,{width:\"100%\",height:\"100%\",children:Le(pf,{children:[ue(cf,{data:m,cx:\"50%\",cy:\"50%\",innerRadius:\"55%\",outerRadius:\"85%\",dataKey:\"revenue\",nameKey:\"name\",paddingAngle:2,children:m.map(d=>ue(uf,{fill:d.color},`cell-${d.id}`))}),ue(ff,{formatter:hf})]})}),Le(va,{\"data-testid\":\"top-offers-donut-center\",children:[ue(ka,{children:O(R.widget.topPerformingOffers.totalRevenue)}),Le(Sa,{children:[\"$\",w.toLocaleString()]}),ue(Da,{direction:k,children:g})]})]}),ue(Ta,{\"data-testid\":\"top-offers-legend-container\",children:m.map((d,b)=>Le(Pa,{\"data-testid\":`offer-legend-${b}`,children:[ue(Ra,{color:d.color}),Le(Ma,{children:[ue(Oa,{children:d.name}),Le(La,{children:[\"$\",d.revenue.toLocaleString()]})]}),Le(Va,{children:[d.percentage,\"%\"]})]},d.id))})]})]})},gr=Xr.memo(bf);gr.displayName=\"TopPerformingOffersPieChart\";import{jsx as Qt,jsxs as bo}from\"react/jsx-runtime\";var xf=[],yf=[],wf=[],ei=({stats:e,topProducts:t,conversionData:r,topOffers:i,isLoading:n=!1,error:s,dashboardTitle:u,className:m,dateRange:w=\"last30days\",market:k=\"all\",productSort:g=\"units\",conversionFilter:d=\"all\",offerSort:b=\"revenue\",onDateRangeChange:x,onMarketChange:S,onProductSortChange:p,onConversionFilterChange:f,onOfferSortChange:h,onProductsTitleClick:v,onConversionTitleClick:C,onOffersTitleClick:T})=>{let $=t??xf,L=r??yf,_=i??wf,l=c=>c?c.startsWith(\"+\")&&c!==\"+0%\"?\"up\":c.startsWith(\"-\")?\"down\":\"neutral\":\"neutral\";return s?Qt(Qr,{as:\"main\",className:m,\"aria-label\":O(R.ariaLabel.dashboard),children:bo(qd,{\"data-testid\":\"dashboard-error\",role:\"alert\",\"aria-live\":\"assertive\",children:[bo(\"strong\",{children:[O(R.error),\":\"]}),\" \",s]})}):bo(Qr,{as:\"main\",className:m,\"data-testid\":\"product-offer-dashboard\",\"aria-label\":O(R.ariaLabel.dashboard),\"aria-busy\":n,children:[Qt(Ro,{shopTitle:u??O(R.title),dateRange:w,market:k,isLoading:n,stats:e?{shopTitle:e.shopTitle??\"\",dateRange:e.dateRange,selectedMarket:e.selectedMarket,metrics:{revenue:e.metrics.revenue,volume:\"\",siteVisits:\"\",conversionRate:e.metrics.conversionRate},trend:{}}:void 0,onDateRangeChange:x,onMarketChange:S}),bo(jd,{\"data-testid\":\"top-charts-row\",children:[Qt(po,{conversionData:L,conversionFilter:d,isLoading:n,onFilterChange:f,onTitleClick:C}),bo(Kd,{\"data-testid\":\"stats-card-stack\",children:[Qt(ft,{title:O(R.stats.revenue),value:e?.metrics?.revenue??\"$0\",trendDirection:l(e?.trend?.revenue),trendValue:e?.trend?.revenue,testId:\"stats-card-revenue\",isLoading:n}),Qt(ft,{title:O(R.stats.offersPurchased),value:e?.metrics?.offersPurchased??\"0\",trendDirection:l(e?.trend?.offersPurchased),trendValue:e?.trend?.offersPurchased,testId:\"stats-card-offers-purchased\",isLoading:n})]})]}),bo(Ud,{\"data-testid\":\"bottom-charts-row\",children:[Qt(so,{products:$,productSort:g,isLoading:n,maxProducts:5,onSortChange:p,onTitleClick:v}),Qt(gr,{offers:_,offerSort:b,isLoading:n,onSortChange:h,onTitleClick:T})]})]})};import X from\"react\";import kt,{useState as vf}from\"react\";import{PieChart as kf,Pie as Sf,Cell as Df,ResponsiveContainer as Tf,Tooltip as Pf}from\"recharts\";import{styled as Ce}from\"@mui/material/styles\";import{Box as st,Typography as xo}from\"@mui/material\";import{ColorUtils as Cf}from\"@nuskin/foundation-theme\";var{getGenomeColor:ti}=Cf,Gd=Ce(st)`\n display: flex;\n gap: 24px;\n padding: 24px;\n background-color: ${({theme:e})=>ti(e,\"N20\")};\n border-radius: 8px;\n box-shadow: ${({theme:e})=>e.shadows[1]};\n\n @media (max-width: 767px) {\n flex-direction: column;\n padding: 16px;\n gap: 16px;\n }\n`,Yd=Ce(st)`\n position: relative;\n width: 280px;\n height: 280px;\n flex-shrink: 0;\n\n @media (max-width: 767px) {\n width: 100%;\n height: 220px;\n }\n`,Jd=Ce(st)`\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n pointer-events: none;\n z-index: 1;\n width: 120px;\n`,Zd=Ce(xo)`\n font-size: 0.75rem;\n line-height: 1.2;\n font-weight: 500;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,Qd=Ce(xo)`\n margin-top: 2px;\n font-size: 1.25rem;\n line-height: 1.2;\n font-weight: 700;\n color: ${({theme:e})=>e.palette.text.primary};\n`,Xd=Ce(xo)`\n margin-top: 2px;\n font-size: 0.875rem;\n line-height: 1.2;\n font-weight: 600;\n color: ${({direction:e,theme:t})=>e===\"up\"?t.palette.success.main:e===\"down\"?t.palette.error.main:t.palette.text.secondary};\n`,ep=Ce(st)`\n display: flex;\n flex-direction: column;\n gap: 12px;\n flex: 1;\n`,tp=Ce(st)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 8px 12px;\n border-radius: 6px;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>ti(e,\"N30\")};\n }\n`,fr=Ce(st)`\n width: 12px;\n height: 12px;\n border-radius: 50%;\n background-color: ${({dotColor:e})=>e};\n flex-shrink: 0;\n`,op=Ce(st)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex: 1;\n`,ap=Ce(xo)`\n font-size: 0.875rem;\n font-weight: 500;\n`,rp=Ce(xo)`\n font-size: 0.75rem;\n color: ${({theme:e})=>e.palette.text.secondary};\n`,ip=Ce(xo)`\n font-size: 1rem;\n font-weight: 600;\n flex-shrink: 0;\n`,np=Ce(st)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`,lp=Ce(st)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`,sp=Ce(st)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 16px;\n background-color: ${({theme:e})=>ti(e,\"N20\")};\n border: 1px solid ${({theme:e})=>e.palette.divider};\n border-radius: 8px;\n`;import{jsx as Z,jsxs as ge}from\"react/jsx-runtime\";function Rf(e){if(!e)return null;let t=e.replace(\"%\",\"\").trim(),r=Number(t);return Number.isFinite(r)?r:null}var oi=({offers:e,dateRange:t,market:r,offerSort:i,isLoading:n=!1,onBack:s,onDateRangeChange:u,onMarketChange:m,onOfferSortChange:w})=>{let[k,g]=vf(1),d=10,b=it(),x=kt.useCallback(()=>s?.(),[s]),S=kt.useMemo(()=>[{key:\"dateRange\",label:O(R.filter.dateRange.label),value:t,icon:\"calendar\",options:[{value:\"last7days\",label:O(R.filter.dateRange.last7days)},{value:\"last30days\",label:O(R.filter.dateRange.last30days)},{value:\"last90days\",label:O(R.filter.dateRange.last90days)},{value:\"thisMonth\",label:O(R.filter.dateRange.thisMonth)}]},{key:\"market\",label:O(R.filter.market.label),value:r,icon:\"globe\",options:[{value:\"all\",label:O(R.filter.market.all)}]},{key:\"sort\",label:O(R.filter.offerSort.byRevenue),value:i,options:[{value:\"revenue\",label:O(R.filter.offerSort.byRevenue)},{value:\"units\",label:O(R.filter.offerSort.byUnits)}]}],[t,r,i]),p=kt.useCallback((l,c)=>{l===\"dateRange\"?u?.(c):l===\"market\"?m?.(c):l===\"sort\"&&(w?.(c),g(1))},[w,u,m]),f=kt.useMemo(()=>[...e].sort((l,c)=>i===\"revenue\"?c.revenue-l.revenue:c.percentage-l.percentage),[e,i]),{totalRevenue:h,totalRevenueTrendDirection:v,totalRevenueTrend:C}=kt.useMemo(()=>{let l=f.reduce((I,fe)=>I+fe.revenue,0),c=f.reduce((I,fe)=>{let xe=Rf(fe.trend?.revenue);return xe===null?I:{weightedSum:I.weightedSum+xe*fe.revenue,weight:I.weight+fe.revenue}},{weightedSum:0,weight:0}),y=c.weight>0?c.weightedSum/c.weight:0,D=\"neutral\";y>0?D=\"up\":y<0&&(D=\"down\");let F=`${y>0?\"+\":\"\"}${y.toFixed(1)}%`;return{totalRevenue:l,totalRevenueTrendDirection:D,totalRevenueTrend:F}},[f]),T=kt.useMemo(()=>f.slice(0,5),[f]),$=kt.useMemo(()=>Ze(f,d),[d,f]),L=kt.useMemo(()=>Qe(f,k,d),[k,d,f]),_=kt.useMemo(()=>[{key:\"name\",label:O(R.fullView.topOffers.columnName),sortable:!0,render:(l,c)=>ge(nr,{children:[Z(fr,{dotColor:c.color}),Z(\"span\",{children:c.name})]})},{key:\"revenue\",label:O(R.fullView.topOffers.columnRevenue),sortable:!0,render:l=>`$${Number(l).toLocaleString()}`},{key:\"percentage\",label:O(R.fullView.topOffers.columnPercentage),sortable:!0,render:l=>`${Number(l)}%`},{key:\"trend\",label:O(R.fullView.topOffers.columnTrend),render:(l,c)=>c.trend?.revenue??O(R.defaults.noData)}],[]);return n?ge(he,{\"data-testid\":\"top-offers-full-view\",children:[Z(se,{title:O(R.fullView.topOffers.title),dateRange:de(t),onBack:x,filters:S,onFilterChange:p}),Z(Lt,{})]}):e.length===0?ge(he,{\"data-testid\":\"top-offers-full-view\",children:[Z(se,{title:O(R.fullView.topOffers.title),dateRange:de(t),onBack:x,filters:S,onFilterChange:p}),Z(At,{\"data-testid\":\"top-offers-fullview-empty\",children:O(R.widget.topPerformingOffers.emptyState)})]}):ge(he,{\"data-testid\":\"top-offers-full-view\",children:[Z(se,{title:O(R.fullView.topOffers.title),dateRange:de(t),onBack:x,filters:S,onFilterChange:p}),ge(Gd,{\"data-testid\":\"top-offers-fullview-top-section\",children:[ge(Yd,{\"data-testid\":\"top-offers-fullview-chart\",children:[Z(Tf,{width:\"100%\",height:\"100%\",children:ge(kf,{children:[Z(Sf,{data:f,cx:\"50%\",cy:\"50%\",innerRadius:\"50%\",outerRadius:\"85%\",dataKey:\"revenue\",nameKey:\"name\",paddingAngle:2,children:f.map(l=>Z(Df,{fill:l.color},`cell-${l.id}`))}),Z(Pf,{formatter:l=>`$${l.toLocaleString()}`})]})}),ge(Jd,{\"data-testid\":\"top-offers-fullview-donut-center\",children:[Z(Zd,{children:O(R.widget.topPerformingOffers.totalRevenue)}),ge(Qd,{children:[\"$\",h.toLocaleString()]}),Z(Xd,{direction:v,children:C})]})]}),Z(ep,{\"data-testid\":\"top-offers-fullview-summary\",children:T.map(l=>ge(tp,{children:[Z(fr,{dotColor:l.color}),ge(op,{children:[Z(ap,{children:l.name}),ge(rp,{children:[\"$\",l.revenue.toLocaleString()]})]}),ge(ip,{children:[l.percentage,\"%\"]})]},l.id))})]}),ge(It,{\"data-testid\":\"top-offers-table\",children:[ge(Nt,{\"data-testid\":\"top-offers-fullview-table-title\",children:[O(R.fullView.topOffers.title),\" (\",f.length,\")\"]}),b?Z(lp,{children:L.map(l=>ge(sp,{children:[Z(fr,{dotColor:l.color}),ge(lr,{children:[Z(sr,{children:l.name}),ge(dr,{children:[\"$\",l.revenue.toLocaleString()]})]}),ge(pr,{children:[l.percentage,\"%\"]})]},l.id))}):Z(np,{children:Z(Ge,{columns:_,data:L,sortable:!0,getRowKey:l=>l.id})}),$>1&&Z(Je,{currentPage:k,totalPages:$,onPageChange:g,itemsPerPage:d,totalItems:f.length,\"data-testid\":\"top-offers-pagination\"})]})]})};import{jsx as hr}from\"react/jsx-runtime\";var Mf=\"productOfferDashboardView\",Of=[],Lf=[],Vf=[],$f=[];function pp(e){return typeof e==\"object\"&&e!==null}function Ff(e){return e===\"dashboard\"||e===\"products\"||e===\"conversion-rate\"||e===\"top-offers\"}function mr(e,t){if(!pp(e))return\"dashboard\";let r=e[t];return Ff(r)?r:\"dashboard\"}function dp(e,t,r){return{...pp(e)?e:{},[t]:r}}function Nf(e,t){return{pathname:e?.pathname,search:e?.search,hash:e?.hash,state:t}}var If=({stats:e,topProducts:t,conversionData:r,topOffers:i,isLoading:n=!1,error:s,dashboardTitle:u,className:m,allProducts:w,orders:k,allOffers:g,initialDateRange:d=\"last30days\",initialMarket:b=\"all\",initialProductSort:x=\"units\",initialConversionFilter:S=\"all\",initialOfferSort:p=\"revenue\",historyAdapter:f,historyStateKey:h=Mf,resetToDashboardOnMount:v=!0,onDateRangeChange:C,onMarketChange:T,onProductSortChange:$,onConversionFilterChange:L,onOfferSortChange:_,onViewChange:l})=>{let[c,y]=X.useState(\"dashboard\"),D=X.useRef(!1),[M,F]=X.useState(d),[I,fe]=X.useState(b),[xe,wo]=X.useState(x),[Ee,eo]=X.useState(S),[St,ee]=X.useState(p),et=t??Of,tt=r??Lf,Bt=i??Vf,Co=w??et,Wo=k??$f,jo=g??Bt,ze=X.useCallback(A=>{y(A),l?.(A)},[l]),vo=X.useCallback(()=>f?mr(f.location?.state,h):typeof window>\"u\"?\"dashboard\":mr(window.history.state,h),[f,h]),Dt=X.useCallback((A,dt)=>{if(f){let to=dp(f.location?.state,h,A),qo=Nf(f.location,to);if(dt===\"replace\"){f.replace(qo);return}f.push(qo);return}if(typeof window>\"u\")return;let pt=dp(window.history.state,h,A);if(dt===\"replace\"){window.history.replaceState(pt,\"\");return}window.history.pushState(pt,\"\")},[f,h]);X.useEffect(()=>{if(v?(Dt(\"dashboard\",\"replace\"),D.current=!1,ze(\"dashboard\")):ze(vo()),f)return f.listen((dt,pt)=>{if(pt===\"POP\"){let to=mr(dt.state,h);D.current=to!==\"dashboard\",ze(to)}});let A=dt=>{let pt=mr(dt.state,h);D.current=pt!==\"dashboard\",ze(pt)};return window.addEventListener(\"popstate\",A),()=>{window.removeEventListener(\"popstate\",A)}},[f,h,vo,v,ze,Dt]);let Tt=X.useCallback(A=>{D.current=!0,Dt(A,\"push\"),ze(A)},[ze,Dt]),Ve=X.useCallback(()=>{if(c!==\"dashboard\"&&D.current){if(f){f.goBack();return}typeof window<\"u\"&&window.history.back();return}D.current=!1,Dt(\"dashboard\",\"replace\"),ze(\"dashboard\")},[c,f,ze,Dt]),Et=X.useCallback(A=>{F(A),C?.(A)},[C]),He=X.useCallback(A=>{fe(A),T?.(A)},[T]),_e=X.useCallback(A=>{wo(A),$?.(A)},[$]),Ht=X.useCallback(A=>{eo(A),L?.(A)},[L]),Pt=X.useCallback(A=>{ee(A),_?.(A)},[_]),_t=X.useCallback(()=>{Tt(\"products\")},[Tt]),Ko=X.useCallback(()=>{Tt(\"conversion-rate\")},[Tt]),Uo=X.useCallback(()=>{Tt(\"top-offers\")},[Tt]);return c===\"products\"?hr(Io,{products:Co,dateRange:M,market:I,productSort:xe,isLoading:n,onBack:Ve,onDateRangeChange:Et,onMarketChange:He,onProductSortChange:_e}):c===\"conversion-rate\"?hr(zo,{conversionData:tt,orders:Wo,dateRange:M,market:I,conversionFilter:Ee,isLoading:n,onBack:Ve,onDateRangeChange:Et,onMarketChange:He,onConversionFilterChange:Ht}):c===\"top-offers\"?hr(oi,{offers:jo,dateRange:M,market:I,offerSort:St,isLoading:n,onBack:Ve,onDateRangeChange:Et,onMarketChange:He,onOfferSortChange:Pt}):hr(ei,{stats:e,topProducts:et,conversionData:tt,topOffers:Bt,isLoading:n,error:s,dashboardTitle:u,className:m,dateRange:M,market:I,productSort:xe,conversionFilter:Ee,offerSort:St,onDateRangeChange:Et,onMarketChange:He,onProductSortChange:_e,onConversionFilterChange:Ht,onOfferSortChange:Pt,onProductsTitleClick:_t,onConversionTitleClick:Ko,onOffersTitleClick:Uo})};import{ColorUtils as Af,styled as ai}from\"@nuskin/foundation-theme\";var{getGenomeColor:Xt}=Af,cp=ai(\"div\")`\n display: flex;\n gap: 12px;\n margin-bottom: 24px;\n flex-wrap: wrap;\n`,up=ai(\"select\")`\n min-width: 160px;\n height: 40px;\n padding: 8px 12px;\n background-color: ${({theme:e})=>Xt(e,\"N20\")};\n border: 1px solid ${({theme:e})=>Xt(e,\"N40\")};\n border-radius: 8px;\n font-size: 14px;\n font-weight: 400;\n color: ${({theme:e})=>Xt(e,\"N100\")};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({theme:e})=>Xt(e,\"N30\")};\n }\n\n &:focus {\n border-color: ${({theme:e})=>Xt(e,\"A70\")};\n box-shadow: 0 0 0 3px ${({theme:e})=>Xt(e,\"A20\")};\n }\n\n &:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n`,gp=ai(\"label\")`\n display: flex;\n flex-direction: column;\n gap: 4px;\n font-size: 12px;\n font-weight: 500;\n color: ${({theme:e})=>Xt(e,\"N70\")};\n`;import{jsx as ri,jsxs as Bf}from\"react/jsx-runtime\";var zf=({filters:e,onChange:t})=>ri(cp,{\"data-testid\":\"filter-bar\",children:e.map(r=>Bf(gp,{htmlFor:`filter-${r.key}`,children:[r.label,ri(up,{id:`filter-${r.key}`,value:r.value,onChange:i=>t(r.key,i.target.value),disabled:r.disabled,\"aria-label\":`${r.label} ${a(o.ariaLabel.filterSuffix)}`,\"data-testid\":`filter-dropdown-${r.key}`,children:r.options.map(i=>ri(\"option\",{value:i.value,children:i.label},i.value))})]},r.key))});var fp={shopTitle:\"My NuSkin Shop\",dateRange:{start:\"2026-03-01\",end:\"2026-03-31\",label:\"Mar 1 - Mar 31\"},selectedMarket:\"all\",metrics:{revenue:\"$9,453\",volume:\"1,211\",siteVisits:\"17,935\",conversionRate:\"4.2%\"},trend:{revenue:\"+12.5%\",volume:\"+8.3%\",siteVisits:\"-2.1%\"}},ii=[{id:\"prod-001\",rank:1,name:\"ageLOC LumiSpa\",imageUrl:\"\",unitsSold:342,revenue:29580,volume:245,trend:{units:\"+15%\",revenue:\"+12%\",volume:\"+8%\"}},{id:\"prod-002\",rank:2,name:\"Pharmanex LifePak\",imageUrl:\"\",unitsSold:287,revenue:24395,volume:198,trend:{units:\"+8%\",revenue:\"+10%\",volume:\"+5%\"}},{id:\"prod-003\",rank:3,name:\"ageLOC Meta\",imageUrl:\"\",unitsSold:256,revenue:21760,volume:176,trend:{units:\"-3%\",revenue:\"-1%\",volume:\"-2%\"}},{id:\"prod-004\",rank:4,name:\"Nu Skin 180 System\",imageUrl:\"\",unitsSold:198,revenue:17820,volume:142,trend:{units:\"+22%\",revenue:\"+18%\",volume:\"+15%\"}},{id:\"prod-005\",rank:5,name:\"Epoch Baobab Body Butter\",imageUrl:\"\",unitsSold:176,revenue:8800,volume:88,trend:{units:\"+5%\",revenue:\"+3%\",volume:\"+2%\"}}],ni=Array.from({length:30},(e,t)=>{let r=new Date(\"2026-03-01\");return r.setDate(r.getDate()+t),{date:`${[\"Jan\",\"Feb\",\"Mar\",\"Apr\",\"May\",\"Jun\",\"Jul\",\"Aug\",\"Sep\",\"Oct\",\"Nov\",\"Dec\"][r.getMonth()]} ${r.getDate()}`,rate:Number((4+t%15*.1).toFixed(2)),orders:200+t*13%100,siteVisits:4e3+t*97%2e3}}),mp=Array.from({length:30},(e,t)=>{let r=new Date(\"2026-03-01\");r.setDate(r.getDate()+t);let i=[\"Jan\",\"Feb\",\"Mar\",\"Apr\",\"May\",\"Jun\",\"Jul\",\"Aug\",\"Sep\",\"Oct\",\"Nov\",\"Dec\"],n=80+t*11%40,s=Math.floor(n*.4),u=Math.floor(n*.35),m=n-s-u;return{date:`${i[r.getMonth()]} ${r.getDate()}`,total:n,members:s,retail:u,brandAffiliates:m}}),hp=[{id:\"cat-001\",name:\"Favorites\",revenue:45200,percentage:29,color:\"#C95D63\",trend:{revenue:\"+8%\",units:\"+10%\"}},{id:\"cat-002\",name:\"Daily Routine\",revenue:42100,percentage:27,color:\"#6C7A9B\",trend:{revenue:\"+12%\",units:\"+15%\"}},{id:\"cat-003\",name:\"Fit & Trim Body\",revenue:34300,percentage:22,color:\"#E8975E\",trend:{revenue:\"-3%\",units:\"-1%\"}},{id:\"cat-004\",name:\"Dull Skin\",revenue:24900,percentage:16,color:\"#5F8FC4\",trend:{revenue:\"+5%\",units:\"+7%\"}},{id:\"cat-005\",name:\"Acne\",revenue:9400,percentage:6,color:\"#A2C3B3\",trend:{revenue:\"+2%\",units:\"+3%\"}}],li=Array.from({length:50},(e,t)=>{let r=[\"Sarah\",\"John\",\"Emma\",\"Michael\",\"Olivia\",\"William\",\"Ava\",\"James\"],i=[\"Smith\",\"Johnson\",\"Williams\",\"Brown\",\"Jones\",\"Garcia\",\"Miller\",\"Davis\"],n=new Date(\"2026-03-31\");return n.setDate(n.getDate()-t%30),{orderId:`ORD-${String(1e4+t).padStart(5,\"0\")}`,date:n.toLocaleDateString(\"en-US\",{month:\"short\",day:\"numeric\",year:\"numeric\"}),customerName:`${r[t%r.length]} ${i[t%i.length]}`,customerType:t%3===0?\"Retail\":\"Member\",items:t%5+1,total:Number((50+t*17%200+t%10*.1).toFixed(2)),bv:30+t*9%150}}),bp=Array.from({length:30},(e,t)=>{let r=[\"Alice\",\"Bob\",\"Carol\",\"David\",\"Eva\",\"Frank\",\"Grace\",\"Henry\"],i=[\"Anderson\",\"Baker\",\"Clark\",\"Davis\",\"Evans\",\"Fisher\",\"Grant\",\"Hall\"],n=[\"Member\",\"Retail\",\"Brand Affiliate\"],s=new Date(\"2026-03-31\");return s.setDate(s.getDate()-t%30),{id:`SU-${String(1e3+t).padStart(4,\"0\")}`,name:`${r[t%r.length]} ${i[t%i.length]}`,date:s.toLocaleDateString(\"en-US\",{month:\"short\",day:\"numeric\",year:\"numeric\"}),type:n[t%n.length],email:`${r[t%r.length].toLowerCase()}.${i[t%i.length].toLowerCase()}@example.com`,status:t%4===0?\"Pending\":\"Active\"}});var yo={shopTitle:\"Performance Overview\",dateRange:{start:\"2026-03-01\",end:\"2026-03-31\",label:\"Mar 1 - Mar 31\"},selectedMarket:\"all\",metrics:{revenue:\"$5,208\",offersPurchased:\"285\",conversionRate:\"4.2%\"},trend:{revenue:\"+2.3%\",offersPurchased:\"+3.7%\"}},K1={...yo,trend:{revenue:\"+5.1%\",offersPurchased:\"+12.5%\"}},U1={...yo,trend:{revenue:\"-1.8%\",offersPurchased:\"-3.7%\"}},q1={...yo,trend:{revenue:\"+0%\",offersPurchased:\"+0%\"}},G1={...yo,metrics:{...yo.metrics,offersPurchased:\"0\"},trend:{revenue:\"+0%\",offersPurchased:\"+0%\"}},Ef=[{id:\"offer-1\",name:\"Winter Skincare Bundle\",revenue:2800,percentage:29,color:\"#6B8E7B\",trend:{revenue:\"-4.2%\"}},{id:\"offer-2\",name:\"Supplement Starter Pack\",revenue:2500,percentage:27,color:\"#E8915A\",trend:{revenue:\"+3.1%\"}},{id:\"offer-3\",name:\"Holiday Special Bundle\",revenue:2100,percentage:22,color:\"#C75B5B\",trend:{revenue:\"-1.5%\"}},{id:\"offer-4\",name:\"LumiSpa Cleansing Kit\",revenue:1500,percentage:16,color:\"#5B8EC7\",trend:{revenue:\"+2.8%\"}},{id:\"offer-5\",name:\"Daily Wellness Bundle\",revenue:529,percentage:6,color:\"#9B8EC7\",trend:{revenue:\"+7.2%\"}}];var xp={all:1,us:1.2,ca:.8,jp:1.5,kr:.9,au:.7,nz:.5};function yp(e){return xp[e]??1}function Hf(e,t){return Math.round(e*yp(t))}function _f(e){return{all:\"All Markets\",us:\"US\",ca:\"Canada\",jp:\"Japan\",kr:\"Korea\",au:\"Australia\",nz:\"New Zealand\"}[e]??e}export{Zr as CategoriesFullView,po as ConversionRateChart,zo as ConversionRateFullView,Es as DATE_RANGE_LABELS,Bs as DAYS_MAP,Ro as DashboardHeader,Ge as DataTable,zf as FilterBar,xp as MARKET_MULTIPLIERS,df as MysiteDashboardWithNavigation,fn as MysiteHero,yr as NsCategoryNavigation,xr as NsProductCard,se as PageHeader,Je as Pagination,If as PoDashboardWithNavigation,Yo as ProductCarousel,ei as ProductOfferDashboard,R as ProductOfferDashboardTranslationKeys,qp as ProductTabCarousel,Io as ProductsFullView,Hr as ShoppingDashboard,o as ShoppingDashboardTranslationKeys,ba as SignupsChart,Yr as SignupsFullView,ft as StatsCard,Na as TopCategoriesPieChart,oi as TopPerformingOffersFullView,gr as TopPerformingOffersPieChart,so as TopSellingProductsList,Ke as WidgetMenu,Hf as applyMarketMultiplier,ug as calculatePercentage,Ze as calculateTotalPages,fg as formatDateRange,de as formatDateRangeLabel,Ur as formatDisplayDate,mg as formatISODate,Hs as formatShortDate,Kr as getDateRangeLabel,gg as getDaysFromDateRange,_f as getMarketDisplayName,yp as getMarketMultiplier,a as getTranslation,Tc as getTrendColor,ut as getTrendIcon,hp as mockCategories,ni as mockConversionData,li as mockOrders,yo as mockProductOfferStats,mp as mockSignupData,bp as mockSignupDetails,fp as mockStats,Ef as mockTopOffers,ii as mockTopProducts,Qe as paginateItems,cg as sortByNumericProperty};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","function _interopRequireDefault(e) {\n return e && e.__esModule ? e : {\n \"default\": e\n };\n}\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","\"use strict\";\n'use client';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function () {\n return _utils.createSvgIcon;\n }\n});\nvar _utils = require(\"@mui/material/utils\");","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M20 3h-1V1h-2v2H7V1H5v2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2m0 18H4V8h16z\"\n}), 'CalendarToday');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m-1 17.93c-3.95-.49-7-3.85-7-7.93 0-.62.08-1.21.21-1.79L9 15v1c0 1.1.9 2 2 2zm6.9-2.54c-.26-.81-1-1.39-1.9-1.39h-1v-3c0-.55-.45-1-1-1H8v-2h2c.55 0 1-.45 1-1V7h2c1.1 0 2-.9 2-2v-.41c2.93 1.19 5 4.06 5 7.41 0 2.08-.8 3.97-2.1 5.39\"\n}), 'Public');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"m16 6 2.29 2.29-4.88 4.88-4-4L2 16.59 3.41 18l6-6 4 4 6.3-6.29L22 12V6z\"\n}), 'TrendingUp');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"m16 18 2.29-2.29-4.88-4.88-4 4L2 7.41 3.41 6l6 6 4-4 6.3 6.29L22 12v6z\"\n}), 'TrendingDown');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19 13H5v-2h14z\"\n}), 'Remove');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2M1 2v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H5.21l-.94-2zm16 16c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2\"\n}), 'ShoppingCart');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2m0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2\"\n}), 'MoreVert');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5M12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5m0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3\"\n}), 'Visibility');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M20 11H7.83l5.59-5.59L12 4l-8 8 8 8 1.41-1.41L7.83 13H20z\"\n}), 'ArrowBack');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2m6.93 6h-2.95c-.32-1.25-.78-2.45-1.38-3.56 1.84.63 3.37 1.91 4.33 3.56M12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96M4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2 0 .68.06 1.34.14 2zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56-1.84-.63-3.37-1.9-4.33-3.56m2.95-8H5.08c.96-1.66 2.49-2.93 4.33-3.56C8.81 5.55 8.35 6.75 8.03 8M12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96M14.34 14H9.66c-.09-.66-.16-1.32-.16-2 0-.68.07-1.35.16-2h4.68c.09.65.16 1.32.16 2 0 .68-.07 1.34-.16 2m.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95c-.96 1.65-2.49 2.93-4.33 3.56M16.36 14c.08-.66.14-1.32.14-2 0-.68-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2z\"\n}), 'Language');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"m4 12 1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8z\"\n}), 'ArrowUpward');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"m20 12-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8z\"\n}), 'ArrowDownward');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M15.41 7.41 14 6l-6 6 6 6 1.41-1.41L10.83 12z\"\n}), 'ChevronLeft');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M10 6 8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z\"\n}), 'ChevronRight');","import React, { ReactElement, useState } from 'react';\nimport { NsImage } from '@nuskin/foundation-ui-components';\nimport { ProductImageType } from '../types/image';\nimport {\n PriceComponent,\n ProductCardContainer,\n ImageContainer,\n DefaultImage,\n ProductTitle,\n ProductBadgeContainer,\n AddToCartButton,\n CartIcon,\n} from './styles/NsProductCard.Styled';\nimport { useMediaQuery } from '@mui/material';\nimport { NsCardButton } from './types';\n\ntype NsProductCardProps = {\n readonly productTitle: string;\n readonly imageDetails?: ProductImageType;\n readonly className?: string;\n readonly button?: NsCardButton & { disabled?: boolean };\n readonly onCardClick?: () => void;\n readonly productStatusBadge?: React.ReactNode;\n readonly directSellerBadge?: React.ReactNode;\n readonly mySitePriceComponent?: React.ReactNode;\n readonly testId?: string;\n};\n\nconst NsProductCard = ({\n productTitle,\n imageDetails,\n className,\n button,\n onCardClick,\n productStatusBadge,\n directSellerBadge,\n mySitePriceComponent,\n testId,\n}: NsProductCardProps): ReactElement => {\n const [isButtonHovered, setIsButtonHovered] = useState(false);\n const isMobile = useMediaQuery('(max-width: 560px)');\n\n const handleImageError = (e: React.SyntheticEvent<HTMLImageElement, Event>) => {\n const target = e.target as HTMLImageElement;\n const noImageFallback = imageDetails?.fallbackImage;\n if (noImageFallback && target.src !== noImageFallback) {\n target.src = noImageFallback;\n }\n };\n\n return (\n <ProductCardContainer\n className={className}\n onClick={onCardClick}\n tabIndex={0}\n data-testid=\"product-card\"\n isMobile={isMobile}\n >\n <ImageContainer bgColor={imageDetails?.bgColor} onError={handleImageError}>\n {imageDetails?.imageSrc ? (\n <NsImage\n data-testid={testId ?? 'test-product-image'}\n className={imageDetails.className ?? ''}\n src={imageDetails.imageSrc}\n alt={imageDetails.imageAlt}\n aria-label={imageDetails.areaLabel ?? imageDetails.imageAlt}\n width={'100%'}\n />\n ) : (\n <DefaultImage alt=\"\" />\n )}\n </ImageContainer>\n <ProductTitle title={productTitle} data-testid=\"product-title\">\n {productTitle}\n </ProductTitle>\n {directSellerBadge && <ProductBadgeContainer>{directSellerBadge}</ProductBadgeContainer>}\n <ProductBadgeContainer>{productStatusBadge}</ProductBadgeContainer>\n <PriceComponent>{mySitePriceComponent}</PriceComponent>\n {button?.showButton && (\n <AddToCartButton\n tabIndex={0}\n aria-roledescription=\":\"\n aria-label={button.buttonText || 'ADD TO CART'}\n data-testid=\"add-to-cart-button\"\n disabled={button?.disabled ?? false}\n isMobile={isMobile}\n isHovered={isButtonHovered}\n onClick={(e) => {\n e.stopPropagation();\n if (!button?.disabled) {\n button.onClick?.();\n }\n }}\n onMouseEnter={() => {\n if (!isMobile && !button?.disabled) {\n setIsButtonHovered(true);\n }\n }}\n onMouseLeave={() => {\n if (!isMobile) {\n setIsButtonHovered(false);\n }\n }}\n >\n <CartIcon className=\"cart-icon\" disabled={button?.disabled}>\n <svg width=\"24\" height=\"22\" viewBox=\"0 0 24 22\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M0 1.86358C0 1.26109 0.488416 0.772675 1.09091 0.772675H3.48173C4.51054 0.772675 5.39955 1.49136 5.61511 2.49733L5.71309 2.95456H22.9091C23.245 2.95456 23.5622 3.10933 23.7689 3.37411C23.9757 3.63889 24.0489 3.98415 23.9674 4.31005L22.4053 10.5583C21.9197 12.5009 20.1743 13.8636 18.172 13.8636H8.05068L8.28444 14.9546H20.7273C21.3298 14.9546 21.8182 15.443 21.8182 16.0455C21.8182 16.648 21.3298 17.1364 20.7273 17.1364H19.6364H8.18182H7.40252C6.88811 17.1364 6.4436 16.777 6.33582 16.274L3.76449 4.27405L3.48173 2.95449H1.09091C0.488416 2.95449 0 2.46608 0 1.86358ZM8.18182 17.1364C6.97683 17.1364 6 18.1132 6 19.3182C6 20.5232 6.97683 21.5 8.18182 21.5C9.3868 21.5 10.3636 20.5232 10.3636 19.3182C10.3636 18.1132 9.3868 17.1364 8.18182 17.1364ZM19.6364 17.1364C18.4314 17.1364 17.4545 18.1132 17.4545 19.3182C17.4545 20.5232 18.4314 21.5 19.6364 21.5C20.8413 21.5 21.8182 20.5232 21.8182 19.3182C21.8182 18.1132 20.8413 17.1364 19.6364 17.1364ZM7.58317 11.6818H18.172C19.1732 11.6818 20.0459 11.0005 20.2887 10.0292L21.5119 5.13638H6.18062L7.58317 11.6818Z\"\n fill={button?.disabled ? '#999' : '#ffffff'}\n />\n </svg>\n </CartIcon>\n {button.buttonText || 'ADD TO CART'}\n </AddToCartButton>\n )}\n </ProductCardContainer>\n );\n};\n\nexport default NsProductCard;\n","import { styled } from '@nuskin/foundation-theme';\n\nexport const PriceComponent = styled('div')`\n width: 200px;\n text-align: left;\n margin-bottom: 5px;\n`;\n\nexport const ProductCardContainer = styled('button')<{ isMobile: boolean }>`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: space-between;\n width: 240px;\n height: ${(props) => (props.isMobile ? '410px' : '513px')};\n overflow: hidden;\n cursor: pointer;\n border: 1px solid #ededed;\n background: var(--color-primary-n-10-primary-white, #fff);\n`;\n\nexport const ImageContainer = styled('div')<{\n bgColor?: string;\n}>`\n width: '240px';\n height: '240px';\n background: ${(props) => props.bgColor ?? '#f5f5f5'};\n border-radius: 8px;\n overflow: hidden;\n margin-bottom: 0;\n display: flex;\n align-items: normal;\n justify-content: center;\n position: relative;\n @media (max-width: 560px) {\n width: 200px;\n height: 200px;\n align-items: unset;\n }\n`;\n\nexport const DefaultImage = styled('img')`\n width: 100%;\n height: 100%;\n object-fit: cover;\n border-radius: 8px;\n display: block;\n`;\n\nexport const ProductTitle = styled('div')`\n width: 200px;\n margin-top: 16px;\n max-height: 66px;\n text-align: left;\n font-size: 16px;\n font-family: 'Inter', sans-serif;\n font-weight: 400;\n line-height: 22px;\n overflow: hidden;\n color: #666;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n text-overflow: ellipsis;\n @media (max-width: 560px) {\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n margin-top: 5px;\n max-height: 54px;\n line-height: 18px;\n }\n`;\n\nexport const ProductBadgeContainer = styled('div')`\n width: 200px;\n text-align: left;\n margin-bottom: 12px;\n @media (max-width: 560px) {\n margin-bottom: 8px;\n }\n`;\n\nexport const AddToCartButton = styled('button')<{\n disabled?: boolean;\n isMobile: boolean;\n isHovered: boolean;\n}>`\n width: 200px;\n height: 40px;\n border-radius: 4px;\n display: flex;\n align-items: center;\n gap: 10px;\n font-family: 'Inter', sans-serif;\n font-size: 14px;\n font-weight: 600;\n line-height: 20px;\n letter-spacing: 0.14px;\n text-transform: none;\n justify-content: flex-start;\n padding-left: 31px;\n overflow: hidden;\n white-space: normal;\n word-break: break-word;\n overflow-wrap: break-word;\n text-overflow: ellipsis;\n margin-top: 8px;\n margin-bottom: 10px;\n -webkit-appearance: none;\n -webkit-tap-highlight-color: transparent;\n\n color: ${(props) => (props.disabled ? '#999' : '#fff')};\n background-color: ${(props) => {\n if (props.disabled) return '#e0e0e0';\n if (!props.isMobile && props.isHovered) return '#888';\n return '#000';\n }};\n border: ${(props) => (props.disabled ? '1px solid #ccc' : 'none')};\n cursor: ${(props) => (props.disabled ? 'not-allowed' : 'pointer')};\n opacity: ${(props) => (props.disabled ? 0.6 : 1)};\n transition: ${(props) => (props.isMobile ? 'none' : 'all 0.3s ease')};\n\n @media (max-width: 560px) {\n margin: 5px 0;\n }\n`;\n\nexport const CartIcon = styled('span')<{ disabled?: boolean }>`\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n display: inline-block;\n background: none;\n transition: all 0.3s ease;\n opacity: ${(props) => (props.disabled ? 0.5 : 1)};\n`;\n","import React, { ReactElement, useCallback, ReactNode, useRef } from 'react';\nimport Slider from 'react-slick';\nimport useMediaQuery from '@mui/material/useMediaQuery';\nimport 'slick-carousel/slick/slick.css';\nimport { NsCardButton, NsCarouselControl } from '@nuskin/foundation-ui-components';\nimport { ProductImageType } from '../types/image';\nimport NsProductCard from '../card/NsProductCard';\nimport {\n SlickContainer,\n ControlsContainer,\n ControlsHeaderRow,\n ScrollableContainer,\n CardList,\n ViewAllWrapper,\n ProductCountWrapper,\n ArrowsWrapper,\n CustomTypography,\n ViewAllLink,\n ProductInfoWrapper,\n CategoryNameWrapper,\n EmptyProductCategories,\n} from './NsProductCarousel.styled';\n\nexport type ProductCardEntry = {\n readonly productTitle: string;\n readonly imageDetails?: ProductImageType;\n readonly button?: NsCardButton;\n readonly onCardClick?: () => void;\n readonly productStatusBadge?: React.ReactNode;\n readonly directSeller?: React.ReactNode;\n readonly mySitePriceComponent?: React.ReactNode;\n};\n\ninterface SlickSettings {\n dots?: boolean;\n infinite?: boolean;\n speed?: number;\n slidesToShow?: number;\n slidesToScroll?: number;\n swipe?: boolean;\n draggable?: boolean;\n arrows?: boolean;\n responsive?: Array<{\n breakpoint: number;\n settings: {\n slidesToShow?: number;\n slidesToScroll?: number;\n arrows?: boolean;\n };\n }>;\n}\n\ninterface ProductCardCarouselProps<T = ProductCardEntry> {\n readonly entries: T[];\n readonly settings?: SlickSettings;\n readonly showControlButtons?: boolean;\n readonly renderEntry?: (entry: T, index: number) => ReactNode;\n readonly allEntryLabel?: string;\n readonly allEntryLink?: string;\n readonly categoryName?: string;\n readonly emptyProductMessage?: string;\n readonly productsCountLabel?: string;\n readonly isInitialDataLoading?: boolean;\n readonly history?: {\n push: (path: string) => void;\n };\n}\n\nexport default function ProductCardCarousel({\n entries,\n renderEntry,\n settings = {},\n showControlButtons = true,\n allEntryLabel = 'View All',\n allEntryLink = '',\n categoryName,\n emptyProductMessage = 'No Products Available For The Selected Category',\n productsCountLabel = 'Products',\n isInitialDataLoading,\n history,\n}: ProductCardCarouselProps): ReactElement {\n const sliderRef = useRef<Slider>(null);\n const isMobile = useMediaQuery('(max-width: 560px)');\n\n const prev = useCallback(() => {\n sliderRef.current?.slickPrev();\n }, []);\n\n const next = useCallback(() => {\n sliderRef.current?.slickNext();\n }, []);\n\n const renderProductEntry =\n renderEntry ??\n ((entry: ProductCardEntry, index: number) => (\n <NsProductCard\n key={`${entry.productTitle}-${index}`}\n productTitle={entry.productTitle}\n imageDetails={entry.imageDetails}\n button={entry.button}\n onCardClick={entry.onCardClick}\n productStatusBadge={entry.productStatusBadge}\n directSellerBadge={entry.directSeller}\n mySitePriceComponent={entry.mySitePriceComponent}\n />\n ));\n\n const sliderSettings = {\n dots: true,\n infinite: true,\n speed: 500,\n slidesToShow: Math.min(entries?.length ?? 0, 4),\n slidesToScroll: 4,\n swipe: true,\n draggable: true,\n arrows: true,\n responsive: [\n {\n breakpoint: 1320,\n settings: {\n slidesToShow: Math.min(entries?.length ?? 0, 3),\n slidesToScroll: 3,\n },\n },\n {\n breakpoint: 900,\n settings: {\n slidesToShow: Math.min(entries?.length ?? 0, 2),\n slidesToScroll: 2,\n },\n },\n {\n breakpoint: 600,\n settings: {\n slidesToShow: 1,\n slidesToScroll: 1,\n arrows: false,\n },\n },\n ],\n ...settings,\n };\n\n const shouldShowNavigation = (entries?.length ?? 0) > sliderSettings.slidesToShow;\n\n const renderCarouselContent = () => {\n if (entries?.length === 0 && !isInitialDataLoading) {\n return <EmptyProductCategories>{emptyProductMessage}</EmptyProductCategories>;\n }\n\n if (isMobile) {\n return (\n <ScrollableContainer>\n <CardList>{entries.map((entry, index) => entry && renderProductEntry(entry, index))}</CardList>\n </ScrollableContainer>\n );\n }\n\n return (\n <Slider {...sliderSettings} ref={sliderRef}>\n {entries.map((entry, index) => entry && renderProductEntry(entry, index))}\n </Slider>\n );\n };\n\n return (\n <SlickContainer>\n {showControlButtons && (\n <ControlsContainer>\n <ControlsHeaderRow>\n <ProductInfoWrapper>\n <ProductCountWrapper>\n <CustomTypography variant=\"body-m\">\n {entries?.length ?? 0} {productsCountLabel}\n </CustomTypography>\n </ProductCountWrapper>\n {!isMobile && categoryName && <CategoryNameWrapper>{categoryName}</CategoryNameWrapper>}\n </ProductInfoWrapper>\n <ViewAllWrapper $isMobile={isMobile}>\n <ViewAllLink\n onClick={(e) => {\n if (history) {\n e.preventDefault();\n history.push(allEntryLink);\n }\n }}\n >\n {allEntryLabel}\n </ViewAllLink>\n </ViewAllWrapper>\n </ControlsHeaderRow>\n {!isMobile && (\n <ArrowsWrapper $isDisabled={!shouldShowNavigation}>\n <NsCarouselControl prev={prev} next={next} viewAllLabel={''} viewAllUrl={''} />\n </ArrowsWrapper>\n )}\n </ControlsContainer>\n )}\n {renderCarouselContent()}\n </SlickContainer>\n );\n}\n","import React from 'react';\nimport { styled } from '@nuskin/foundation-theme';\nimport Box, { BoxProps } from '@mui/material/Box';\nimport { NsTypography } from '@nuskin/foundation-ui-components';\n\nexport const SlickContainer: React.ComponentType<BoxProps> = styled(Box)`\n padding: 30px 0 60px;\n width: 100%;\n margin: auto;\n margin-top: 50px;\n position: relative;\n\n .slick-list {\n padding-left: 24px;\n padding-right: 24px;\n }\n .slick-slide {\n display: flex;\n justify-content: center;\n padding: 0 12px;\n box-sizing: border-box;\n }\n .slick-prev,\n .slick-next {\n display: none !important;\n }\n\n @media (max-width: 1200px) {\n max-width: 1024px;\n .slick-list {\n padding-left: 12px;\n padding-right: 12px;\n }\n .slick-slide {\n padding: 0 6px;\n }\n }\n @media (max-width: 700px) {\n max-width: 100vw;\n padding: 10px 0 50px;\n .slick-list {\n padding-left: 4px;\n padding-right: 4px;\n }\n .slick-slide {\n padding: 0 2px;\n }\n }\n @media (max-width: 560px) {\n padding: 10px 0 10px;\n margin-top: 25px;\n }\n`;\nexport const ScrollableContainer = styled('div')`\n overflow-x: auto;\n display: flex;\n scroll-snap-type: x mandatory;\n -webkit-overflow-scrolling: touch;\n gap: 16px;\n padding: 0 8px 16px;\n width: 100%;\n box-sizing: border-box;\n\n &::-webkit-scrollbar {\n height: 6px;\n }\n\n &::-webkit-scrollbar-thumb {\n background: #007bff;\n border-radius: 10px;\n }\n`;\n\nexport const CardList = styled('div')`\n display: flex;\n scroll-snap-align: start;\n justify-content: center;\n gap: 15px;\n`;\n\nexport const ControlsContainer: React.ComponentType<BoxProps> = styled(Box)`\n position: absolute;\n bottom: calc(100% + 1px);\n right: 1px;\n width: 100%;\n display: flex;\n justify-content: space-between;\n align-items: center;\n box-sizing: border-box;\n`;\n\nexport const ViewAllWrapper: React.ComponentType<BoxProps & { $isMobile?: boolean }> = styled(Box)<{\n $isMobile?: boolean;\n}>`\n display: flex;\n align-items: center;\n margin-left: auto;\n margin-right: ${({ $isMobile }) => ($isMobile ? 0 : '24px')};\n\n @media (max-width: 560px) {\n margin-left: 0;\n order: 2;\n }\n`;\n\nexport const ProductCountWrapper: React.ComponentType<BoxProps> = styled(Box)`\n display: none;\n\n @media (max-width: 560px) {\n color: #666666;\n font-family: Inter;\n font-size: 14px !important;\n font-style: normal;\n font-weight: 600;\n line-height: 18px;\n display: flex;\n align-items: center;\n order: 1;\n }\n`;\n\nexport const ArrowsWrapper: React.ComponentType<BoxProps & { $isDisabled?: boolean }> = styled(Box)<{\n $isDisabled?: boolean;\n}>`\n display: flex;\n align-items: center;\n opacity: ${({ $isDisabled }) => ($isDisabled ? 0.3 : 1)};\n pointer-events: ${({ $isDisabled }) => ($isDisabled ? 'none' : 'auto')};\n transition: opacity 0.3s ease;\n\n .carousal-prev-button,\n .carousal-next-button {\n transition: all 0.3s ease;\n border: 2px solid #000000;\n border-radius: 3px;\n padding: 9px;\n cursor: pointer;\n\n svg {\n transition: all 0.3s ease;\n }\n\n svg polyline {\n stroke: #000000;\n fill: none;\n }\n\n &:hover {\n background-color: #f5f5f5;\n border: 2px solid #ddd;\n\n svg {\n opacity: 0.5;\n }\n\n svg polyline {\n stroke: #000000;\n fill: none;\n }\n }\n }\n\n @media (max-width: 560px) {\n display: none;\n }\n`;\nexport const Scrollablewrapper = styled('div')`\n @media (max-width: 560px) {\n overflow-y: hidden;\n scrollbar-width: thin;\n scrollbar-color: #007bff #eee;\n &::-webkit-scrollbar {\n width: 8px;\n }\n &::-webkit-scrollbar-track {\n background: #eee;\n }\n &::-webkit-scrollbar-thumb {\n background-color: red;\n border-radius: 8px;\n border: 2px solid #eee;\n }\n }\n`;\nexport const CustomTypography = styled(NsTypography)`\n color: #666666;\n font-family: Inter;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 22px;\n @media (max-width: 560px) {\n margin: 0 3px;\n }\n`;\n\nexport const ViewAllLink = styled('a')`\n color: #000000;\n font-family: Inter, sans-serif;\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 22px;\n text-decoration: none;\n border-bottom: 1px solid #000000;\n padding-bottom: 4px;\n transition: all 0.3s ease;\n cursor: pointer;\n\n @media (max-width: 560px) {\n font-size: 14px;\n line-height: 18px;\n }\n\n &:hover {\n color: #666666;\n border-bottom: 1px solid #666666;\n cursor: pointer;\n }\n`;\n\nexport const EmptyProductCategories = styled('div')`\n padding-top: 20px;\n font-size: 20px;\n text-align: center;\n`;\nexport const ControlsHeaderRow = styled('div')`\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n`;\n\nexport const ProductInfoWrapper = styled('div')`\n display: flex;\n align-items: center;\n flex: 1;\n min-width: 0;\n`;\n\nexport const CategoryNameWrapper = styled('div')`\n font-family: 'Lora';\n font-weight: 400;\n font-size: 22px;\n margin-left: 16px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n margin-bottom: 13px;\n`;\n","import React, { useState, useEffect, useCallback } from 'react';\nimport { useMediaQuery } from '@mui/material';\n\nimport { NsCategoryNavigation } from '../Nav-Category-Navigation';\nimport { NsSpinner } from '@nuskin/foundation-ui-components';\nimport ProductCardCarousel, { ProductCardEntry } from './NsProductCarousel';\nimport {\n ProductTabCarouselContainer,\n TabsContainer,\n ContentContainer,\n NoTabsContainer,\n SpinnerContainer,\n} from './ProductTabCarousel.styled';\n\ninterface Category {\n label: string;\n categoryId: string;\n}\n\ninterface SlickSettings {\n dots?: boolean;\n infinite?: boolean;\n speed?: number;\n slidesToShow?: number;\n slidesToScroll?: number;\n swipe?: boolean;\n draggable?: boolean;\n arrows?: boolean;\n responsive?: Array<{\n breakpoint: number;\n settings: {\n slidesToShow?: number;\n slidesToScroll?: number;\n arrows?: boolean;\n };\n }>;\n}\n\ninterface ProductTabCarouselProps {\n readonly allEntryLabel?: string;\n readonly allEntryLink?: string;\n readonly renderEntry?: (entry: ProductCardEntry) => React.ReactNode;\n readonly settings?: SlickSettings;\n readonly showControlButtons?: boolean;\n readonly fetchCategories: () => Promise<Category[]>;\n readonly fetchProducts: (categoryId: string) => Promise<ProductCardEntry[]>;\n readonly emptyProductTabs?: string;\n readonly emptyProductMessage?: string;\n readonly showCustomCategory?: boolean;\n readonly productsCountLabel?: string;\n readonly getCategoryId: (categoryId: string) => Promise<Category[]>;\n readonly history?: {\n push: (path: string) => void;\n };\n}\n\nconst ProductTabCarousel: React.FC<ProductTabCarouselProps> = ({\n allEntryLabel,\n allEntryLink,\n renderEntry,\n settings,\n showControlButtons = true,\n fetchCategories,\n fetchProducts,\n showCustomCategory = false,\n emptyProductTabs = 'No tabs available',\n emptyProductMessage,\n productsCountLabel,\n getCategoryId,\n history,\n}) => {\n const isMobile = useMediaQuery('(max-width:768px)');\n const [isLoadingInitialData, setIsLoadingInitialData] = useState(true);\n const [categories, setCategories] = useState<Category[]>([]);\n const [selectedTab, setSelectedTab] = useState(0);\n const [products, setProducts] = useState<ProductCardEntry[]>([]);\n const [loading, setLoading] = useState(false);\n const [shouldShowSpinner, setShouldShowSpinner] = useState(true);\n\n const checkForExistingSpinners = useCallback(() => {\n const existingSpinners = document.querySelectorAll('[data-testid*=\"spinner\"], .ns-spinner, [class*=\"spinner\"]');\n setShouldShowSpinner(existingSpinners.length === 0);\n }, []);\n\n useEffect(() => {\n if (loading) {\n checkForExistingSpinners();\n }\n }, [loading, checkForExistingSpinners]);\n\n useEffect(() => {\n fetchCategories().then(setCategories);\n }, [fetchCategories]);\n\n useEffect(() => {\n if (categories.length > 0) {\n const categoryId = categories[selectedTab]?.categoryId;\n if (getCategoryId) {\n getCategoryId(categoryId);\n }\n\n setLoading(true);\n fetchProducts(categoryId)\n .then(setProducts)\n .finally(() => {\n setLoading(false);\n setIsLoadingInitialData(false);\n });\n }\n }, [categories, selectedTab, fetchProducts]);\n\n const itemArray = categories.map((cat) => ({\n label: cat.label,\n content: '',\n categoryId: cat.categoryId,\n }));\n\n return (\n <ProductTabCarouselContainer isMobile={isMobile}>\n {showCustomCategory &&\n (itemArray.length > 0 ? (\n <TabsContainer isMobile={isMobile}>\n <NsCategoryNavigation\n itemArray={itemArray}\n value={selectedTab}\n onChange={(_, newValue) => setSelectedTab(newValue)}\n />\n </TabsContainer>\n ) : (\n <NoTabsContainer>{emptyProductTabs}</NoTabsContainer>\n ))}\n <ContentContainer isMobile={isMobile}>\n {loading ? (\n <SpinnerContainer>{shouldShowSpinner && <NsSpinner />}</SpinnerContainer>\n ) : (\n <ProductCardCarousel\n isInitialDataLoading={isLoadingInitialData}\n entries={products}\n allEntryLabel={allEntryLabel}\n allEntryLink={allEntryLink}\n renderEntry={\n renderEntry\n ? (entry) => renderEntry({ ...entry, productStatusBadge: entry.productStatusBadge })\n : undefined\n }\n settings={settings}\n showControlButtons={showControlButtons}\n categoryName={categories[selectedTab]?.label}\n emptyProductMessage={emptyProductMessage}\n productsCountLabel={productsCountLabel}\n history={history}\n />\n )}\n </ContentContainer>\n </ProductTabCarouselContainer>\n );\n};\n\nexport default ProductTabCarousel;\n","import * as React from 'react';\nimport Tabs from '@mui/material/Tabs';\nimport Tab from '@mui/material/Tab';\nimport Box from '@mui/material/Box';\nimport PropTypes from 'prop-types';\nimport { NsCategoryNavigationContainer } from './NsCategoryNavigation.styled';\nimport { useMediaQuery } from '@mui/material';\n\nfunction TabPanel(\n props: Readonly<{\n children?: React.ReactNode;\n value: number;\n index: number;\n [key: string]: unknown;\n }>,\n) {\n const { children, value, index, ...other } = props;\n return (\n <div\n role=\"tabpanel\"\n hidden={value !== index}\n id={`vertical-tabpanel-${index}`}\n aria-labelledby={`vertical-tab-${index}`}\n {...other}\n >\n {value === index && <Box className=\"tabPanel\">{children}</Box>}\n </div>\n );\n}\nTabPanel.propTypes = {\n children: PropTypes.node,\n index: PropTypes.number.isRequired,\n value: PropTypes.number.isRequired,\n};\n\ninterface NsCategoryNavigationProps {\n itemArray: { label: string; content: React.ReactNode; categoryId: string }[];\n value?: number;\n onChange?: (event: React.SyntheticEvent, newValue: number) => void;\n}\n\nexport const NsCategoryNavigation: React.FC<Readonly<NsCategoryNavigationProps>> = ({\n itemArray,\n value: controlledValue,\n onChange,\n}) => {\n const [internalValue, setInternalValue] = React.useState(0);\n const isMobile = useMediaQuery('(max-width:768px)');\n const value = controlledValue ?? internalValue;\n const handleChange = (event: React.SyntheticEvent, newValue: number) => {\n if (onChange) {\n onChange(event, newValue);\n } else {\n setInternalValue(newValue);\n }\n };\n\n return (\n <NsCategoryNavigationContainer>\n <Box className=\"tabContainer\">\n <Tabs\n orientation={isMobile ? 'horizontal' : 'vertical'}\n variant=\"scrollable\"\n value={value}\n onChange={handleChange}\n aria-label=\"Vertical tabs example\"\n className=\"tabsStyle\"\n >\n {itemArray.map((item) => (\n <Tab key={item.categoryId} label={item.label} className=\"tabStyle\" />\n ))}\n </Tabs>\n {itemArray.map((item) => (\n <TabPanel\n key={item.categoryId}\n value={value}\n index={itemArray.findIndex((i) => i.categoryId === item.categoryId)}\n >\n {item.content}\n </TabPanel>\n ))}\n </Box>\n </NsCategoryNavigationContainer>\n );\n};\n","import { styled } from '@nuskin/foundation-theme';\nexport const NsCategoryNavigationContainer = styled.div`\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: flex-start;\n width: 100%;\n height: 100%;\n background-color: #fff;\n .tabsStyle {\n display: flex;\n padding-top: 8.533px;\n flex-direction: column;\n align-items: flex-start;\n gap: 12.8px;\n border-right: 1px;\n border-color: divider;\n width: 200px;\n & .Mui-selected {\n font-weight: 700;\n font-size: 14px;\n font-family: 'inter', sans-serif;\n font-style: normal;\n font-height: 20px;\n border-radius: 4px;\n }\n & .MuiTabs-indicator {\n left: 0;\n background-color: #5b81a5;\n color: #5b81a5;\n\n @media (max-width: 768px) {\n display: none;\n }\n }\n }\n\n .tabContainer {\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: flex-start;\n min-width: 100%;\n background-color: #fff;\n @media (max-width: 768px) {\n flex-direction: column;\n justify-content: center;\n align-items: center;\n }\n }\n\n .tabStyle {\n align-items: flex-start;\n display: flex;\n text-align: left;\n font-size: 14px;\n font-family: 'inter' sans-serif;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n min-height: 20px;\n padding: 1px;\n padding-left: 10px;\n margin-bottom: 10px;\n cursor: pointer;\n text-transform: none;\n }\n @media (max-width: 768px) {\n flex-direction: row;\n\n .tabsStyle {\n width: 100%;\n border-right: none;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding-top: 0px;\n }\n\n .tabStyle {\n display: flex;\n align-items: center;\n gap: 10px;\n font-size: 14px;\n border: 1px solid #ccc;\n border-radius: 70px;\n padding: 8px 16px;\n text-align: center;\n margin: 4px;\n background-color: #fff;\n cursor: pointer;\n color: black;\n font-family: Inter;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .tabStyle.Mui-selected {\n background-color: #5b81a5;\n color: #ffffff !important;\n font-weight: 700;\n border-radius: 70px;\n }\n }\n .tabPanel {\n padding: 8px;\n text-align: left;\n }\n`;\n","import { styled } from '@nuskin/foundation-theme';\n\nexport const ProductTabCarouselContainer = styled('div')<{ isMobile?: boolean }>`\n display: flex;\n flex-direction: ${({ isMobile }) => (isMobile ? 'column' : 'row')};\n align-items: ${({ isMobile }) => (isMobile ? 'stretch' : 'flex-start')};\n width: 100%;\n max-width: 1920px;\n min-height: ${({ isMobile }) => (isMobile ? 'auto' : '800px')};\n margin: 0 auto;\n box-sizing: border-box;\n overflow: visible;\n background: #fff;\n padding: ${({ isMobile }) => (isMobile ? '10px 16px 0px 16px' : '50px 60px 0px 60px')};\n\n @media (max-width: 768px) {\n padding: 10px 16px 0px 16px;\n min-height: auto;\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n padding: 30px 40px 0px 40px;\n gap: 20px;\n }\n\n transform: translateZ(0);\n will-change: auto;\n`;\n\nexport const TabsContainer = styled('div')<{ isMobile?: boolean }>`\n min-width: ${({ isMobile }) => (isMobile ? '100%' : 'auto')};\n height: ${({ isMobile }) => (isMobile ? 'auto' : '100%')};\n flex-shrink: 0;\n\n @media (max-width: 768px) {\n width: 100%;\n height: auto;\n\n overflow-x: auto;\n overflow-y: visible;\n -webkit-overflow-scrolling: touch;\n scrollbar-width: none;\n -ms-overflow-style: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n min-width: 200px;\n margin-right: 20px;\n }\n`;\n\nexport const ContentContainer = styled('div')<{ isMobile?: boolean }>`\n flex: 1;\n min-width: 0;\n height: ${({ isMobile }) => (isMobile ? 'auto' : '100%')};\n\n @media (max-width: 768px) {\n width: 100%;\n height: auto;\n min-height: 300px;\n\n -webkit-overflow-scrolling: touch;\n overflow-x: hidden;\n overflow-y: auto;\n }\n\n @media (min-width: 769px) and (max-width: 1024px) {\n min-height: 400px;\n }\n\n contain: layout style paint;\n transform: translateZ(0);\n`;\n\nexport const LoadingContainer = styled('div')`\n display: flex;\n justify-content: center;\n align-items: center;\n min-height: 200px;\n padding: 20px;\n\n @media (max-width: 768px) {\n min-height: 150px;\n padding: 16px;\n }\n`;\n\nexport const NoTabsContainer = styled('div')`\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 40px 20px;\n color: #666;\n font-size: 16px;\n\n @media (max-width: 768px) {\n padding: 20px 16px;\n font-size: 14px;\n }\n`;\nexport const SpinnerContainer = styled('div')`\n padding: 10px;\n display: flex;\n justify-content: center;\n`;\n","import React, { ReactElement, useState, useEffect, useMemo } from 'react';\nimport { Typography, Box, useMediaQuery, Tooltip } from '@mui/material';\nimport { NsLink, NsImage } from '@nuskin/foundation-ui-components';\nimport {\n MysiteHeroContainer,\n MysiteHeroContainerMobile,\n BadgeContainer,\n Badge,\n ToggleButtonMobile,\n StyledSpan,\n ImgTabIndex,\n ContactLink,\n BadgeValue,\n} from '@/common/headers/MysiteHero.styled';\nimport { PlaceholderImage } from '../icon/icons/PlaceholderImage';\nimport { ArrowDownIcon } from '../icon/icons/ArrowDownIcon';\nimport { trackGTMEvent } from '../utils/gtmTracking';\n\ntype MysiteHeroProps = {\n readonly imageDetails?: {\n imageSrc: string;\n imageAlt: string;\n bgColor: string;\n };\n readonly shopTitle: string;\n readonly shopDescription: string;\n readonly socialTitleText: string;\n readonly email: string;\n readonly phone: string;\n readonly className?: string;\n readonly bannerProps?: {\n backgroundColor?: string;\n headlineFont?: string;\n paragraphFont?: string;\n };\n readonly socialIcons?: {\n type: string;\n url: string;\n }[];\n readonly expirationDate?: string;\n readonly showBadges?: boolean;\n};\n\ntype ImageDetails = {\n imageSrc: string;\n imageAlt: string;\n bgColor: string;\n};\n\ntype BannerProps = {\n backgroundColor?: string;\n headlineFont?: string;\n paragraphFont?: string;\n};\n\ntype ContentProps = {\n shopTitle: string;\n shopDescription: string;\n socialTitleText: string;\n email: string;\n phone: string;\n showBadges: boolean;\n expirationDate?: string;\n};\n\nconst renderImageContent = (imageDetails: ImageDetails | undefined, bannerProps: BannerProps, className: string) => {\n const placeholderClass = className.includes('mobile') ? 'placeholder-image-mobile' : 'placeholder-image';\n return imageDetails?.imageSrc ? (\n <ImgTabIndex tabIndex={0}>\n <NsImage className={className} src={imageDetails.imageSrc} alt={imageDetails.imageAlt} />\n </ImgTabIndex>\n ) : (\n <Box className={placeholderClass}>\n <PlaceholderImage\n width={className.includes('mobile') ? '144px' : '246px'}\n height={className.includes('mobile') ? '144px' : '246px'}\n backgroundColor={bannerProps?.backgroundColor ?? '#5F5F5F'}\n />\n </Box>\n );\n};\n\nconst renderBadges = (showBadges: boolean, expirationDate: string, isMobile: boolean, hasWhiteBackground: boolean) => {\n if (!showBadges || !expirationDate) return null;\n\n const badgeClass = isMobile ? 'mobile-badge' : 'tablet-badge';\n const containerClass = isMobile ? 'mobile-badges' : 'tablet-badges';\n\n return (\n <BadgeContainer className={containerClass}>\n {expirationDate && (\n <Badge className={badgeClass} hasWhiteBackground={hasWhiteBackground} tabIndex={0}>\n <BadgeValue className=\"badge-value\">{expirationDate}</BadgeValue>\n </Badge>\n )}\n </BadgeContainer>\n );\n};\n\nconst renderMobileContent = (\n props: ContentProps,\n isScrolled: boolean,\n renderSocialMediaIcons: React.ReactNode,\n isMobile: boolean,\n hasWhiteBackground: boolean,\n) => {\n const { shopTitle, socialTitleText, email, showBadges, expirationDate, phone } = props;\n\n return (\n <Box className=\"content-mobile\">\n <Typography tabIndex={0} className=\"body-title-mobile\">\n {shopTitle}\n </Typography>\n {!isScrolled && (\n <>\n <Typography tabIndex={0} className=\"social-title-text-mobile\">\n {socialTitleText}\n </Typography>\n {renderContactLink('email', email, 'email-text-mobile')}\n {renderContactLink('phone', phone, 'phone-text-mobile')}\n <Box className=\"social-icons-mobile\">{renderSocialMediaIcons}</Box>\n {renderBadges(showBadges, expirationDate ?? '', isMobile, hasWhiteBackground)}\n </>\n )}\n </Box>\n );\n};\n\nconst renderDesktopContent = (\n props: ContentProps,\n isScrolled: boolean,\n renderSocialMediaIcons: React.ReactNode,\n isMobile: boolean,\n hasWhiteBackground: boolean,\n) => {\n const { shopTitle, shopDescription, socialTitleText, email, phone, showBadges, expirationDate } = props;\n\n return (\n <Box className=\"content\">\n <Typography tabIndex={0} className=\"body-title\">\n {shopTitle}\n </Typography>\n {!isScrolled && (\n <>\n {shopDescription?.length > 480 ? (\n <Tooltip title={shopDescription} arrow>\n <Typography tabIndex={0} className=\"body-text\">\n {shopDescription}\n </Typography>\n </Tooltip>\n ) : (\n <Typography tabIndex={0} className=\"body-text\">\n {shopDescription}\n </Typography>\n )}\n <Box className=\"social-media\">\n <Typography tabIndex={0} className=\"social-title-text\">\n {socialTitleText}\n </Typography>\n <Box className=\"social-icons\">\n {renderSocialMediaIcons}\n {renderContactLink('email', email, 'email-text')}\n {renderContactLink('phone', phone, 'phone-text')}\n </Box>\n </Box>\n {renderBadges(showBadges, expirationDate ?? '', isMobile, hasWhiteBackground)}\n </>\n )}\n </Box>\n );\n};\n\nconst checkIfImageIsCircular = (url: string): Promise<boolean> => {\n return new Promise((resolve, reject) => {\n const imageContext = new Image();\n imageContext.crossOrigin = 'anonymous';\n imageContext.src = url;\n\n imageContext.onload = () => {\n const canvas = document.createElement('canvas');\n const context = canvas.getContext('2d');\n if (!context) return reject(new Error('Canvas not supported'));\n\n canvas.width = imageContext.width;\n canvas.height = imageContext.height;\n\n context.drawImage(imageContext, 0, 0);\n\n const corners = [\n context.getImageData(0, 0, 1, 1).data,\n context.getImageData(imageContext.width - 1, 0, 1, 1).data,\n context.getImageData(0, imageContext.height - 1, 1, 1).data,\n context.getImageData(imageContext.width - 1, imageContext.height - 1, 1, 1).data,\n ];\n\n const isCircular = corners.every((corner) => {\n const imageArray = Array.prototype.slice.call(corner);\n const alpha = imageArray[3];\n return alpha < 10;\n });\n resolve(isCircular);\n };\n imageContext.onerror = () => reject(new Error('Failed to load image'));\n });\n};\n\nconst isWhiteOrNearWhite = (color: string | undefined): boolean => {\n if (!color) return false;\n\n const hex = color.replace('#', '').toLowerCase();\n\n /* regex pattern for hex color format: 3 chars (#fff), 4 chars (#ffff), 6 chars (#ffffff), or 8 chars (#ffffffff)*/\n if (!/^[0-9a-f]{3,4}$|^[0-9a-f]{6}$|^[0-9a-f]{8}$/i.test(hex)) return false;\n\n let fullHex = hex;\n if (hex.length === 3 || hex.length === 4) {\n fullHex = hex\n .split('')\n .map((char) => char + char)\n .join('');\n }\n\n const r = Number.parseInt(fullHex.substring(0, 2), 16);\n const g = Number.parseInt(fullHex.substring(2, 4), 16);\n const b = Number.parseInt(fullHex.substring(4, 6), 16);\n\n const threshold = 220;\n return r >= threshold && g >= threshold && b >= threshold;\n};\n\nconst createContactClickHandler = (contactType: 'email' | 'phone', contactValue: string) => ({\n onClick: () => {\n trackGTMEvent({\n event: 'contact_click',\n contact_type: contactType,\n contact_value: contactValue,\n click_element: `${contactType}_link`,\n });\n },\n onKeyDown: (e: React.KeyboardEvent<HTMLAnchorElement>) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n trackGTMEvent({\n event: 'contact_click',\n contact_type: contactType,\n contact_value: contactValue,\n click_element: `${contactType}_link`,\n });\n globalThis.location.href = `${contactType === 'email' ? 'mailto' : 'tel'}:${contactValue}`;\n }\n },\n});\n\nconst renderContactLink = (contactType: 'email' | 'phone', contactValue: string, className: string) => {\n const protocol = contactType === 'email' ? 'mailto:' : 'tel:';\n const handlers = createContactClickHandler(contactType, contactValue);\n\n return (\n <Typography className={className}>\n <ContactLink href={`${protocol}${contactValue}`} {...handlers}>\n {contactValue}\n </ContactLink>\n </Typography>\n );\n};\nexport default function MysiteHero({\n className,\n shopTitle,\n shopDescription,\n socialTitleText,\n imageDetails,\n email,\n phone,\n bannerProps,\n socialIcons,\n expirationDate,\n showBadges = false,\n}: MysiteHeroProps): ReactElement {\n const isMobile = useMediaQuery('(max-width: 560px)');\n const [isScrolled, setIsScrolled] = useState(false);\n const [isDescriptionExpanded, setIsDescriptionExpanded] = useState(false);\n const [hasWhiteBackground, setHasWhiteBackground] = useState(false);\n const [isImageCircular, setIsImageCircular] = useState(false);\n\n const toggleDescription = () => {\n setIsDescriptionExpanded(!isDescriptionExpanded);\n };\n\n useEffect(() => {\n const checkImage = async () => {\n if (imageDetails?.imageSrc) {\n const isCircular = await checkIfImageIsCircular(imageDetails.imageSrc);\n setIsImageCircular(isCircular);\n } else {\n setIsImageCircular(false);\n }\n };\n\n checkImage();\n }, [imageDetails?.imageSrc]);\n\n useEffect(() => {\n setHasWhiteBackground(isWhiteOrNearWhite(bannerProps?.backgroundColor));\n }, [bannerProps?.backgroundColor]);\n\n useEffect(() => {\n let debounceTimeout: ReturnType<typeof setTimeout>;\n let lastScrollY = window.scrollY;\n let currentScrollState = false;\n let isTransitioning = false;\n let lastUpdateTime = 0;\n\n const updateScrollState = (newState: boolean) => {\n const now = Date.now();\n\n if (currentScrollState !== newState && !isTransitioning) {\n if (now - lastUpdateTime < 100) {\n return;\n }\n\n isTransitioning = true;\n currentScrollState = newState;\n lastUpdateTime = now;\n\n if (newState) {\n setIsDescriptionExpanded(false);\n }\n\n clearTimeout(debounceTimeout);\n setIsScrolled(newState);\n\n debounceTimeout = setTimeout(() => {\n isTransitioning = false;\n\n if (newState && window.scrollY < 15) {\n window.scrollTo({\n top: isMobile ? 20 : 30,\n behavior: 'smooth',\n });\n }\n }, 300);\n }\n };\n\n const handleScroll = () => {\n const currentScrollY = window.scrollY;\n\n if (isTransitioning) {\n lastScrollY = currentScrollY;\n return;\n }\n\n const scrollDelta = Math.abs(currentScrollY - lastScrollY);\n\n if (scrollDelta < 0.5) {\n return;\n }\n\n const scrollingDown = currentScrollY > lastScrollY;\n\n const scrollDownThreshold = isMobile ? 15 : 25;\n const scrollUpThreshold = isMobile ? 8 : 12;\n\n if (scrollingDown && currentScrollY > scrollDownThreshold && !currentScrollState) {\n updateScrollState(true);\n } else if (!scrollingDown && currentScrollY < scrollUpThreshold && currentScrollState) {\n updateScrollState(false);\n }\n\n lastScrollY = currentScrollY;\n };\n\n const initializeState = () => {\n const initialScrollY = window.scrollY;\n const scrollThreshold = isMobile ? 5 : 10;\n const shouldStartCompact = initialScrollY > scrollThreshold;\n\n currentScrollState = shouldStartCompact;\n setIsScrolled(shouldStartCompact);\n lastScrollY = initialScrollY;\n lastUpdateTime = Date.now();\n };\n\n let rafId: number | null = null;\n let lastRafTime = 0;\n const throttledScrollHandler = () => {\n if (rafId) return;\n\n const now = Date.now();\n if (now - lastRafTime < 16) {\n return;\n }\n\n rafId = requestAnimationFrame(() => {\n handleScroll();\n lastRafTime = Date.now();\n rafId = null;\n });\n };\n\n initializeState();\n window.addEventListener('scroll', throttledScrollHandler, { passive: true });\n\n return () => {\n window.removeEventListener('scroll', throttledScrollHandler);\n if (rafId) cancelAnimationFrame(rafId);\n clearTimeout(debounceTimeout);\n };\n }, [isMobile]);\n\n const renderSocialMediaIcons = useMemo(() => {\n return socialIcons?.map((icon, index) => {\n const handleSocialClick = (e: React.MouseEvent) => {\n e.preventDefault();\n trackGTMEvent({\n event: 'social_click',\n social_platform: icon.type,\n social_url: icon.url,\n click_element: 'social_icon',\n });\n window.open(icon.url, '_blank');\n };\n\n return (\n <StyledSpan key={icon?.type + index} onClick={handleSocialClick}>\n <NsLink href={icon.url} target=\"_blank\">\n <NsImage\n key={icon?.type + index}\n src={`https://www.google.com/s2/favicons?domain=${icon?.url}&sz=24`}\n alt={`${icon.type} icon`}\n width=\"24\"\n height=\"24\"\n />\n </NsLink>\n </StyledSpan>\n );\n });\n }, [socialIcons]);\n\n const containerClass = `${className} ${isScrolled ? 'scrolled' : ''}`;\n const props = { shopTitle, shopDescription, socialTitleText, email, phone, showBadges, expirationDate };\n\n const getCharacterLimit = () => {\n if (window.innerWidth <= 380) return 50;\n if (window.innerWidth <= 415) return 56;\n if (window.innerWidth <= 460) return 62;\n return 80;\n };\n\n const shouldShowToggle = isMobile && shopDescription && shopDescription.length > getCharacterLimit();\n\n return isMobile ? (\n <MysiteHeroContainerMobile\n className={containerClass}\n data-testid=\"my-site-shop-header\"\n bannerProps={bannerProps}\n isCircularImage={isImageCircular}\n hasWhiteBackground={hasWhiteBackground}\n >\n <Box className=\"image-content-mobile\">\n {renderImageContent(imageDetails, bannerProps ?? {}, 'bg-image-mobile')}\n {renderMobileContent(props, isScrolled, renderSocialMediaIcons, isMobile, hasWhiteBackground)}\n </Box>\n {!isScrolled && (\n <Box className=\"expandable-description-mobile\">\n <Typography\n className={`description-content-mobile ${isDescriptionExpanded || !shouldShowToggle ? 'expanded' : 'collapsed'}`}\n >\n {shopDescription}\n </Typography>\n {shouldShowToggle && (\n <ToggleButtonMobile onClick={toggleDescription}>\n <ArrowDownIcon\n width={16}\n height={16}\n className={`arrow-icon-mobile ${isDescriptionExpanded ? 'expanded' : ''}`}\n />\n </ToggleButtonMobile>\n )}\n </Box>\n )}\n </MysiteHeroContainerMobile>\n ) : (\n <MysiteHeroContainer\n className={containerClass}\n data-testid=\"my-site-shop-header\"\n bannerProps={bannerProps}\n isCircularImage={isImageCircular}\n hasWhiteBackground={hasWhiteBackground}\n >\n {renderImageContent(imageDetails, bannerProps ?? {}, 'bg-image')}\n {renderDesktopContent(props, isScrolled, renderSocialMediaIcons, isMobile, hasWhiteBackground)}\n </MysiteHeroContainer>\n );\n}\n","import React from 'react';\nimport { styled } from '@nuskin/foundation-theme';\nimport { Box, BoxProps } from '@mui/material';\n\ninterface StyledBoxProps extends BoxProps {\n bannerProps?: {\n backgroundColor?: string;\n headlineFont?: string;\n paragraphFont?: string;\n };\n isCircularImage?: boolean;\n hasWhiteBackground?: boolean;\n}\n\ninterface BadgeProps extends BoxProps {\n hasWhiteBackground?: boolean;\n}\n\nconst getContactTextStyles = (hasWhiteBackground: boolean | undefined) => ({\n fontSize: '12px',\n fontStyle: 'normal' as const,\n fontWeight: '600',\n lineHeight: '16px',\n letterSpacing: '0.12px',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n '& a': {\n color: 'inherit',\n textDecoration: 'none',\n '&:hover': {\n textDecoration: 'underline',\n },\n },\n});\n\nconst getSocialTitleStyles = (hasWhiteBackground: boolean | undefined) => ({\n fontSize: '12px',\n fontStyle: 'normal' as const,\n fontWeight: '700',\n lineHeight: '16px',\n letterSpacing: '0.48px',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n textTransform: 'uppercase' as const,\n paddingLeft: '5px',\n});\n\nconst getSocialIconsStyles = () => ({\n display: 'flex',\n flexDirection: 'row' as const,\n gap: '10px',\n alignItems: 'center',\n});\n\nconst getContactTextMobileStyles = (hasWhiteBackground: boolean | undefined) => ({\n ...getContactTextStyles(hasWhiteBackground),\n paddingBottom: '11px',\n wordBreak: 'break-all' as const,\n overflowWrap: 'break-word' as const,\n paddingLeft: '5px',\n '& a': {\n color: 'inherit',\n textDecoration: 'none',\n },\n '@media (max-width: 420px)': {\n fontSize: '11px',\n lineHeight: '15px',\n paddingBottom: '8px',\n },\n '@media (max-width: 400px)': {\n fontSize: '10px',\n lineHeight: '14px',\n paddingBottom: '6px',\n },\n '@media (max-width: 375px)': {\n fontSize: '8px',\n lineHeight: '12px',\n paddingBottom: '4px',\n },\n});\n\nconst getSocialTitleMobileStyles = (hasWhiteBackground: boolean | undefined) => ({\n ...getSocialTitleStyles(hasWhiteBackground),\n marginBottom: '11px',\n transition: 'opacity 0.3s ease-out, transform 0.3s ease-out',\n opacity: 1,\n transform: 'translateY(0)',\n '@media (max-width: 420px)': {\n fontSize: '11px',\n lineHeight: '14px',\n marginBottom: '8px',\n },\n '@media (max-width: 400px)': {\n fontSize: '10px',\n lineHeight: '12px',\n marginBottom: '5px',\n },\n '@media (max-width: 375px)': {\n fontSize: '8px',\n lineHeight: '11px',\n marginBottom: '4px',\n },\n});\n\nexport const MysiteHeroContainer = styled((props: StyledBoxProps) => <Box {...props} />)(\n ({ bannerProps, isCircularImage, hasWhiteBackground }) => ({\n backgroundClip: 'border-box',\n display: 'flex',\n background: bannerProps?.backgroundColor ?? '#383838',\n position: 'relative',\n overflow: 'hidden',\n width: '100%',\n height: 'auto',\n flexDirection: 'row',\n alignItems: 'center',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'transform, opacity',\n transform: 'translateZ(0)',\n backfaceVisibility: 'hidden',\n '&.scrolled': {\n top: 0,\n left: 0,\n right: 0,\n boxShadow: '0 2px 8px rgba(0,0,0,0.2)',\n '.content': {\n paddingTop: '0',\n justifyContent: 'center',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.body-title': {\n fontSize: '26px',\n lineHeight: '34px',\n marginBottom: '0',\n fontStyle: 'normal',\n fontWeight: '400',\n fontFamily: bannerProps?.headlineFont ?? 'Lora',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n\n '.bg-image': {\n width: '90px',\n height: '90px',\n padding: isCircularImage ? '2px' : '0px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n objectFit: 'cover',\n objectPosition: 'center',\n },\n '.placeholder-image': {\n '& > div': {\n width: '90px',\n height: '90px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n },\n },\n '.content': {\n width: '70%',\n height: '100%',\n marginLeft: '2%',\n marginRight: 'auto',\n display: 'flex',\n flexDirection: 'column',\n position: 'relative',\n boxSizing: 'border-box',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.bg-image': {\n width: '252px',\n height: '252px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'width, height, transform',\n padding: isCircularImage ? '3px' : '0px',\n objectFit: 'cover',\n objectPosition: 'center',\n },\n '.placeholder-image': {\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'width, height, transform',\n '& > div': {\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n },\n '.body-title': {\n fontSize: '32px',\n lineHeight: '38px',\n marginBottom: '8px',\n fontWeight: '400',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n fontFamily: bannerProps?.headlineFont ?? 'Lora',\n paddingLeft: '5px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.body-text': {\n fontSize: '16px',\n marginBottom: '12px',\n fontStyle: 'normal',\n fontWeight: '400',\n lineHeight: '22px',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n fontFamily: bannerProps?.paragraphFont ?? 'inherit',\n display: '-webkit-box',\n WebkitBoxOrient: 'vertical',\n overflow: 'hidden',\n WebkitLineClamp: 3,\n textOverflow: 'ellipsis',\n paddingLeft: '5px',\n transition: 'opacity 0.3s ease-out, transform 0.3s ease-out',\n opacity: 1,\n transform: 'translateY(0)',\n },\n '.social-media': {\n display: 'flex',\n flexDirection: 'column',\n transition: 'opacity 0.3s ease-out, transform 0.3s ease-out',\n opacity: 1,\n transform: 'translateY(0)',\n },\n '.email-text': getContactTextStyles(hasWhiteBackground),\n '.phone-text': getContactTextStyles(hasWhiteBackground),\n '.social-title-text': {\n ...getSocialTitleStyles(hasWhiteBackground),\n marginBottom: '8px',\n },\n '.social-icons': {\n ...getSocialIconsStyles(),\n paddingBottom: '8px',\n },\n }),\n);\n\nexport const MysiteHeroContainerMobile = styled((props: StyledBoxProps) => <Box {...props} />)(\n ({ bannerProps, isCircularImage, hasWhiteBackground }) => ({\n backgroundClip: 'border-box',\n display: 'flex',\n background: bannerProps?.backgroundColor ?? '#383838',\n position: 'relative',\n overflow: 'hidden',\n width: '100%',\n flexDirection: 'column',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'transform, opacity',\n transform: 'translateZ(0)',\n backfaceVisibility: 'hidden',\n '&.scrolled': {\n top: 0,\n left: 0,\n right: 0,\n boxShadow: '0 2px 8px rgba(0,0,0,0.2)',\n '.content-mobile': {\n paddingTop: '5px',\n width: '60%',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.body-title-mobile': {\n fontSize: '18px',\n lineHeight: '28px',\n marginBottom: '0',\n fontStyle: 'normal',\n fontWeight: '400',\n fontFamily: bannerProps?.headlineFont ?? 'Lora',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n '.bg-image-mobile': {\n width: '75px',\n height: '75px',\n padding: isCircularImage ? '2px' : '0px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n objectFit: 'cover',\n objectPosition: 'center',\n },\n '.placeholder-image-mobile': {\n '& > div': {\n width: '75px !important',\n height: '75px !important',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n },\n },\n },\n '.image-content-mobile': {\n display: 'flex',\n flexDirection: 'row',\n width: '100%',\n justifyContent: 'center',\n alignItems: 'center',\n },\n '.content-mobile': {\n width: '55%',\n height: '100%',\n paddingTop: '10px',\n paddingRight: '10px',\n marginLeft: '8px',\n marginRight: 'auto',\n display: 'flex',\n flexDirection: 'column',\n justifyContent: 'center',\n position: 'relative',\n boxSizing: 'border-box',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n '@media (max-width: 420px)': {\n paddingTop: '8px',\n width: '100%',\n },\n '@media (max-width: 400px)': {\n paddingTop: '6px',\n width: '100%',\n height: '100%',\n },\n '@media (max-width: 375px)': {\n paddingTop: '4px',\n width: '100%',\n height: '100%',\n },\n },\n '.bg-image-mobile': {\n width: '144px',\n height: '144px',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n objectFit: 'cover',\n objectPosition: 'center',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'width, height, transform',\n padding: isCircularImage ? '2px' : '0px',\n '@media (max-width: 420px)': {\n width: '120px',\n height: '120px',\n },\n '@media (max-width: 400px)': {\n width: '112px',\n height: '112px',\n },\n '@media (max-width: 375px)': {\n width: '90px',\n height: '90px',\n },\n },\n '.placeholder-image-mobile': {\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n willChange: 'width, height, transform',\n '& > div': {\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n width: '144px',\n height: '144px',\n '@media (max-width: 420px)': {\n width: '120px',\n height: '120px',\n },\n '@media (max-width: 400px)': {\n width: '110px !important',\n height: '110px !important',\n },\n '@media (max-width: 375px)': {\n width: '90px',\n height: '90px',\n },\n },\n },\n '.body-title-mobile': {\n fontSize: '22px',\n lineHeight: '28px',\n marginBottom: '13px',\n fontWeight: '400',\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n fontStyle: 'normal',\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n fontFamily: bannerProps?.headlineFont ?? 'Lora',\n paddingLeft: '5px',\n transition: 'all 0.2s cubic-bezier(0.4, 0, 0.2, 1)',\n '@media (max-width: 420px)': {\n fontSize: '16px',\n lineHeight: '24px',\n marginBottom: '8px',\n },\n '@media (max-width: 400px)': {\n fontSize: '16px',\n lineHeight: '22px',\n marginBottom: '6px',\n },\n '@media (max-width: 375px)': {\n fontSize: '14px',\n lineHeight: '20px',\n marginBottom: '4px',\n },\n },\n '.body-text-mobile': {\n fontSize: '14px',\n padding: '20px 25px 20px 25px',\n fontStyle: 'normal',\n fontWeight: '400',\n lineHeight: '20px',\n color: '#252525',\n backgroundColor: '#E0E0E0',\n fontFamily: bannerProps?.paragraphFont ?? 'inherit',\n transition: 'all 0.25s cubic-bezier(0.4, 0, 0.2, 1)',\n opacity: 1,\n transform: 'translateY(0)',\n },\n '.expandable-description-mobile': {\n backgroundColor: '#E0E0E0',\n position: 'relative',\n },\n '.description-content-mobile': {\n fontSize: '14px',\n padding: '10px 15px',\n fontStyle: 'normal',\n fontWeight: '400',\n lineHeight: '20px',\n color: '#252525',\n fontFamily: bannerProps?.paragraphFont ?? 'inherit',\n transition: 'max-height 0.3s ease-in-out, opacity 0.3s ease-in-out',\n overflow: 'hidden',\n position: 'relative',\n '&.collapsed': {\n maxHeight: '50px',\n display: '-webkit-box',\n WebkitLineClamp: 2,\n WebkitBoxOrient: 'vertical',\n '&::after': {\n content: '\"\"',\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n height: '20px',\n background: 'linear-gradient(transparent, rgba(224, 224, 224, 0.8), #E0E0E0)',\n pointerEvents: 'none',\n },\n },\n '&.expanded': {\n maxHeight: 'none',\n whiteSpace: 'normal',\n display: 'block',\n '&::after': {\n display: 'none',\n },\n },\n },\n '.email-text-mobile': getContactTextMobileStyles(hasWhiteBackground),\n '.phone-text-mobile': getContactTextMobileStyles(hasWhiteBackground),\n '.social-title-text-mobile': getSocialTitleMobileStyles(hasWhiteBackground),\n '.social-icons-mobile': {\n ...getSocialIconsStyles(),\n paddingBottom: '10px',\n transition: 'opacity 0.3s ease-out, transform 0.3s ease-out',\n opacity: 1,\n transform: 'translateY(0)',\n '& img': {\n width: '24px',\n height: '24px',\n '@media (max-width: 400px)': {\n width: '20px',\n height: '20px',\n },\n '@media (max-width: 375px)': {\n width: '18px',\n height: '18px',\n },\n },\n '@media (max-width: 420px)': {\n paddingBottom: '8px',\n },\n '@media (max-width: 400px)': {\n paddingBottom: '4px',\n },\n '@media (max-width: 375px)': {\n paddingBottom: '3px',\n },\n },\n }),\n);\n\nexport const BadgeContainer = styled(Box)({\n display: 'flex',\n gap: '12px',\n marginBottom: '16px',\n paddingLeft: '5px',\n\n '&.mobile-badges': {\n flexDirection: 'column',\n gap: '8px',\n marginBottom: '12px',\n },\n\n '&.tablet-badges': {\n flexDirection: 'row',\n gap: '12px',\n marginBottom: '8px',\n },\n});\n\nexport const Badge = styled((props: BadgeProps) => <Box {...props} />)(({ hasWhiteBackground }) => ({\n backgroundColor: 'rgba(255, 255, 255, 0.2)',\n backdropFilter: 'blur(10px)',\n borderRadius: '20px',\n padding: '8px 16px',\n display: 'flex',\n alignItems: 'center',\n gap: '4px',\n border: '1px solid rgba(255, 255, 255, 0.3)',\n transition: 'all 0.3s ease',\n\n '&.mobile-badge': {\n padding: '6px 12px',\n borderRadius: '16px',\n fontSize: '12px',\n },\n\n '&.tablet-badge': {\n padding: '8px 16px',\n borderRadius: '20px',\n fontSize: '14px',\n },\n\n '&:hover': {\n backgroundColor: 'rgba(255, 255, 255, 0.3)',\n transform: 'translateY(-1px)',\n boxShadow: '0 4px 12px rgba(0, 0, 0, 0.1)',\n },\n\n '.badge-text': {\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n fontWeight: '400',\n opacity: 0.9,\n },\n\n '.badge-value': {\n color: hasWhiteBackground ? '#000000' : '#FFFFFF',\n fontWeight: '600',\n },\n}));\nexport const ToggleButtonMobile = styled('button')({\n backgroundColor: '#E0E0E0',\n border: '1px solid #252525',\n borderRadius: '10px',\n cursor: 'pointer',\n width: '40px',\n height: '20px',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n margin: '10px auto 5px auto',\n transition: 'all 0.2s ease',\n '& .arrow-icon-mobile': {\n transition: 'transform 0.3s ease',\n '&.expanded': {\n transform: 'rotate(180deg)',\n },\n },\n});\nexport const StyledSpan = styled(Box)`\n background: none;\n border: 2px solid transparent;\n cursor: pointer;\n padding: 2px;\n display: flex;\n align-items: center;\n border-radius: 8px;\n transition: all 0.3s ease;\n\n &:hover {\n transform: scale(1.1);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n }\n\n &:focus,\n &:focus-within {\n outline: none;\n border-color: #007bff;\n box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25);\n }\n\n &:hover svg {\n fill: #ffffff;\n }\n`;\nexport const ImgTabIndex = styled('span')`\n line-height: 0.5;\n`;\n\nexport const ContactLink = styled('a')({\n fontSize: 'inherit',\n fontFamily: 'inherit',\n fontWeight: 'inherit',\n lineHeight: 'inherit',\n letterSpacing: 'inherit',\n color: 'inherit',\n textDecoration: 'none',\n '&:hover': {\n textDecoration: 'underline',\n },\n});\n\nexport const BadgeValue = styled('span')({});\n","import React from 'react';\nimport { Box } from '@mui/material';\n\ntype PlaceholderImageProps = {\n readonly width: string | number;\n readonly height: string | number;\n readonly backgroundColor: string;\n};\n\nexport const PlaceholderImage: React.FC<PlaceholderImageProps> = ({ width, height, backgroundColor }) => {\n return (\n <Box\n sx={{\n width,\n height,\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n backgroundColor,\n }}\n data-testid=\"placeholder-image\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"128\" height=\"129\" viewBox=\"0 0 128 129\" fill=\"none\">\n <g id=\"ns_logomark\">\n <path\n id=\"Vector\"\n d=\"M127.495 52.1946C125.663 47.9538 122.999 44.1171 119.661 40.9073C112.565 34.2835 102.562 31.7037 93.1175 34.0622C83.6733 36.4206 76.0882 43.3926 72.991 52.5619C71.4142 56.8414 70.6063 61.3627 70.6039 65.9196C70.6039 85.8227 70.6039 105.737 70.6039 125.662C70.6039 129.001 70.6039 129.001 66.9051 128.834C66.9051 128.2 66.9051 127.499 66.9051 126.831C66.9051 104.323 66.9051 81.8263 66.9051 59.3409C66.3415 45.3064 74.9302 32.5039 88.1888 27.6164C89.79 27.0612 91.4307 26.6259 93.0981 26.314C94.7114 25.98 96.4605 25.8465 98.0738 25.6461C96.0231 16.3291 78.9419 5.60953 65.0889 4.97504C50.3084 4.62252 36.6074 12.6365 29.7509 25.6461C31.331 25.8465 32.8779 25.9466 34.3569 26.2138C48.0999 28.544 58.7086 39.4998 60.5168 53.2298C60.8904 55.7285 61.0812 58.2508 61.0877 60.7769C61.0877 82.7507 61.0877 104.724 61.0877 126.697C61.0877 128.434 60.6842 129.169 58.8016 128.968C56.9183 128.768 57.1204 128.2 57.1204 126.965C57.1204 119.985 57.1204 113.006 57.1204 105.993C57.1204 92.1674 57.1204 78.3423 57.1204 64.5171C57.2385 56.3928 54.2457 48.5271 48.7477 42.5103C42.2429 35.5282 32.6539 32.2371 23.1959 33.7401C13.7379 35.243 5.66194 41.3411 1.67448 49.9906C1.23781 50.8254 0.867444 51.6937 0.262573 52.9293C5.79294 22.3996 32.4752 0.139867 63.7085 0.000656323C94.9411 -0.138555 121.824 21.8824 127.629 52.3616\"\n fill=\"#252525\"\n />\n <path\n id=\"Vector_2\"\n d=\"M86.0995 124.927C86.0995 124.293 86.0995 123.858 86.0995 123.425C86.0995 111.669 86.0995 100.049 86.0995 88.1269C85.8836 82.4231 88.0775 76.89 92.1523 72.8653C97.3131 67.9567 104.984 66.7091 111.452 69.7263C117.892 72.1185 122.166 78.225 122.178 85.0541C122.372 92.1747 119.781 99.0921 114.949 104.356C107.882 113.237 98.6134 120.141 88.05 124.392C87.4217 124.616 86.782 124.805 86.1335 124.96\"\n fill=\"#252525\"\n />\n <path\n id=\"Vector_3\"\n d=\"M41.8183 125.395C37.6149 123.224 33.6477 121.487 29.9828 119.25C21.5405 114.299 14.4778 107.331 9.43828 98.9796C6.53442 94.3985 5.34408 88.9493 6.07591 83.5852C7.056 75.2882 13.8859 68.8841 22.2829 68.3905C31.1231 67.2473 39.3527 73.0751 41.1455 81.7484C41.76 84.263 42.0762 86.8411 42.0868 89.4287C42.0868 100.516 42.0868 111.636 42.0868 122.823C42.0868 123.457 42.0867 124.059 41.8854 125.294\"\n fill=\"#252525\"\n />\n <path\n id=\"Vector_4\"\n d=\"M51.3337 127.431C47.9713 127.431 47.6681 127.198 47.6681 124.326V76.6386C48.1096 67.937 42.9747 59.906 34.8574 56.602C25.8992 52.8557 15.5485 54.8615 8.66523 61.6779C4.28638 66.6086 1.89197 72.9696 1.94049 79.5438C1.95423 80.2444 1.78037 80.9357 1.43588 81.5476C1.06552 79.9446 0.62885 78.2081 0.426687 76.7387C-0.724024 70.4463 0.471163 63.9529 3.78906 58.472C6.09291 54.6111 9.65016 51.6434 13.8762 50.0567C22.8587 46.555 32.9393 47.1785 41.4148 51.7598C47.6592 54.8694 51.5262 61.2882 51.3337 68.2232C51.5019 87.6249 51.3337 107.027 51.3337 126.396C51.3337 126.797 51.3337 127.164 51.3337 127.532\"\n fill=\"#252525\"\n />\n <path\n id=\"Vector_5\"\n d=\"M76.287 127.499V125.094C76.287 107.196 76.4883 89.2963 76.287 71.3966C76.0848 56.9034 84.2554 50.6588 95.7553 48.3545C101.535 47.2005 107.524 47.6393 113.071 49.6235C122.914 53.3319 128.994 63.1725 127.866 73.5672C127.631 76.2831 127.17 78.975 126.487 81.6151C125.916 78.2758 125.68 74.9364 124.772 71.597C122.808 64.3002 117.377 58.4174 110.228 55.8421C103.078 53.2668 95.1132 54.3239 88.8955 58.6734C83.0441 62.6207 79.7011 69.3237 80.086 76.3389C80.086 92.2349 80.086 108.131 80.086 124.026C80.086 127.366 80.086 127.366 76.2198 127.366\"\n fill=\"#252525\"\n />\n </g>\n </svg>\n </Box>\n );\n};\n","import React from 'react';\n\ntype ArrowDownIconProps = {\n readonly width?: string | number;\n readonly height?: string | number;\n readonly className?: string;\n};\n\nexport const ArrowDownIcon: React.FC<ArrowDownIconProps> = ({ width = 16, height = 16, className = '' }) => {\n return (\n <svg\n width={width}\n height={height}\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className={className}\n data-testid=\"arrow-down-icon\"\n >\n <path d=\"M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z\" />\n </svg>\n );\n};\n","export interface GTMEvent {\n event: string;\n\n [key: string]: unknown;\n}\n\ndeclare global {\n interface Window {\n dataLayer: unknown[];\n }\n}\n\nexport function trackGTMEvent(eventData: GTMEvent): void {\n if (typeof window === 'undefined') {\n return;\n }\n\n const url = window.location.href;\n const updatedEventData = { ...eventData };\n\n const prefix = url.includes('personal-offer') ? 'postorefront_' : 'mysite_';\n updatedEventData.event = prefix + eventData.event;\n\n try {\n if (window.dataLayer) {\n window.dataLayer.push(updatedEventData);\n } else {\n console.error('GTM dataLayer not available, but event logged');\n window.dataLayer = [];\n window.dataLayer.push(updatedEventData);\n }\n } catch (error) {\n console.error('Failed to track GTM event:', error);\n }\n}\n","import { styled } from '@nuskin/foundation-theme';\n\nexport const DashboardContainer = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 24px;\n padding: 16px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 24px;\n gap: 32px;\n }\n\n @media (min-width: 1080px) {\n padding: 32px;\n gap: 40px;\n }\n`;\n\nexport const StatsRow = styled('div')`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 768px) {\n grid-template-columns: repeat(3, 1fr);\n gap: 20px;\n }\n\n @media (min-width: 1080px) {\n gap: 24px;\n }\n`;\n\nexport const WidgetContainer = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 768px) {\n gap: 20px;\n }\n\n @media (min-width: 1080px) {\n gap: 24px;\n }\n`;\n\nexport const TwoColumnGrid = styled('div')`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 1080px) {\n grid-template-columns: repeat(2, 1fr);\n gap: 24px;\n }\n`;\n\nexport const ErrorContainer = styled('div')`\n padding: 24px;\n text-align: center;\n color: #d32f2f;\n background-color: #ffebee;\n border-radius: 8px;\n`;\n","import React from 'react';\nimport CalendarTodayIcon from '@mui/icons-material/CalendarToday';\nimport PublicIcon from '@mui/icons-material/Public';\nimport { NsSpinner } from '@nuskin/foundation-ui-components';\nimport {\n HeaderContainer,\n TitleSection,\n ShopTitle,\n DateRangeLabel,\n FiltersSection,\n FilterDropdownContainer,\n FilterLabel,\n StyledSelect,\n FilterIcon,\n LoadingIndicatorContainer,\n DesktopFiltersContainer,\n} from './DashboardHeader.styled';\nimport type { DateRangeOption, MarketOption, DashboardStats } from '../types.d';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface DashboardHeaderProps {\n readonly shopTitle?: string;\n readonly dateRange: DateRangeOption;\n readonly market: MarketOption;\n readonly dateRangeLabel?: string;\n readonly isLoading?: boolean;\n readonly stats?: DashboardStats | null;\n readonly onDateRangeChange?: (range: DateRangeOption) => void;\n readonly onMarketChange?: (market: MarketOption) => void;\n}\n\nexport const DashboardHeader: React.FC<DashboardHeaderProps> = ({\n shopTitle,\n dateRange,\n market,\n dateRangeLabel: dateRangeLabelProp,\n isLoading = false,\n stats,\n onDateRangeChange,\n onMarketChange,\n}) => {\n const handleDateRangeChange = (event: React.ChangeEvent<HTMLSelectElement>) => {\n const newDateRange = event.target.value as DateRangeOption;\n onDateRangeChange?.(newDateRange);\n };\n\n const handleMarketChange = (event: React.ChangeEvent<HTMLSelectElement>) => {\n const newMarket = event.target.value as MarketOption;\n onMarketChange?.(newMarket);\n };\n\n const handleFilterKeyDown = (event: React.KeyboardEvent<HTMLSelectElement>) => {\n if (event.key === 'Escape') {\n (event.target as HTMLSelectElement).blur();\n }\n };\n\n const getDateRangeLabelText = () => {\n if (dateRangeLabelProp) return dateRangeLabelProp;\n if (stats?.dateRange) return stats.dateRange.label;\n return getTranslation(Keys.filter.dateRange.last30days);\n };\n\n return (\n <HeaderContainer as=\"header\" data-testid=\"dashboard-header\">\n <TitleSection>\n <ShopTitle data-testid=\"dashboard-shop-title\">\n {shopTitle ?? stats?.shopTitle ?? getTranslation(Keys.title)}\n </ShopTitle>\n <DateRangeLabel aria-live=\"polite\" data-testid=\"dashboard-date-range-label\">\n {getDateRangeLabelText()}\n </DateRangeLabel>\n </TitleSection>\n\n <FiltersSection\n aria-label={getTranslation(Keys.ariaLabel.dashboardFilters)}\n data-testid=\"dashboard-filters-section\"\n >\n <DesktopFiltersContainer>\n {isLoading && (\n <LoadingIndicatorContainer\n as=\"output\"\n aria-live=\"polite\"\n aria-label={getTranslation(Keys.ariaLabel.loadingDashboard)}\n data-testid=\"dashboard-loading-indicator\"\n >\n <NsSpinner />\n </LoadingIndicatorContainer>\n )}\n\n <FilterDropdownContainer>\n <FilterLabel htmlFor=\"filter-date-range\">\n {getTranslation(Keys.filter.dateRangeLabel)}\n </FilterLabel>\n <FilterIcon aria-hidden=\"true\">\n <CalendarTodayIcon />\n </FilterIcon>\n <StyledSelect\n id=\"filter-date-range\"\n data-testid=\"filter-date-range\"\n value={dateRange}\n onChange={handleDateRangeChange}\n onKeyDown={handleFilterKeyDown}\n disabled={isLoading}\n aria-label={`${getTranslation(Keys.ariaLabel.dateRangeFilter)} ${getTranslation(Keys.filter.dateRange[dateRange])}`}\n >\n <option value=\"last7days\">{getTranslation(Keys.filter.dateRange.last7days)}</option>\n <option value=\"last30days\">{getTranslation(Keys.filter.dateRange.last30days)}</option>\n <option value=\"last90days\">{getTranslation(Keys.filter.dateRange.last90days)}</option>\n <option value=\"thisMonth\">{getTranslation(Keys.filter.dateRange.thisMonth)}</option>\n </StyledSelect>\n </FilterDropdownContainer>\n\n <FilterDropdownContainer>\n <FilterLabel htmlFor=\"filter-market\">{getTranslation(Keys.filter.marketLabel)}</FilterLabel>\n <FilterIcon aria-hidden=\"true\">\n <PublicIcon />\n </FilterIcon>\n <StyledSelect\n id=\"filter-market\"\n data-testid=\"filter-market\"\n value={market}\n onChange={handleMarketChange}\n onKeyDown={handleFilterKeyDown}\n disabled={isLoading}\n aria-label={`${getTranslation(Keys.ariaLabel.marketFilter)} ${getTranslation(Keys.filter.market[market])}`}\n >\n <option value=\"all\">{getTranslation(Keys.filter.market.all)}</option>\n <option value=\"us\">{getTranslation(Keys.filter.market.us)}</option>\n <option value=\"ca\">{getTranslation(Keys.filter.market.ca)}</option>\n <option value=\"jp\">{getTranslation(Keys.filter.market.jp)}</option>\n <option value=\"kr\">{getTranslation(Keys.filter.market.kr)}</option>\n <option value=\"au\">{getTranslation(Keys.filter.market.au)}</option>\n <option value=\"nz\">{getTranslation(Keys.filter.market.nz)}</option>\n </StyledSelect>\n </FilterDropdownContainer>\n </DesktopFiltersContainer>\n </FiltersSection>\n </HeaderContainer>\n );\n};\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const HeaderContainer = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 12px;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border-radius: 12px;\n min-height: 64px;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n padding: 24px;\n }\n\n @media (min-width: 1080px) {\n padding: 24px 32px;\n }\n`;\n\nexport const TitleSection = styled('div')`\n display: flex;\n flex-direction: row;\n align-items: baseline;\n gap: 12px;\n flex-wrap: wrap;\n`;\n\nexport const ShopTitle = styled('h1')`\n font-size: 20px;\n font-weight: 600;\n line-height: 1.3;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n\n @media (min-width: 768px) {\n font-size: 24px;\n }\n\n @media (min-width: 1080px) {\n font-size: 28px;\n }\n`;\n\nexport const DateRangeLabel = styled('div')`\n font-size: 13px;\n font-weight: 400;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n\n @media (min-width: 768px) {\n font-size: 14px;\n }\n`;\n\nexport const FiltersSection = styled('div')`\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-items: center;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 768px) {\n width: auto;\n }\n`;\n\nexport const FilterDropdownContainer = styled('div')`\n display: flex;\n align-items: center;\n gap: 8px;\n position: relative;\n`;\n\nexport const FilterLabel = styled('label')`\n font-size: 14px;\n font-weight: 500;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N80')};\n white-space: nowrap;\n display: none;\n\n @media (min-width: 1080px) {\n display: block;\n }\n`;\n\nexport const StyledSelect = styled('select')`\n display: flex;\n align-items: center;\n gap: 12px;\n height: 40px;\n padding: 8px 12px;\n background-color: transparent;\n border: none;\n border-radius: 4px;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n appearance: none;\n background-image: url('data:image/svg+xml;charset=UTF-8,%3csvg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3e%3cpath d=\"M5.625 7.3125L9 10.6875L12.375 7.3125\" stroke=\"%235f5f5f\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/%3e%3c/svg%3e');\n background-repeat: no-repeat;\n background-position: right 8px center;\n padding-right: 32px;\n min-width: auto;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n\n &:focus {\n border-color: ${({ theme }) => getGenomeColor(theme, 'A70')};\n box-shadow: 0 0 0 3px ${({ theme }) => getGenomeColor(theme, 'A20')};\n }\n\n &:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n @media (min-width: 768px) {\n min-width: 160px;\n }\n\n @media (min-width: 1080px) {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N10')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n border-radius: 8px;\n min-width: 180px;\n }\n`;\n\nexport const FilterIcon = styled('span')`\n display: inline-flex;\n align-items: center;\n justify-content: center;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n\n svg {\n width: 16px;\n height: 16px;\n }\n`;\n\nexport const LoadingIndicatorContainer = styled('div')`\n display: flex;\n align-items: center;\n justify-content: center;\n width: 28px;\n height: 28px;\n overflow: hidden;\n\n svg,\n img,\n > * {\n width: 28px !important;\n height: 28px !important;\n max-width: 28px;\n max-height: 28px;\n }\n`;\n\nexport const DesktopFiltersContainer = styled('div')`\n display: flex;\n flex-wrap: wrap;\n gap: 16px;\n align-items: center;\n width: 100%;\n\n @media (min-width: 768px) {\n width: auto;\n }\n`;\n\nexport const StyledCircularProgress = styled('div')`\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n","/**\n * Translation Keys for Shopping Dashboard\n * i18n key mapping with fallback strings for internationalization support.\n */\n\nexport const ShoppingDashboardTranslationKeys = {\n title: {\n key: 'shoppingDashboard.title',\n fallback: 'Shop Performance',\n },\n error: {\n key: 'shoppingDashboard.error',\n fallback: 'Error loading dashboard',\n },\n stats: {\n revenue: {\n key: 'shoppingDashboard.stats.revenue',\n fallback: 'Total Revenue',\n },\n volume: {\n key: 'shoppingDashboard.stats.volume',\n fallback: 'Volume',\n },\n visits: {\n key: 'shoppingDashboard.stats.visits',\n fallback: 'Site Visits',\n },\n subtitle: {\n dcSv: {\n key: 'shoppingDashboard.stats.subtitle.dcSv',\n fallback: 'DC-SV',\n },\n conversionRate: {\n key: 'shoppingDashboard.stats.subtitle.conversionRate',\n fallback: 'Conversion Rate',\n },\n },\n trend: {\n increased: {\n key: 'shoppingDashboard.stats.trend.increased',\n fallback: 'increased',\n },\n decreased: {\n key: 'shoppingDashboard.stats.trend.decreased',\n fallback: 'decreased',\n },\n unchanged: {\n key: 'shoppingDashboard.stats.trend.unchanged',\n fallback: 'unchanged',\n },\n },\n details: {\n key: 'shoppingDashboard.stats.details',\n fallback: 'details',\n },\n },\n filter: {\n dateRange: {\n label: {\n key: 'shoppingDashboard.filter.dateRange.label',\n fallback: 'Date Range',\n },\n last7days: {\n key: 'shoppingDashboard.filter.dateRange.last7days',\n fallback: 'Last 7 Days',\n },\n last30days: {\n key: 'shoppingDashboard.filter.dateRange.last30days',\n fallback: 'Last 30 Days',\n },\n last90days: {\n key: 'shoppingDashboard.filter.dateRange.last90days',\n fallback: 'Last 90 Days',\n },\n thisMonth: {\n key: 'shoppingDashboard.filter.dateRange.thisMonth',\n fallback: 'This Month',\n },\n },\n dateRangeLabel: {\n key: 'shoppingDashboard.filter.dateRangeLabel',\n fallback: 'Date Range',\n },\n market: {\n label: {\n key: 'shoppingDashboard.filter.market.label',\n fallback: 'Market',\n },\n all: {\n key: 'shoppingDashboard.filter.market.all',\n fallback: 'All Markets',\n },\n us: {\n key: 'shoppingDashboard.filter.market.us',\n fallback: 'United States',\n },\n ca: {\n key: 'shoppingDashboard.filter.market.ca',\n fallback: 'Canada',\n },\n jp: {\n key: 'shoppingDashboard.filter.market.jp',\n fallback: 'Japan',\n },\n kr: {\n key: 'shoppingDashboard.filter.market.kr',\n fallback: 'Korea',\n },\n au: {\n key: 'shoppingDashboard.filter.market.au',\n fallback: 'Australia',\n },\n nz: {\n key: 'shoppingDashboard.filter.market.nz',\n fallback: 'New Zealand',\n },\n },\n marketLabel: {\n key: 'shoppingDashboard.filter.marketLabel',\n fallback: 'Market',\n },\n productSort: {\n label: {\n key: 'shoppingDashboard.filter.productSort.label',\n fallback: 'Sort By',\n },\n units: {\n key: 'shoppingDashboard.filter.productSort.units',\n fallback: 'Units',\n },\n revenue: {\n key: 'shoppingDashboard.filter.productSort.revenue',\n fallback: 'Revenue',\n },\n volume: {\n key: 'shoppingDashboard.filter.productSort.volume',\n fallback: 'Volume',\n },\n byUnits: {\n key: 'shoppingDashboard.filter.productSort.byUnits',\n fallback: 'By: Units',\n },\n byRevenue: {\n key: 'shoppingDashboard.filter.productSort.byRevenue',\n fallback: 'By: Revenue',\n },\n byVolume: {\n key: 'shoppingDashboard.filter.productSort.byVolume',\n fallback: 'By: Volume',\n },\n },\n signupView: {\n label: {\n key: 'shoppingDashboard.filter.signupView.label',\n fallback: 'Show',\n },\n all: {\n key: 'shoppingDashboard.filter.signupView.all',\n fallback: 'All',\n },\n members: {\n key: 'shoppingDashboard.filter.signupView.members',\n fallback: 'Members',\n },\n retail: {\n key: 'shoppingDashboard.filter.signupView.retail',\n fallback: 'Retail',\n },\n brandAffiliates: {\n key: 'shoppingDashboard.filter.signupView.brandAffiliates',\n fallback: 'Brand Affiliates',\n },\n showAll: {\n key: 'shoppingDashboard.filter.signupView.showAll',\n fallback: 'Show: All',\n },\n showMembers: {\n key: 'shoppingDashboard.filter.signupView.showMembers',\n fallback: 'Show: Members',\n },\n showRetail: {\n key: 'shoppingDashboard.filter.signupView.showRetail',\n fallback: 'Show: Retail',\n },\n showBrandAffiliates: {\n key: 'shoppingDashboard.filter.signupView.showBrandAffiliates',\n fallback: 'Show: Brand Affiliates',\n },\n },\n categorySort: {\n byRevenue: {\n key: 'shoppingDashboard.filter.categorySort.byRevenue',\n fallback: 'By: Revenue',\n },\n byUnits: {\n key: 'shoppingDashboard.filter.categorySort.byUnits',\n fallback: 'By: Units',\n },\n },\n },\n widget: {\n topProducts: {\n title: {\n key: 'shoppingDashboard.widget.topProducts.title',\n fallback: 'Top Selling Products',\n },\n viewAll: {\n key: 'shoppingDashboard.widget.topProducts.viewAll',\n fallback: 'View All Products',\n },\n units: {\n key: 'shoppingDashboard.widget.topProducts.units',\n fallback: 'Units',\n },\n revenue: {\n key: 'shoppingDashboard.widget.topProducts.revenue',\n fallback: 'Revenue',\n },\n loading: {\n key: 'shoppingDashboard.widget.topProducts.loading',\n fallback: 'Loading products...',\n },\n empty: {\n key: 'shoppingDashboard.widget.topProducts.empty',\n fallback: 'No products available',\n },\n ariaLabel: {\n key: 'shoppingDashboard.widget.topProducts.ariaLabel',\n fallback: 'Top Selling Products widget',\n },\n titleAriaLabel: {\n key: 'shoppingDashboard.widget.topProducts.titleAriaLabel',\n fallback: 'Click to view full top products details page',\n },\n sortAriaLabel: {\n key: 'shoppingDashboard.widget.topProducts.sortAriaLabel',\n fallback: 'Sort products by',\n },\n noImageAriaLabel: {\n key: 'shoppingDashboard.widget.topProducts.noImageAriaLabel',\n fallback: 'No image available',\n },\n unitsSuffix: {\n key: 'shoppingDashboard.widget.topProducts.unitsSuffix',\n fallback: 'units',\n },\n revenueSuffix: {\n key: 'shoppingDashboard.widget.topProducts.revenueSuffix',\n fallback: 'revenue',\n },\n dcSvSuffix: {\n key: 'shoppingDashboard.widget.topProducts.dcSvSuffix',\n fallback: 'DC-SV',\n },\n rank: {\n key: 'shoppingDashboard.widget.topProducts.rank',\n fallback: 'Rank',\n },\n trend: {\n key: 'shoppingDashboard.widget.topProducts.trend',\n fallback: 'Trend',\n },\n },\n conversionRate: {\n title: {\n key: 'shoppingDashboard.widget.conversionRate.title',\n fallback: 'Conversion Rate',\n },\n formula: {\n key: 'shoppingDashboard.widget.conversionRate.formula',\n fallback: 'Orders \\u00F7 Site visits',\n },\n comparison: {\n key: 'shoppingDashboard.widget.conversionRate.comparison',\n fallback: 'compared to this time last month',\n },\n chartAriaLabel: {\n key: 'shoppingDashboard.widget.conversionRate.chartAriaLabel',\n fallback: 'Conversion Rate chart showing daily rates',\n },\n titleAriaLabel: {\n key: 'shoppingDashboard.widget.conversionRate.titleAriaLabel',\n fallback: 'Click to view full conversion rate details page',\n },\n filterAriaLabel: {\n key: 'shoppingDashboard.widget.conversionRate.filterAriaLabel',\n fallback: 'Filter conversion rate by customer type',\n },\n noData: {\n key: 'shoppingDashboard.widget.conversionRate.noData',\n fallback: 'No data',\n },\n noChange: {\n key: 'shoppingDashboard.widget.conversionRate.noChange',\n fallback: 'No change',\n },\n tooltipOrders: {\n key: 'shoppingDashboard.widget.conversionRate.tooltipOrders',\n fallback: 'orders',\n },\n tooltipVisits: {\n key: 'shoppingDashboard.widget.conversionRate.tooltipVisits',\n fallback: 'visits',\n },\n ordersPerSiteVisits: {\n key: 'shoppingDashboard.widget.conversionRate.ordersPerSiteVisits',\n fallback: 'Orders / Site Visits',\n },\n },\n signups: {\n title: {\n key: 'shoppingDashboard.widget.signups.title',\n fallback: 'Sign-ups',\n },\n total: {\n key: 'shoppingDashboard.widget.signups.total',\n fallback: 'Total',\n },\n members: {\n key: 'shoppingDashboard.widget.signups.members',\n fallback: 'Members',\n },\n retail: {\n key: 'shoppingDashboard.widget.signups.retail',\n fallback: 'Retail',\n },\n brandAffiliates: {\n key: 'shoppingDashboard.widget.signups.brandAffiliates',\n fallback: 'Brand Affiliates',\n },\n chartAriaLabel: {\n key: 'shoppingDashboard.widget.signups.chartAriaLabel',\n fallback: 'Signups multi-line chart showing Total, Members, Retail, and Brand Affiliates',\n },\n titleAriaLabel: {\n key: 'shoppingDashboard.widget.signups.titleAriaLabel',\n fallback: 'Click to view full signups details page',\n },\n filterAriaLabel: {\n key: 'shoppingDashboard.widget.signups.filterAriaLabel',\n fallback: 'Filter signups view',\n },\n noData: {\n key: 'shoppingDashboard.widget.signups.noData',\n fallback: 'No data',\n },\n noChange: {\n key: 'shoppingDashboard.widget.signups.noChange',\n fallback: 'No change',\n },\n totalSignupsInPeriod: {\n key: 'shoppingDashboard.widget.signups.totalSignupsInPeriod',\n fallback: 'Total sign-ups in period',\n },\n noTrendData: {\n key: 'shoppingDashboard.widget.signups.noTrendData',\n fallback: 'No sign-up trend data available.',\n },\n },\n topCategories: {\n title: {\n key: 'shoppingDashboard.widget.topCategories.title',\n fallback: 'Top Categories',\n },\n revenue: {\n key: 'shoppingDashboard.widget.topCategories.revenue',\n fallback: 'Revenue',\n },\n units: {\n key: 'shoppingDashboard.widget.topCategories.units',\n fallback: 'Units',\n },\n empty: {\n key: 'shoppingDashboard.widget.topCategories.empty',\n fallback: 'No category data available',\n },\n chartAriaLabel: {\n key: 'shoppingDashboard.widget.topCategories.chartAriaLabel',\n fallback: 'Top Categories donut chart showing revenue distribution by category',\n },\n titleAriaLabel: {\n key: 'shoppingDashboard.widget.topCategories.titleAriaLabel',\n fallback: 'Click to view full categories details page',\n },\n sortAriaLabel: {\n key: 'shoppingDashboard.widget.topCategories.sortAriaLabel',\n fallback: 'Sort categories by',\n },\n },\n menu: {\n ariaLabel: {\n key: 'shoppingDashboard.widget.menu.ariaLabel',\n fallback: 'widget options',\n },\n fullView: {\n key: 'shoppingDashboard.widget.menu.fullView',\n fallback: 'Full View',\n },\n },\n },\n navigation: {\n backToDashboard: {\n key: 'shoppingDashboard.navigation.backToDashboard',\n fallback: 'Back to Dashboard',\n },\n backAriaLabel: {\n key: 'shoppingDashboard.navigation.backAriaLabel',\n fallback: 'Back to dashboard',\n },\n },\n ariaLabel: {\n dashboard: {\n key: 'shoppingDashboard.ariaLabel.dashboard',\n fallback: 'Shopping Dashboard',\n },\n statsRow: {\n key: 'shoppingDashboard.ariaLabel.statsRow',\n fallback: 'Key performance metrics',\n },\n dashboardFilters: {\n key: 'shoppingDashboard.ariaLabel.dashboardFilters',\n fallback: 'Dashboard filters',\n },\n loadingDashboard: {\n key: 'shoppingDashboard.ariaLabel.loadingDashboard',\n fallback: 'Loading dashboard data',\n },\n dateRangeFilter: {\n key: 'shoppingDashboard.ariaLabel.dateRangeFilter',\n fallback: 'Date range filter, currently selected:',\n },\n marketFilter: {\n key: 'shoppingDashboard.ariaLabel.marketFilter',\n fallback: 'Market filter, currently selected:',\n },\n filterSuffix: {\n key: 'shoppingDashboard.ariaLabel.filterSuffix',\n fallback: 'filter',\n },\n },\n fullView: {\n signups: {\n columns: {\n id: { key: 'shoppingDashboard.fullView.signups.columns.id', fallback: 'ID' },\n name: { key: 'shoppingDashboard.fullView.signups.columns.name', fallback: 'Name' },\n date: { key: 'shoppingDashboard.fullView.signups.columns.date', fallback: 'Date' },\n type: { key: 'shoppingDashboard.fullView.signups.columns.type', fallback: 'Type' },\n email: { key: 'shoppingDashboard.fullView.signups.columns.email', fallback: 'Email' },\n status: { key: 'shoppingDashboard.fullView.signups.columns.status', fallback: 'Status' },\n },\n detailsTitle: {\n key: 'shoppingDashboard.fullView.signups.detailsTitle',\n fallback: 'Signup Details',\n },\n },\n conversionRate: {\n columns: {\n orderId: { key: 'shoppingDashboard.fullView.conversionRate.columns.orderId', fallback: 'Order ID' },\n date: { key: 'shoppingDashboard.fullView.conversionRate.columns.date', fallback: 'Date' },\n customer: { key: 'shoppingDashboard.fullView.conversionRate.columns.customer', fallback: 'Customer' },\n type: { key: 'shoppingDashboard.fullView.conversionRate.columns.type', fallback: 'Type' },\n items: { key: 'shoppingDashboard.fullView.conversionRate.columns.items', fallback: 'Items' },\n total: { key: 'shoppingDashboard.fullView.conversionRate.columns.total', fallback: 'Total' },\n bv: { key: 'shoppingDashboard.fullView.conversionRate.columns.bv', fallback: 'BV' },\n orderTotal: {\n key: 'shoppingDashboard.fullView.conversionRate.columns.orderTotal',\n fallback: 'Order Total',\n },\n totalSv: { key: 'shoppingDashboard.fullView.conversionRate.columns.totalSv', fallback: 'Total SV' },\n },\n orderDetailsTitle: {\n key: 'shoppingDashboard.fullView.conversionRate.orderDetailsTitle',\n fallback: 'Order Details',\n },\n notAvailable: {\n key: 'shoppingDashboard.fullView.conversionRate.notAvailable',\n fallback: 'N/A',\n },\n },\n products: {\n columns: {\n rank: { key: 'shoppingDashboard.fullView.products.columns.rank', fallback: '#' },\n product: { key: 'shoppingDashboard.fullView.products.columns.product', fallback: 'Product' },\n unitsSold: { key: 'shoppingDashboard.fullView.products.columns.unitsSold', fallback: 'Units Sold' },\n revenue: { key: 'shoppingDashboard.fullView.products.columns.revenue', fallback: 'Revenue' },\n volume: { key: 'shoppingDashboard.fullView.products.columns.volume', fallback: 'Volume (DC-SV)' },\n },\n skuPrefix: {\n key: 'shoppingDashboard.fullView.products.skuPrefix',\n fallback: 'SKU',\n },\n noProducts: {\n key: 'shoppingDashboard.fullView.products.noProducts',\n fallback: 'No products available.',\n },\n },\n categories: {\n columns: {\n category: { key: 'shoppingDashboard.fullView.categories.columns.category', fallback: 'Category' },\n revenue: { key: 'shoppingDashboard.fullView.categories.columns.revenue', fallback: 'Revenue' },\n percentOfTotal: {\n key: 'shoppingDashboard.fullView.categories.columns.percentOfTotal',\n fallback: '% of Total',\n },\n trend: { key: 'shoppingDashboard.fullView.categories.columns.trend', fallback: 'Trend' },\n },\n allCategoriesTitle: {\n key: 'shoppingDashboard.fullView.categories.allCategoriesTitle',\n fallback: 'All Categories',\n },\n noCategoryData: {\n key: 'shoppingDashboard.fullView.categories.noCategoryData',\n fallback: 'No category data available.',\n },\n },\n },\n dataTable: {\n noDataAvailable: {\n key: 'shoppingDashboard.dataTable.noDataAvailable',\n fallback: 'No data available',\n },\n sortableColumn: {\n key: 'shoppingDashboard.dataTable.sortableColumn',\n fallback: ', sortable column',\n },\n },\n pagination: {\n previousPage: {\n key: 'shoppingDashboard.pagination.previousPage',\n fallback: 'Previous page',\n },\n nextPage: {\n key: 'shoppingDashboard.pagination.nextPage',\n fallback: 'Next page',\n },\n goToPage: {\n key: 'shoppingDashboard.pagination.goToPage',\n fallback: 'Go to page',\n },\n of: {\n key: 'shoppingDashboard.pagination.of',\n fallback: 'of',\n },\n },\n defaults: {\n zeroTrend: {\n key: 'shoppingDashboard.defaults.zeroTrend',\n fallback: '+0%',\n },\n noValue: {\n key: 'shoppingDashboard.defaults.noValue',\n fallback: '--',\n },\n },\n} as const;\n\ntype TranslationEntry = { readonly key: string; readonly fallback: string };\n\n/**\n * Get translation text from a translation key entry.\n * Returns the fallback string (future: integrate with i18n provider).\n */\nexport function getTranslation(entry: TranslationEntry): string {\n return entry.fallback;\n}\n","import React from 'react';\nimport { getTrendIcon } from '../utils/trendUtils';\nimport {\n StatsCardContainer,\n StatsTitle,\n StatsValueContainer,\n StatsValue,\n StatsSubtitle,\n TrendContainer,\n TrendIcon,\n TrendText,\n StatsCardHeader,\n} from './StatsCard.styled';\nimport { StatsCardSkeleton } from './LoadingSkeletons';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface StatsCardProps {\n readonly title: string;\n readonly value: string;\n readonly subtitle?: string;\n readonly trendDirection?: 'up' | 'down' | 'neutral';\n readonly trendValue?: string;\n readonly testId?: string;\n readonly isLoading?: boolean;\n}\n\nconst StatsCardComponent: React.FC<StatsCardProps> = ({\n title,\n value,\n subtitle,\n trendDirection = 'neutral',\n trendValue,\n testId,\n isLoading = false,\n}) => {\n if (isLoading) {\n return (\n <StatsCardContainer data-testid={testId}>\n <StatsCardSkeleton />\n </StatsCardContainer>\n );\n }\n\n const getTrendAriaLabel = () => {\n let directionText = getTranslation(Keys.stats.trend.unchanged);\n if (trendDirection === 'up') directionText = getTranslation(Keys.stats.trend.increased);\n else if (trendDirection === 'down') directionText = getTranslation(Keys.stats.trend.decreased);\n\n return `${title} ${directionText} ${trendValue ?? ''}`;\n };\n\n return (\n <StatsCardContainer as=\"article\" aria-label={`${title}: ${value}`} data-testid={testId}>\n <StatsCardHeader>\n <StatsTitle id={`stats-title-${testId}`}>{title}</StatsTitle>\n\n {trendValue && (\n <TrendContainer\n as=\"output\"\n direction={trendDirection}\n aria-live=\"polite\"\n aria-label={getTrendAriaLabel()}\n data-testid={`stats-trend-${testId}`}\n >\n <TrendIcon aria-hidden=\"true\">{getTrendIcon(trendDirection)}</TrendIcon>\n <TrendText>{trendValue}</TrendText>\n </TrendContainer>\n )}\n </StatsCardHeader>\n\n <StatsValueContainer>\n <StatsValue aria-describedby={`stats-title-${testId}`} data-testid={`stats-value-${testId}`}>\n {value}\n </StatsValue>\n {subtitle && (\n <StatsSubtitle\n aria-label={`${title} ${getTranslation(Keys.stats.details)}: ${subtitle}`}\n data-testid={`stats-subtitle-${testId}`}\n >\n {subtitle}\n </StatsSubtitle>\n )}\n </StatsValueContainer>\n </StatsCardContainer>\n );\n};\n\nexport const StatsCard = React.memo(StatsCardComponent);\nStatsCard.displayName = 'StatsCard';\n","/**\n * Trend Utilities\n *\n * Shared utilities for rendering trend indicators across dashboard widgets.\n * Centralizes trend icon logic to eliminate duplication.\n */\n\nimport React from 'react';\nimport TrendingUpIcon from '@mui/icons-material/TrendingUp';\nimport TrendingDownIcon from '@mui/icons-material/TrendingDown';\nimport RemoveIcon from '@mui/icons-material/Remove';\nimport type { TrendDirection } from '../shared/types';\n\n/**\n * Get trend icon component based on direction\n */\nexport function getTrendIcon(direction: TrendDirection): React.ReactNode {\n switch (direction) {\n case 'up':\n return <TrendingUpIcon />;\n case 'down':\n return <TrendingDownIcon />;\n case 'neutral':\n default:\n return <RemoveIcon />;\n }\n}\n\n/**\n * Get trend color based on direction\n */\nexport function getTrendColor(direction: TrendDirection): string {\n switch (direction) {\n case 'up':\n return '#4caf50';\n case 'down':\n return '#f44336';\n case 'neutral':\n default:\n return '#757575';\n }\n}\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const StatsCardContainer = styled('div')`\n display: flex;\n flex-direction: column;\n padding: 12px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N30')};\n border-radius: 8px;\n min-height: 120px;\n transition: box-shadow 0.2s ease;\n\n &:hover {\n box-shadow: 0px 2px 8px rgba(0, 0, 0, 0.08);\n }\n\n @media (min-width: 768px) {\n padding: 20px;\n min-height: 140px;\n }\n\n @media (min-width: 1080px) {\n padding: 24px;\n min-height: 160px;\n }\n`;\n\nexport const StatsTitle = styled('div')`\n font-size: 12px;\n font-weight: 400;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n margin-bottom: 4px;\n text-transform: capitalize;\n\n @media (min-width: 768px) {\n font-size: 13px;\n margin-bottom: 6px;\n }\n\n @media (min-width: 1080px) {\n font-size: 14px;\n }\n`;\n\nexport const StatsValueContainer = styled('div')`\n display: flex;\n flex-direction: row;\n align-items: flex-end;\n gap: 8px;\n margin-top: 8px;\n`;\n\nexport const StatsValue = styled('div')`\n font-size: 24px;\n font-weight: 700;\n line-height: 1.2;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n\n @media (min-width: 768px) {\n font-size: 28px;\n }\n\n @media (min-width: 1080px) {\n font-size: 32px;\n }\n`;\n\nexport const StatsSubtitle = styled('div')`\n font-size: 16px;\n font-weight: 400;\n line-height: normal;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n padding-bottom: 2px;\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`;\n\nexport const TrendContainer = styled('div')<{ direction: 'up' | 'down' | 'neutral' }>`\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: 12px;\n font-weight: 500;\n line-height: 1;\n flex-shrink: 0;\n color: ${({ theme, direction }) => {\n if (direction === 'up') return '#22C55E';\n if (direction === 'down') return '#DC2626';\n return getGenomeColor(theme, 'N70');\n }};\n\n svg {\n width: 14px;\n height: 14px;\n }\n\n @media (min-width: 768px) {\n font-size: 14px;\n margin-top: 12px;\n\n svg {\n width: 18px;\n height: 18px;\n }\n }\n`;\n\nexport const TrendIcon = styled('span')`\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const TrendText = styled('span')`\n white-space: nowrap;\n`;\n\nexport const StatsCardHeader = styled('div')`\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n`;\n","import React from 'react';\nimport Skeleton from '@mui/material/Skeleton';\nimport {\n SkeletonCard,\n SkeletonHeader,\n SkeletonRow,\n StatsCardWrapper,\n StatsCardHeaderRow,\n StatsCardBody,\n StatsCardSubtitle,\n ProductRowInfo,\n ProductRowMetrics,\n ChartMetricRow,\n ChartMetricTrend,\n ChartAreaSkeleton,\n PieChartLayout,\n PieCircleSkeleton,\n LegendList,\n LegendRowWrapper,\n LegendRowInfo,\n DashboardLayout,\n DashboardHeaderRow,\n DashboardFilterGroup,\n StatsGrid,\n WidgetGrid,\n FullViewLayout,\n FullViewMetricCard,\n FullViewMetricCenter,\n FullViewChartArea,\n FullViewTableCard,\n FullViewTableRow,\n SummaryCardsGrid,\n} from './LoadingSkeletons.styled';\n\n/**\n * Shared loading skeleton components for the Shopping Dashboard.\n *\n * Each skeleton mirrors the real widget layout so the page does not\n * shift when data arrives.\n */\n\n/* ------------------------------------------------------------------ */\n/* StatsCard Skeleton */\n/* ------------------------------------------------------------------ */\n\nexport const StatsCardSkeleton: React.FC = () => (\n <StatsCardWrapper data-testid=\"skeleton-stats-card\">\n <StatsCardHeaderRow>\n <Skeleton variant=\"text\" width={80} height={18} />\n <Skeleton variant=\"text\" width={48} height={16} />\n </StatsCardHeaderRow>\n <StatsCardBody>\n <Skeleton variant=\"text\" width={120} height={36} />\n <StatsCardSubtitle variant=\"text\" width={100} height={16} />\n </StatsCardBody>\n </StatsCardWrapper>\n);\n\n/* ------------------------------------------------------------------ */\n/* TopSellingProductsList Skeleton */\n/* ------------------------------------------------------------------ */\n\nconst ProductRowSkeleton: React.FC = () => (\n <SkeletonRow>\n <Skeleton variant=\"rounded\" width={28} height={28} />\n <Skeleton variant=\"rounded\" width={50} height={50} />\n <ProductRowInfo>\n <Skeleton variant=\"text\" width=\"70%\" height={18} />\n <Skeleton variant=\"text\" width=\"50%\" height={14} />\n </ProductRowInfo>\n <ProductRowMetrics>\n <Skeleton variant=\"text\" width={80} height={18} />\n <Skeleton variant=\"text\" width={48} height={14} />\n </ProductRowMetrics>\n </SkeletonRow>\n);\n\nexport const ProductsListSkeleton: React.FC = () => (\n <SkeletonCard data-testid=\"skeleton-products-list\">\n <SkeletonHeader>\n <Skeleton variant=\"text\" width={160} height={22} />\n <Skeleton variant=\"rounded\" width={100} height={32} />\n </SkeletonHeader>\n {['product-1', 'product-2', 'product-3', 'product-4', 'product-5'].map((rowKey) => (\n <ProductRowSkeleton key={rowKey} />\n ))}\n </SkeletonCard>\n);\n\n/* ------------------------------------------------------------------ */\n/* Chart Widget Skeleton (Signups / ConversionRate) */\n/* ------------------------------------------------------------------ */\n\nexport const ChartWidgetSkeleton: React.FC = () => (\n <SkeletonCard data-testid=\"skeleton-chart-widget\">\n <SkeletonHeader>\n <Skeleton variant=\"text\" width={140} height={22} />\n <Skeleton variant=\"rounded\" width={110} height={32} />\n </SkeletonHeader>\n <ChartMetricRow>\n <Skeleton variant=\"text\" width={100} height={36} />\n <ChartMetricTrend>\n <Skeleton variant=\"text\" width={60} height={18} />\n <Skeleton variant=\"text\" width={140} height={14} />\n </ChartMetricTrend>\n </ChartMetricRow>\n <ChartAreaSkeleton variant=\"rounded\" width=\"100%\" />\n </SkeletonCard>\n);\n\n/* ------------------------------------------------------------------ */\n/* TopCategoriesPieChart Skeleton */\n/* ------------------------------------------------------------------ */\n\nconst LegendRowSkeleton: React.FC = () => (\n <LegendRowWrapper>\n <Skeleton variant=\"circular\" width={12} height={12} />\n <LegendRowInfo>\n <Skeleton variant=\"text\" width=\"60%\" height={16} />\n <Skeleton variant=\"text\" width=\"40%\" height={14} />\n </LegendRowInfo>\n <Skeleton variant=\"text\" width={36} height={18} />\n </LegendRowWrapper>\n);\n\nexport const CategoriesPieChartSkeleton: React.FC = () => (\n <SkeletonCard data-testid=\"skeleton-categories-pie\">\n <SkeletonHeader>\n <Skeleton variant=\"text\" width={140} height={22} />\n <Skeleton variant=\"rounded\" width={100} height={32} />\n </SkeletonHeader>\n <PieChartLayout>\n <PieCircleSkeleton variant=\"circular\" />\n <LegendList>\n {['legend-1', 'legend-2', 'legend-3', 'legend-4', 'legend-5'].map((rowKey) => (\n <LegendRowSkeleton key={rowKey} />\n ))}\n </LegendList>\n </PieChartLayout>\n </SkeletonCard>\n);\n\n/* ------------------------------------------------------------------ */\n/* Full Dashboard Skeleton */\n/* ------------------------------------------------------------------ */\n\nexport const DashboardSkeleton: React.FC = () => (\n <DashboardLayout data-testid=\"skeleton-dashboard\">\n <DashboardHeaderRow>\n <Skeleton variant=\"text\" width={200} height={32} />\n <DashboardFilterGroup>\n <Skeleton variant=\"rounded\" width={140} height={36} />\n <Skeleton variant=\"rounded\" width={140} height={36} />\n </DashboardFilterGroup>\n </DashboardHeaderRow>\n\n <StatsGrid>\n <StatsCardSkeleton />\n <StatsCardSkeleton />\n <StatsCardSkeleton />\n </StatsGrid>\n\n <WidgetGrid>\n <ProductsListSkeleton />\n <ChartWidgetSkeleton />\n </WidgetGrid>\n\n <WidgetGrid>\n <ChartWidgetSkeleton />\n <CategoriesPieChartSkeleton />\n </WidgetGrid>\n </DashboardLayout>\n);\n\n/* ------------------------------------------------------------------ */\n/* Full View Skeletons */\n/* ------------------------------------------------------------------ */\n\nexport const FullViewChartSkeleton: React.FC = () => (\n <FullViewLayout data-testid=\"skeleton-fullview-chart\">\n <FullViewMetricCard>\n <FullViewMetricCenter>\n <Skeleton variant=\"text\" width={140} height={52} />\n <Skeleton variant=\"text\" width={80} height={24} />\n <Skeleton variant=\"text\" width={160} height={16} />\n </FullViewMetricCenter>\n <FullViewChartArea variant=\"rounded\" width=\"100%\" />\n </FullViewMetricCard>\n\n <FullViewTableCard>\n <Skeleton variant=\"text\" width={200} height={24} />\n {['table-row-1', 'table-row-2', 'table-row-3', 'table-row-4', 'table-row-5'].map((rowKey) => (\n <FullViewTableRow key={rowKey} variant=\"rounded\" width=\"100%\" height={44} />\n ))}\n </FullViewTableCard>\n </FullViewLayout>\n);\n\nexport const FullViewTableSkeleton: React.FC = () => (\n <FullViewLayout data-testid=\"skeleton-fullview-table\">\n <SummaryCardsGrid>\n <StatsCardSkeleton />\n <StatsCardSkeleton />\n <StatsCardSkeleton />\n </SummaryCardsGrid>\n\n <FullViewTableCard>\n <Skeleton variant=\"text\" width={200} height={24} />\n <FullViewTableRow variant=\"rounded\" width=\"100%\" height={40} />\n {[\n 'summary-row-1',\n 'summary-row-2',\n 'summary-row-3',\n 'summary-row-4',\n 'summary-row-5',\n 'summary-row-6',\n 'summary-row-7',\n 'summary-row-8',\n ].map((rowKey) => (\n <FullViewTableRow key={rowKey} variant=\"rounded\" width=\"100%\" height={44} />\n ))}\n </FullViewTableCard>\n </FullViewLayout>\n);\n","import { styled } from '@nuskin/foundation-theme';\nimport Skeleton from '@mui/material/Skeleton';\n\n/* ------------------------------------------------------------------ */\n/* Shared Layout Helpers */\n/* ------------------------------------------------------------------ */\n\nexport const SkeletonCard = styled('div')`\n display: flex;\n flex-direction: column;\n padding: 16px;\n border-radius: 12px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 20px;\n }\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`;\n\nexport const SkeletonHeader = styled('div')`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 16px;\n padding-bottom: 12px;\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`;\n\nexport const SkeletonRow = styled('div')`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 12px 0;\n\n @media (min-width: 768px) {\n gap: 14px;\n padding: 14px 0;\n }\n`;\n\n/* ------------------------------------------------------------------ */\n/* StatsCard Skeleton */\n/* ------------------------------------------------------------------ */\n\nexport const StatsCardWrapper = styled('div')`\n display: flex;\n flex-direction: column;\n padding: 12px;\n border-radius: 8px;\n min-height: 120px;\n\n @media (min-width: 600px) {\n padding: 20px;\n min-height: 140px;\n }\n @media (min-width: 900px) {\n padding: 24px;\n min-height: 160px;\n }\n`;\n\nexport const StatsCardHeaderRow = styled('div')`\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n`;\n\nexport const StatsCardBody = styled('div')`\n margin-top: 8px;\n`;\n\nexport const StatsCardSubtitle = styled(Skeleton)`\n margin-top: 4px;\n`;\n\n/* ------------------------------------------------------------------ */\n/* Product Row */\n/* ------------------------------------------------------------------ */\n\nexport const ProductRowInfo = styled('div')`\n flex: 1;\n min-width: 0;\n`;\n\nexport const ProductRowMetrics = styled('div')`\n display: flex;\n flex-direction: column;\n align-items: flex-end;\n gap: 4px;\n`;\n\n/* ------------------------------------------------------------------ */\n/* Chart Widget */\n/* ------------------------------------------------------------------ */\n\nexport const ChartMetricRow = styled('div')`\n display: flex;\n align-items: flex-start;\n gap: 8px;\n margin-bottom: 16px;\n`;\n\nexport const ChartMetricTrend = styled('div')`\n padding-top: 4px;\n`;\n\nexport const ChartAreaSkeleton = styled(Skeleton)`\n border-radius: 8px;\n height: 220px;\n\n @media (min-width: 600px) {\n height: 280px;\n }\n @media (min-width: 900px) {\n height: 340px;\n }\n`;\n\n/* ------------------------------------------------------------------ */\n/* Categories Pie Chart */\n/* ------------------------------------------------------------------ */\n\nexport const PieChartLayout = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 16px;\n\n @media (min-width: 600px) {\n flex-direction: row;\n gap: 24px;\n }\n`;\n\nexport const PieCircleSkeleton = styled(Skeleton)`\n width: 100%;\n height: 200px;\n border-radius: 8px;\n flex-shrink: 0;\n\n @media (min-width: 600px) {\n width: 200px;\n border-radius: 50%;\n }\n`;\n\nexport const LegendList = styled('div')`\n flex: 1;\n display: flex;\n flex-direction: column;\n gap: 4px;\n`;\n\nexport const LegendRowWrapper = styled('div')`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 8px;\n`;\n\nexport const LegendRowInfo = styled('div')`\n flex: 1;\n`;\n\n/* ------------------------------------------------------------------ */\n/* Full Dashboard Skeleton */\n/* ------------------------------------------------------------------ */\n\nexport const DashboardLayout = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 24px;\n\n @media (min-width: 600px) {\n gap: 32px;\n }\n @media (min-width: 900px) {\n gap: 40px;\n }\n`;\n\nexport const DashboardHeaderRow = styled('div')`\n display: flex;\n justify-content: space-between;\n align-items: center;\n flex-wrap: wrap;\n gap: 16px;\n`;\n\nexport const DashboardFilterGroup = styled('div')`\n display: flex;\n gap: 16px;\n`;\n\nexport const StatsGrid = styled('div')`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n\n @media (min-width: 600px) {\n grid-template-columns: repeat(3, 1fr);\n gap: 20px;\n }\n @media (min-width: 900px) {\n gap: 24px;\n }\n`;\n\nexport const WidgetGrid = styled('div')`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n\n @media (min-width: 900px) {\n grid-template-columns: repeat(2, 1fr);\n gap: 24px;\n }\n`;\n\n/* ------------------------------------------------------------------ */\n/* Full View Skeletons */\n/* ------------------------------------------------------------------ */\n\nexport const FullViewLayout = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 24px;\n`;\n\nexport const FullViewMetricCard = styled('div')`\n padding: 24px;\n border-radius: 8px;\n display: flex;\n flex-direction: column;\n gap: 24px;\n`;\n\nexport const FullViewMetricCenter = styled('div')`\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 16px 0;\n gap: 8px;\n`;\n\nexport const FullViewChartArea = styled(Skeleton)`\n border-radius: 8px;\n height: 260px;\n\n @media (min-width: 600px) {\n height: 320px;\n }\n @media (min-width: 900px) {\n height: 400px;\n }\n`;\n\nexport const FullViewTableCard = styled('div')`\n padding: 20px;\n border-radius: 8px;\n display: flex;\n flex-direction: column;\n gap: 16px;\n`;\n\nexport const FullViewTableRow = styled(Skeleton)`\n border-radius: 4px;\n`;\n\nexport const SummaryCardsGrid = styled('div')`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n\n @media (min-width: 600px) {\n grid-template-columns: repeat(3, 1fr);\n }\n`;\n","import React from 'react';\nimport ShoppingCartIcon from '@mui/icons-material/ShoppingCart';\nimport { getTrendIcon } from '../../utils/trendUtils';\nimport {\n ProductsListContainer,\n WidgetHeader,\n WidgetTitle,\n SortDropdown,\n HeaderActionsContainer,\n ProductsList,\n ProductItem,\n ProductRank,\n ProductImage,\n ProductImagePlaceholder,\n ProductInfo,\n ProductName,\n ProductSubtitle,\n ProductMetrics,\n ProductValue,\n ProductTrend,\n EmptyState,\n EmptyStateText,\n} from './TopSellingProductsList.styled';\nimport { WidgetMenu } from '../WidgetMenu';\nimport type { TopProduct, ProductSortOption } from '../../types.d';\nimport type { TrendDirection } from '../types';\nimport { ProductsListSkeleton } from '../LoadingSkeletons';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface TopSellingProductsListProps {\n readonly products: TopProduct[];\n readonly productSort: ProductSortOption;\n readonly isLoading?: boolean;\n readonly maxProducts?: number;\n readonly onSortChange?: (sort: ProductSortOption) => void;\n readonly onTitleClick?: () => void;\n}\n\nconst TopSellingProductsListComponent: React.FC<TopSellingProductsListProps> = ({\n products,\n productSort,\n isLoading = false,\n maxProducts = 5,\n onSortChange,\n onTitleClick,\n}) => {\n const handleSortChange = (event: React.ChangeEvent<HTMLSelectElement>) => {\n const newSort = event.target.value as ProductSortOption;\n onSortChange?.(newSort);\n };\n\n const formatValue = (product: TopProduct, sortBy: ProductSortOption) => {\n switch (sortBy) {\n case 'units':\n return `${product.unitsSold.toLocaleString()} ${getTranslation(Keys.widget.topProducts.unitsSuffix)}`;\n case 'revenue':\n return `$${product.revenue.toLocaleString()}`;\n case 'volume':\n return `${product.volume.toLocaleString()} ${getTranslation(Keys.widget.topProducts.dcSvSuffix)}`;\n default:\n return `${product.unitsSold.toLocaleString()} ${getTranslation(Keys.widget.topProducts.unitsSuffix)}`;\n }\n };\n\n const getSubtitle = (product: TopProduct, sortBy: ProductSortOption) => {\n switch (sortBy) {\n case 'units':\n return `$${product.revenue.toLocaleString()} ${getTranslation(Keys.widget.topProducts.revenueSuffix)}`;\n case 'revenue':\n return `${product.unitsSold.toLocaleString()} ${getTranslation(Keys.widget.topProducts.unitsSuffix)}`;\n case 'volume':\n return `$${product.revenue.toLocaleString()} ${getTranslation(Keys.widget.topProducts.revenueSuffix)}`;\n default:\n return `$${product.revenue.toLocaleString()} ${getTranslation(Keys.widget.topProducts.revenueSuffix)}`;\n }\n };\n\n const getTrendValue = (product: TopProduct, sortBy: ProductSortOption) => {\n const trend = product.trend;\n if (!trend) return '';\n switch (sortBy) {\n case 'units':\n return trend.units ?? '';\n case 'revenue':\n return trend.revenue ?? '';\n case 'volume':\n return trend.volume ?? '';\n default:\n return trend.units ?? '';\n }\n };\n\n const getTrendDirection = (product: TopProduct, sortBy: ProductSortOption): TrendDirection => {\n const trendValue = getTrendValue(product, sortBy);\n if (!trendValue) return 'neutral';\n if (trendValue.startsWith('+')) return 'up';\n if (trendValue.startsWith('-')) return 'down';\n return 'neutral';\n };\n\n const displayedProducts = products.slice(0, maxProducts);\n const rankLabel = getTranslation(Keys.widget.topProducts.rank);\n const trendLabel = getTranslation(Keys.widget.topProducts.trend);\n\n const getTrendDirectionLabel = (direction: TrendDirection): string => {\n if (direction === 'up') return getTranslation(Keys.stats.trend.increased);\n if (direction === 'down') return getTranslation(Keys.stats.trend.decreased);\n return getTranslation(Keys.stats.trend.unchanged);\n };\n\n if (isLoading && products.length === 0) {\n return (\n <ProductsListContainer data-testid=\"widget-top-products\">\n <ProductsListSkeleton />\n </ProductsListContainer>\n );\n }\n\n if (products.length === 0) {\n return (\n <ProductsListContainer data-testid=\"widget-top-products\">\n <WidgetHeader>\n <WidgetTitle>{getTranslation(Keys.widget.topProducts.title)}</WidgetTitle>\n </WidgetHeader>\n <EmptyState data-testid=\"products-empty-state\">\n <ShoppingCartIcon />\n <EmptyStateText>{getTranslation(Keys.widget.topProducts.empty)}</EmptyStateText>\n </EmptyState>\n </ProductsListContainer>\n );\n }\n\n return (\n <ProductsListContainer\n as=\"section\"\n data-testid=\"widget-top-products\"\n aria-label={getTranslation(Keys.widget.topProducts.ariaLabel)}\n >\n <WidgetHeader>\n <WidgetTitle\n as=\"button\"\n onClick={onTitleClick}\n aria-label={getTranslation(Keys.widget.topProducts.titleAriaLabel)}\n data-testid=\"widget-title-top-products\"\n >\n {getTranslation(Keys.widget.topProducts.title)}\n </WidgetTitle>\n <HeaderActionsContainer>\n <SortDropdown\n id=\"product-sort\"\n data-testid=\"product-sort-dropdown\"\n value={productSort}\n onChange={handleSortChange}\n disabled={isLoading}\n aria-label={getTranslation(Keys.widget.topProducts.sortAriaLabel)}\n >\n <option value=\"units\">{getTranslation(Keys.filter.productSort.byUnits)}</option>\n <option value=\"revenue\">{getTranslation(Keys.filter.productSort.byRevenue)}</option>\n <option value=\"volume\">{getTranslation(Keys.filter.productSort.byVolume)}</option>\n </SortDropdown>\n <WidgetMenu widgetId=\"top-products\" onFullView={onTitleClick} />\n </HeaderActionsContainer>\n </WidgetHeader>\n\n <ProductsList as=\"ul\" data-testid=\"products-list\">\n {displayedProducts.map((product, index) => {\n const trendDirection = getTrendDirection(product, productSort);\n const trendValue = getTrendValue(product, productSort);\n\n return (\n <ProductItem\n as=\"li\"\n key={product.id}\n data-testid={`product-item-${index}`}\n aria-label={`${rankLabel} ${product.rank}: ${product.name}, ${formatValue(product, productSort)}`}\n >\n <ProductRank aria-label={`${rankLabel} ${product.rank}`}>{product.rank}</ProductRank>\n\n {product.imageUrl ? (\n <ProductImage\n src={product.imageUrl}\n alt={product.name}\n loading=\"lazy\"\n onError={(e) => {\n e.currentTarget.hidden = true;\n }}\n />\n ) : (\n <ProductImagePlaceholder\n aria-label={getTranslation(Keys.widget.topProducts.noImageAriaLabel)}\n >\n {product.name.substring(0, 2).toUpperCase()}\n </ProductImagePlaceholder>\n )}\n\n <ProductInfo>\n <ProductName title={product.name}>{product.name}</ProductName>\n <ProductSubtitle>{getSubtitle(product, productSort)}</ProductSubtitle>\n </ProductInfo>\n\n <ProductMetrics>\n <ProductValue>{formatValue(product, productSort)}</ProductValue>\n {trendValue && (\n <ProductTrend\n as=\"output\"\n direction={trendDirection}\n aria-live=\"polite\"\n aria-label={`${trendLabel}: ${getTrendDirectionLabel(trendDirection)} ${trendValue}`}\n >\n <span aria-hidden=\"true\">{getTrendIcon(trendDirection)}</span>\n <span>{trendValue}</span>\n </ProductTrend>\n )}\n </ProductMetrics>\n </ProductItem>\n );\n })}\n </ProductsList>\n </ProductsListContainer>\n );\n};\n\nexport const TopSellingProductsList = React.memo(TopSellingProductsListComponent);\nTopSellingProductsList.displayName = 'TopSellingProductsList';\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const ProductsListContainer = styled('div')`\n display: flex;\n flex-direction: column;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N30')};\n border-radius: 12px;\n min-height: 320px;\n width: 100%;\n box-sizing: border-box;\n overflow: hidden;\n\n @media (min-width: 768px) {\n padding: 20px;\n min-height: 400px;\n }\n\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`;\n\nexport const WidgetHeader = styled('div')`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 16px;\n padding-bottom: 12px;\n border-bottom: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`;\n\nexport const HeaderActionsContainer = styled('div')`\n display: flex;\n align-items: center;\n gap: 8px;\n`;\n\nexport const WidgetTitle = styled('h2')`\n font-size: 16px;\n font-weight: 600;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n cursor: pointer;\n transition: all 0.2s ease-in-out;\n border: 0;\n background: transparent;\n padding: 0;\n text-align: left;\n\n &:hover {\n text-decoration: underline;\n color: ${({ theme }) => getGenomeColor(theme, 'A80')};\n }\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`;\n\nexport const SortDropdown = styled('select')`\n height: 32px;\n padding: 4px 8px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n border-radius: 6px;\n font-size: 12px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n\n &:focus {\n border-color: ${({ theme }) => getGenomeColor(theme, 'A70')};\n box-shadow: 0 0 0 3px ${({ theme }) => getGenomeColor(theme, 'A20')};\n }\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`;\n\nexport const ProductsList = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 12px;\n width: 100%;\n overflow: hidden;\n list-style: none;\n margin: 0;\n padding: 0;\n\n @media (min-width: 768px) {\n gap: 14px;\n }\n`;\n\nexport const ProductItem = styled('div')`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 12px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border-radius: 8px;\n transition:\n background-color 0.2s ease,\n box-shadow 0.2s ease;\n cursor: pointer;\n width: 100%;\n box-sizing: border-box;\n overflow: hidden;\n list-style: none;\n\n &:not(:last-child) {\n border-bottom: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n }\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.06);\n }\n\n @media (min-width: 768px) {\n padding: 14px;\n gap: 14px;\n }\n`;\n\nexport const ProductRank = styled('div')`\n display: flex;\n align-items: center;\n justify-content: center;\n min-width: 24px;\n height: 24px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'A10')};\n color: ${({ theme }) => getGenomeColor(theme, 'A80')};\n border-radius: 4px;\n font-size: 12px;\n font-weight: 600;\n\n @media (min-width: 768px) {\n min-width: 28px;\n height: 28px;\n font-size: 13px;\n }\n`;\n\nexport const ProductImage = styled('img')`\n width: 40px;\n height: 40px;\n border-radius: 8px;\n object-fit: cover;\n flex-shrink: 0;\n\n @media (min-width: 768px) {\n width: 50px;\n height: 50px;\n }\n`;\n\nexport const ProductImagePlaceholder = styled('div')`\n width: 40px;\n height: 40px;\n border-radius: 8px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N40')};\n display: flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n font-size: 10px;\n font-weight: 500;\n\n @media (min-width: 768px) {\n width: 50px;\n height: 50px;\n font-size: 11px;\n }\n`;\n\nexport const ProductInfo = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex-grow: 1;\n min-width: 0;\n`;\n\nexport const ProductName = styled('div')`\n font-size: 13px;\n font-weight: 500;\n line-height: 1.3;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n max-width: 18ch;\n\n @media (min-width: 768px) {\n font-size: 14px;\n max-width: none;\n }\n`;\n\nexport const ProductSubtitle = styled('div')`\n font-size: 11px;\n font-weight: 400;\n line-height: 1.3;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n\n @media (min-width: 768px) {\n font-size: 12px;\n }\n`;\n\nexport const ProductMetrics = styled('div')`\n display: flex;\n flex-direction: column;\n align-items: flex-end;\n gap: 4px;\n flex-shrink: 0;\n`;\n\nexport const ProductValue = styled('div')`\n font-size: 14px;\n font-weight: 600;\n line-height: 1.2;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n white-space: nowrap;\n\n @media (min-width: 768px) {\n font-size: 16px;\n }\n`;\n\nexport const ProductTrend = styled('div')<{ direction: 'up' | 'down' | 'neutral' }>`\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: 11px;\n font-weight: 500;\n color: ${({ theme, direction }) => {\n if (direction === 'up') return '#22C55E';\n if (direction === 'down') return '#DC2626';\n return getGenomeColor(theme, 'N70');\n }};\n\n svg {\n width: 14px;\n height: 14px;\n }\n\n @media (min-width: 768px) {\n font-size: 12px;\n\n svg {\n width: 16px;\n height: 16px;\n }\n }\n`;\n\nexport const EmptyState = styled('div')`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n gap: 12px;\n padding: 40px 20px;\n text-align: center;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n\n svg {\n width: 48px;\n height: 48px;\n color: ${({ theme }) => getGenomeColor(theme, 'N50')};\n }\n`;\n\nexport const EmptyStateText = styled('div')`\n font-size: 14px;\n font-weight: 400;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n`;\n","import React, { useState } from 'react';\nimport Menu from '@mui/material/Menu';\nimport MenuItem from '@mui/material/MenuItem';\nimport ListItemIcon from '@mui/material/ListItemIcon';\nimport ListItemText from '@mui/material/ListItemText';\nimport MoreVertIcon from '@mui/icons-material/MoreVert';\nimport VisibilityIcon from '@mui/icons-material/Visibility';\nimport { StyledIconButton } from './WidgetMenu.styled';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface WidgetMenuProps {\n readonly widgetId?: string;\n readonly onFullView?: () => void;\n}\n\nexport const WidgetMenu: React.FC<WidgetMenuProps> = ({ widgetId, onFullView }) => {\n const [anchorEl, setAnchorEl] = useState<null | HTMLElement>(null);\n const open = Boolean(anchorEl);\n\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n setAnchorEl(event.currentTarget);\n };\n\n const handleClose = () => {\n setAnchorEl(null);\n };\n\n const handleFullView = () => {\n handleClose();\n if (onFullView) {\n onFullView();\n }\n };\n\n return (\n <>\n <StyledIconButton\n data-testid={`widget-menu-button-${widgetId}`}\n aria-label={getTranslation(Keys.widget.menu.ariaLabel)}\n aria-controls={open ? 'widget-menu' : undefined}\n aria-haspopup=\"true\"\n aria-expanded={open ? 'true' : undefined}\n onClick={handleClick}\n size=\"small\"\n >\n <MoreVertIcon fontSize=\"small\" />\n </StyledIconButton>\n <Menu\n id=\"widget-menu\"\n data-testid={`widget-menu-${widgetId}`}\n anchorEl={anchorEl}\n open={open}\n onClose={handleClose}\n MenuListProps={{\n 'aria-labelledby': 'widget-options-button',\n }}\n anchorOrigin={{\n vertical: 'bottom',\n horizontal: 'right',\n }}\n transformOrigin={{\n vertical: 'top',\n horizontal: 'right',\n }}\n >\n <MenuItem onClick={handleFullView} data-testid=\"widget-menu-item-fullview\">\n <ListItemIcon>\n <VisibilityIcon fontSize=\"small\" />\n </ListItemIcon>\n <ListItemText>{getTranslation(Keys.widget.menu.fullView)}</ListItemText>\n </MenuItem>\n </Menu>\n </>\n );\n};\n","import IconButton from '@mui/material/IconButton';\nimport { styled } from '@nuskin/foundation-theme';\n\nexport const StyledIconButton = styled(IconButton)(() => ({\n padding: '4px',\n}));\n","import React from 'react';\nimport { LineChart, Line, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer } from 'recharts';\nimport { WidgetMenu } from '../WidgetMenu';\nimport { getTrendIcon } from '../../utils/trendUtils';\nimport {\n ConversionRateContainer,\n ChartHeader,\n ChartTitle,\n FilterDropdown,\n MetricDisplay,\n MetricValue,\n MetricTrend,\n FormulaDisplay,\n ChartContainer,\n TooltipContainer,\n TooltipLabel,\n TooltipValue,\n TooltipDetails,\n TitleRow,\n HeaderActionsContainer,\n} from './ConversionRateChart.styled';\nimport type { ConversionDataPoint, ConversionFilterOption } from '../../types.d';\nimport { ChartWidgetSkeleton } from '../LoadingSkeletons';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface ConversionRateChartProps {\n readonly conversionData: ConversionDataPoint[];\n readonly conversionFilter: ConversionFilterOption;\n readonly isLoading?: boolean;\n readonly title?: string;\n readonly onFilterChange?: (filter: ConversionFilterOption) => void;\n readonly onTitleClick?: () => void;\n}\n\nconst MONTH_MAP: Record<string, string> = {\n Jan: '1',\n Feb: '2',\n Mar: '3',\n Apr: '4',\n May: '5',\n Jun: '6',\n Jul: '7',\n Aug: '8',\n Sep: '9',\n Oct: '10',\n Nov: '11',\n Dec: '12',\n};\n\nconst CHART_MARGIN = { top: 5, right: 10, left: -10, bottom: 5 };\nconst AXIS_TICK = { fontSize: 10 };\nconst LINE_DOT = { r: 3, fill: '#3B82F6' };\nconst ACTIVE_DOT = { r: 5 };\n\ninterface CustomTooltipProps {\n readonly active?: boolean;\n readonly payload?: Array<{ payload?: unknown }>;\n}\n\nconst rateTickFormatter = (value: number | string): string => `${value}%`;\n\nfunction formatShortDate(dateStr: string): string {\n const parts = dateStr.split(' ');\n if (parts.length !== 2) return dateStr;\n return `${MONTH_MAP[parts[0]] || parts[0]}/${parts[1]}`;\n}\n\nconst CustomTooltip: React.FC<CustomTooltipProps> = ({ active, payload }) => {\n if (!active || !payload?.length) return null;\n const data = payload[0].payload as ConversionDataPoint;\n return (\n <TooltipContainer>\n <TooltipLabel>{data.date}</TooltipLabel>\n <TooltipValue>{data.rate.toFixed(2)}%</TooltipValue>\n <TooltipDetails>\n {data.orders} {getTranslation(Keys.widget.conversionRate.tooltipOrders)} /{' '}\n {data.siteVisits.toLocaleString()} {getTranslation(Keys.widget.conversionRate.tooltipVisits)}\n </TooltipDetails>\n </TooltipContainer>\n );\n};\n\nconst ConversionRateChartComponent: React.FC<ConversionRateChartProps> = ({\n conversionData,\n conversionFilter,\n isLoading = false,\n title,\n onFilterChange,\n onTitleClick,\n}) => {\n const handleFilterChange = React.useCallback(\n (event: React.ChangeEvent<HTMLSelectElement>) => {\n const newFilter = event.target.value as ConversionFilterOption;\n onFilterChange?.(newFilter);\n },\n [onFilterChange],\n );\n\n const noDataText = getTranslation(Keys.widget.conversionRate.noData);\n const noChangeText = getTranslation(Keys.widget.conversionRate.noChange);\n\n const currentRate = React.useMemo(() => {\n if (conversionData.length === 0) return 0;\n return conversionData[conversionData.length - 1].rate;\n }, [conversionData]);\n\n const trendInfo = React.useMemo((): { direction: 'up' | 'down' | 'neutral'; value: string } => {\n if (conversionData.length < 2) return { direction: 'neutral', value: noDataText };\n const latestRate = conversionData[conversionData.length - 1].rate;\n const previousRate = conversionData[0].rate;\n const change = latestRate - previousRate;\n const percentageChange = (change / previousRate) * 100;\n if (Math.abs(percentageChange) < 0.1) return { direction: 'neutral', value: noChangeText };\n const direction = change > 0 ? 'up' : 'down';\n const formattedChange = `${change > 0 ? '+' : ''}${change.toFixed(2)}%`;\n return { direction, value: formattedChange };\n }, [conversionData, noChangeText, noDataText]);\n\n const formattedData = React.useMemo(\n () => conversionData.map((item) => ({ ...item, shortDate: formatShortDate(item.date) })),\n [conversionData],\n );\n\n const getTrendDirectionLabel = (direction: 'up' | 'down' | 'neutral'): string => {\n if (direction === 'up') return getTranslation(Keys.stats.trend.increased);\n if (direction === 'down') return getTranslation(Keys.stats.trend.decreased);\n return getTranslation(Keys.stats.trend.unchanged);\n };\n\n if (isLoading && conversionData.length === 0) {\n return (\n <ConversionRateContainer data-testid=\"widget-conversion-rate\">\n <ChartWidgetSkeleton />\n </ConversionRateContainer>\n );\n }\n\n const chartAriaLabel = getTranslation(Keys.widget.conversionRate.chartAriaLabel);\n\n return (\n <ConversionRateContainer as=\"section\" data-testid=\"widget-conversion-rate\" aria-label={chartAriaLabel}>\n <ChartHeader>\n <TitleRow>\n <ChartTitle\n as=\"button\"\n onClick={onTitleClick}\n aria-label={getTranslation(Keys.widget.conversionRate.titleAriaLabel)}\n data-testid=\"widget-title-conversion-rate\"\n >\n {title ?? getTranslation(Keys.widget.conversionRate.title)}\n </ChartTitle>\n <HeaderActionsContainer>\n <FilterDropdown\n id=\"conversion-filter\"\n data-testid=\"conversion-filter-dropdown\"\n value={conversionFilter}\n onChange={handleFilterChange}\n disabled={isLoading}\n aria-label={getTranslation(Keys.widget.conversionRate.filterAriaLabel)}\n >\n <option value=\"all\">{getTranslation(Keys.filter.signupView.all)}</option>\n <option value=\"members\">{getTranslation(Keys.filter.signupView.members)}</option>\n <option value=\"retail\">{getTranslation(Keys.filter.signupView.retail)}</option>\n <option value=\"brandAffiliates\">\n {getTranslation(Keys.filter.signupView.brandAffiliates)}\n </option>\n </FilterDropdown>\n <WidgetMenu widgetId=\"conversion-rate\" onFullView={onTitleClick} />\n </HeaderActionsContainer>\n </TitleRow>\n <FormulaDisplay data-testid=\"conversion-formula\">\n {getTranslation(Keys.widget.conversionRate.formula)}\n </FormulaDisplay>\n </ChartHeader>\n\n <MetricDisplay>\n <MetricValue\n aria-label={`${getTranslation(Keys.widget.conversionRate.title)}: ${currentRate.toFixed(2)}%`}\n data-testid=\"conversion-metric-value\"\n >\n {currentRate.toFixed(2)}%\n </MetricValue>\n {trendInfo.value !== noDataText && (\n <MetricTrend\n as=\"output\"\n direction={trendInfo.direction}\n aria-live=\"polite\"\n aria-label={`${getTrendDirectionLabel(trendInfo.direction)} ${trendInfo.value}`}\n data-testid=\"conversion-metric-trend\"\n >\n <div className=\"trend-line\">\n <span aria-hidden=\"true\">{getTrendIcon(trendInfo.direction)}</span>\n <span className=\"change-value\">{trendInfo.value.replace('%', '')}</span>\n <span className=\"change-percent\">%</span>\n </div>\n <div className=\"comparison-text\">{getTranslation(Keys.widget.conversionRate.comparison)}</div>\n </MetricTrend>\n )}\n </MetricDisplay>\n\n <ChartContainer data-testid=\"conversion-chart\">\n <ResponsiveContainer width=\"100%\" height=\"100%\" minHeight={200}>\n <LineChart data={formattedData} margin={CHART_MARGIN}>\n <CartesianGrid strokeDasharray=\"3 3\" />\n <XAxis dataKey=\"shortDate\" tick={AXIS_TICK} tickLine={false} interval=\"preserveStartEnd\" />\n <YAxis\n tick={AXIS_TICK}\n tickLine={false}\n tickFormatter={rateTickFormatter}\n domain={['dataMin - 0.5', 'dataMax + 0.5']}\n />\n <Tooltip content={CustomTooltip} />\n <Line\n type=\"monotone\"\n dataKey=\"rate\"\n stroke=\"#3B82F6\"\n strokeWidth={2}\n dot={LINE_DOT}\n activeDot={ACTIVE_DOT}\n />\n </LineChart>\n </ResponsiveContainer>\n </ChartContainer>\n </ConversionRateContainer>\n );\n};\n\nexport const ConversionRateChart = React.memo(ConversionRateChartComponent);\nConversionRateChart.displayName = 'ConversionRateChart';\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const ConversionRateContainer = styled('div')`\n display: flex;\n flex-direction: column;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N30')};\n border-radius: 12px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 20px;\n }\n\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`;\n\nexport const ChartHeader = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 8px;\n margin-bottom: 16px;\n padding-bottom: 12px;\n border-bottom: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`;\n\nexport const TitleRow = styled('div')`\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n`;\n\nexport const HeaderActionsContainer = styled('div')`\n display: flex;\n align-items: center;\n gap: 8px;\n`;\n\nexport const ChartTitle = styled('h2')`\n font-size: 16px;\n font-weight: 600;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n cursor: pointer;\n transition: all 0.2s ease-in-out;\n border: 0;\n background: transparent;\n padding: 0;\n text-align: left;\n\n &:hover {\n text-decoration: underline;\n color: ${({ theme }) => getGenomeColor(theme, 'A80')};\n }\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`;\n\nexport const FilterDropdown = styled('select')`\n height: 32px;\n padding: 4px 8px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n border-radius: 6px;\n font-size: 12px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n\n &:focus {\n border-color: ${({ theme }) => getGenomeColor(theme, 'A70')};\n box-shadow: 0 0 0 3px ${({ theme }) => getGenomeColor(theme, 'A20')};\n }\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`;\n\nexport const MetricDisplay = styled('div')`\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n gap: 10px;\n margin-bottom: 8px;\n`;\n\nexport const MetricValue = styled('div')`\n font-size: 28px;\n font-weight: 700;\n line-height: 1.2;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n\n @media (min-width: 768px) {\n font-size: 32px;\n }\n`;\n\nexport const MetricTrend = styled('div')<{ direction: 'up' | 'down' | 'neutral' }>`\n display: flex;\n flex-direction: column;\n gap: 2px;\n padding-top: 4px;\n\n .trend-line {\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: 14px;\n color: ${({ theme, direction }) => {\n if (direction === 'up') return '#066100';\n if (direction === 'down') return '#DC2626';\n return getGenomeColor(theme, 'N70');\n }};\n\n svg {\n width: 16px;\n height: 16px;\n }\n\n .change-value {\n font-weight: 600;\n line-height: 20px;\n }\n\n .change-percent {\n font-weight: 400;\n line-height: 20px;\n }\n }\n\n .comparison-text {\n font-size: 12px;\n font-weight: 400;\n line-height: 16px;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n letter-spacing: 0.12px;\n }\n`;\n\nexport const FormulaDisplay = styled('div')`\n font-size: 12px;\n font-weight: 400;\n line-height: 16px;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin-bottom: 16px;\n letter-spacing: 0.12px;\n`;\n\nexport const ChartContainer = styled('div')`\n width: 100%;\n height: 220px;\n margin-top: 16px;\n\n @media (min-width: 768px) {\n height: 280px;\n }\n\n @media (min-width: 1080px) {\n height: 340px;\n }\n\n .recharts-cartesian-grid-horizontal line,\n .recharts-cartesian-grid-vertical line {\n stroke: ${({ theme }) => getGenomeColor(theme, 'N40')};\n stroke-width: 1px;\n }\n\n .recharts-text {\n fill: ${({ theme }) => getGenomeColor(theme, 'N70')};\n font-size: 10px;\n }\n\n .recharts-tooltip-wrapper {\n z-index: 100;\n }\n`;\n\nexport const TooltipContainer = styled('div')`\n background-color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n border-radius: 6px;\n padding: 8px 12px;\n box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.15);\n`;\n\nexport const TooltipLabel = styled('div')`\n font-size: 11px;\n font-weight: 600;\n color: ${({ theme }) => getGenomeColor(theme, 'N10')};\n margin-bottom: 4px;\n`;\n\nexport const TooltipValue = styled('div')`\n font-size: 13px;\n font-weight: 700;\n color: ${({ theme }) => getGenomeColor(theme, 'A10')};\n`;\n\nexport const TooltipDetails = styled('div')`\n font-size: 10px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n margin-top: 2px;\n`;\n","import React from 'react';\nimport { LineChart, Line, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer } from 'recharts';\nimport { getTrendIcon } from '../../utils/trendUtils';\nimport { WidgetMenu } from '../WidgetMenu';\nimport {\n SignupsContainer,\n ChartHeader,\n ChartTitle,\n FilterDropdown,\n MetricDisplay,\n MetricValue,\n MetricTrend,\n ChartContainer,\n Legend,\n LegendItem,\n LegendColor,\n LegendLabel,\n HeaderActionsContainer,\n} from './SignupsChart.styled';\nimport type { SignupDataPoint, SignupViewOption } from '../../types.d';\nimport { ChartWidgetSkeleton } from '../LoadingSkeletons';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface SignupsChartProps {\n readonly signupData: SignupDataPoint[];\n readonly signupView: SignupViewOption;\n readonly isLoading?: boolean;\n readonly title?: string;\n readonly onViewChange?: (view: SignupViewOption) => void;\n readonly onTitleClick?: () => void;\n}\n\nconst SERIES_COLORS = {\n total: '#3B82F6',\n members: '#7B92A8',\n retail: '#A3B5C7',\n brandAffiliates: '#CBD6E0',\n};\n\nconst MONTH_MAP: Record<string, string> = {\n Jan: '1',\n Feb: '2',\n Mar: '3',\n Apr: '4',\n May: '5',\n Jun: '6',\n Jul: '7',\n Aug: '8',\n Sep: '9',\n Oct: '10',\n Nov: '11',\n Dec: '12',\n};\n\nconst CHART_MARGIN = { top: 5, right: 10, left: -10, bottom: 5 };\nconst AXIS_TICK = { fontSize: 10 };\nconst LINE_DOT = { r: 2 };\n\nfunction formatShortDate(dateStr: string): string {\n const parts = dateStr.split(' ');\n if (parts.length !== 2) return dateStr;\n return `${MONTH_MAP[parts[0]] || parts[0]}/${parts[1]}`;\n}\n\nconst SignupsChartComponent: React.FC<SignupsChartProps> = ({\n signupData,\n signupView,\n isLoading = false,\n title,\n onViewChange,\n onTitleClick,\n}) => {\n const handleViewChange = React.useCallback(\n (event: React.ChangeEvent<HTMLSelectElement>) => {\n const newView = event.target.value as SignupViewOption;\n onViewChange?.(newView);\n },\n [onViewChange],\n );\n\n const noDataText = getTranslation(Keys.widget.signups.noData);\n const noChangeText = getTranslation(Keys.widget.signups.noChange);\n\n const totalSignups = React.useMemo(() => {\n if (signupData.length === 0) return 0;\n return signupData[signupData.length - 1].total;\n }, [signupData]);\n\n const trendInfo = React.useMemo((): { direction: 'up' | 'down' | 'neutral'; value: string } => {\n if (signupData.length < 2) return { direction: 'neutral', value: noDataText };\n const latestTotal = signupData[signupData.length - 1].total;\n const previousTotal = signupData[0].total;\n const change = latestTotal - previousTotal;\n const percentageChange = (change / previousTotal) * 100;\n if (Math.abs(percentageChange) < 0.1) return { direction: 'neutral', value: noChangeText };\n const direction = change > 0 ? 'up' : 'down';\n const formattedChange = `${change > 0 ? '+' : ''}${change} (${percentageChange.toFixed(1)}%)`;\n return { direction, value: formattedChange };\n }, [noChangeText, noDataText, signupData]);\n\n const formattedData = React.useMemo(\n () => signupData.map((item) => ({ ...item, shortDate: formatShortDate(item.date) })),\n [signupData],\n );\n const totalLabel = getTranslation(Keys.widget.signups.total);\n const membersLabel = getTranslation(Keys.widget.signups.members);\n const retailLabel = getTranslation(Keys.widget.signups.retail);\n const brandAffiliatesLabel = getTranslation(Keys.widget.signups.brandAffiliates);\n\n const getTrendDirectionLabel = (direction: 'up' | 'down' | 'neutral'): string => {\n if (direction === 'up') return getTranslation(Keys.stats.trend.increased);\n if (direction === 'down') return getTranslation(Keys.stats.trend.decreased);\n return getTranslation(Keys.stats.trend.unchanged);\n };\n\n if (isLoading && signupData.length === 0) {\n return (\n <SignupsContainer data-testid=\"widget-signups\">\n <ChartWidgetSkeleton />\n </SignupsContainer>\n );\n }\n\n return (\n <SignupsContainer\n as=\"section\"\n data-testid=\"widget-signups\"\n aria-label={getTranslation(Keys.widget.signups.chartAriaLabel)}\n >\n <ChartHeader>\n <ChartTitle\n as=\"button\"\n onClick={onTitleClick}\n aria-label={getTranslation(Keys.widget.signups.titleAriaLabel)}\n data-testid=\"widget-title-signups\"\n >\n {title ?? getTranslation(Keys.widget.signups.title)}\n </ChartTitle>\n <HeaderActionsContainer>\n <FilterDropdown\n id=\"signup-view\"\n data-testid=\"signup-view-dropdown\"\n value={signupView}\n onChange={handleViewChange}\n disabled={isLoading}\n aria-label={getTranslation(Keys.widget.signups.filterAriaLabel)}\n >\n <option value=\"all\">{getTranslation(Keys.filter.signupView.showAll)}</option>\n <option value=\"members\">{getTranslation(Keys.filter.signupView.showMembers)}</option>\n <option value=\"retail\">{getTranslation(Keys.filter.signupView.showRetail)}</option>\n <option value=\"brandAffiliates\">\n {getTranslation(Keys.filter.signupView.showBrandAffiliates)}\n </option>\n </FilterDropdown>\n <WidgetMenu widgetId=\"signups\" onFullView={onTitleClick} />\n </HeaderActionsContainer>\n </ChartHeader>\n\n <MetricDisplay data-testid=\"signups-metric-display\">\n <MetricValue\n data-testid=\"signups-metric-value\"\n aria-label={`${totalLabel}: ${totalSignups.toLocaleString()}`}\n >\n {totalSignups.toLocaleString()}\n </MetricValue>\n {trendInfo.value !== noDataText && (\n <MetricTrend\n as=\"output\"\n data-testid=\"signups-metric-trend\"\n direction={trendInfo.direction}\n aria-live=\"polite\"\n aria-label={`${getTrendDirectionLabel(trendInfo.direction)} ${trendInfo.value}`}\n >\n <div className=\"trend-line\">\n <span aria-hidden=\"true\">{getTrendIcon(trendInfo.direction)}</span>\n <span className=\"change-value\">{trendInfo.value.split(' ')[0]}</span>\n <span className=\"change-percent\">{trendInfo.value.split(' ')[1]}</span>\n </div>\n <div className=\"comparison-text\">{getTranslation(Keys.widget.conversionRate.comparison)}</div>\n </MetricTrend>\n )}\n </MetricDisplay>\n\n <ChartContainer data-testid=\"signups-chart\">\n <ResponsiveContainer width=\"100%\" height=\"100%\" minHeight={200}>\n <LineChart data={formattedData} margin={CHART_MARGIN}>\n <CartesianGrid strokeDasharray=\"3 3\" />\n <XAxis dataKey=\"shortDate\" tick={AXIS_TICK} tickLine={false} interval=\"preserveStartEnd\" />\n <YAxis tick={AXIS_TICK} tickLine={false} />\n <Tooltip />\n {(signupView === 'all' || signupView === 'members') && (\n <Line\n type=\"monotone\"\n dataKey={signupView === 'all' ? 'total' : 'members'}\n stroke={signupView === 'all' ? SERIES_COLORS.total : SERIES_COLORS.members}\n strokeWidth={2}\n dot={LINE_DOT}\n name={signupView === 'all' ? totalLabel : membersLabel}\n />\n )}\n {signupView === 'all' && (\n <>\n <Line\n type=\"monotone\"\n dataKey=\"members\"\n stroke={SERIES_COLORS.members}\n strokeWidth={2}\n dot={LINE_DOT}\n name={membersLabel}\n />\n <Line\n type=\"monotone\"\n dataKey=\"retail\"\n stroke={SERIES_COLORS.retail}\n strokeWidth={2}\n dot={LINE_DOT}\n name={retailLabel}\n />\n <Line\n type=\"monotone\"\n dataKey=\"brandAffiliates\"\n stroke={SERIES_COLORS.brandAffiliates}\n strokeWidth={2}\n dot={LINE_DOT}\n name={brandAffiliatesLabel}\n />\n </>\n )}\n {signupView === 'retail' && (\n <Line\n type=\"monotone\"\n dataKey=\"retail\"\n stroke={SERIES_COLORS.retail}\n strokeWidth={2}\n dot={LINE_DOT}\n name={retailLabel}\n />\n )}\n {signupView === 'brandAffiliates' && (\n <Line\n type=\"monotone\"\n dataKey=\"brandAffiliates\"\n stroke={SERIES_COLORS.brandAffiliates}\n strokeWidth={2}\n dot={LINE_DOT}\n name={brandAffiliatesLabel}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n </ChartContainer>\n\n {signupView === 'all' && (\n <Legend data-testid=\"signups-legend\">\n <LegendItem data-testid=\"legend-total\">\n <LegendColor color={SERIES_COLORS.total} />\n <LegendLabel>{totalLabel}</LegendLabel>\n </LegendItem>\n <LegendItem data-testid=\"legend-members\">\n <LegendColor color={SERIES_COLORS.members} />\n <LegendLabel>{membersLabel}</LegendLabel>\n </LegendItem>\n <LegendItem data-testid=\"legend-retail\">\n <LegendColor color={SERIES_COLORS.retail} />\n <LegendLabel>{retailLabel}</LegendLabel>\n </LegendItem>\n <LegendItem data-testid=\"legend-brandAffiliates\">\n <LegendColor color={SERIES_COLORS.brandAffiliates} />\n <LegendLabel>{brandAffiliatesLabel}</LegendLabel>\n </LegendItem>\n </Legend>\n )}\n </SignupsContainer>\n );\n};\n\nexport const SignupsChart = React.memo(SignupsChartComponent);\nSignupsChart.displayName = 'SignupsChart';\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const SignupsContainer = styled('div')`\n display: flex;\n flex-direction: column;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N30')};\n border-radius: 12px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 20px;\n }\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`;\n\nexport const ChartHeader = styled('div')`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 16px;\n padding-bottom: 12px;\n border-bottom: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`;\n\nexport const HeaderActionsContainer = styled('div')`\n display: flex;\n align-items: center;\n gap: 8px;\n`;\n\nexport const ChartTitle = styled('h2')`\n font-size: 16px;\n font-weight: 600;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n cursor: pointer;\n transition: all 0.2s ease-in-out;\n border: 0;\n background: transparent;\n padding: 0;\n text-align: left;\n\n &:hover {\n text-decoration: underline;\n color: ${({ theme }) => getGenomeColor(theme, 'A80')};\n }\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`;\n\nexport const FilterDropdown = styled('select')`\n height: 32px;\n padding: 4px 8px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n border-radius: 6px;\n font-size: 12px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n &:focus {\n border-color: ${({ theme }) => getGenomeColor(theme, 'A70')};\n box-shadow: 0 0 0 3px ${({ theme }) => getGenomeColor(theme, 'A20')};\n }\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`;\n\nexport const MetricDisplay = styled('div')`\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n gap: 10px;\n margin-bottom: 16px;\n`;\n\nexport const MetricValue = styled('div')`\n font-size: 28px;\n font-weight: 700;\n line-height: 1.2;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n\n @media (min-width: 768px) {\n font-size: 32px;\n }\n`;\n\nexport const MetricTrend = styled('div')<{ direction: 'up' | 'down' | 'neutral' }>`\n display: flex;\n flex-direction: column;\n gap: 2px;\n padding-top: 4px;\n\n .trend-line {\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: 14px;\n color: ${({ theme, direction }) => {\n if (direction === 'up') return '#066100';\n if (direction === 'down') return '#DC2626';\n return getGenomeColor(theme, 'N70');\n }};\n\n svg {\n width: 16px;\n height: 16px;\n }\n .change-value {\n font-weight: 600;\n line-height: 20px;\n }\n .change-percent {\n font-weight: 400;\n line-height: 20px;\n }\n }\n\n .comparison-text {\n font-size: 12px;\n font-weight: 400;\n line-height: 16px;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n letter-spacing: 0.12px;\n }\n`;\n\nexport const ChartContainer = styled('div')`\n width: 100%;\n height: 220px;\n margin-top: 16px;\n\n @media (min-width: 768px) {\n height: 280px;\n }\n @media (min-width: 1080px) {\n height: 340px;\n }\n\n .recharts-cartesian-grid-horizontal line,\n .recharts-cartesian-grid-vertical line {\n stroke: ${({ theme }) => getGenomeColor(theme, 'N40')};\n stroke-width: 1px;\n }\n .recharts-text {\n fill: ${({ theme }) => getGenomeColor(theme, 'N70')};\n font-size: 10px;\n }\n`;\n\nexport const Legend = styled('div')`\n display: flex;\n flex-wrap: wrap;\n gap: 16px;\n margin-top: 16px;\n padding-top: 12px;\n border-top: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n`;\n\nexport const LegendItem = styled('div')`\n display: flex;\n align-items: center;\n gap: 8px;\n cursor: pointer;\n padding: 4px 8px;\n border-radius: 4px;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n`;\n\nexport const LegendColor = styled('div')<{ color: string }>`\n width: 12px;\n height: 12px;\n border-radius: 50%;\n background-color: ${({ color }) => color};\n flex-shrink: 0;\n`;\n\nexport const LegendLabel = styled('span')`\n font-size: 12px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`;\n","import React from 'react';\nimport { PieChart, Pie, Cell, ResponsiveContainer, Tooltip } from 'recharts';\nimport { WidgetMenu } from '../WidgetMenu';\nimport {\n CategoriesContainer,\n ChartHeader,\n ChartTitle,\n SortDropdown,\n ChartAndLegendContainer,\n ChartWrapper,\n LegendContainer,\n LegendItem,\n LegendColor,\n LegendInfo,\n LegendName,\n LegendValue,\n LegendPercentage,\n DonutCenterOverlay,\n DonutCenterLabel,\n DonutCenterValue,\n DonutCenterTrend,\n EmptyState,\n EmptyStateText,\n HeaderActionsContainer,\n} from './TopCategoriesPieChart.styled';\nimport type { CategoryRevenue, CategorySortOption } from '../../types.d';\nimport { CategoriesPieChartSkeleton } from '../LoadingSkeletons';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface TopCategoriesPieChartProps {\n readonly categories: CategoryRevenue[];\n readonly categorySort: CategorySortOption;\n readonly isLoading?: boolean;\n readonly title?: string;\n readonly onSortChange?: (sort: CategorySortOption) => void;\n readonly onTitleClick?: () => void;\n}\n\nfunction parseTrendPercent(value?: string): number | null {\n if (!value) return null;\n const cleanedValue = value.replace('%', '').trim();\n const parsedValue = Number(cleanedValue);\n return Number.isFinite(parsedValue) ? parsedValue : null;\n}\n\nconst tooltipFormatter = (value: number): string => `$${value.toLocaleString()}`;\n\nconst TopCategoriesPieChartComponent: React.FC<TopCategoriesPieChartProps> = ({\n categories,\n categorySort,\n isLoading = false,\n title,\n onSortChange,\n onTitleClick,\n}) => {\n const handleSortChange = React.useCallback(\n (event: React.ChangeEvent<HTMLSelectElement>) => {\n const newSort = event.target.value as CategorySortOption;\n onSortChange?.(newSort);\n },\n [onSortChange],\n );\n\n const { sortedCategories, totalRevenue, trendDirection, formattedTrend } = React.useMemo(() => {\n const nextSortedCategories = [...categories].sort((a, b) => {\n if (categorySort === 'revenue') return b.revenue - a.revenue;\n return b.percentage - a.percentage;\n });\n\n const nextTotalRevenue = nextSortedCategories.reduce((sum, category) => sum + category.revenue, 0);\n\n const weightedRevenueTrend = nextSortedCategories.reduce(\n (accumulator, category) => {\n const trendValue = parseTrendPercent(category.trend?.revenue);\n if (trendValue === null) return accumulator;\n\n return {\n weightedSum: accumulator.weightedSum + trendValue * category.revenue,\n weight: accumulator.weight + category.revenue,\n };\n },\n { weightedSum: 0, weight: 0 },\n );\n\n const averageRevenueTrend =\n weightedRevenueTrend.weight > 0 ? weightedRevenueTrend.weightedSum / weightedRevenueTrend.weight : 0;\n\n let nextTrendDirection: 'up' | 'down' | 'neutral' = 'neutral';\n if (averageRevenueTrend > 0) nextTrendDirection = 'up';\n else if (averageRevenueTrend < 0) nextTrendDirection = 'down';\n\n const trendSign = averageRevenueTrend > 0 ? '+' : '';\n const nextFormattedTrend = `${trendSign}${averageRevenueTrend.toFixed(1)}%`;\n\n return {\n sortedCategories: nextSortedCategories,\n totalRevenue: nextTotalRevenue,\n trendDirection: nextTrendDirection,\n formattedTrend: nextFormattedTrend,\n };\n }, [categories, categorySort]);\n\n if (isLoading && categories.length === 0) {\n return (\n <CategoriesContainer data-testid=\"widget-top-categories\">\n <CategoriesPieChartSkeleton />\n </CategoriesContainer>\n );\n }\n\n if (categories.length === 0) {\n return (\n <CategoriesContainer data-testid=\"widget-top-categories\">\n <ChartHeader>\n <ChartTitle>{title ?? getTranslation(Keys.widget.topCategories.title)}</ChartTitle>\n </ChartHeader>\n <EmptyState data-testid=\"categories-empty-state\">\n <EmptyStateText>{getTranslation(Keys.widget.topCategories.empty)}</EmptyStateText>\n </EmptyState>\n </CategoriesContainer>\n );\n }\n\n return (\n <CategoriesContainer\n as=\"section\"\n data-testid=\"widget-top-categories\"\n aria-label={getTranslation(Keys.widget.topCategories.chartAriaLabel)}\n >\n <ChartHeader>\n <ChartTitle\n as=\"button\"\n onClick={onTitleClick}\n aria-label={getTranslation(Keys.widget.topCategories.titleAriaLabel)}\n data-testid=\"widget-title-top-categories\"\n >\n {title ?? getTranslation(Keys.widget.topCategories.title)}\n </ChartTitle>\n <HeaderActionsContainer>\n <SortDropdown\n id=\"category-sort\"\n data-testid=\"category-sort-dropdown\"\n value={categorySort}\n onChange={handleSortChange}\n disabled={isLoading}\n aria-label={getTranslation(Keys.widget.topCategories.sortAriaLabel)}\n >\n <option value=\"revenue\">{getTranslation(Keys.filter.categorySort.byRevenue)}</option>\n <option value=\"units\">{getTranslation(Keys.filter.categorySort.byUnits)}</option>\n </SortDropdown>\n <WidgetMenu widgetId=\"top-categories\" onFullView={onTitleClick} />\n </HeaderActionsContainer>\n </ChartHeader>\n\n <ChartAndLegendContainer>\n <ChartWrapper data-testid=\"categories-chart\">\n <ResponsiveContainer width=\"100%\" height=\"100%\">\n <PieChart>\n <Pie\n data={sortedCategories}\n cx=\"50%\"\n cy=\"50%\"\n innerRadius=\"55%\"\n outerRadius=\"85%\"\n dataKey=\"revenue\"\n nameKey=\"name\"\n paddingAngle={2}\n >\n {sortedCategories.map((entry) => (\n <Cell key={`cell-${entry.id}`} fill={entry.color} />\n ))}\n </Pie>\n <Tooltip formatter={tooltipFormatter} />\n </PieChart>\n </ResponsiveContainer>\n <DonutCenterOverlay data-testid=\"categories-donut-center\">\n <DonutCenterLabel>{getTranslation(Keys.stats.revenue)}</DonutCenterLabel>\n <DonutCenterValue>${totalRevenue.toLocaleString()}</DonutCenterValue>\n <DonutCenterTrend direction={trendDirection}>{formattedTrend}</DonutCenterTrend>\n </DonutCenterOverlay>\n </ChartWrapper>\n\n <LegendContainer data-testid=\"categories-legend-container\">\n {sortedCategories.map((category, index) => (\n <LegendItem key={category.id} data-testid={`category-legend-${index}`}>\n <LegendColor color={category.color} />\n <LegendInfo>\n <LegendName>{category.name}</LegendName>\n <LegendValue>${category.revenue.toLocaleString()}</LegendValue>\n </LegendInfo>\n <LegendPercentage>{category.percentage}%</LegendPercentage>\n </LegendItem>\n ))}\n </LegendContainer>\n </ChartAndLegendContainer>\n </CategoriesContainer>\n );\n};\n\nexport const TopCategoriesPieChart = React.memo(TopCategoriesPieChartComponent);\nTopCategoriesPieChart.displayName = 'TopCategoriesPieChart';\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const CategoriesContainer = styled('div')`\n display: flex;\n flex-direction: column;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N30')};\n border-radius: 12px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n padding: 20px;\n }\n @media (min-width: 1080px) {\n padding: 24px;\n }\n`;\n\nexport const ChartHeader = styled('div')`\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 16px;\n padding-bottom: 12px;\n border-bottom: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n\n @media (min-width: 768px) {\n margin-bottom: 20px;\n }\n`;\n\nexport const HeaderActionsContainer = styled('div')`\n display: flex;\n align-items: center;\n gap: 8px;\n`;\n\nexport const ChartTitle = styled('h2')`\n font-size: 16px;\n font-weight: 600;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n cursor: pointer;\n transition: all 0.2s ease-in-out;\n border: 0;\n background: transparent;\n padding: 0;\n text-align: left;\n\n &:hover {\n text-decoration: underline;\n color: ${({ theme }) => getGenomeColor(theme, 'A80')};\n }\n\n @media (min-width: 768px) {\n font-size: 18px;\n }\n`;\n\nexport const SortDropdown = styled('select')`\n height: 32px;\n padding: 4px 8px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n border-radius: 6px;\n font-size: 12px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n &:focus {\n border-color: ${({ theme }) => getGenomeColor(theme, 'A70')};\n box-shadow: 0 0 0 3px ${({ theme }) => getGenomeColor(theme, 'A20')};\n }\n\n @media (min-width: 768px) {\n font-size: 13px;\n }\n`;\n\nexport const ChartAndLegendContainer = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 16px;\n\n @media (min-width: 768px) {\n flex-direction: row;\n gap: 24px;\n }\n`;\n\nexport const ChartWrapper = styled('div')`\n position: relative;\n width: 100%;\n height: 200px;\n flex-shrink: 0;\n\n @media (min-width: 768px) {\n width: 200px;\n height: 200px;\n }\n`;\n\nexport const DonutCenterOverlay = styled('div')`\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n pointer-events: none;\n z-index: 1;\n width: 96px;\n`;\n\nexport const DonutCenterLabel = styled('div')`\n font-size: 10px;\n line-height: 1.2;\n font-weight: 500;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n`;\n\nexport const DonutCenterValue = styled('div')`\n margin-top: 2px;\n font-size: 16px;\n line-height: 1.2;\n font-weight: 700;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n`;\n\nexport const DonutCenterTrend = styled('div')<{ direction: 'up' | 'down' | 'neutral' }>`\n margin-top: 2px;\n font-size: 11px;\n line-height: 1.2;\n font-weight: 600;\n color: ${({ direction, theme }) => {\n if (direction === 'up') return '#2e7d32';\n if (direction === 'down') return '#d32f2f';\n return getGenomeColor(theme, 'N70');\n }};\n`;\n\nexport const LegendContainer = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 8px;\n flex: 1;\n`;\n\nexport const LegendItem = styled('div')`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 8px;\n border-radius: 6px;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n`;\n\nexport const LegendColor = styled('div')<{ color: string }>`\n width: 12px;\n height: 12px;\n border-radius: 50%;\n background-color: ${({ color }) => color};\n flex-shrink: 0;\n`;\n\nexport const LegendInfo = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex: 1;\n min-width: 0;\n`;\n\nexport const LegendName = styled('div')`\n font-size: 13px;\n font-weight: 500;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n\n @media (min-width: 768px) {\n font-size: 14px;\n }\n`;\n\nexport const LegendValue = styled('div')`\n font-size: 11px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n\n @media (min-width: 768px) {\n font-size: 12px;\n }\n`;\n\nexport const LegendPercentage = styled('div')`\n font-size: 14px;\n font-weight: 600;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n flex-shrink: 0;\n\n @media (min-width: 768px) {\n font-size: 16px;\n }\n`;\n\nexport const EmptyState = styled('div')`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n gap: 12px;\n padding: 40px 20px;\n text-align: center;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n`;\n\nexport const EmptyStateText = styled('div')`\n font-size: 14px;\n font-weight: 400;\n line-height: 1.4;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n`;\n","import React from 'react';\nimport {\n DashboardContainer,\n StatsRow,\n WidgetContainer,\n TwoColumnGrid,\n ErrorContainer,\n} from './ShoppingDashboard.styled';\nimport { DashboardHeader } from './shared/DashboardHeader';\nimport { StatsCard } from './shared/StatsCard';\nimport { TopSellingProductsList } from './shared/TopProducts/TopSellingProductsList';\nimport { ConversionRateChart } from './shared/ConversionRate/ConversionRateChart';\nimport { SignupsChart } from './shared/Signups/SignupsChart';\nimport { TopCategoriesPieChart } from './shared/TopCategories/TopCategoriesPieChart';\nimport type {\n DashboardStats,\n TopProduct,\n ConversionDataPoint,\n SignupDataPoint,\n CategoryRevenue,\n DateRangeOption,\n MarketOption,\n ProductSortOption,\n SignupViewOption,\n ConversionFilterOption,\n CategorySortOption,\n} from './types.d';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from './TranslationKeys/ShoppingDashboardTranslationKeys';\n\nconst EMPTY_TOP_PRODUCTS: TopProduct[] = [];\nconst EMPTY_CONVERSION_DATA: ConversionDataPoint[] = [];\nconst EMPTY_SIGNUP_DATA: SignupDataPoint[] = [];\nconst EMPTY_CATEGORIES: CategoryRevenue[] = [];\n\nexport interface ShoppingDashboardProps {\n readonly stats?: DashboardStats | null;\n readonly topProducts?: TopProduct[];\n readonly conversionData?: ConversionDataPoint[];\n readonly signupData?: SignupDataPoint[];\n readonly categories?: CategoryRevenue[];\n readonly isLoading?: boolean;\n readonly error?: string | null;\n readonly shopTitle?: string;\n readonly className?: string;\n\n // Filter states\n readonly dateRange?: DateRangeOption;\n readonly market?: MarketOption;\n readonly productSort?: ProductSortOption;\n readonly signupView?: SignupViewOption;\n readonly conversionFilter?: ConversionFilterOption;\n readonly categorySort?: CategorySortOption;\n\n // Filter callbacks\n readonly onDateRangeChange?: (range: DateRangeOption) => void;\n readonly onMarketChange?: (market: MarketOption) => void;\n readonly onProductSortChange?: (sort: ProductSortOption) => void;\n readonly onSignupViewChange?: (view: SignupViewOption) => void;\n readonly onConversionFilterChange?: (filter: ConversionFilterOption) => void;\n readonly onCategorySortChange?: (sort: CategorySortOption) => void;\n\n // Navigation callbacks\n readonly onProductsTitleClick?: () => void;\n readonly onConversionTitleClick?: () => void;\n readonly onSignupsTitleClick?: () => void;\n readonly onCategoriesToTitleClick?: () => void;\n}\n\n/**\n * ShoppingDashboard Main Container Component\n *\n * Orchestrates all dashboard widgets. Pure presentational - receives all data via props.\n * The consuming application is responsible for data fetching and state management.\n */\nexport const ShoppingDashboard: React.FC<ShoppingDashboardProps> = ({\n stats,\n topProducts,\n conversionData,\n signupData,\n categories,\n isLoading = false,\n error,\n shopTitle,\n className,\n dateRange = 'last30days',\n market = 'all',\n productSort = 'units',\n signupView = 'all',\n conversionFilter = 'all',\n categorySort = 'revenue',\n onDateRangeChange,\n onMarketChange,\n onProductSortChange,\n onSignupViewChange,\n onConversionFilterChange,\n onCategorySortChange,\n onProductsTitleClick,\n onConversionTitleClick,\n onSignupsTitleClick,\n onCategoriesToTitleClick,\n}) => {\n const resolvedTopProducts = topProducts ?? EMPTY_TOP_PRODUCTS;\n const resolvedConversionData = conversionData ?? EMPTY_CONVERSION_DATA;\n const resolvedSignupData = signupData ?? EMPTY_SIGNUP_DATA;\n const resolvedCategories = categories ?? EMPTY_CATEGORIES;\n\n // Error state\n if (error) {\n return (\n <DashboardContainer as=\"main\" className={className} aria-label={getTranslation(Keys.ariaLabel.dashboard)}>\n <ErrorContainer data-testid=\"dashboard-error\" role=\"alert\" aria-live=\"assertive\">\n <strong>{getTranslation(Keys.error)}:</strong> {error}\n </ErrorContainer>\n </DashboardContainer>\n );\n }\n\n const getTrendDirection = (trendValue?: string): 'up' | 'down' | 'neutral' => {\n if (!trendValue) return 'neutral';\n if (trendValue.startsWith('+')) return 'up';\n if (trendValue.startsWith('-')) return 'down';\n return 'neutral';\n };\n\n return (\n <DashboardContainer\n as=\"main\"\n className={className}\n data-testid=\"shopping-dashboard\"\n aria-label={getTranslation(Keys.ariaLabel.dashboard)}\n aria-busy={isLoading}\n >\n <DashboardHeader\n shopTitle={shopTitle}\n dateRange={dateRange}\n market={market}\n isLoading={isLoading}\n stats={stats}\n onDateRangeChange={onDateRangeChange}\n onMarketChange={onMarketChange}\n />\n\n <StatsRow as=\"section\" data-testid=\"stats-row\" aria-label={getTranslation(Keys.ariaLabel.statsRow)}>\n <StatsCard\n title={getTranslation(Keys.stats.revenue)}\n value={stats?.metrics?.revenue ?? '$0'}\n trendDirection={getTrendDirection(stats?.trend?.revenue)}\n trendValue={stats?.trend?.revenue}\n testId=\"stats-card-revenue\"\n isLoading={isLoading}\n />\n <StatsCard\n title={getTranslation(Keys.stats.volume)}\n value={stats?.metrics?.volume ?? '0'}\n subtitle={getTranslation(Keys.stats.subtitle.dcSv)}\n trendDirection={getTrendDirection(stats?.trend?.volume)}\n trendValue={stats?.trend?.volume}\n testId=\"stats-card-volume\"\n isLoading={isLoading}\n />\n <StatsCard\n title={getTranslation(Keys.stats.visits)}\n value={stats?.metrics?.siteVisits ?? '0'}\n subtitle={`${stats?.metrics?.conversionRate ?? '0%'} ${getTranslation(Keys.stats.subtitle.conversionRate)}`}\n trendDirection={getTrendDirection(stats?.trend?.siteVisits)}\n trendValue={stats?.trend?.siteVisits}\n testId=\"stats-card-visits\"\n isLoading={isLoading}\n />\n </StatsRow>\n\n <WidgetContainer data-testid=\"widget-container\">\n <TwoColumnGrid data-testid=\"widget-row-1\">\n <TopSellingProductsList\n products={resolvedTopProducts}\n productSort={productSort}\n isLoading={isLoading}\n maxProducts={5}\n onSortChange={onProductSortChange}\n onTitleClick={onProductsTitleClick}\n />\n <SignupsChart\n signupData={resolvedSignupData}\n signupView={signupView}\n isLoading={isLoading}\n onViewChange={onSignupViewChange}\n onTitleClick={onSignupsTitleClick}\n />\n </TwoColumnGrid>\n\n <TwoColumnGrid data-testid=\"widget-row-2\">\n <ConversionRateChart\n conversionData={resolvedConversionData}\n conversionFilter={conversionFilter}\n isLoading={isLoading}\n onFilterChange={onConversionFilterChange}\n onTitleClick={onConversionTitleClick}\n />\n <TopCategoriesPieChart\n categories={resolvedCategories}\n categorySort={categorySort}\n isLoading={isLoading}\n onSortChange={onCategorySortChange}\n onTitleClick={onCategoriesToTitleClick}\n />\n </TwoColumnGrid>\n </WidgetContainer>\n </DashboardContainer>\n );\n};\n\nexport default ShoppingDashboard;\n","import React from 'react';\nimport { ShoppingDashboard } from './ShoppingDashboard';\nimport { ProductsFullView } from './shared/TopProducts/ProductsFullView';\nimport { ConversionRateFullView } from './shared/ConversionRate/ConversionRateFullView';\nimport { SignupsFullView } from './shared/Signups/SignupsFullView';\nimport { CategoriesFullView } from './shared/TopCategories/CategoriesFullView';\nimport type {\n DashboardStats,\n TopProduct,\n ConversionDataPoint,\n SignupDataPoint,\n CategoryRevenue,\n OrderHistory,\n SignupDetail,\n DateRangeOption,\n MarketOption,\n ProductSortOption,\n SignupViewOption,\n ConversionFilterOption,\n CategorySortOption,\n FullViewWidgetType,\n} from './types.d';\n\ntype ViewMode = 'push' | 'replace';\n\nexport type MysiteDashboardView = 'dashboard' | FullViewWidgetType;\n\nexport interface MysiteDashboardHistoryLocation {\n readonly pathname?: string;\n readonly search?: string;\n readonly hash?: string;\n readonly state?: unknown;\n}\n\nexport interface MysiteDashboardHistoryAdapter {\n readonly location?: MysiteDashboardHistoryLocation;\n push(location: MysiteDashboardHistoryLocation): void;\n replace(location: MysiteDashboardHistoryLocation): void;\n goBack(): void;\n listen(listener: (location: MysiteDashboardHistoryLocation, action: string) => void): () => void;\n}\n\nexport interface MysiteDashboardWithNavigationProps {\n readonly stats?: DashboardStats | null;\n readonly topProducts?: TopProduct[];\n readonly conversionData?: ConversionDataPoint[];\n readonly signupData?: SignupDataPoint[];\n readonly categories?: CategoryRevenue[];\n readonly orders?: OrderHistory[];\n readonly signups?: SignupDetail[];\n readonly isLoading?: boolean;\n readonly error?: string | null;\n readonly shopTitle?: string;\n readonly className?: string;\n\n readonly initialDateRange?: DateRangeOption;\n readonly initialMarket?: MarketOption;\n readonly initialProductSort?: ProductSortOption;\n readonly initialSignupView?: SignupViewOption;\n readonly initialConversionFilter?: ConversionFilterOption;\n readonly initialCategorySort?: CategorySortOption;\n\n readonly historyAdapter?: MysiteDashboardHistoryAdapter;\n readonly historyStateKey?: string;\n readonly resetToDashboardOnMount?: boolean;\n\n readonly onDateRangeChange?: (range: DateRangeOption) => void;\n readonly onMarketChange?: (market: MarketOption) => void;\n readonly onProductSortChange?: (sort: ProductSortOption) => void;\n readonly onSignupViewChange?: (view: SignupViewOption) => void;\n readonly onConversionFilterChange?: (filter: ConversionFilterOption) => void;\n readonly onCategorySortChange?: (sort: CategorySortOption) => void;\n readonly onViewChange?: (view: MysiteDashboardView) => void;\n}\n\nconst DEFAULT_HISTORY_STATE_KEY = 'shoppingDashboardView';\n\nconst EMPTY_TOP_PRODUCTS: TopProduct[] = [];\nconst EMPTY_CONVERSION_DATA: ConversionDataPoint[] = [];\nconst EMPTY_SIGNUP_DATA: SignupDataPoint[] = [];\nconst EMPTY_CATEGORIES: CategoryRevenue[] = [];\nconst EMPTY_ORDERS: OrderHistory[] = [];\nconst EMPTY_SIGNUPS: SignupDetail[] = [];\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null;\n}\n\nfunction isMysiteDashboardView(value: unknown): value is MysiteDashboardView {\n return (\n value === 'dashboard' ||\n value === 'products' ||\n value === 'conversion-rate' ||\n value === 'signups' ||\n value === 'categories'\n );\n}\n\nfunction readViewFromState(state: unknown, stateKey: string): MysiteDashboardView {\n if (!isRecord(state)) {\n return 'dashboard';\n }\n\n const view = state[stateKey];\n return isMysiteDashboardView(view) ? view : 'dashboard';\n}\n\nfunction buildStateWithView(state: unknown, stateKey: string, view: MysiteDashboardView): Record<string, unknown> {\n const currentState = isRecord(state) ? state : {};\n\n return {\n ...currentState,\n [stateKey]: view,\n };\n}\n\nfunction buildLocationWithState(\n location: MysiteDashboardHistoryLocation | undefined,\n state: Record<string, unknown>,\n): MysiteDashboardHistoryLocation {\n return {\n pathname: location?.pathname,\n search: location?.search,\n hash: location?.hash,\n state,\n };\n}\n\nexport const MysiteDashboardWithNavigation: React.FC<MysiteDashboardWithNavigationProps> = ({\n stats,\n topProducts,\n conversionData,\n signupData,\n categories,\n orders,\n signups,\n isLoading = false,\n error,\n shopTitle,\n className,\n initialDateRange = 'last30days',\n initialMarket = 'all',\n initialProductSort = 'units',\n initialSignupView = 'all',\n initialConversionFilter = 'all',\n initialCategorySort = 'revenue',\n historyAdapter,\n historyStateKey = DEFAULT_HISTORY_STATE_KEY,\n resetToDashboardOnMount = true,\n onDateRangeChange,\n onMarketChange,\n onProductSortChange,\n onSignupViewChange,\n onConversionFilterChange,\n onCategorySortChange,\n onViewChange,\n}) => {\n const [currentView, setCurrentView] = React.useState<MysiteDashboardView>('dashboard');\n const hasIntraDashboardHistoryRef = React.useRef(false);\n const [dateRange, setDateRange] = React.useState<DateRangeOption>(initialDateRange);\n const [market, setMarket] = React.useState<MarketOption>(initialMarket);\n const [productSort, setProductSort] = React.useState<ProductSortOption>(initialProductSort);\n const [signupView, setSignupView] = React.useState<SignupViewOption>(initialSignupView);\n const [conversionFilter, setConversionFilter] = React.useState<ConversionFilterOption>(initialConversionFilter);\n const [categorySort, setCategorySort] = React.useState<CategorySortOption>(initialCategorySort);\n\n const resolvedTopProducts = topProducts ?? EMPTY_TOP_PRODUCTS;\n const resolvedConversionData = conversionData ?? EMPTY_CONVERSION_DATA;\n const resolvedSignupData = signupData ?? EMPTY_SIGNUP_DATA;\n const resolvedCategories = categories ?? EMPTY_CATEGORIES;\n const resolvedOrders = orders ?? EMPTY_ORDERS;\n const resolvedSignups = signups ?? EMPTY_SIGNUPS;\n\n const updateView = React.useCallback(\n (view: MysiteDashboardView) => {\n setCurrentView(view);\n onViewChange?.(view);\n },\n [onViewChange],\n );\n\n const readCurrentView = React.useCallback((): MysiteDashboardView => {\n if (historyAdapter) {\n return readViewFromState(historyAdapter.location?.state, historyStateKey);\n }\n\n if (typeof window === 'undefined') {\n return 'dashboard';\n }\n\n return readViewFromState(window.history.state, historyStateKey);\n }, [historyAdapter, historyStateKey]);\n\n const writeCurrentView = React.useCallback(\n (view: MysiteDashboardView, mode: ViewMode) => {\n if (historyAdapter) {\n const nextState = buildStateWithView(historyAdapter.location?.state, historyStateKey, view);\n const nextLocation = buildLocationWithState(historyAdapter.location, nextState);\n\n if (mode === 'replace') {\n historyAdapter.replace(nextLocation);\n return;\n }\n\n historyAdapter.push(nextLocation);\n return;\n }\n\n if (typeof window === 'undefined') {\n return;\n }\n\n const nextState = buildStateWithView(window.history.state, historyStateKey, view);\n\n if (mode === 'replace') {\n window.history.replaceState(nextState, '');\n return;\n }\n\n window.history.pushState(nextState, '');\n },\n [historyAdapter, historyStateKey],\n );\n\n React.useEffect(() => {\n if (resetToDashboardOnMount) {\n writeCurrentView('dashboard', 'replace');\n hasIntraDashboardHistoryRef.current = false;\n updateView('dashboard');\n } else {\n updateView(readCurrentView());\n }\n\n if (historyAdapter) {\n return historyAdapter.listen((location, action) => {\n if (action === 'POP') {\n const nextView = readViewFromState(location.state, historyStateKey);\n hasIntraDashboardHistoryRef.current = nextView !== 'dashboard';\n updateView(nextView);\n }\n });\n }\n\n const handlePopState = (event: PopStateEvent) => {\n const nextView = readViewFromState(event.state, historyStateKey);\n hasIntraDashboardHistoryRef.current = nextView !== 'dashboard';\n updateView(nextView);\n };\n\n window.addEventListener('popstate', handlePopState);\n return () => {\n window.removeEventListener('popstate', handlePopState);\n };\n }, [historyAdapter, historyStateKey, readCurrentView, resetToDashboardOnMount, updateView, writeCurrentView]);\n\n const handleOpenFullView = React.useCallback(\n (view: FullViewWidgetType) => {\n hasIntraDashboardHistoryRef.current = true;\n writeCurrentView(view, 'push');\n updateView(view);\n },\n [updateView, writeCurrentView],\n );\n\n const handleBack = React.useCallback(() => {\n if (currentView !== 'dashboard' && hasIntraDashboardHistoryRef.current) {\n if (historyAdapter) {\n historyAdapter.goBack();\n return;\n }\n\n if (typeof window !== 'undefined') {\n window.history.back();\n }\n\n return;\n }\n\n hasIntraDashboardHistoryRef.current = false;\n writeCurrentView('dashboard', 'replace');\n updateView('dashboard');\n }, [currentView, historyAdapter, updateView, writeCurrentView]);\n\n const handleDateRangeChange = React.useCallback(\n (nextDateRange: DateRangeOption) => {\n setDateRange(nextDateRange);\n onDateRangeChange?.(nextDateRange);\n },\n [onDateRangeChange],\n );\n\n const handleMarketChange = React.useCallback(\n (nextMarket: MarketOption) => {\n setMarket(nextMarket);\n onMarketChange?.(nextMarket);\n },\n [onMarketChange],\n );\n\n const handleProductSortChange = React.useCallback(\n (nextProductSort: ProductSortOption) => {\n setProductSort(nextProductSort);\n onProductSortChange?.(nextProductSort);\n },\n [onProductSortChange],\n );\n\n const handleSignupViewChange = React.useCallback(\n (nextSignupView: SignupViewOption) => {\n setSignupView(nextSignupView);\n onSignupViewChange?.(nextSignupView);\n },\n [onSignupViewChange],\n );\n\n const handleConversionFilterChange = React.useCallback(\n (nextFilter: ConversionFilterOption) => {\n setConversionFilter(nextFilter);\n onConversionFilterChange?.(nextFilter);\n },\n [onConversionFilterChange],\n );\n\n const handleCategorySortChange = React.useCallback(\n (nextSort: CategorySortOption) => {\n setCategorySort(nextSort);\n onCategorySortChange?.(nextSort);\n },\n [onCategorySortChange],\n );\n\n const handleProductsTitleClick = React.useCallback(() => {\n handleOpenFullView('products');\n }, [handleOpenFullView]);\n\n const handleConversionTitleClick = React.useCallback(() => {\n handleOpenFullView('conversion-rate');\n }, [handleOpenFullView]);\n\n const handleSignupsTitleClick = React.useCallback(() => {\n handleOpenFullView('signups');\n }, [handleOpenFullView]);\n\n const handleCategoriesTitleClick = React.useCallback(() => {\n handleOpenFullView('categories');\n }, [handleOpenFullView]);\n\n if (currentView === 'products') {\n return (\n <ProductsFullView\n products={resolvedTopProducts}\n dateRange={dateRange}\n market={market}\n productSort={productSort}\n isLoading={isLoading}\n onBack={handleBack}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onProductSortChange={handleProductSortChange}\n />\n );\n }\n\n if (currentView === 'conversion-rate') {\n return (\n <ConversionRateFullView\n conversionData={resolvedConversionData}\n orders={resolvedOrders}\n dateRange={dateRange}\n market={market}\n conversionFilter={conversionFilter}\n isLoading={isLoading}\n onBack={handleBack}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onConversionFilterChange={handleConversionFilterChange}\n />\n );\n }\n\n if (currentView === 'signups') {\n return (\n <SignupsFullView\n signupData={resolvedSignupData}\n signups={resolvedSignups}\n dateRange={dateRange}\n market={market}\n signupView={signupView}\n isLoading={isLoading}\n onBack={handleBack}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onSignupViewChange={handleSignupViewChange}\n />\n );\n }\n\n if (currentView === 'categories') {\n return (\n <CategoriesFullView\n categories={resolvedCategories}\n dateRange={dateRange}\n market={market}\n categorySort={categorySort}\n isLoading={isLoading}\n onBack={handleBack}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onCategorySortChange={handleCategorySortChange}\n />\n );\n }\n\n return (\n <ShoppingDashboard\n stats={stats}\n topProducts={resolvedTopProducts}\n conversionData={resolvedConversionData}\n signupData={resolvedSignupData}\n categories={resolvedCategories}\n isLoading={isLoading}\n error={error}\n shopTitle={shopTitle}\n className={className}\n dateRange={dateRange}\n market={market}\n productSort={productSort}\n signupView={signupView}\n conversionFilter={conversionFilter}\n categorySort={categorySort}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onProductSortChange={handleProductSortChange}\n onSignupViewChange={handleSignupViewChange}\n onConversionFilterChange={handleConversionFilterChange}\n onCategorySortChange={handleCategorySortChange}\n onProductsTitleClick={handleProductsTitleClick}\n onConversionTitleClick={handleConversionTitleClick}\n onSignupsTitleClick={handleSignupsTitleClick}\n onCategoriesToTitleClick={handleCategoriesTitleClick}\n />\n );\n};\n\nexport default MysiteDashboardWithNavigation;\n","import React, { useState } from 'react';\nimport { PageHeader, type FilterConfig } from '../PageHeader';\nimport { DataTable, type ColumnDef } from '../DataTable';\nimport { Pagination } from '../Pagination';\nimport { paginateItems, calculateTotalPages } from '../../utils/dataUtils';\nimport { formatDateRangeLabel } from '../../utils/dateFormat';\nimport type { TopProduct, DateRangeOption, MarketOption, ProductSortOption } from '../../types.d';\nimport { FullViewTableSkeleton } from '../LoadingSkeletons';\nimport { PageContainer, EmptyStateText } from '../FullViewComponents.styled';\nimport {\n ProductImageCell,\n ProductImage,\n ProductInfo,\n ProductName,\n ProductSku,\n MetricValue,\n MobileCardsContainer,\n DesktopTableContainer,\n MobileProductCard,\n MobileCardHeader,\n MobileProductRank,\n MobileProductImage,\n MobileProductDetails,\n MobileProductName,\n MobileProductSku,\n MobileMetricsGrid,\n MobileMetricItem,\n MobileMetricLabel,\n MobileMetricValue,\n} from './ProductsFullView.styled';\nimport { useIsMobileViewport } from '../useViewport';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ShoppingDashboardTranslationKeys';\n\n// Product table interface\ninterface ProductRow {\n rank: number;\n name: string;\n sku: string;\n image: string;\n units: number;\n revenue: number;\n volume: number;\n}\n\nexport interface ProductsFullViewProps {\n readonly products: TopProduct[];\n readonly dateRange: DateRangeOption;\n readonly market: MarketOption;\n readonly productSort: ProductSortOption;\n readonly isLoading?: boolean;\n readonly onBack?: () => void;\n readonly onDateRangeChange?: (range: DateRangeOption) => void;\n readonly onMarketChange?: (market: MarketOption) => void;\n readonly onProductSortChange?: (sort: ProductSortOption) => void;\n}\n\nfunction mapProductToRow(product: TopProduct): ProductRow {\n return {\n rank: product.rank,\n name: product.name,\n sku: `${getTranslation(Keys.fullView.products.skuPrefix)}-${product.id.replace('prod-', '').padStart(3, '0')}`,\n image: product.imageUrl,\n units: product.unitsSold,\n revenue: product.revenue,\n volume: product.volume,\n };\n}\n\nexport const ProductsFullView: React.FC<ProductsFullViewProps> = ({\n products,\n dateRange,\n market,\n productSort,\n isLoading = false,\n onBack,\n onDateRangeChange,\n onMarketChange,\n onProductSortChange,\n}) => {\n const [currentPage, setCurrentPage] = useState(1);\n const [sortColumn, setSortColumn] = useState<string>(productSort === 'revenue' ? 'revenue' : 'units');\n const [sortDirection, setSortDirection] = useState<'asc' | 'desc'>('desc');\n const itemsPerPage = 10;\n const isMobileView = useIsMobileViewport();\n\n const handleBack = React.useCallback(() => onBack?.(), [onBack]);\n\n const filters: FilterConfig[] = React.useMemo(\n () => [\n {\n key: 'dateRange',\n label: getTranslation(Keys.filter.dateRange.label),\n value: dateRange,\n icon: 'calendar',\n options: [\n { value: 'last7days', label: getTranslation(Keys.filter.dateRange.last7days) },\n { value: 'last30days', label: getTranslation(Keys.filter.dateRange.last30days) },\n { value: 'last90days', label: getTranslation(Keys.filter.dateRange.last90days) },\n { value: 'thisMonth', label: getTranslation(Keys.filter.dateRange.thisMonth) },\n ],\n },\n {\n key: 'market',\n label: getTranslation(Keys.filter.market.label),\n value: market,\n icon: 'globe',\n options: [\n { value: 'all', label: getTranslation(Keys.filter.market.all) },\n { value: 'us', label: getTranslation(Keys.filter.market.us) },\n { value: 'ca', label: getTranslation(Keys.filter.market.ca) },\n { value: 'jp', label: getTranslation(Keys.filter.market.jp) },\n { value: 'kr', label: getTranslation(Keys.filter.market.kr) },\n { value: 'au', label: getTranslation(Keys.filter.market.au) },\n { value: 'nz', label: getTranslation(Keys.filter.market.nz) },\n ],\n },\n {\n key: 'sort',\n label: getTranslation(Keys.filter.productSort.label),\n value: productSort,\n options: [\n { value: 'units', label: getTranslation(Keys.filter.productSort.units) },\n { value: 'revenue', label: getTranslation(Keys.filter.productSort.revenue) },\n { value: 'volume', label: getTranslation(Keys.filter.productSort.volume) },\n ],\n },\n ],\n [dateRange, market, productSort],\n );\n\n const handleFilterChange = React.useCallback(\n (key: string, value: string) => {\n if (key === 'dateRange') onDateRangeChange?.(value as DateRangeOption);\n else if (key === 'market') onMarketChange?.(value as MarketOption);\n else if (key === 'sort') {\n onProductSortChange?.(value as ProductSortOption);\n setCurrentPage(1);\n }\n },\n [onDateRangeChange, onMarketChange, onProductSortChange],\n );\n\n const handleSort = React.useCallback((columnKey: string, direction: 'asc' | 'desc') => {\n setSortColumn(columnKey);\n setSortDirection(direction);\n setCurrentPage(1);\n }, []);\n\n const productRows = React.useMemo(() => products.map(mapProductToRow), [products]);\n\n // Sort\n const sortedRows = React.useMemo(\n () =>\n [...productRows].sort((a, b) => {\n const aVal = a[sortColumn as keyof ProductRow] as number;\n const bVal = b[sortColumn as keyof ProductRow] as number;\n return sortDirection === 'asc' ? aVal - bVal : bVal - aVal;\n }),\n [productRows, sortColumn, sortDirection],\n );\n\n const totalPages = React.useMemo(() => calculateTotalPages(sortedRows, itemsPerPage), [itemsPerPage, sortedRows]);\n const paginatedRows = React.useMemo(\n () => paginateItems(sortedRows, currentPage, itemsPerPage),\n [currentPage, itemsPerPage, sortedRows],\n );\n\n const columns: ColumnDef<ProductRow>[] = React.useMemo(\n () => [\n { key: 'rank', label: getTranslation(Keys.fullView.products.columns.rank), sortable: true },\n {\n key: 'name',\n label: getTranslation(Keys.fullView.products.columns.product),\n sortable: true,\n render: (_: unknown, row: ProductRow) => (\n <ProductImageCell>\n {row.image && <ProductImage src={row.image} alt={row.name} />}\n <ProductInfo>\n <ProductName>{row.name}</ProductName>\n <ProductSku>{row.sku}</ProductSku>\n </ProductInfo>\n </ProductImageCell>\n ),\n },\n {\n key: 'units',\n label: getTranslation(Keys.fullView.products.columns.unitsSold),\n sortable: true,\n render: (value: unknown) => <MetricValue>{Number(value).toLocaleString()}</MetricValue>,\n },\n {\n key: 'revenue',\n label: getTranslation(Keys.fullView.products.columns.revenue),\n sortable: true,\n render: (value: unknown) => <MetricValue>${Number(value).toLocaleString()}</MetricValue>,\n },\n {\n key: 'volume',\n label: getTranslation(Keys.fullView.products.columns.volume),\n sortable: true,\n render: (value: unknown) => <MetricValue>{Number(value).toLocaleString()}</MetricValue>,\n },\n ],\n [],\n );\n\n if (isLoading) {\n return (\n <PageContainer data-testid=\"products-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.topProducts.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n <FullViewTableSkeleton />\n </PageContainer>\n );\n }\n\n if (products.length === 0) {\n return (\n <PageContainer data-testid=\"products-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.topProducts.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n <EmptyStateText data-testid=\"products-fullview-empty\">\n {getTranslation(Keys.fullView.products.noProducts)}\n </EmptyStateText>\n </PageContainer>\n );\n }\n\n return (\n <PageContainer data-testid=\"products-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.topProducts.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n\n {!isMobileView ? (\n <DesktopTableContainer data-testid=\"products-fullview-desktop-table\">\n <DataTable\n columns={columns}\n data={paginatedRows}\n sortable\n onSort={handleSort}\n sortColumn={sortColumn}\n sortDirection={sortDirection}\n getRowKey={(row: ProductRow) => row.rank}\n />\n </DesktopTableContainer>\n ) : (\n <MobileCardsContainer data-testid=\"products-fullview-mobile-cards\">\n {paginatedRows.map((row) => (\n <MobileProductCard key={row.rank}>\n <MobileCardHeader>\n <MobileProductRank>#{row.rank}</MobileProductRank>\n {row.image && <MobileProductImage src={row.image} alt={row.name} />}\n <MobileProductDetails>\n <MobileProductName>{row.name}</MobileProductName>\n <MobileProductSku>{row.sku}</MobileProductSku>\n </MobileProductDetails>\n </MobileCardHeader>\n <MobileMetricsGrid>\n <MobileMetricItem>\n <MobileMetricLabel>\n {getTranslation(Keys.widget.topProducts.units)}\n </MobileMetricLabel>\n <MobileMetricValue>{row.units.toLocaleString()}</MobileMetricValue>\n </MobileMetricItem>\n <MobileMetricItem>\n <MobileMetricLabel>\n {getTranslation(Keys.widget.topProducts.revenue)}\n </MobileMetricLabel>\n <MobileMetricValue>${row.revenue.toLocaleString()}</MobileMetricValue>\n </MobileMetricItem>\n <MobileMetricItem>\n <MobileMetricLabel>\n {getTranslation(Keys.filter.productSort.volume)}\n </MobileMetricLabel>\n <MobileMetricValue>{row.volume.toLocaleString()}</MobileMetricValue>\n </MobileMetricItem>\n </MobileMetricsGrid>\n </MobileProductCard>\n ))}\n </MobileCardsContainer>\n )}\n\n {totalPages > 1 && (\n <Pagination\n currentPage={currentPage}\n totalPages={totalPages}\n onPageChange={setCurrentPage}\n itemsPerPage={itemsPerPage}\n totalItems={sortedRows.length}\n />\n )}\n </PageContainer>\n );\n};\n","import React from 'react';\nimport ArrowBackIcon from '@mui/icons-material/ArrowBack';\nimport CalendarTodayIcon from '@mui/icons-material/CalendarToday';\nimport LanguageIcon from '@mui/icons-material/Language';\nimport {\n PageHeaderWrapper,\n BackButtonWrapper,\n BackButton,\n HeaderContainer,\n LeftSection,\n Title,\n DateRange,\n MobileDateRange,\n FiltersSection,\n FilterWrapper,\n FilterIcon,\n FilterDropdown,\n MobileTitleWrapper,\n MobileTitle,\n} from './PageHeader.styled';\nimport type { FilterConfig } from './types';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport type { FilterConfig } from './types';\n\nexport interface PageHeaderProps {\n readonly title: string;\n readonly dateRange: string;\n readonly onBack: () => void;\n readonly filters?: FilterConfig[];\n readonly onFilterChange?: (filterKey: string, value: string) => void;\n}\n\nexport const PageHeader: React.FC<PageHeaderProps> = ({ title, dateRange, onBack, filters, onFilterChange }) => {\n const renderFilterIcon = (iconType?: 'calendar' | 'globe') => {\n if (!iconType) return null;\n return (\n <FilterIcon>\n {iconType === 'calendar' && <CalendarTodayIcon />}\n {iconType === 'globe' && <LanguageIcon />}\n </FilterIcon>\n );\n };\n\n return (\n <PageHeaderWrapper data-testid=\"page-header\">\n <BackButtonWrapper>\n <BackButton\n onClick={onBack}\n aria-label={getTranslation(Keys.navigation.backAriaLabel)}\n data-testid=\"page-back-button\"\n type=\"button\"\n >\n <ArrowBackIcon />\n <span>{getTranslation(Keys.navigation.backToDashboard)}</span>\n </BackButton>\n </BackButtonWrapper>\n\n <MobileTitleWrapper>\n <MobileTitle>{title}</MobileTitle>\n </MobileTitleWrapper>\n\n <HeaderContainer>\n <LeftSection>\n <Title data-testid=\"page-header-title\">{title}</Title>\n <DateRange data-testid=\"page-header-date-range\">{dateRange}</DateRange>\n </LeftSection>\n\n {filters && filters.length > 0 && onFilterChange && (\n <FiltersSection data-testid=\"page-header-filters\">\n {filters.map((filter) => (\n <FilterWrapper key={filter.key}>\n {renderFilterIcon(filter.icon)}\n <FilterDropdown\n id={`filter-${filter.key}`}\n value={filter.value}\n onChange={(e) => onFilterChange(filter.key, e.target.value)}\n disabled={filter.disabled}\n aria-label={`${filter.label} ${getTranslation(Keys.ariaLabel.filterSuffix)}`}\n data-testid={`filter-dropdown-${filter.key}`}\n >\n {filter.options.map((option) => (\n <option key={option.value} value={option.value}>\n {filter.label && filter.key === 'customerType'\n ? `${filter.label} ${option.label}`\n : option.label}\n </option>\n ))}\n </FilterDropdown>\n </FilterWrapper>\n ))}\n </FiltersSection>\n )}\n\n <MobileDateRange>{dateRange}</MobileDateRange>\n </HeaderContainer>\n </PageHeaderWrapper>\n );\n};\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const PageHeaderWrapper = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 16px;\n margin-bottom: 24px;\n`;\n\nexport const BackButtonWrapper = styled('div')`\n display: flex;\n align-items: center;\n`;\n\nexport const BackButton = styled('button')`\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 0;\n border: none;\n background-color: transparent;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n cursor: pointer;\n transition: color 0.2s ease;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n\n &:hover {\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n }\n\n &:focus {\n outline: 2px solid ${({ theme }) => getGenomeColor(theme, 'A70')};\n outline-offset: 2px;\n border-radius: 4px;\n }\n\n svg {\n font-size: 16px;\n }\n\n span {\n line-height: 1;\n }\n`;\n\nexport const HeaderContainer = styled('div')`\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding-bottom: 16px;\n border-bottom: 1px solid ${({ theme }) => getGenomeColor(theme, 'N30')};\n gap: 24px;\n\n @media (max-width: 767px) {\n align-items: flex-end;\n gap: 16px;\n }\n`;\n\nexport const LeftSection = styled('div')`\n display: flex;\n align-items: center;\n gap: 16px;\n flex: 1;\n\n @media (max-width: 767px) {\n display: none;\n }\n`;\n\nexport const Title = styled('h1')`\n font-size: 16px;\n font-weight: 600;\n line-height: 22px;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n white-space: nowrap;\n\n @media (max-width: 767px) {\n display: block;\n margin-bottom: 16px;\n }\n`;\n\nexport const DateRange = styled('p')`\n font-size: 16px;\n font-weight: 400;\n line-height: 22px;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n white-space: nowrap;\n`;\n\nexport const MobileDateRange = styled('p')`\n display: none;\n font-size: 16px;\n font-weight: 400;\n line-height: 22px;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n white-space: nowrap;\n\n @media (max-width: 767px) {\n display: block;\n flex-shrink: 0;\n }\n`;\n\nexport const FiltersSection = styled('div')`\n display: flex;\n gap: 24px;\n align-items: center;\n flex-shrink: 0;\n\n @media (max-width: 767px) {\n flex-direction: column;\n align-items: flex-start;\n gap: 8px;\n }\n`;\n\nexport const FilterWrapper = styled('div')`\n display: flex;\n align-items: center;\n gap: 8px;\n`;\n\nexport const FilterIcon = styled('span')`\n display: flex;\n align-items: center;\n justify-content: center;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n\n svg {\n font-size: 16px;\n }\n`;\n\nexport const FilterDropdown = styled('select')`\n min-width: 120px;\n height: 32px;\n padding: 6px 8px;\n padding-right: 24px;\n background-color: transparent;\n border: none;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n cursor: pointer;\n outline: none;\n transition: background-color 0.2s ease;\n appearance: none;\n background-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"><path fill=\"%23667085\" d=\"M6 8L2 4h8L6 8z\"/></svg>');\n background-repeat: no-repeat;\n background-position: right 4px center;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border-radius: 4px;\n }\n\n &:focus {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border-radius: 4px;\n outline: 2px solid ${({ theme }) => getGenomeColor(theme, 'A70')};\n outline-offset: 2px;\n }\n\n &:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n\n @media (max-width: 767px) {\n min-width: auto;\n width: auto;\n flex: none;\n padding-right: 24px;\n background-position: right 8px center;\n }\n`;\n\nexport const MobileTitleWrapper = styled('div')`\n display: none;\n\n @media (max-width: 767px) {\n display: block;\n margin-bottom: 16px;\n }\n`;\n\nexport const MobileTitle = styled('h1')`\n font-size: 16px;\n font-weight: 600;\n line-height: 22px;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n margin: 0;\n`;\n","import React from 'react';\nimport ArrowUpwardIcon from '@mui/icons-material/ArrowUpward';\nimport ArrowDownwardIcon from '@mui/icons-material/ArrowDownward';\nimport {\n TableContainer,\n Table,\n TableHeader,\n TableHeaderCell,\n TableBody,\n TableRow,\n TableCell,\n EmptyTableCell,\n SortIconContainer,\n} from './DataTable.styled';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface ColumnDef<TData = unknown> {\n key: string;\n label: string;\n sortable?: boolean;\n render?: (value: unknown, row: TData) => React.ReactNode;\n align?: 'left' | 'center' | 'right';\n}\n\nexport interface DataTableProps<TData = unknown> {\n readonly columns: ColumnDef<TData>[];\n readonly data: TData[];\n readonly sortable?: boolean;\n readonly onSort?: (columnKey: string, direction: 'asc' | 'desc') => void;\n readonly sortColumn?: string;\n readonly sortDirection?: 'asc' | 'desc';\n readonly getRowKey?: (row: TData, rowIndex: number) => React.Key;\n}\n\nexport const DataTable = <TData,>({\n columns,\n data,\n sortable = false,\n onSort,\n sortColumn,\n sortDirection = 'asc',\n getRowKey,\n}: DataTableProps<TData>) => {\n const handleSort = (columnKey: string) => {\n if (!sortable || !onSort) return;\n const newDirection = sortColumn === columnKey && sortDirection === 'asc' ? 'desc' : 'asc';\n onSort(columnKey, newDirection);\n };\n\n const handleKeyDown = (e: React.KeyboardEvent, columnKey: string) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n handleSort(columnKey);\n }\n };\n\n const getAriaSort = (columnKey: string): 'ascending' | 'descending' | undefined => {\n if (sortColumn !== columnKey) return undefined;\n return sortDirection === 'asc' ? 'ascending' : 'descending';\n };\n\n return (\n <TableContainer data-testid=\"data-table\">\n <Table>\n <TableHeader>\n <tr>\n {columns.map((column) => (\n <TableHeaderCell\n key={column.key}\n sortable={sortable && column.sortable}\n onClick={() => column.sortable && handleSort(column.key)}\n onKeyDown={(e) => column.sortable && handleKeyDown(e, column.key)}\n tabIndex={sortable && column.sortable ? 0 : -1}\n aria-sort={getAriaSort(column.key)}\n aria-label={`${column.label}${column.sortable ? getTranslation(Keys.dataTable.sortableColumn) : ''}`}\n data-testid={`table-header-${column.key}`}\n >\n {column.label}\n {sortable && column.sortable && (\n <SortIconContainer isActive={sortColumn === column.key}>\n {sortColumn === column.key && sortDirection === 'desc' ? (\n <ArrowDownwardIcon />\n ) : (\n <ArrowUpwardIcon />\n )}\n </SortIconContainer>\n )}\n </TableHeaderCell>\n ))}\n </tr>\n </TableHeader>\n <TableBody>\n {data.length === 0 ? (\n <TableRow data-testid=\"table-empty-row\">\n <EmptyTableCell colSpan={columns.length}>\n {getTranslation(Keys.dataTable.noDataAvailable)}\n </EmptyTableCell>\n </TableRow>\n ) : (\n data.map((row, rowIndex) => (\n <TableRow\n key={getRowKey ? getRowKey(row, rowIndex) : rowIndex}\n data-testid={`table-row-${rowIndex}`}\n >\n {columns.map((column) => (\n <TableCell key={column.key} data-testid={`table-cell-${column.key}`}>\n {column.render\n ? column.render((row as Record<string, unknown>)[column.key], row)\n : ((row as Record<string, unknown>)[column.key] as React.ReactNode)}\n </TableCell>\n ))}\n </TableRow>\n ))\n )}\n </TableBody>\n </Table>\n </TableContainer>\n );\n};\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const TableContainer = styled('div')`\n width: 100%;\n overflow-x: auto;\n border-radius: 8px;\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N30')};\n`;\n\nexport const Table = styled('table')`\n width: 100%;\n border-collapse: collapse;\n`;\n\nexport const TableHeader = styled('thead')`\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border-bottom: 2px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n`;\n\nexport const TableHeaderCell = styled('th')<{ sortable?: boolean }>`\n padding: 12px 16px;\n font-size: 14px;\n font-weight: 600;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n text-align: left;\n cursor: ${({ sortable }) => (sortable ? 'pointer' : 'default')};\n user-select: none;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({ theme, sortable }) => (sortable ? getGenomeColor(theme, 'N30') : 'transparent')};\n }\n\n &:focus {\n outline: 2px solid ${({ theme }) => getGenomeColor(theme, 'A70')};\n outline-offset: -2px;\n }\n`;\n\nexport const TableBody = styled('tbody')``;\n\nexport const TableRow = styled('tr')`\n border-bottom: 1px solid ${({ theme }) => getGenomeColor(theme, 'N30')};\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n }\n\n &:last-child {\n border-bottom: none;\n }\n`;\n\nexport const TableCell = styled('td')`\n padding: 12px 16px;\n font-size: 14px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n text-align: left;\n`;\n\nexport const EmptyTableCell = styled(TableCell)`\n text-align: center;\n`;\n\nexport const SortIconContainer = styled('span')<{ isActive?: boolean }>`\n display: inline-flex;\n margin-left: 6px;\n opacity: ${({ isActive }) => (isActive ? 1 : 0.4)};\n transition: opacity 0.2s ease;\n\n svg {\n font-size: 16px;\n }\n`;\n","import React from 'react';\nimport ChevronLeftIcon from '@mui/icons-material/ChevronLeft';\nimport ChevronRightIcon from '@mui/icons-material/ChevronRight';\nimport { PaginationContainer, PageButton, PageInfo, NavButton } from './Pagination.styled';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface PaginationProps {\n readonly currentPage: number;\n readonly totalPages: number;\n readonly onPageChange: (page: number) => void;\n readonly itemsPerPage?: number;\n readonly totalItems?: number;\n}\n\nexport const Pagination: React.FC<PaginationProps> = ({\n currentPage,\n totalPages,\n onPageChange,\n itemsPerPage,\n totalItems,\n}) => {\n const handlePrevious = () => {\n if (currentPage > 1) {\n onPageChange(currentPage - 1);\n }\n };\n\n const handleNext = () => {\n if (currentPage < totalPages) {\n onPageChange(currentPage + 1);\n }\n };\n\n const handleKeyDown = (e: React.KeyboardEvent, action: () => void) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n action();\n }\n };\n\n const getPageNumbers = (): number[] => {\n if (totalPages <= 7) {\n return Array.from({ length: totalPages }, (_, i) => i + 1);\n }\n\n const pages: number[] = [];\n if (currentPage <= 4) {\n pages.push(1, 2, 3, 4, 5);\n } else if (currentPage >= totalPages - 3) {\n pages.push(totalPages - 4, totalPages - 3, totalPages - 2, totalPages - 1, totalPages);\n } else {\n pages.push(currentPage - 1, currentPage, currentPage + 1);\n }\n\n return pages;\n };\n\n const pageNumbers = getPageNumbers();\n const startItem = itemsPerPage ? (currentPage - 1) * itemsPerPage + 1 : null;\n const endItem = itemsPerPage ? Math.min(currentPage * itemsPerPage, totalItems ?? Infinity) : null;\n const goToPageLabel = getTranslation(Keys.pagination.goToPage);\n\n return (\n <PaginationContainer data-testid=\"pagination\">\n <NavButton\n onClick={handlePrevious}\n onKeyDown={(e) => handleKeyDown(e, handlePrevious)}\n disabled={currentPage === 1}\n aria-label={getTranslation(Keys.pagination.previousPage)}\n data-testid=\"pagination-previous\"\n type=\"button\"\n >\n <ChevronLeftIcon />\n </NavButton>\n\n {totalPages > 7 && currentPage > 4 && (\n <>\n <PageButton\n onClick={() => onPageChange(1)}\n isActive={false}\n aria-label={`${goToPageLabel} 1`}\n data-testid=\"pagination-page-1\"\n type=\"button\"\n >\n 1\n </PageButton>\n <PageInfo>...</PageInfo>\n </>\n )}\n\n {pageNumbers.map((page) => (\n <PageButton\n key={page}\n onClick={() => onPageChange(page)}\n isActive={currentPage === page}\n aria-label={`${goToPageLabel} ${page}`}\n aria-current={currentPage === page ? 'page' : undefined}\n data-testid={`pagination-page-${page}`}\n type=\"button\"\n >\n {page}\n </PageButton>\n ))}\n\n {totalPages > 7 && currentPage < totalPages - 3 && (\n <>\n <PageInfo>...</PageInfo>\n <PageButton\n onClick={() => onPageChange(totalPages)}\n isActive={false}\n aria-label={`${goToPageLabel} ${totalPages}`}\n data-testid={`pagination-page-${totalPages}`}\n type=\"button\"\n >\n {totalPages}\n </PageButton>\n </>\n )}\n\n <NavButton\n onClick={handleNext}\n onKeyDown={(e) => handleKeyDown(e, handleNext)}\n disabled={currentPage === totalPages}\n aria-label={getTranslation(Keys.pagination.nextPage)}\n data-testid=\"pagination-next\"\n type=\"button\"\n >\n <ChevronRightIcon />\n </NavButton>\n\n {itemsPerPage && totalItems && (\n <PageInfo as=\"output\" aria-live=\"polite\" data-testid=\"pagination-page-info\">\n {startItem}-{endItem} {getTranslation(Keys.pagination.of)} {totalItems}\n </PageInfo>\n )}\n </PaginationContainer>\n );\n};\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const PaginationContainer = styled('div')`\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 8px;\n margin-top: 24px;\n`;\n\nexport const PageButton = styled('button')<{ isActive?: boolean }>`\n width: 32px;\n height: 32px;\n border-radius: 4px;\n border: none;\n background-color: ${({ theme, isActive }) =>\n isActive ? getGenomeColor(theme, 'A80') : getGenomeColor(theme, 'N20')};\n color: ${({ theme, isActive }) => (isActive ? '#ffffff' : getGenomeColor(theme, 'N100'))};\n font-size: 14px;\n font-weight: 500;\n cursor: pointer;\n transition: all 0.2s ease;\n\n &:hover:not(:disabled) {\n background-color: ${({ theme, isActive }) =>\n isActive ? getGenomeColor(theme, 'A70') : getGenomeColor(theme, 'N30')};\n }\n\n &:focus {\n outline: 2px solid ${({ theme }) => getGenomeColor(theme, 'A70')};\n outline-offset: 2px;\n }\n\n &:disabled {\n opacity: 0.4;\n cursor: not-allowed;\n }\n`;\n\nexport const PageInfo = styled('span')`\n font-size: 14px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n margin: 0 8px;\n`;\n\nexport const NavButton = styled('button')`\n width: 32px;\n height: 32px;\n border-radius: 4px;\n border: none;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n transition: background-color 0.2s ease;\n\n &:hover:not(:disabled) {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n\n &:focus {\n outline: 2px solid ${({ theme }) => getGenomeColor(theme, 'A70')};\n outline-offset: 2px;\n }\n\n &:disabled {\n opacity: 0.4;\n cursor: not-allowed;\n }\n\n svg {\n font-size: 18px;\n }\n`;\n","/**\n * Data Utilities\n *\n * Shared functions for data manipulation across dashboard components.\n * Includes pagination, sorting, and filtering utilities.\n */\n\n/** Calculate total number of pages for pagination */\nexport function calculateTotalPages<T>(items: T[], itemsPerPage: number): number {\n return Math.ceil(items.length / itemsPerPage);\n}\n\n/** Get paginated slice of items for current page */\nexport function paginateItems<T>(items: T[], currentPage: number, itemsPerPage: number): T[] {\n const startIndex = (currentPage - 1) * itemsPerPage;\n const endIndex = startIndex + itemsPerPage;\n return items.slice(startIndex, endIndex);\n}\n\n/** Sort array by a numeric property */\nexport function sortByNumericProperty<T extends Record<string, unknown>>(\n items: T[],\n key: keyof T,\n direction: 'asc' | 'desc' = 'desc',\n): T[] {\n return [...items].sort((a, b) => {\n const aVal = a[key] as number;\n const bVal = b[key] as number;\n return direction === 'asc' ? aVal - bVal : bVal - aVal;\n });\n}\n\n/** Calculate percentage of a value relative to total */\nexport function calculatePercentage(value: number, total: number, decimalPlaces: number = 1): string {\n if (total === 0) return '0.0';\n return ((value / total) * 100).toFixed(decimalPlaces);\n}\n","/**\n * Date Constants\n *\n * Centralized date-related constants for dashboard filtering and display.\n */\n\nimport type { DateRangeOption } from '../types.d';\n\n/** Maps date range options to number of days */\nexport const DAYS_MAP: Record<DateRangeOption, number> = {\n last7days: 7,\n last30days: 30,\n last90days: 90,\n thisMonth: 31,\n};\n\n/** Maps date range options to human-readable labels */\nexport const DATE_RANGE_LABELS: Record<DateRangeOption, string> = {\n last7days: 'Last 7 Days',\n last30days: 'Last 30 Days',\n last90days: 'Last 90 Days',\n thisMonth: 'This Month',\n};\n\n/** Get number of days for a date range option */\nexport function getDaysFromDateRange(dateRange: DateRangeOption): number {\n return DAYS_MAP[dateRange] ?? 30;\n}\n\n/** Get human-readable label for a date range option */\nexport function getDateRangeLabel(dateRange: DateRangeOption): string {\n return DATE_RANGE_LABELS[dateRange] ?? 'Last 30 Days';\n}\n","/**\n * Date Format Utilities\n *\n * Shared functions for formatting dates and date ranges across dashboard components.\n */\n\nimport type { DateRangeOption } from '../types.d';\nimport { getDateRangeLabel } from './dateConstants';\n\n/** Format date range option to display label */\nexport function formatDateRangeLabel(dateRange: DateRangeOption): string {\n return getDateRangeLabel(dateRange);\n}\n\n/** Format Date object to \"MMM D\" format */\nexport function formatShortDate(date: Date): string {\n const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n return `${months[date.getMonth()]} ${date.getDate()}`;\n}\n\n/** Format date string to display format */\nexport function formatDisplayDate(dateStr: string): string {\n const date = new Date(dateStr);\n return formatShortDate(date);\n}\n\n/** Format date range as \"MMM D - MMM D\" */\nexport function formatDateRange(start: string, end: string): string {\n return `${formatDisplayDate(start)} - ${formatDisplayDate(end)}`;\n}\n\n/** Format ISO date to standard format */\nexport function formatISODate(date: Date): string {\n return date.toISOString().split('T')[0];\n}\n","import { styled } from '@mui/material/styles';\nimport { Box, Typography } from '@mui/material';\nimport { ColorUtils } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const PageContainer = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 24px;\n padding: 24px;\n max-width: 1400px;\n margin: 0 auto;\n\n @media (max-width: 767px) {\n padding: 16px;\n gap: 16px;\n }\n`;\n\nexport const MetricChartCardSection = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 24px;\n padding: 24px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border-radius: 8px;\n box-shadow: ${({ theme }) => theme.shadows[1]};\n\n @media (max-width: 767px) {\n padding: 16px;\n gap: 16px;\n }\n`;\n\nexport const MetricSection = styled(Box)`\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 16px 0;\n\n @media (max-width: 767px) {\n padding: 8px 0;\n }\n`;\n\nexport const MetricValue = styled(Typography)`\n font-size: 3rem;\n font-weight: 600;\n color: ${({ theme }) => theme.palette.text.primary};\n line-height: 1.2;\n\n @media (max-width: 767px) {\n font-size: 2.5rem;\n }\n`;\n\nexport const MetricTrend = styled(Box)<{ direction: 'up' | 'down' | 'neutral' }>`\n display: flex;\n align-items: center;\n gap: 4px;\n margin-top: 8px;\n font-size: 1.25rem;\n font-weight: 500;\n color: ${({ theme, direction }) => {\n if (direction === 'up') return theme.palette.success.main;\n if (direction === 'down') return theme.palette.error.main;\n return theme.palette.text.secondary;\n }};\n\n svg {\n font-size: 1.5rem;\n }\n\n @media (max-width: 767px) {\n font-size: 1rem;\n\n svg {\n font-size: 1.25rem;\n }\n }\n`;\n\nexport const ComparisonText = styled(Typography)`\n margin-top: 4px;\n font-size: 0.875rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n\n @media (max-width: 767px) {\n font-size: 0.8125rem;\n }\n`;\n\nexport const ChartSection = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 12px;\n padding: 0;\n\n @media (max-width: 767px) {\n gap: 8px;\n }\n`;\n\nexport const ChartTitle = styled(Typography)`\n font-size: 1.25rem;\n font-weight: 600;\n color: ${({ theme }) => theme.palette.text.primary};\n\n @media (max-width: 767px) {\n font-size: 1.125rem;\n }\n`;\n\nexport const ChartContainer = styled(Box)`\n width: 100%;\n height: 400px;\n\n @media (max-width: 767px) {\n height: 200px;\n }\n`;\n\nexport const TableSection = styled(Box)<{ withCard?: boolean }>`\n display: flex;\n flex-direction: column;\n gap: 16px;\n\n ${({ withCard = true, theme }) =>\n withCard &&\n `\n padding: 20px;\n background-color: ${getGenomeColor(theme, 'N20')};\n border-radius: 8px;\n box-shadow: ${theme.shadows[1]};\n\n @media (max-width: 767px) {\n padding: 16px;\n }\n `}\n`;\n\nexport const LoadingContainer = styled(Box)`\n display: flex;\n justify-content: center;\n align-items: center;\n min-height: 400px;\n`;\n\nexport const EmptyStateText = styled(Typography)`\n text-align: center;\n color: ${({ theme }) => theme.palette.text.secondary};\n font-size: 1rem;\n padding: 40px 20px;\n\n @media (max-width: 767px) {\n font-size: 0.875rem;\n padding: 32px 16px;\n }\n`;\n\nexport const MobileCardName = styled(Typography)`\n font-weight: 600;\n font-size: 14px;\n`;\n\nexport const MobileCardSubtext = styled(Typography)`\n font-size: 13px;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const MobileCardDetail = styled(Typography)`\n font-size: 13px;\n`;\n\nexport const MobileCardStatus = styled(Typography)<{ status: string }>`\n font-size: 13px;\n color: ${({ theme, status }) => (status === 'Active' ? theme.palette.success.main : theme.palette.warning.main)};\n`;\n","import { styled } from '@mui/material/styles';\nimport { Box, Typography } from '@mui/material';\nimport { ColorUtils } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const ProductImageCell = styled(Box)`\n display: flex;\n align-items: center;\n gap: 12px;\n`;\n\nexport const ProductImage = styled('img')`\n width: 40px;\n height: 40px;\n border-radius: 8px;\n object-fit: cover;\n`;\n\nexport const ProductInfo = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n`;\n\nexport const ProductName = styled(Typography)`\n font-size: 0.875rem;\n font-weight: 500;\n color: ${({ theme }) => theme.palette.text.primary};\n`;\n\nexport const ProductSku = styled(Typography)`\n font-size: 0.75rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const MetricValue = styled(Typography)`\n font-size: 0.875rem;\n font-weight: 500;\n`;\n\nexport const MobileCardsContainer = styled(Box)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`;\n\nexport const DesktopTableContainer = styled(Box)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`;\n\nexport const MobileProductCard = styled(Box)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => theme.palette.divider};\n border-radius: 8px;\n`;\n\nexport const MobileCardHeader = styled(Box)`\n display: flex;\n align-items: center;\n gap: 12px;\n flex: 1;\n`;\n\nexport const MobileProductRank = styled(Typography)`\n font-size: 1rem;\n font-weight: 700;\n color: ${({ theme }) => theme.palette.primary.main};\n min-width: 24px;\n`;\n\nexport const MobileProductImage = styled('img')`\n width: 48px;\n height: 48px;\n border-radius: 8px;\n object-fit: cover;\n`;\n\nexport const MobileProductDetails = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex: 1;\n`;\n\nexport const MobileProductName = styled(Typography)`\n font-size: 0.875rem;\n font-weight: 600;\n`;\n\nexport const MobileProductSku = styled(Typography)`\n font-size: 0.75rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const MobileMetricsGrid = styled(Box)`\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n gap: 8px;\n margin-top: 8px;\n padding-top: 8px;\n border-top: 1px solid ${({ theme }) => theme.palette.divider};\n`;\n\nexport const MobileMetricItem = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n text-align: center;\n`;\n\nexport const MobileMetricLabel = styled(Typography)`\n font-size: 0.625rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n text-transform: uppercase;\n`;\n\nexport const MobileMetricValue = styled(Typography)`\n font-size: 0.875rem;\n font-weight: 500;\n`;\n","import useMediaQuery from '@mui/material/useMediaQuery';\n\nexport const MOBILE_VIEWPORT_QUERY = '(max-width:767px)';\n\nexport function useIsMobileViewport(): boolean {\n return useMediaQuery(MOBILE_VIEWPORT_QUERY, { noSsr: true });\n}\n","import React, { useState } from 'react';\nimport { LineChart, Line, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer, Legend } from 'recharts';\nimport TrendingUpIcon from '@mui/icons-material/TrendingUp';\nimport TrendingDownIcon from '@mui/icons-material/TrendingDown';\nimport { PageHeader, type FilterConfig } from '../PageHeader';\nimport { DataTable, type ColumnDef } from '../DataTable';\nimport { Pagination } from '../Pagination';\nimport { paginateItems, calculateTotalPages } from '../../utils/dataUtils';\nimport { formatDateRangeLabel } from '../../utils/dateFormat';\nimport type {\n ConversionDataPoint,\n OrderHistory,\n DateRangeOption,\n MarketOption,\n ConversionFilterOption,\n} from '../../types.d';\nimport { FullViewChartSkeleton } from '../LoadingSkeletons';\nimport {\n PageContainer,\n MetricChartCardSection,\n MetricSection,\n MetricValue,\n MetricTrend,\n ChartSection,\n ChartTitle,\n ChartContainer,\n TableSection,\n} from '../FullViewComponents.styled';\nimport {\n MobileOrderCard,\n MobileOrderHeader,\n MobileCustomerInfo,\n MobileCustomerName,\n MobileOrderDate,\n MobileOrderId,\n MobileOrderMetrics,\n MobileMetricItem,\n MobileMetricLabel,\n MobileMetricValue,\n MobileOrdersContainer,\n DesktopTableContainer,\n ComparisonTextMobile,\n} from './ConversionRateFullView.styled';\nimport { useIsMobileViewport } from '../useViewport';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface ConversionRateFullViewProps {\n readonly conversionData: ConversionDataPoint[];\n readonly orders: OrderHistory[];\n readonly dateRange: DateRangeOption;\n readonly market: MarketOption;\n readonly conversionFilter: ConversionFilterOption;\n readonly isLoading?: boolean;\n readonly onBack?: () => void;\n readonly onDateRangeChange?: (range: DateRangeOption) => void;\n readonly onMarketChange?: (market: MarketOption) => void;\n readonly onConversionFilterChange?: (filter: ConversionFilterOption) => void;\n}\n\nexport const ConversionRateFullView: React.FC<ConversionRateFullViewProps> = ({\n conversionData,\n orders,\n dateRange,\n market,\n conversionFilter,\n isLoading = false,\n onBack,\n onDateRangeChange,\n onMarketChange,\n onConversionFilterChange,\n}) => {\n const [currentPage, setCurrentPage] = useState(1);\n const itemsPerPage = 10;\n const isMobileView = useIsMobileViewport();\n\n const handleBack = React.useCallback(() => onBack?.(), [onBack]);\n\n const currentRate = React.useMemo(() => {\n if (conversionData.length === 0) return 0;\n return conversionData[conversionData.length - 1]?.rate || 0;\n }, [conversionData]);\n\n const trend = React.useMemo((): { direction: 'up' | 'down' | 'neutral'; value: string } => {\n if (conversionData.length < 2) return { direction: 'neutral', value: getTranslation(Keys.defaults.zeroTrend) };\n const firstRate = conversionData[0].rate;\n const lastRate = conversionData[conversionData.length - 1]?.rate || 0;\n const change = ((lastRate - firstRate) / firstRate) * 100;\n let direction: 'up' | 'down' | 'neutral' = 'neutral';\n if (change > 0) direction = 'up';\n else if (change < 0) direction = 'down';\n return { direction, value: `${change >= 0 ? '+' : ''}${change.toFixed(1)}%` };\n }, [conversionData]);\n\n const getConversionFilterLabel = React.useCallback((filter: ConversionFilterOption): string => {\n if (filter === 'members') return getTranslation(Keys.filter.signupView.members);\n if (filter === 'retail') return getTranslation(Keys.filter.signupView.retail);\n if (filter === 'brandAffiliates') return getTranslation(Keys.filter.signupView.brandAffiliates);\n return getTranslation(Keys.filter.signupView.all);\n }, []);\n\n const conversionFilterLabel = React.useMemo(\n () => getConversionFilterLabel(conversionFilter),\n [conversionFilter, getConversionFilterLabel],\n );\n\n const filters: FilterConfig[] = React.useMemo(\n () => [\n {\n key: 'dateRange',\n label: getTranslation(Keys.filter.dateRange.label),\n value: dateRange,\n icon: 'calendar',\n options: [\n { value: 'last7days', label: getTranslation(Keys.filter.dateRange.last7days) },\n { value: 'last30days', label: getTranslation(Keys.filter.dateRange.last30days) },\n { value: 'last90days', label: getTranslation(Keys.filter.dateRange.last90days) },\n { value: 'thisMonth', label: getTranslation(Keys.filter.dateRange.thisMonth) },\n ],\n },\n {\n key: 'market',\n label: getTranslation(Keys.filter.market.label),\n value: market,\n icon: 'globe',\n options: [\n { value: 'all', label: getTranslation(Keys.filter.market.all) },\n { value: 'us', label: getTranslation(Keys.filter.market.us) },\n { value: 'ca', label: getTranslation(Keys.filter.market.ca) },\n { value: 'jp', label: getTranslation(Keys.filter.market.jp) },\n { value: 'kr', label: getTranslation(Keys.filter.market.kr) },\n { value: 'au', label: getTranslation(Keys.filter.market.au) },\n { value: 'nz', label: getTranslation(Keys.filter.market.nz) },\n ],\n },\n {\n key: 'customerType',\n label: getTranslation(Keys.filter.signupView.label),\n value: conversionFilter,\n options: [\n { value: 'all', label: getTranslation(Keys.filter.signupView.all) },\n { value: 'members', label: getTranslation(Keys.filter.signupView.members) },\n { value: 'retail', label: getTranslation(Keys.filter.signupView.retail) },\n ],\n },\n ],\n [conversionFilter, dateRange, market],\n );\n\n const handleFilterChange = React.useCallback(\n (key: string, value: string) => {\n if (key === 'dateRange') onDateRangeChange?.(value as DateRangeOption);\n else if (key === 'market') onMarketChange?.(value as MarketOption);\n else if (key === 'customerType') {\n onConversionFilterChange?.(value as ConversionFilterOption);\n setCurrentPage(1);\n }\n },\n [onConversionFilterChange, onDateRangeChange, onMarketChange],\n );\n\n const totalPages = React.useMemo(() => calculateTotalPages(orders, itemsPerPage), [itemsPerPage, orders]);\n const paginatedOrders = React.useMemo(\n () => paginateItems(orders, currentPage, itemsPerPage),\n [currentPage, itemsPerPage, orders],\n );\n\n const columns: ColumnDef<OrderHistory>[] = React.useMemo(\n () => [\n { key: 'orderId', label: getTranslation(Keys.fullView.conversionRate.columns.orderId), sortable: true },\n { key: 'date', label: getTranslation(Keys.fullView.conversionRate.columns.date), sortable: true },\n {\n key: 'customerName',\n label: getTranslation(Keys.fullView.conversionRate.columns.customer),\n sortable: true,\n },\n { key: 'customerType', label: getTranslation(Keys.fullView.conversionRate.columns.type), sortable: true },\n { key: 'items', label: getTranslation(Keys.fullView.conversionRate.columns.items), sortable: true },\n {\n key: 'total',\n label: getTranslation(Keys.fullView.conversionRate.columns.total),\n sortable: true,\n render: (value: unknown) => `$${Number(value).toFixed(2)}`,\n },\n { key: 'bv', label: getTranslation(Keys.fullView.conversionRate.columns.bv), sortable: true },\n ],\n [],\n );\n\n const getChartColor = React.useCallback(() => {\n if (conversionFilter === 'members') return '#2e7d32';\n if (conversionFilter === 'retail') return '#ed6c02';\n return '#1976d2';\n }, [conversionFilter]);\n\n if (isLoading) {\n return (\n <PageContainer data-testid=\"conversion-rate-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.conversionRate.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n <FullViewChartSkeleton />\n </PageContainer>\n );\n }\n\n return (\n <PageContainer data-testid=\"conversion-rate-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.conversionRate.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n\n <MetricChartCardSection data-testid=\"conversion-fullview-metric-chart\">\n <MetricSection>\n <MetricValue data-testid=\"conversion-rate-value\">{currentRate.toFixed(1)}%</MetricValue>\n <MetricTrend direction={trend.direction} data-testid=\"conversion-rate-trend\">\n {trend.direction === 'up' && <TrendingUpIcon />}\n {trend.direction === 'down' && <TrendingDownIcon />}\n {trend.value}\n </MetricTrend>\n <ComparisonTextMobile>\n {getTranslation(Keys.widget.conversionRate.ordersPerSiteVisits)}\n </ComparisonTextMobile>\n </MetricSection>\n\n <ChartSection>\n <ChartContainer data-testid=\"conversion-fullview-chart\">\n <ResponsiveContainer width=\"100%\" height=\"100%\">\n <LineChart data={conversionData}>\n <CartesianGrid strokeDasharray=\"3 3\" />\n <XAxis dataKey=\"date\" />\n <YAxis tickFormatter={(value) => `${value}%`} domain={[0, 'auto']} />\n <Tooltip\n formatter={(value: unknown) => {\n if (typeof value === 'number') return `${value.toFixed(2)}%`;\n if (typeof value === 'string') return value;\n return getTranslation(Keys.fullView.conversionRate.notAvailable);\n }}\n />\n <Legend />\n <Line\n type=\"monotone\"\n dataKey=\"rate\"\n stroke={getChartColor()}\n strokeWidth={2}\n name={`${getTranslation(Keys.widget.conversionRate.title)} (${conversionFilterLabel})`}\n dot={false}\n />\n </LineChart>\n </ResponsiveContainer>\n </ChartContainer>\n </ChartSection>\n </MetricChartCardSection>\n\n <TableSection data-testid=\"conversion-fullview-table-section\">\n <ChartTitle data-testid=\"conversion-fullview-table-title\">\n {getTranslation(Keys.fullView.conversionRate.orderDetailsTitle)} ({orders.length})\n </ChartTitle>\n {!isMobileView ? (\n <DesktopTableContainer data-testid=\"conversion-fullview-desktop-table\">\n <DataTable\n columns={columns}\n data={paginatedOrders}\n sortable\n getRowKey={(row: OrderHistory) => row.orderId}\n />\n </DesktopTableContainer>\n ) : (\n <MobileOrdersContainer data-testid=\"conversion-fullview-mobile-orders\">\n {paginatedOrders.map((order) => (\n <MobileOrderCard key={order.orderId}>\n <MobileOrderHeader>\n <MobileCustomerInfo>\n <MobileCustomerName>{order.customerName}</MobileCustomerName>\n <MobileOrderDate>{order.date}</MobileOrderDate>\n </MobileCustomerInfo>\n <MobileOrderId>{order.orderId}</MobileOrderId>\n </MobileOrderHeader>\n <MobileOrderMetrics>\n <MobileMetricItem>\n <MobileMetricLabel>\n {getTranslation(Keys.fullView.conversionRate.columns.items)}\n </MobileMetricLabel>\n <MobileMetricValue>{order.items}</MobileMetricValue>\n </MobileMetricItem>\n <MobileMetricItem>\n <MobileMetricLabel>\n {getTranslation(Keys.fullView.conversionRate.columns.orderTotal)}\n </MobileMetricLabel>\n <MobileMetricValue>${order.total.toFixed(2)}</MobileMetricValue>\n </MobileMetricItem>\n <MobileMetricItem>\n <MobileMetricLabel>\n {getTranslation(Keys.fullView.conversionRate.columns.totalSv)}\n </MobileMetricLabel>\n <MobileMetricValue>{order.bv}</MobileMetricValue>\n </MobileMetricItem>\n </MobileOrderMetrics>\n </MobileOrderCard>\n ))}\n </MobileOrdersContainer>\n )}\n {totalPages > 1 && (\n <Pagination\n currentPage={currentPage}\n totalPages={totalPages}\n onPageChange={setCurrentPage}\n itemsPerPage={itemsPerPage}\n totalItems={orders.length}\n />\n )}\n </TableSection>\n </PageContainer>\n );\n};\n","import { styled } from '@mui/material/styles';\nimport { Box, Typography } from '@mui/material';\nimport { ColorUtils } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const MobileOrderCard = styled(Box)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => theme.palette.divider};\n border-radius: 8px;\n }\n`;\n\nexport const MobileOrderHeader = styled(Box)`\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n`;\n\nexport const MobileCustomerInfo = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 4px;\n`;\n\nexport const MobileCustomerName = styled(Typography)`\n font-size: 1rem;\n font-weight: 600;\n`;\n\nexport const MobileOrderDate = styled(Typography)`\n font-size: 0.875rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const MobileOrderId = styled('a')`\n font-size: 0.875rem;\n color: ${({ theme }) => theme.palette.primary.main};\n text-decoration: none;\n cursor: pointer;\n &:hover {\n text-decoration: underline;\n }\n`;\n\nexport const MobileOrderMetrics = styled(Box)`\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n gap: 16px;\n padding-top: 12px;\n border-top: 1px solid ${({ theme }) => theme.palette.divider};\n`;\n\nexport const MobileMetricItem = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 4px;\n text-align: center;\n`;\n\nexport const MobileMetricLabel = styled(Typography)`\n font-size: 0.75rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const MobileMetricValue = styled(Typography)`\n font-size: 0.875rem;\n font-weight: 500;\n`;\n\nexport const MobileOrdersContainer = styled(Box)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`;\n\nexport const DesktopTableContainer = styled(Box)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`;\n\nexport const ComparisonTextMobile = styled(Typography)`\n margin-top: 4px;\n font-size: 0.875rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n @media (max-width: 767px) {\n font-size: 0.75rem;\n }\n`;\n","import React, { useState } from 'react';\nimport { LineChart, Line, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer, Legend } from 'recharts';\nimport TrendingUpIcon from '@mui/icons-material/TrendingUp';\nimport TrendingDownIcon from '@mui/icons-material/TrendingDown';\nimport { PageHeader, type FilterConfig } from '../PageHeader';\nimport { DataTable, type ColumnDef } from '../DataTable';\nimport { Pagination } from '../Pagination';\nimport { paginateItems, calculateTotalPages } from '../../utils/dataUtils';\nimport { formatDateRangeLabel } from '../../utils/dateFormat';\nimport type { SignupDataPoint, SignupDetail, DateRangeOption, MarketOption, SignupViewOption } from '../../types.d';\nimport { FullViewChartSkeleton } from '../LoadingSkeletons';\nimport {\n PageContainer,\n MetricChartCardSection,\n MetricSection,\n MetricValue,\n MetricTrend,\n ChartSection,\n ChartTitle,\n TableSection,\n EmptyStateText,\n MobileCardName,\n MobileCardSubtext,\n MobileCardDetail,\n MobileCardStatus,\n} from '../FullViewComponents.styled';\nimport {\n MobileSignupsContainer,\n DesktopTableContainer,\n MobileSignupCard,\n SignupTrendChartContainer,\n ComparisonTextMobile,\n} from './SignupsFullView.styled';\nimport { useIsMobileViewport } from '../useViewport';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nconst SERIES_COLORS = { total: '#3B82F6', members: '#7B92A8', retail: '#A3B5C7', brandAffiliates: '#5F7388' };\n\nfunction toNumeric(value: unknown): number {\n if (typeof value === 'number') {\n return Number.isFinite(value) ? value : 0;\n }\n\n if (typeof value === 'string') {\n const parsed = Number(value.replace(/,/g, ''));\n return Number.isFinite(parsed) ? parsed : 0;\n }\n\n return 0;\n}\n\nexport interface SignupsFullViewProps {\n readonly signupData: SignupDataPoint[];\n readonly signups: SignupDetail[];\n readonly dateRange: DateRangeOption;\n readonly market: MarketOption;\n readonly signupView: SignupViewOption;\n readonly isLoading?: boolean;\n readonly onBack?: () => void;\n readonly onDateRangeChange?: (range: DateRangeOption) => void;\n readonly onMarketChange?: (market: MarketOption) => void;\n readonly onSignupViewChange?: (view: SignupViewOption) => void;\n}\n\nexport const SignupsFullView: React.FC<SignupsFullViewProps> = ({\n signupData,\n signups,\n dateRange,\n market,\n signupView,\n isLoading = false,\n onBack,\n onDateRangeChange,\n onMarketChange,\n onSignupViewChange,\n}) => {\n const [currentPage, setCurrentPage] = useState(1);\n const itemsPerPage = 10;\n const isMobileView = useIsMobileViewport();\n\n const handleBack = React.useCallback(() => onBack?.(), [onBack]);\n\n const normalizedSignupData = React.useMemo(\n () =>\n signupData.map((point) => {\n const rawPoint = point as unknown as Record<string, unknown>;\n const members = toNumeric(rawPoint.members);\n const retail = toNumeric(rawPoint.retail);\n const brandAffiliates = toNumeric(\n rawPoint.brandAffiliates ??\n rawPoint.brandAffiliate ??\n rawPoint.brand_affiliates ??\n rawPoint.brand_affiliate,\n );\n const total = toNumeric(rawPoint.total ?? rawPoint.all ?? rawPoint.signupTotal ?? rawPoint.value);\n\n return {\n ...point,\n total: total > 0 ? total : members + retail + brandAffiliates,\n members,\n retail,\n brandAffiliates,\n };\n }),\n [signupData],\n );\n\n const totalSignups = React.useMemo(() => {\n if (normalizedSignupData.length === 0) return 0;\n return normalizedSignupData[normalizedSignupData.length - 1].total;\n }, [normalizedSignupData]);\n\n const trend = React.useMemo((): { direction: 'up' | 'down' | 'neutral'; value: string } => {\n if (normalizedSignupData.length < 2)\n return { direction: 'neutral', value: getTranslation(Keys.defaults.zeroTrend) };\n const first = normalizedSignupData[0].total;\n const last = normalizedSignupData[normalizedSignupData.length - 1].total;\n if (first <= 0) return { direction: 'neutral', value: getTranslation(Keys.defaults.zeroTrend) };\n const change = ((last - first) / first) * 100;\n let direction: 'up' | 'down' | 'neutral' = 'neutral';\n if (change > 0) direction = 'up';\n else if (change < 0) direction = 'down';\n return { direction, value: `${change >= 0 ? '+' : ''}${change.toFixed(1)}%` };\n }, [normalizedSignupData]);\n\n const hasSignupTrendData = normalizedSignupData.length > 0;\n\n const filters: FilterConfig[] = React.useMemo(\n () => [\n {\n key: 'dateRange',\n label: getTranslation(Keys.filter.dateRange.label),\n value: dateRange,\n icon: 'calendar',\n options: [\n { value: 'last7days', label: getTranslation(Keys.filter.dateRange.last7days) },\n { value: 'last30days', label: getTranslation(Keys.filter.dateRange.last30days) },\n { value: 'last90days', label: getTranslation(Keys.filter.dateRange.last90days) },\n { value: 'thisMonth', label: getTranslation(Keys.filter.dateRange.thisMonth) },\n ],\n },\n {\n key: 'market',\n label: getTranslation(Keys.filter.market.label),\n value: market,\n icon: 'globe',\n options: [\n { value: 'all', label: getTranslation(Keys.filter.market.all) },\n { value: 'us', label: getTranslation(Keys.filter.market.us) },\n { value: 'ca', label: getTranslation(Keys.filter.market.ca) },\n { value: 'jp', label: getTranslation(Keys.filter.market.jp) },\n { value: 'kr', label: getTranslation(Keys.filter.market.kr) },\n { value: 'au', label: getTranslation(Keys.filter.market.au) },\n { value: 'nz', label: getTranslation(Keys.filter.market.nz) },\n ],\n },\n {\n key: 'signupView',\n label: getTranslation(Keys.filter.signupView.label),\n value: signupView,\n options: [\n { value: 'all', label: getTranslation(Keys.filter.signupView.all) },\n { value: 'members', label: getTranslation(Keys.filter.signupView.members) },\n { value: 'retail', label: getTranslation(Keys.filter.signupView.retail) },\n { value: 'brandAffiliates', label: getTranslation(Keys.filter.signupView.brandAffiliates) },\n ],\n },\n ],\n [dateRange, market, signupView],\n );\n\n const handleFilterChange = React.useCallback(\n (key: string, value: string) => {\n if (key === 'dateRange') onDateRangeChange?.(value as DateRangeOption);\n else if (key === 'market') onMarketChange?.(value as MarketOption);\n else if (key === 'signupView') {\n onSignupViewChange?.(value as SignupViewOption);\n setCurrentPage(1);\n }\n },\n [onDateRangeChange, onMarketChange, onSignupViewChange],\n );\n\n const totalPages = React.useMemo(() => calculateTotalPages(signups, itemsPerPage), [signups, itemsPerPage]);\n const paginatedSignups = React.useMemo(\n () => paginateItems(signups, currentPage, itemsPerPage),\n [currentPage, itemsPerPage, signups],\n );\n\n const columns: ColumnDef<SignupDetail>[] = React.useMemo(\n () => [\n { key: 'id', label: getTranslation(Keys.fullView.signups.columns.id), sortable: true },\n { key: 'name', label: getTranslation(Keys.fullView.signups.columns.name), sortable: true },\n { key: 'date', label: getTranslation(Keys.fullView.signups.columns.date), sortable: true },\n { key: 'type', label: getTranslation(Keys.fullView.signups.columns.type), sortable: true },\n { key: 'email', label: getTranslation(Keys.fullView.signups.columns.email), sortable: true },\n { key: 'status', label: getTranslation(Keys.fullView.signups.columns.status), sortable: true },\n ],\n [],\n );\n\n if (isLoading) {\n return (\n <PageContainer data-testid=\"signups-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.signups.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n <FullViewChartSkeleton />\n </PageContainer>\n );\n }\n\n return (\n <PageContainer data-testid=\"signups-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.signups.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n\n <MetricChartCardSection data-testid=\"signups-fullview-metric-chart\">\n <MetricSection>\n <MetricValue data-testid=\"signups-total\">{totalSignups.toLocaleString()}</MetricValue>\n <MetricTrend direction={trend.direction}>\n {trend.direction === 'up' && <TrendingUpIcon />}\n {trend.direction === 'down' && <TrendingDownIcon />}\n {trend.value}\n </MetricTrend>\n <ComparisonTextMobile>\n {getTranslation(Keys.widget.signups.totalSignupsInPeriod)}\n </ComparisonTextMobile>\n </MetricSection>\n\n <ChartSection>\n {hasSignupTrendData ? (\n <SignupTrendChartContainer data-testid=\"signups-fullview-chart\">\n <ResponsiveContainer width=\"100%\" height=\"100%\" minHeight={240}>\n <LineChart data={normalizedSignupData}>\n <CartesianGrid strokeDasharray=\"3 3\" />\n <XAxis dataKey=\"date\" />\n <YAxis />\n <Tooltip />\n <Legend />\n {signupView === 'all' && (\n <>\n <Line\n type=\"monotone\"\n dataKey=\"total\"\n stroke={SERIES_COLORS.total}\n strokeWidth={2}\n name={getTranslation(Keys.widget.signups.total)}\n dot={{ r: 2 }}\n connectNulls\n />\n <Line\n type=\"monotone\"\n dataKey=\"members\"\n stroke={SERIES_COLORS.members}\n strokeWidth={2}\n name={getTranslation(Keys.widget.signups.members)}\n dot={{ r: 2 }}\n connectNulls\n />\n <Line\n type=\"monotone\"\n dataKey=\"retail\"\n stroke={SERIES_COLORS.retail}\n strokeWidth={2}\n name={getTranslation(Keys.widget.signups.retail)}\n dot={{ r: 2 }}\n connectNulls\n />\n <Line\n type=\"monotone\"\n dataKey=\"brandAffiliates\"\n stroke={SERIES_COLORS.brandAffiliates}\n strokeWidth={2}\n name={getTranslation(Keys.widget.signups.brandAffiliates)}\n dot={{ r: 2 }}\n connectNulls\n />\n </>\n )}\n {signupView === 'members' && (\n <Line\n type=\"monotone\"\n dataKey=\"members\"\n stroke={SERIES_COLORS.members}\n strokeWidth={2}\n name={getTranslation(Keys.widget.signups.members)}\n dot={{ r: 2 }}\n connectNulls\n />\n )}\n {signupView === 'retail' && (\n <Line\n type=\"monotone\"\n dataKey=\"retail\"\n stroke={SERIES_COLORS.retail}\n strokeWidth={2}\n name={getTranslation(Keys.widget.signups.retail)}\n dot={{ r: 2 }}\n connectNulls\n />\n )}\n {signupView === 'brandAffiliates' && (\n <Line\n type=\"monotone\"\n dataKey=\"brandAffiliates\"\n stroke={SERIES_COLORS.brandAffiliates}\n strokeWidth={2}\n name={getTranslation(Keys.widget.signups.brandAffiliates)}\n dot={{ r: 2 }}\n connectNulls\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n </SignupTrendChartContainer>\n ) : (\n <EmptyStateText data-testid=\"signups-fullview-chart-empty\">\n {getTranslation(Keys.widget.signups.noTrendData)}\n </EmptyStateText>\n )}\n </ChartSection>\n </MetricChartCardSection>\n\n <TableSection data-testid=\"signups-fullview-table-section\">\n <ChartTitle data-testid=\"signups-fullview-table-title\">{`${getTranslation(Keys.fullView.signups.detailsTitle)} (${signups.length})`}</ChartTitle>\n {!isMobileView ? (\n <DesktopTableContainer data-testid=\"signups-fullview-desktop-table\">\n <DataTable\n columns={columns}\n data={paginatedSignups}\n sortable\n getRowKey={(row: SignupDetail) => row.id}\n />\n </DesktopTableContainer>\n ) : (\n <MobileSignupsContainer data-testid=\"signups-fullview-mobile-cards\">\n {paginatedSignups.map((signup) => (\n <MobileSignupCard key={signup.id}>\n <MobileCardName>{signup.name}</MobileCardName>\n <MobileCardSubtext>\n {signup.date} - {signup.type}\n </MobileCardSubtext>\n <MobileCardDetail>{signup.email}</MobileCardDetail>\n <MobileCardStatus status={signup.status}>{signup.status}</MobileCardStatus>\n </MobileSignupCard>\n ))}\n </MobileSignupsContainer>\n )}\n {totalPages > 1 && (\n <Pagination\n currentPage={currentPage}\n totalPages={totalPages}\n onPageChange={setCurrentPage}\n itemsPerPage={itemsPerPage}\n totalItems={signups.length}\n />\n )}\n </TableSection>\n </PageContainer>\n );\n};\n","import { styled } from '@mui/material/styles';\nimport { Box, Typography } from '@mui/material';\nimport { ColorUtils } from '@nuskin/foundation-theme';\nimport { ChartContainer } from '../FullViewComponents.styled';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const MobileSignupsContainer = styled(Box)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`;\n\nexport const DesktopTableContainer = styled(Box)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`;\n\nexport const MobileSignupCard = styled(Box)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 8px;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => theme.palette.divider};\n border-radius: 8px;\n }\n`;\n\nexport const SignupTrendChartContainer = styled(ChartContainer)`\n min-height: 320px;\n\n @media (max-width: 767px) {\n min-height: 260px;\n height: 260px;\n }\n`;\n\nexport const ComparisonTextMobile = styled(Typography)`\n margin-top: 4px;\n font-size: 0.875rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n","import React, { useState } from 'react';\nimport { PieChart, Pie, Cell, ResponsiveContainer, Tooltip } from 'recharts';\nimport { PageHeader, type FilterConfig } from '../PageHeader';\nimport { DataTable, type ColumnDef } from '../DataTable';\nimport { Pagination } from '../Pagination';\nimport { paginateItems, calculateTotalPages } from '../../utils/dataUtils';\nimport { formatDateRangeLabel } from '../../utils/dateFormat';\nimport type { CategoryRevenue, DateRangeOption, MarketOption, CategorySortOption } from '../../types.d';\nimport { FullViewChartSkeleton } from '../LoadingSkeletons';\nimport { PageContainer, TableSection, ChartTitle, EmptyStateText } from '../FullViewComponents.styled';\nimport {\n SummaryItemRow,\n SummaryItemInfo,\n SummaryItemName,\n SummaryItemSubtext,\n SummaryItemPercentage,\n TopSection,\n ChartWrapper,\n DonutCenterOverlay,\n DonutCenterLabel,\n DonutCenterValue,\n DonutCenterTrend,\n SummaryContainer,\n SummaryItem,\n ColorDot,\n SummaryInfo,\n SummaryName,\n SummaryValue,\n SummaryPercentage,\n DesktopTableContainer,\n MobileCategoriesContainer,\n MobileCategoryCard,\n} from './CategoriesFullView.styled';\nimport { useIsMobileViewport } from '../useViewport';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface CategoriesFullViewProps {\n readonly categories: CategoryRevenue[];\n readonly dateRange: DateRangeOption;\n readonly market: MarketOption;\n readonly categorySort: CategorySortOption;\n readonly isLoading?: boolean;\n readonly onBack?: () => void;\n readonly onDateRangeChange?: (range: DateRangeOption) => void;\n readonly onMarketChange?: (market: MarketOption) => void;\n readonly onCategorySortChange?: (sort: CategorySortOption) => void;\n}\n\nfunction parseTrendPercent(value?: string): number | null {\n if (!value) return null;\n const cleanedValue = value.replace('%', '').trim();\n const parsedValue = Number(cleanedValue);\n return Number.isFinite(parsedValue) ? parsedValue : null;\n}\n\nexport const CategoriesFullView: React.FC<CategoriesFullViewProps> = ({\n categories,\n dateRange,\n market,\n categorySort,\n isLoading = false,\n onBack,\n onDateRangeChange,\n onMarketChange,\n onCategorySortChange,\n}) => {\n const [currentPage, setCurrentPage] = useState(1);\n const itemsPerPage = 10;\n const isMobileView = useIsMobileViewport();\n\n const handleBack = React.useCallback(() => onBack?.(), [onBack]);\n\n const filters: FilterConfig[] = React.useMemo(\n () => [\n {\n key: 'dateRange',\n label: getTranslation(Keys.filter.dateRange.label),\n value: dateRange,\n icon: 'calendar',\n options: [\n { value: 'last7days', label: getTranslation(Keys.filter.dateRange.last7days) },\n { value: 'last30days', label: getTranslation(Keys.filter.dateRange.last30days) },\n { value: 'last90days', label: getTranslation(Keys.filter.dateRange.last90days) },\n { value: 'thisMonth', label: getTranslation(Keys.filter.dateRange.thisMonth) },\n ],\n },\n {\n key: 'market',\n label: getTranslation(Keys.filter.market.label),\n value: market,\n icon: 'globe',\n options: [\n { value: 'all', label: getTranslation(Keys.filter.market.all) },\n { value: 'us', label: getTranslation(Keys.filter.market.us) },\n { value: 'ca', label: getTranslation(Keys.filter.market.ca) },\n { value: 'jp', label: getTranslation(Keys.filter.market.jp) },\n { value: 'kr', label: getTranslation(Keys.filter.market.kr) },\n { value: 'au', label: getTranslation(Keys.filter.market.au) },\n { value: 'nz', label: getTranslation(Keys.filter.market.nz) },\n ],\n },\n {\n key: 'sort',\n label: getTranslation(Keys.filter.productSort.label),\n value: categorySort,\n options: [\n { value: 'revenue', label: getTranslation(Keys.filter.productSort.revenue) },\n { value: 'units', label: getTranslation(Keys.filter.productSort.units) },\n ],\n },\n ],\n [categorySort, dateRange, market],\n );\n\n const handleFilterChange = React.useCallback(\n (key: string, value: string) => {\n if (key === 'dateRange') onDateRangeChange?.(value as DateRangeOption);\n else if (key === 'market') onMarketChange?.(value as MarketOption);\n else if (key === 'sort') {\n onCategorySortChange?.(value as CategorySortOption);\n setCurrentPage(1);\n }\n },\n [onCategorySortChange, onDateRangeChange, onMarketChange],\n );\n\n const sortedCategories = React.useMemo(\n () =>\n [...categories].sort((a, b) => {\n if (categorySort === 'revenue') return b.revenue - a.revenue;\n return b.percentage - a.percentage;\n }),\n [categories, categorySort],\n );\n\n const { totalRevenue, totalRevenueTrendDirection, totalRevenueTrend } = React.useMemo(() => {\n const nextTotalRevenue = sortedCategories.reduce((sum, category) => sum + category.revenue, 0);\n\n const weightedRevenueTrend = sortedCategories.reduce(\n (accumulator, category) => {\n const trendValue = parseTrendPercent(category.trend?.revenue);\n if (trendValue === null) return accumulator;\n\n return {\n weightedSum: accumulator.weightedSum + trendValue * category.revenue,\n weight: accumulator.weight + category.revenue,\n };\n },\n { weightedSum: 0, weight: 0 },\n );\n\n const averageRevenueTrend =\n weightedRevenueTrend.weight > 0 ? weightedRevenueTrend.weightedSum / weightedRevenueTrend.weight : 0;\n\n let direction: 'up' | 'down' | 'neutral' = 'neutral';\n if (averageRevenueTrend > 0) direction = 'up';\n else if (averageRevenueTrend < 0) direction = 'down';\n\n const sign = averageRevenueTrend > 0 ? '+' : '';\n const trend = `${sign}${averageRevenueTrend.toFixed(1)}%`;\n\n return {\n totalRevenue: nextTotalRevenue,\n totalRevenueTrendDirection: direction,\n totalRevenueTrend: trend,\n };\n }, [sortedCategories]);\n\n const topCategories = React.useMemo(() => sortedCategories.slice(0, 5), [sortedCategories]);\n\n const totalPages = React.useMemo(\n () => calculateTotalPages(sortedCategories, itemsPerPage),\n [itemsPerPage, sortedCategories],\n );\n const paginatedCategories = React.useMemo(\n () => paginateItems(sortedCategories, currentPage, itemsPerPage),\n [currentPage, itemsPerPage, sortedCategories],\n );\n\n const columns: ColumnDef<CategoryRevenue>[] = React.useMemo(\n () => [\n {\n key: 'name',\n label: getTranslation(Keys.fullView.categories.columns.category),\n sortable: true,\n render: (_: unknown, row: CategoryRevenue) => (\n <SummaryItemRow>\n <ColorDot dotColor={row.color} />\n <span>{row.name}</span>\n </SummaryItemRow>\n ),\n },\n {\n key: 'revenue',\n label: getTranslation(Keys.fullView.categories.columns.revenue),\n sortable: true,\n render: (value: unknown) => `$${Number(value).toLocaleString()}`,\n },\n {\n key: 'percentage',\n label: getTranslation(Keys.fullView.categories.columns.percentOfTotal),\n sortable: true,\n render: (value: unknown) => `${Number(value)}%`,\n },\n {\n key: 'trend',\n label: getTranslation(Keys.fullView.categories.columns.trend),\n render: (_: unknown, row: CategoryRevenue) =>\n row.trend?.revenue ?? getTranslation(Keys.defaults.noValue),\n },\n ],\n [],\n );\n\n if (isLoading) {\n return (\n <PageContainer data-testid=\"categories-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.topCategories.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n <FullViewChartSkeleton />\n </PageContainer>\n );\n }\n\n if (categories.length === 0) {\n return (\n <PageContainer data-testid=\"categories-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.topCategories.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n <EmptyStateText data-testid=\"categories-fullview-empty\">\n {getTranslation(Keys.fullView.categories.noCategoryData)}\n </EmptyStateText>\n </PageContainer>\n );\n }\n\n return (\n <PageContainer data-testid=\"categories-full-view\">\n <PageHeader\n title={getTranslation(Keys.widget.topCategories.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n\n <TopSection data-testid=\"categories-fullview-top-section\">\n <ChartWrapper data-testid=\"categories-fullview-chart\">\n <ResponsiveContainer width=\"100%\" height=\"100%\">\n <PieChart>\n <Pie\n data={sortedCategories}\n cx=\"50%\"\n cy=\"50%\"\n innerRadius=\"50%\"\n outerRadius=\"85%\"\n dataKey=\"revenue\"\n nameKey=\"name\"\n paddingAngle={2}\n >\n {sortedCategories.map((entry) => (\n <Cell key={`cell-${entry.id}`} fill={entry.color} />\n ))}\n </Pie>\n <Tooltip formatter={(value: number) => `$${value.toLocaleString()}`} />\n </PieChart>\n </ResponsiveContainer>\n <DonutCenterOverlay data-testid=\"categories-fullview-donut-center\">\n <DonutCenterLabel>{getTranslation(Keys.stats.revenue)}</DonutCenterLabel>\n <DonutCenterValue>${totalRevenue.toLocaleString()}</DonutCenterValue>\n <DonutCenterTrend direction={totalRevenueTrendDirection}>{totalRevenueTrend}</DonutCenterTrend>\n </DonutCenterOverlay>\n </ChartWrapper>\n\n <SummaryContainer data-testid=\"categories-fullview-summary\">\n {topCategories.map((category) => (\n <SummaryItem key={category.id}>\n <ColorDot dotColor={category.color} />\n <SummaryInfo>\n <SummaryName>{category.name}</SummaryName>\n <SummaryValue>${category.revenue.toLocaleString()}</SummaryValue>\n </SummaryInfo>\n <SummaryPercentage>{category.percentage}%</SummaryPercentage>\n </SummaryItem>\n ))}\n </SummaryContainer>\n </TopSection>\n\n <TableSection data-testid=\"categories-fullview-table-section\">\n <ChartTitle data-testid=\"categories-fullview-table-title\">\n {getTranslation(Keys.fullView.categories.allCategoriesTitle)} ({sortedCategories.length})\n </ChartTitle>\n {!isMobileView ? (\n <DesktopTableContainer>\n <DataTable\n columns={columns}\n data={paginatedCategories}\n sortable\n getRowKey={(row: CategoryRevenue) => row.id}\n />\n </DesktopTableContainer>\n ) : (\n <MobileCategoriesContainer>\n {paginatedCategories.map((category) => (\n <MobileCategoryCard key={category.id}>\n <ColorDot dotColor={category.color} />\n <SummaryItemInfo>\n <SummaryItemName>{category.name}</SummaryItemName>\n <SummaryItemSubtext>${category.revenue.toLocaleString()}</SummaryItemSubtext>\n </SummaryItemInfo>\n <SummaryItemPercentage>{category.percentage}%</SummaryItemPercentage>\n </MobileCategoryCard>\n ))}\n </MobileCategoriesContainer>\n )}\n {totalPages > 1 && (\n <Pagination\n currentPage={currentPage}\n totalPages={totalPages}\n onPageChange={setCurrentPage}\n itemsPerPage={itemsPerPage}\n totalItems={sortedCategories.length}\n />\n )}\n </TableSection>\n </PageContainer>\n );\n};\n","import { styled } from '@nuskin/foundation-theme';\nimport { styled as muiStyled } from '@mui/material/styles';\nimport { Box, Typography } from '@mui/material';\nimport { ColorUtils } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const SummaryItemRow = styled('div')`\n display: flex;\n align-items: center;\n gap: 8px;\n`;\n\nexport const SummaryItemInfo = styled('div')`\n flex: 1;\n`;\n\nexport const SummaryItemName = styled('span')`\n font-weight: 600;\n`;\n\nexport const SummaryItemSubtext = styled('span')`\n font-size: 0.875rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const SummaryItemPercentage = styled('span')`\n font-weight: 600;\n`;\n\nexport const TopSection = muiStyled(Box)`\n display: flex;\n gap: 24px;\n padding: 24px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border-radius: 8px;\n box-shadow: ${({ theme }) => theme.shadows[1]};\n\n @media (max-width: 767px) {\n flex-direction: column;\n padding: 16px;\n gap: 16px;\n }\n`;\n\nexport const ChartWrapper = muiStyled(Box)`\n position: relative;\n width: 280px;\n height: 280px;\n flex-shrink: 0;\n\n @media (max-width: 767px) {\n width: 100%;\n height: 220px;\n }\n`;\n\nexport const DonutCenterOverlay = muiStyled(Box)`\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n pointer-events: none;\n z-index: 1;\n width: 120px;\n`;\n\nexport const DonutCenterLabel = muiStyled(Typography)`\n font-size: 0.75rem;\n line-height: 1.2;\n font-weight: 500;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const DonutCenterValue = muiStyled(Typography)`\n margin-top: 2px;\n font-size: 1.25rem;\n line-height: 1.2;\n font-weight: 700;\n color: ${({ theme }) => theme.palette.text.primary};\n`;\n\nexport const DonutCenterTrend = muiStyled(Typography)<{ direction: 'up' | 'down' | 'neutral' }>`\n margin-top: 2px;\n font-size: 0.875rem;\n line-height: 1.2;\n font-weight: 600;\n color: ${({ direction, theme }) => {\n if (direction === 'up') return theme.palette.success.main;\n if (direction === 'down') return theme.palette.error.main;\n return theme.palette.text.secondary;\n }};\n`;\n\nexport const SummaryContainer = muiStyled(Box)`\n display: flex;\n flex-direction: column;\n gap: 12px;\n flex: 1;\n`;\n\nexport const SummaryItem = muiStyled(Box)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 8px 12px;\n border-radius: 6px;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n`;\n\nexport const ColorDot = muiStyled(Box)<{ dotColor: string }>`\n width: 12px;\n height: 12px;\n border-radius: 50%;\n background-color: ${({ dotColor }) => dotColor};\n flex-shrink: 0;\n`;\n\nexport const SummaryInfo = muiStyled(Box)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex: 1;\n`;\n\nexport const SummaryName = muiStyled(Typography)`\n font-size: 0.875rem;\n font-weight: 500;\n`;\n\nexport const SummaryValue = muiStyled(Typography)`\n font-size: 0.75rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const SummaryPercentage = muiStyled(Typography)`\n font-size: 1rem;\n font-weight: 600;\n flex-shrink: 0;\n`;\n\nexport const DesktopTableContainer = muiStyled(Box)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`;\n\nexport const MobileCategoriesContainer = muiStyled(Box)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`;\n\nexport const MobileCategoryCard = muiStyled(Box)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => theme.palette.divider};\n border-radius: 8px;\n`;\n","import { styled } from '@nuskin/foundation-theme';\n\nexport const PoDashboardContainer = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 16px;\n width: 100%;\n box-sizing: border-box;\n\n @media (min-width: 768px) {\n gap: 24px;\n }\n\n @media (min-width: 1080px) {\n gap: 24px;\n }\n`;\n\nexport const TopChartsRow = styled('div')`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 1080px) {\n grid-template-columns: 1fr 1fr;\n gap: 24px;\n }\n`;\n\nexport const StatsCardStack = styled('div')`\n display: flex;\n flex-direction: column;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 1080px) {\n gap: 24px;\n justify-content: stretch;\n }\n\n & > * {\n flex: 1;\n }\n`;\n\nexport const BottomChartsRow = styled('div')`\n display: grid;\n grid-template-columns: 1fr;\n gap: 16px;\n width: 100%;\n\n @media (min-width: 1080px) {\n grid-template-columns: 1fr 1fr;\n gap: 24px;\n }\n`;\n\nexport const ErrorContainer = styled('div')`\n padding: 24px;\n text-align: center;\n color: #d32f2f;\n background-color: #ffebee;\n border-radius: 8px;\n`;\n","import React from 'react';\nimport { PieChart, Pie, Cell, ResponsiveContainer, Tooltip } from 'recharts';\nimport { WidgetMenu } from '../WidgetMenu';\nimport {\n CategoriesContainer,\n ChartHeader,\n ChartTitle,\n SortDropdown,\n ChartAndLegendContainer,\n ChartWrapper,\n LegendContainer,\n LegendItem,\n LegendColor,\n LegendInfo,\n LegendName,\n LegendValue,\n LegendPercentage,\n DonutCenterOverlay,\n DonutCenterLabel,\n DonutCenterValue,\n DonutCenterTrend,\n EmptyState,\n EmptyStateText,\n HeaderActionsContainer,\n} from '../TopCategories/TopCategoriesPieChart.styled';\nimport type { TopPerformingOffer, OfferSortOption } from '../../types.d';\nimport { CategoriesPieChartSkeleton } from '../LoadingSkeletons';\nimport {\n getTranslation,\n ProductOfferDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ProductOfferDashboardTranslationKeys';\n\nexport interface TopPerformingOffersPieChartProps {\n readonly offers: TopPerformingOffer[];\n readonly offerSort: OfferSortOption;\n readonly isLoading?: boolean;\n readonly title?: string;\n readonly onSortChange?: (sort: OfferSortOption) => void;\n readonly onTitleClick?: () => void;\n}\n\nfunction parseTrendPercent(value?: string): number | null {\n if (!value) return null;\n const cleanedValue = value.replace('%', '').trim();\n const parsedValue = Number(cleanedValue);\n return Number.isFinite(parsedValue) ? parsedValue : null;\n}\n\nconst tooltipFormatter = (value: number): string => `$${value.toLocaleString()}`;\n\nconst TopPerformingOffersPieChartComponent: React.FC<TopPerformingOffersPieChartProps> = ({\n offers,\n offerSort,\n isLoading = false,\n title,\n onSortChange,\n onTitleClick,\n}) => {\n const handleSortChange = React.useCallback(\n (event: React.ChangeEvent<HTMLSelectElement>) => {\n const newSort = event.target.value as OfferSortOption;\n onSortChange?.(newSort);\n },\n [onSortChange],\n );\n\n const { sortedOffers, totalRevenue, trendDirection, formattedTrend } = React.useMemo(() => {\n const nextSortedOffers = [...offers].sort((a, b) => {\n if (offerSort === 'revenue') return b.revenue - a.revenue;\n return b.percentage - a.percentage;\n });\n\n const nextTotalRevenue = nextSortedOffers.reduce((sum, offer) => sum + offer.revenue, 0);\n\n const weightedRevenueTrend = nextSortedOffers.reduce(\n (accumulator, offer) => {\n const trendValue = parseTrendPercent(offer.trend?.revenue);\n if (trendValue === null) return accumulator;\n\n return {\n weightedSum: accumulator.weightedSum + trendValue * offer.revenue,\n weight: accumulator.weight + offer.revenue,\n };\n },\n { weightedSum: 0, weight: 0 },\n );\n\n const averageRevenueTrend =\n weightedRevenueTrend.weight > 0 ? weightedRevenueTrend.weightedSum / weightedRevenueTrend.weight : 0;\n\n let nextTrendDirection: 'up' | 'down' | 'neutral' = 'neutral';\n if (averageRevenueTrend > 0) nextTrendDirection = 'up';\n else if (averageRevenueTrend < 0) nextTrendDirection = 'down';\n\n const trendSign = averageRevenueTrend > 0 ? '+' : '';\n const nextFormattedTrend = `${trendSign}${averageRevenueTrend.toFixed(1)}%`;\n\n return {\n sortedOffers: nextSortedOffers,\n totalRevenue: nextTotalRevenue,\n trendDirection: nextTrendDirection,\n formattedTrend: nextFormattedTrend,\n };\n }, [offers, offerSort]);\n\n if (isLoading && offers.length === 0) {\n return (\n <CategoriesContainer data-testid=\"widget-top-offers\">\n <CategoriesPieChartSkeleton />\n </CategoriesContainer>\n );\n }\n\n if (offers.length === 0) {\n return (\n <CategoriesContainer data-testid=\"widget-top-offers\">\n <ChartHeader>\n <ChartTitle>{title ?? getTranslation(Keys.widget.topPerformingOffers.title)}</ChartTitle>\n </ChartHeader>\n <EmptyState data-testid=\"top-offers-empty-state\">\n <EmptyStateText>{getTranslation(Keys.widget.topPerformingOffers.emptyState)}</EmptyStateText>\n </EmptyState>\n </CategoriesContainer>\n );\n }\n\n return (\n <CategoriesContainer\n as=\"section\"\n data-testid=\"widget-top-offers\"\n aria-label={getTranslation(Keys.ariaLabel.topOffers)}\n >\n <ChartHeader>\n <ChartTitle\n as=\"button\"\n onClick={onTitleClick}\n aria-label={getTranslation(Keys.ariaLabel.topOffers)}\n data-testid=\"widget-title-top-offers\"\n >\n {title ?? getTranslation(Keys.widget.topPerformingOffers.title)}\n </ChartTitle>\n <HeaderActionsContainer>\n <SortDropdown\n id=\"offer-sort\"\n data-testid=\"offer-sort-dropdown\"\n value={offerSort}\n onChange={handleSortChange}\n disabled={isLoading}\n aria-label={getTranslation(Keys.ariaLabel.topOffers)}\n >\n <option value=\"revenue\">{getTranslation(Keys.filter.offerSort.byRevenue)}</option>\n <option value=\"units\">{getTranslation(Keys.filter.offerSort.byUnits)}</option>\n </SortDropdown>\n <WidgetMenu widgetId=\"top-offers\" onFullView={onTitleClick} />\n </HeaderActionsContainer>\n </ChartHeader>\n\n <ChartAndLegendContainer>\n <ChartWrapper data-testid=\"top-offers-chart\">\n <ResponsiveContainer width=\"100%\" height=\"100%\">\n <PieChart>\n <Pie\n data={sortedOffers}\n cx=\"50%\"\n cy=\"50%\"\n innerRadius=\"55%\"\n outerRadius=\"85%\"\n dataKey=\"revenue\"\n nameKey=\"name\"\n paddingAngle={2}\n >\n {sortedOffers.map((entry) => (\n <Cell key={`cell-${entry.id}`} fill={entry.color} />\n ))}\n </Pie>\n <Tooltip formatter={tooltipFormatter} />\n </PieChart>\n </ResponsiveContainer>\n <DonutCenterOverlay data-testid=\"top-offers-donut-center\">\n <DonutCenterLabel>\n {getTranslation(Keys.widget.topPerformingOffers.totalRevenue)}\n </DonutCenterLabel>\n <DonutCenterValue>${totalRevenue.toLocaleString()}</DonutCenterValue>\n <DonutCenterTrend direction={trendDirection}>{formattedTrend}</DonutCenterTrend>\n </DonutCenterOverlay>\n </ChartWrapper>\n\n <LegendContainer data-testid=\"top-offers-legend-container\">\n {sortedOffers.map((offer, index) => (\n <LegendItem key={offer.id} data-testid={`offer-legend-${index}`}>\n <LegendColor color={offer.color} />\n <LegendInfo>\n <LegendName>{offer.name}</LegendName>\n <LegendValue>${offer.revenue.toLocaleString()}</LegendValue>\n </LegendInfo>\n <LegendPercentage>{offer.percentage}%</LegendPercentage>\n </LegendItem>\n ))}\n </LegendContainer>\n </ChartAndLegendContainer>\n </CategoriesContainer>\n );\n};\n\nexport const TopPerformingOffersPieChart = React.memo(TopPerformingOffersPieChartComponent);\nTopPerformingOffersPieChart.displayName = 'TopPerformingOffersPieChart';\n","/**\n * Translation Keys for the Product Offer Dashboard\n *\n * All user-visible strings must use these keys with fallback text.\n * Follow the same { key, fallback } pattern as ShoppingDashboardTranslationKeys.\n */\n\ntype TranslationEntry = { readonly key: string; readonly fallback: string };\n\nexport const ProductOfferDashboardTranslationKeys = {\n title: { key: 'productOfferDashboard.title', fallback: 'Performance Overview' },\n error: { key: 'productOfferDashboard.error', fallback: 'Failed to load dashboard data. Please try again.' },\n\n stats: {\n revenue: { key: 'productOfferDashboard.stats.revenue', fallback: 'Total Revenue' },\n offersPurchased: { key: 'productOfferDashboard.stats.offersPurchased', fallback: 'Offers Purchased' },\n conversionRate: { key: 'productOfferDashboard.stats.conversionRate', fallback: 'Conversion Rate' },\n trendUp: { key: 'productOfferDashboard.stats.trendUp', fallback: 'Trending up' },\n trendDown: { key: 'productOfferDashboard.stats.trendDown', fallback: 'Trending down' },\n trendNeutral: { key: 'productOfferDashboard.stats.trendNeutral', fallback: 'No change' },\n comparedTo: { key: 'productOfferDashboard.stats.comparedTo', fallback: 'compared to this time last month' },\n },\n\n filter: {\n dateRange: {\n label: { key: 'productOfferDashboard.filter.dateRange.label', fallback: 'Date Range' },\n last7days: { key: 'productOfferDashboard.filter.dateRange.last7days', fallback: 'Last 7 Days' },\n last30days: { key: 'productOfferDashboard.filter.dateRange.last30days', fallback: 'Last 30 Days' },\n last90days: { key: 'productOfferDashboard.filter.dateRange.last90days', fallback: 'Last 90 Days' },\n thisMonth: { key: 'productOfferDashboard.filter.dateRange.thisMonth', fallback: 'This Month' },\n },\n market: {\n label: { key: 'productOfferDashboard.filter.market.label', fallback: 'Market' },\n all: { key: 'productOfferDashboard.filter.market.all', fallback: 'All Markets' },\n },\n offerSort: {\n byRevenue: { key: 'productOfferDashboard.filter.offerSort.byRevenue', fallback: 'Revenue' },\n byUnits: { key: 'productOfferDashboard.filter.offerSort.byUnits', fallback: 'Units' },\n },\n productSort: {\n byUnits: { key: 'productOfferDashboard.filter.productSort.byUnits', fallback: 'Units' },\n byRevenue: { key: 'productOfferDashboard.filter.productSort.byRevenue', fallback: 'Revenue' },\n byVolume: { key: 'productOfferDashboard.filter.productSort.byVolume', fallback: 'Volume' },\n },\n conversionFilter: {\n overall: { key: 'productOfferDashboard.filter.conversionFilter.overall', fallback: 'Overall' },\n },\n },\n\n widget: {\n topProducts: {\n title: { key: 'productOfferDashboard.widget.topProducts.title', fallback: 'Top Selling Products' },\n emptyState: {\n key: 'productOfferDashboard.widget.topProducts.emptyState',\n fallback: 'No products data available',\n },\n },\n conversionRate: {\n title: { key: 'productOfferDashboard.widget.conversionRate.title', fallback: 'Conversion Rate' },\n subtitle: { key: 'productOfferDashboard.widget.conversionRate.subtitle', fallback: 'Orders ÷ Site visits' },\n },\n topPerformingOffers: {\n title: { key: 'productOfferDashboard.widget.topPerformingOffers.title', fallback: 'Top Performing Offers' },\n totalRevenue: {\n key: 'productOfferDashboard.widget.topPerformingOffers.totalRevenue',\n fallback: 'Total revenue',\n },\n emptyState: {\n key: 'productOfferDashboard.widget.topPerformingOffers.emptyState',\n fallback: 'No offers data available',\n },\n },\n menu: {\n fullView: { key: 'productOfferDashboard.widget.menu.fullView', fallback: 'Full View' },\n },\n },\n\n navigation: {\n back: { key: 'productOfferDashboard.navigation.back', fallback: 'Back to Dashboard' },\n },\n\n ariaLabel: {\n dashboard: {\n key: 'productOfferDashboard.ariaLabel.dashboard',\n fallback: 'Product Offer Performance Dashboard',\n },\n statsCard: { key: 'productOfferDashboard.ariaLabel.statsCard', fallback: 'Performance metric' },\n conversionChart: { key: 'productOfferDashboard.ariaLabel.conversionChart', fallback: 'Conversion rate chart' },\n topProducts: { key: 'productOfferDashboard.ariaLabel.topProducts', fallback: 'Top selling products' },\n topOffers: { key: 'productOfferDashboard.ariaLabel.topOffers', fallback: 'Top performing offers chart' },\n widgetMenu: { key: 'productOfferDashboard.ariaLabel.widgetMenu', fallback: 'Widget options menu' },\n filterDateRange: { key: 'productOfferDashboard.ariaLabel.filterDateRange', fallback: 'Filter by date range' },\n filterMarket: { key: 'productOfferDashboard.ariaLabel.filterMarket', fallback: 'Filter by market' },\n backButton: { key: 'productOfferDashboard.ariaLabel.backButton', fallback: 'Back to dashboard overview' },\n },\n\n fullView: {\n topOffers: {\n title: { key: 'productOfferDashboard.fullView.topOffers.title', fallback: 'Top Performing Offers' },\n columnName: { key: 'productOfferDashboard.fullView.topOffers.columnName', fallback: 'Offer Name' },\n columnRevenue: { key: 'productOfferDashboard.fullView.topOffers.columnRevenue', fallback: 'Revenue' },\n columnPercentage: { key: 'productOfferDashboard.fullView.topOffers.columnPercentage', fallback: 'Share' },\n columnTrend: { key: 'productOfferDashboard.fullView.topOffers.columnTrend', fallback: 'Trend' },\n },\n },\n\n defaults: {\n trendZero: { key: 'productOfferDashboard.defaults.trendZero', fallback: '+0%' },\n noData: { key: 'productOfferDashboard.defaults.noData', fallback: '--' },\n },\n} as const;\n\n/**\n * Get translation text from a translation entry.\n * Currently returns the fallback text. When an i18n provider is integrated,\n * this function will use the key to look up the translated string.\n */\nexport function getTranslation(entry: TranslationEntry): string {\n return entry.fallback;\n}\n","import React from 'react';\nimport {\n PoDashboardContainer,\n TopChartsRow,\n StatsCardStack,\n BottomChartsRow,\n ErrorContainer,\n} from './ProductOfferDashboard.styled';\nimport { DashboardHeader } from './shared/DashboardHeader';\nimport { StatsCard } from './shared/StatsCard';\nimport { TopSellingProductsList } from './shared/TopProducts/TopSellingProductsList';\nimport { ConversionRateChart } from './shared/ConversionRate/ConversionRateChart';\nimport { TopPerformingOffersPieChart } from './shared/TopPerformingOffers/TopPerformingOffersPieChart';\nimport type { ProductOfferDashboardProps, TopProduct, ConversionDataPoint, TopPerformingOffer } from './types.d';\nimport {\n getTranslation,\n ProductOfferDashboardTranslationKeys as Keys,\n} from './TranslationKeys/ProductOfferDashboardTranslationKeys';\n\nconst EMPTY_TOP_PRODUCTS: TopProduct[] = [];\nconst EMPTY_CONVERSION_DATA: ConversionDataPoint[] = [];\nconst EMPTY_TOP_OFFERS: TopPerformingOffer[] = [];\n\n/**\n * ProductOfferDashboard Main Container Component\n *\n * Orchestrates all dashboard widgets for the Product Offer Performance view.\n * Pure presentational - receives all data via props.\n * The consuming application is responsible for data fetching and state management.\n *\n * Layout (desktop):\n * - Top row: Conversion Rate chart (left) | Total Revenue + Offers Purchased stacked (right)\n * - Bottom row: Top Selling Products (left) | Top Performing Offers donut (right)\n */\nexport const ProductOfferDashboard: React.FC<ProductOfferDashboardProps> = ({\n stats,\n topProducts,\n conversionData,\n topOffers,\n isLoading = false,\n error,\n dashboardTitle,\n className,\n dateRange = 'last30days',\n market = 'all',\n productSort = 'units',\n conversionFilter = 'all',\n offerSort = 'revenue',\n onDateRangeChange,\n onMarketChange,\n onProductSortChange,\n onConversionFilterChange,\n onOfferSortChange,\n onProductsTitleClick,\n onConversionTitleClick,\n onOffersTitleClick,\n}) => {\n const resolvedTopProducts = topProducts ?? EMPTY_TOP_PRODUCTS;\n const resolvedConversionData = conversionData ?? EMPTY_CONVERSION_DATA;\n const resolvedTopOffers = topOffers ?? EMPTY_TOP_OFFERS;\n\n const getTrendDirection = (trendValue?: string): 'up' | 'down' | 'neutral' => {\n if (!trendValue) return 'neutral';\n if (trendValue.startsWith('+') && trendValue !== '+0%') return 'up';\n if (trendValue.startsWith('-')) return 'down';\n return 'neutral';\n };\n\n // Error state\n if (error) {\n return (\n <PoDashboardContainer as=\"main\" className={className} aria-label={getTranslation(Keys.ariaLabel.dashboard)}>\n <ErrorContainer data-testid=\"dashboard-error\" role=\"alert\" aria-live=\"assertive\">\n <strong>{getTranslation(Keys.error)}:</strong> {error}\n </ErrorContainer>\n </PoDashboardContainer>\n );\n }\n\n return (\n <PoDashboardContainer\n as=\"main\"\n className={className}\n data-testid=\"product-offer-dashboard\"\n aria-label={getTranslation(Keys.ariaLabel.dashboard)}\n aria-busy={isLoading}\n >\n <DashboardHeader\n shopTitle={dashboardTitle ?? getTranslation(Keys.title)}\n dateRange={dateRange}\n market={market}\n isLoading={isLoading}\n stats={\n stats\n ? {\n shopTitle: stats.shopTitle ?? '',\n dateRange: stats.dateRange,\n selectedMarket: stats.selectedMarket,\n metrics: {\n revenue: stats.metrics.revenue,\n volume: '',\n siteVisits: '',\n conversionRate: stats.metrics.conversionRate,\n },\n trend: {},\n }\n : undefined\n }\n onDateRangeChange={onDateRangeChange}\n onMarketChange={onMarketChange}\n />\n\n <TopChartsRow data-testid=\"top-charts-row\">\n <ConversionRateChart\n conversionData={resolvedConversionData}\n conversionFilter={conversionFilter}\n isLoading={isLoading}\n onFilterChange={onConversionFilterChange}\n onTitleClick={onConversionTitleClick}\n />\n <StatsCardStack data-testid=\"stats-card-stack\">\n <StatsCard\n title={getTranslation(Keys.stats.revenue)}\n value={stats?.metrics?.revenue ?? '$0'}\n trendDirection={getTrendDirection(stats?.trend?.revenue)}\n trendValue={stats?.trend?.revenue}\n testId=\"stats-card-revenue\"\n isLoading={isLoading}\n />\n <StatsCard\n title={getTranslation(Keys.stats.offersPurchased)}\n value={stats?.metrics?.offersPurchased ?? '0'}\n trendDirection={getTrendDirection(stats?.trend?.offersPurchased)}\n trendValue={stats?.trend?.offersPurchased}\n testId=\"stats-card-offers-purchased\"\n isLoading={isLoading}\n />\n </StatsCardStack>\n </TopChartsRow>\n\n <BottomChartsRow data-testid=\"bottom-charts-row\">\n <TopSellingProductsList\n products={resolvedTopProducts}\n productSort={productSort}\n isLoading={isLoading}\n maxProducts={5}\n onSortChange={onProductSortChange}\n onTitleClick={onProductsTitleClick}\n />\n <TopPerformingOffersPieChart\n offers={resolvedTopOffers}\n offerSort={offerSort}\n isLoading={isLoading}\n onSortChange={onOfferSortChange}\n onTitleClick={onOffersTitleClick}\n />\n </BottomChartsRow>\n </PoDashboardContainer>\n );\n};\n\nexport default ProductOfferDashboard;\n","import React from 'react';\nimport { ProductOfferDashboard } from './ProductOfferDashboard';\nimport { ProductsFullView } from './shared/TopProducts/ProductsFullView';\nimport { ConversionRateFullView } from './shared/ConversionRate/ConversionRateFullView';\nimport { TopPerformingOffersFullView } from './shared/TopPerformingOffers/TopPerformingOffersFullView';\nimport type {\n TopProduct,\n ConversionDataPoint,\n TopPerformingOffer,\n OrderHistory,\n DateRangeOption,\n MarketOption,\n ProductSortOption,\n ConversionFilterOption,\n OfferSortOption,\n ProductOfferFullViewWidgetType,\n ProductOfferDashboardView,\n PoDashboardWithNavigationProps,\n ProductOfferDashboardHistoryLocation,\n} from './types.d';\n\ntype ViewMode = 'push' | 'replace';\n\nconst DEFAULT_HISTORY_STATE_KEY = 'productOfferDashboardView';\n\nconst EMPTY_TOP_PRODUCTS: TopProduct[] = [];\nconst EMPTY_CONVERSION_DATA: ConversionDataPoint[] = [];\nconst EMPTY_TOP_OFFERS: TopPerformingOffer[] = [];\nconst EMPTY_ORDERS: OrderHistory[] = [];\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null;\n}\n\nfunction isProductOfferDashboardView(value: unknown): value is ProductOfferDashboardView {\n return value === 'dashboard' || value === 'products' || value === 'conversion-rate' || value === 'top-offers';\n}\n\nfunction readViewFromState(state: unknown, stateKey: string): ProductOfferDashboardView {\n if (!isRecord(state)) {\n return 'dashboard';\n }\n\n const view = state[stateKey];\n return isProductOfferDashboardView(view) ? view : 'dashboard';\n}\n\nfunction buildStateWithView(\n state: unknown,\n stateKey: string,\n view: ProductOfferDashboardView,\n): Record<string, unknown> {\n const currentState = isRecord(state) ? state : {};\n\n return {\n ...currentState,\n [stateKey]: view,\n };\n}\n\nfunction buildLocationWithState(\n location: ProductOfferDashboardHistoryLocation | undefined,\n state: Record<string, unknown>,\n): ProductOfferDashboardHistoryLocation {\n return {\n pathname: location?.pathname,\n search: location?.search,\n hash: location?.hash,\n state,\n };\n}\n\n/**\n * PoDashboardWithNavigation\n *\n * Stateful navigation wrapper for the Product Offer Dashboard.\n * Manages dashboard/full-view switching with browser history integration,\n * filter state ownership, and back navigation.\n *\n * Follows the same pattern as MysiteDashboardWithNavigation but for the\n * Product Offer Dashboard with reduced view types (no signups/categories).\n */\nexport const PoDashboardWithNavigation: React.FC<PoDashboardWithNavigationProps> = ({\n stats,\n topProducts,\n conversionData,\n topOffers,\n isLoading = false,\n error,\n dashboardTitle,\n className,\n allProducts,\n orders,\n allOffers,\n initialDateRange = 'last30days',\n initialMarket = 'all',\n initialProductSort = 'units',\n initialConversionFilter = 'all',\n initialOfferSort = 'revenue',\n historyAdapter,\n historyStateKey = DEFAULT_HISTORY_STATE_KEY,\n resetToDashboardOnMount = true,\n onDateRangeChange,\n onMarketChange,\n onProductSortChange,\n onConversionFilterChange,\n onOfferSortChange,\n onViewChange,\n}) => {\n const [currentView, setCurrentView] = React.useState<ProductOfferDashboardView>('dashboard');\n const hasIntraDashboardHistoryRef = React.useRef(false);\n const [dateRange, setDateRange] = React.useState<DateRangeOption>(initialDateRange);\n const [market, setMarket] = React.useState<MarketOption>(initialMarket);\n const [productSort, setProductSort] = React.useState<ProductSortOption>(initialProductSort);\n const [conversionFilter, setConversionFilter] = React.useState<ConversionFilterOption>(initialConversionFilter);\n const [offerSort, setOfferSort] = React.useState<OfferSortOption>(initialOfferSort);\n\n const resolvedTopProducts = topProducts ?? EMPTY_TOP_PRODUCTS;\n const resolvedConversionData = conversionData ?? EMPTY_CONVERSION_DATA;\n const resolvedTopOffers = topOffers ?? EMPTY_TOP_OFFERS;\n const resolvedAllProducts = allProducts ?? resolvedTopProducts;\n const resolvedOrders = orders ?? EMPTY_ORDERS;\n const resolvedAllOffers = allOffers ?? resolvedTopOffers;\n\n const updateView = React.useCallback(\n (view: ProductOfferDashboardView) => {\n setCurrentView(view);\n onViewChange?.(view);\n },\n [onViewChange],\n );\n\n const readCurrentView = React.useCallback((): ProductOfferDashboardView => {\n if (historyAdapter) {\n return readViewFromState(historyAdapter.location?.state, historyStateKey);\n }\n\n if (typeof window === 'undefined') {\n return 'dashboard';\n }\n\n return readViewFromState(window.history.state, historyStateKey);\n }, [historyAdapter, historyStateKey]);\n\n const writeCurrentView = React.useCallback(\n (view: ProductOfferDashboardView, mode: ViewMode) => {\n if (historyAdapter) {\n const nextState = buildStateWithView(historyAdapter.location?.state, historyStateKey, view);\n const nextLocation = buildLocationWithState(historyAdapter.location, nextState);\n\n if (mode === 'replace') {\n historyAdapter.replace(nextLocation);\n return;\n }\n\n historyAdapter.push(nextLocation);\n return;\n }\n\n if (typeof window === 'undefined') {\n return;\n }\n\n const nextState = buildStateWithView(window.history.state, historyStateKey, view);\n\n if (mode === 'replace') {\n window.history.replaceState(nextState, '');\n return;\n }\n\n window.history.pushState(nextState, '');\n },\n [historyAdapter, historyStateKey],\n );\n\n React.useEffect(() => {\n if (resetToDashboardOnMount) {\n writeCurrentView('dashboard', 'replace');\n hasIntraDashboardHistoryRef.current = false;\n updateView('dashboard');\n } else {\n updateView(readCurrentView());\n }\n\n if (historyAdapter) {\n return historyAdapter.listen((location, action) => {\n if (action === 'POP') {\n const nextView = readViewFromState(location.state, historyStateKey);\n hasIntraDashboardHistoryRef.current = nextView !== 'dashboard';\n updateView(nextView);\n }\n });\n }\n\n const handlePopState = (event: PopStateEvent) => {\n const nextView = readViewFromState(event.state, historyStateKey);\n hasIntraDashboardHistoryRef.current = nextView !== 'dashboard';\n updateView(nextView);\n };\n\n window.addEventListener('popstate', handlePopState);\n return () => {\n window.removeEventListener('popstate', handlePopState);\n };\n }, [historyAdapter, historyStateKey, readCurrentView, resetToDashboardOnMount, updateView, writeCurrentView]);\n\n const handleOpenFullView = React.useCallback(\n (view: ProductOfferFullViewWidgetType) => {\n hasIntraDashboardHistoryRef.current = true;\n writeCurrentView(view, 'push');\n updateView(view);\n },\n [updateView, writeCurrentView],\n );\n\n const handleBack = React.useCallback(() => {\n if (currentView !== 'dashboard' && hasIntraDashboardHistoryRef.current) {\n if (historyAdapter) {\n historyAdapter.goBack();\n return;\n }\n\n if (typeof window !== 'undefined') {\n window.history.back();\n }\n\n return;\n }\n\n hasIntraDashboardHistoryRef.current = false;\n writeCurrentView('dashboard', 'replace');\n updateView('dashboard');\n }, [currentView, historyAdapter, updateView, writeCurrentView]);\n\n // --- Filter handlers ---\n\n const handleDateRangeChange = React.useCallback(\n (nextDateRange: DateRangeOption) => {\n setDateRange(nextDateRange);\n onDateRangeChange?.(nextDateRange);\n },\n [onDateRangeChange],\n );\n\n const handleMarketChange = React.useCallback(\n (nextMarket: MarketOption) => {\n setMarket(nextMarket);\n onMarketChange?.(nextMarket);\n },\n [onMarketChange],\n );\n\n const handleProductSortChange = React.useCallback(\n (nextProductSort: ProductSortOption) => {\n setProductSort(nextProductSort);\n onProductSortChange?.(nextProductSort);\n },\n [onProductSortChange],\n );\n\n const handleConversionFilterChange = React.useCallback(\n (nextFilter: ConversionFilterOption) => {\n setConversionFilter(nextFilter);\n onConversionFilterChange?.(nextFilter);\n },\n [onConversionFilterChange],\n );\n\n const handleOfferSortChange = React.useCallback(\n (nextSort: OfferSortOption) => {\n setOfferSort(nextSort);\n onOfferSortChange?.(nextSort);\n },\n [onOfferSortChange],\n );\n\n // --- Navigation callbacks ---\n\n const handleProductsTitleClick = React.useCallback(() => {\n handleOpenFullView('products');\n }, [handleOpenFullView]);\n\n const handleConversionTitleClick = React.useCallback(() => {\n handleOpenFullView('conversion-rate');\n }, [handleOpenFullView]);\n\n const handleOffersTitleClick = React.useCallback(() => {\n handleOpenFullView('top-offers');\n }, [handleOpenFullView]);\n\n // --- View rendering ---\n\n if (currentView === 'products') {\n return (\n <ProductsFullView\n products={resolvedAllProducts}\n dateRange={dateRange}\n market={market}\n productSort={productSort}\n isLoading={isLoading}\n onBack={handleBack}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onProductSortChange={handleProductSortChange}\n />\n );\n }\n\n if (currentView === 'conversion-rate') {\n return (\n <ConversionRateFullView\n conversionData={resolvedConversionData}\n orders={resolvedOrders}\n dateRange={dateRange}\n market={market}\n conversionFilter={conversionFilter}\n isLoading={isLoading}\n onBack={handleBack}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onConversionFilterChange={handleConversionFilterChange}\n />\n );\n }\n\n if (currentView === 'top-offers') {\n return (\n <TopPerformingOffersFullView\n offers={resolvedAllOffers}\n dateRange={dateRange}\n market={market}\n offerSort={offerSort}\n isLoading={isLoading}\n onBack={handleBack}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onOfferSortChange={handleOfferSortChange}\n />\n );\n }\n\n return (\n <ProductOfferDashboard\n stats={stats}\n topProducts={resolvedTopProducts}\n conversionData={resolvedConversionData}\n topOffers={resolvedTopOffers}\n isLoading={isLoading}\n error={error}\n dashboardTitle={dashboardTitle}\n className={className}\n dateRange={dateRange}\n market={market}\n productSort={productSort}\n conversionFilter={conversionFilter}\n offerSort={offerSort}\n onDateRangeChange={handleDateRangeChange}\n onMarketChange={handleMarketChange}\n onProductSortChange={handleProductSortChange}\n onConversionFilterChange={handleConversionFilterChange}\n onOfferSortChange={handleOfferSortChange}\n onProductsTitleClick={handleProductsTitleClick}\n onConversionTitleClick={handleConversionTitleClick}\n onOffersTitleClick={handleOffersTitleClick}\n />\n );\n};\n\nexport default PoDashboardWithNavigation;\n","import React, { useState } from 'react';\nimport { PieChart, Pie, Cell, ResponsiveContainer, Tooltip } from 'recharts';\nimport { PageHeader, type FilterConfig } from '../PageHeader';\nimport { DataTable, type ColumnDef } from '../DataTable';\nimport { Pagination } from '../Pagination';\nimport { paginateItems, calculateTotalPages } from '../../utils/dataUtils';\nimport { formatDateRangeLabel } from '../../utils/dateFormat';\nimport type { TopPerformingOffer, DateRangeOption, MarketOption, OfferSortOption } from '../../types.d';\nimport { FullViewChartSkeleton } from '../LoadingSkeletons';\nimport { PageContainer, TableSection, ChartTitle, EmptyStateText } from '../FullViewComponents.styled';\nimport {\n SummaryItemRow,\n SummaryItemInfo,\n SummaryItemName,\n SummaryItemSubtext,\n SummaryItemPercentage,\n} from '../TopCategories/CategoriesFullView.styled';\nimport {\n TopSection,\n ChartWrapper,\n DonutCenterOverlay,\n DonutCenterLabel,\n DonutCenterValue,\n DonutCenterTrend,\n SummaryContainer,\n SummaryItem,\n ColorDot,\n SummaryInfo,\n SummaryName,\n SummaryValue,\n SummaryPercentage,\n DesktopTableContainer,\n MobileOffersContainer,\n MobileOfferCard,\n} from './TopPerformingOffersFullView.styled';\nimport { useIsMobileViewport } from '../useViewport';\nimport {\n getTranslation,\n ProductOfferDashboardTranslationKeys as Keys,\n} from '../../TranslationKeys/ProductOfferDashboardTranslationKeys';\n\nexport interface TopPerformingOffersFullViewProps {\n readonly offers: TopPerformingOffer[];\n readonly dateRange: DateRangeOption;\n readonly market: MarketOption;\n readonly offerSort: OfferSortOption;\n readonly isLoading?: boolean;\n readonly onBack?: () => void;\n readonly onDateRangeChange?: (range: DateRangeOption) => void;\n readonly onMarketChange?: (market: MarketOption) => void;\n readonly onOfferSortChange?: (sort: OfferSortOption) => void;\n}\n\nfunction parseTrendPercent(value?: string): number | null {\n if (!value) return null;\n const cleanedValue = value.replace('%', '').trim();\n const parsedValue = Number(cleanedValue);\n return Number.isFinite(parsedValue) ? parsedValue : null;\n}\n\nexport const TopPerformingOffersFullView: React.FC<TopPerformingOffersFullViewProps> = ({\n offers,\n dateRange,\n market,\n offerSort,\n isLoading = false,\n onBack,\n onDateRangeChange,\n onMarketChange,\n onOfferSortChange,\n}) => {\n const [currentPage, setCurrentPage] = useState(1);\n const itemsPerPage = 10;\n const isMobileView = useIsMobileViewport();\n\n const handleBack = React.useCallback(() => onBack?.(), [onBack]);\n\n const filters: FilterConfig[] = React.useMemo(\n () => [\n {\n key: 'dateRange',\n label: getTranslation(Keys.filter.dateRange.label),\n value: dateRange,\n icon: 'calendar',\n options: [\n { value: 'last7days', label: getTranslation(Keys.filter.dateRange.last7days) },\n { value: 'last30days', label: getTranslation(Keys.filter.dateRange.last30days) },\n { value: 'last90days', label: getTranslation(Keys.filter.dateRange.last90days) },\n { value: 'thisMonth', label: getTranslation(Keys.filter.dateRange.thisMonth) },\n ],\n },\n {\n key: 'market',\n label: getTranslation(Keys.filter.market.label),\n value: market,\n icon: 'globe',\n options: [{ value: 'all', label: getTranslation(Keys.filter.market.all) }],\n },\n {\n key: 'sort',\n label: getTranslation(Keys.filter.offerSort.byRevenue),\n value: offerSort,\n options: [\n { value: 'revenue', label: getTranslation(Keys.filter.offerSort.byRevenue) },\n { value: 'units', label: getTranslation(Keys.filter.offerSort.byUnits) },\n ],\n },\n ],\n [dateRange, market, offerSort],\n );\n\n const handleFilterChange = React.useCallback(\n (key: string, value: string) => {\n if (key === 'dateRange') onDateRangeChange?.(value as DateRangeOption);\n else if (key === 'market') onMarketChange?.(value as MarketOption);\n else if (key === 'sort') {\n onOfferSortChange?.(value as OfferSortOption);\n setCurrentPage(1);\n }\n },\n [onOfferSortChange, onDateRangeChange, onMarketChange],\n );\n\n const sortedOffers = React.useMemo(\n () =>\n [...offers].sort((a, b) => {\n if (offerSort === 'revenue') return b.revenue - a.revenue;\n return b.percentage - a.percentage;\n }),\n [offers, offerSort],\n );\n\n const { totalRevenue, totalRevenueTrendDirection, totalRevenueTrend } = React.useMemo(() => {\n const nextTotalRevenue = sortedOffers.reduce((sum, offer) => sum + offer.revenue, 0);\n\n const weightedRevenueTrend = sortedOffers.reduce(\n (accumulator, offer) => {\n const trendValue = parseTrendPercent(offer.trend?.revenue);\n if (trendValue === null) return accumulator;\n\n return {\n weightedSum: accumulator.weightedSum + trendValue * offer.revenue,\n weight: accumulator.weight + offer.revenue,\n };\n },\n { weightedSum: 0, weight: 0 },\n );\n\n const averageRevenueTrend =\n weightedRevenueTrend.weight > 0 ? weightedRevenueTrend.weightedSum / weightedRevenueTrend.weight : 0;\n\n let direction: 'up' | 'down' | 'neutral' = 'neutral';\n if (averageRevenueTrend > 0) direction = 'up';\n else if (averageRevenueTrend < 0) direction = 'down';\n\n const sign = averageRevenueTrend > 0 ? '+' : '';\n const trend = `${sign}${averageRevenueTrend.toFixed(1)}%`;\n\n return {\n totalRevenue: nextTotalRevenue,\n totalRevenueTrendDirection: direction,\n totalRevenueTrend: trend,\n };\n }, [sortedOffers]);\n\n const topOffers = React.useMemo(() => sortedOffers.slice(0, 5), [sortedOffers]);\n\n const totalPages = React.useMemo(\n () => calculateTotalPages(sortedOffers, itemsPerPage),\n [itemsPerPage, sortedOffers],\n );\n const paginatedOffers = React.useMemo(\n () => paginateItems(sortedOffers, currentPage, itemsPerPage),\n [currentPage, itemsPerPage, sortedOffers],\n );\n\n const columns: ColumnDef<TopPerformingOffer>[] = React.useMemo(\n () => [\n {\n key: 'name',\n label: getTranslation(Keys.fullView.topOffers.columnName),\n sortable: true,\n render: (_: unknown, row: TopPerformingOffer) => (\n <SummaryItemRow>\n <ColorDot dotColor={row.color} />\n <span>{row.name}</span>\n </SummaryItemRow>\n ),\n },\n {\n key: 'revenue',\n label: getTranslation(Keys.fullView.topOffers.columnRevenue),\n sortable: true,\n render: (value: unknown) => `$${Number(value).toLocaleString()}`,\n },\n {\n key: 'percentage',\n label: getTranslation(Keys.fullView.topOffers.columnPercentage),\n sortable: true,\n render: (value: unknown) => `${Number(value)}%`,\n },\n {\n key: 'trend',\n label: getTranslation(Keys.fullView.topOffers.columnTrend),\n render: (_: unknown, row: TopPerformingOffer) =>\n row.trend?.revenue ?? getTranslation(Keys.defaults.noData),\n },\n ],\n [],\n );\n\n if (isLoading) {\n return (\n <PageContainer data-testid=\"top-offers-full-view\">\n <PageHeader\n title={getTranslation(Keys.fullView.topOffers.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n <FullViewChartSkeleton />\n </PageContainer>\n );\n }\n\n if (offers.length === 0) {\n return (\n <PageContainer data-testid=\"top-offers-full-view\">\n <PageHeader\n title={getTranslation(Keys.fullView.topOffers.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n <EmptyStateText data-testid=\"top-offers-fullview-empty\">\n {getTranslation(Keys.widget.topPerformingOffers.emptyState)}\n </EmptyStateText>\n </PageContainer>\n );\n }\n\n return (\n <PageContainer data-testid=\"top-offers-full-view\">\n <PageHeader\n title={getTranslation(Keys.fullView.topOffers.title)}\n dateRange={formatDateRangeLabel(dateRange)}\n onBack={handleBack}\n filters={filters}\n onFilterChange={handleFilterChange}\n />\n\n <TopSection data-testid=\"top-offers-fullview-top-section\">\n <ChartWrapper data-testid=\"top-offers-fullview-chart\">\n <ResponsiveContainer width=\"100%\" height=\"100%\">\n <PieChart>\n <Pie\n data={sortedOffers}\n cx=\"50%\"\n cy=\"50%\"\n innerRadius=\"50%\"\n outerRadius=\"85%\"\n dataKey=\"revenue\"\n nameKey=\"name\"\n paddingAngle={2}\n >\n {sortedOffers.map((entry) => (\n <Cell key={`cell-${entry.id}`} fill={entry.color} />\n ))}\n </Pie>\n <Tooltip formatter={(value: number) => `$${value.toLocaleString()}`} />\n </PieChart>\n </ResponsiveContainer>\n <DonutCenterOverlay data-testid=\"top-offers-fullview-donut-center\">\n <DonutCenterLabel>\n {getTranslation(Keys.widget.topPerformingOffers.totalRevenue)}\n </DonutCenterLabel>\n <DonutCenterValue>${totalRevenue.toLocaleString()}</DonutCenterValue>\n <DonutCenterTrend direction={totalRevenueTrendDirection}>{totalRevenueTrend}</DonutCenterTrend>\n </DonutCenterOverlay>\n </ChartWrapper>\n\n <SummaryContainer data-testid=\"top-offers-fullview-summary\">\n {topOffers.map((offer) => (\n <SummaryItem key={offer.id}>\n <ColorDot dotColor={offer.color} />\n <SummaryInfo>\n <SummaryName>{offer.name}</SummaryName>\n <SummaryValue>${offer.revenue.toLocaleString()}</SummaryValue>\n </SummaryInfo>\n <SummaryPercentage>{offer.percentage}%</SummaryPercentage>\n </SummaryItem>\n ))}\n </SummaryContainer>\n </TopSection>\n\n <TableSection data-testid=\"top-offers-table\">\n <ChartTitle data-testid=\"top-offers-fullview-table-title\">\n {getTranslation(Keys.fullView.topOffers.title)} ({sortedOffers.length})\n </ChartTitle>\n {!isMobileView ? (\n <DesktopTableContainer>\n <DataTable\n columns={columns}\n data={paginatedOffers}\n sortable\n getRowKey={(row: TopPerformingOffer) => row.id}\n />\n </DesktopTableContainer>\n ) : (\n <MobileOffersContainer>\n {paginatedOffers.map((offer) => (\n <MobileOfferCard key={offer.id}>\n <ColorDot dotColor={offer.color} />\n <SummaryItemInfo>\n <SummaryItemName>{offer.name}</SummaryItemName>\n <SummaryItemSubtext>${offer.revenue.toLocaleString()}</SummaryItemSubtext>\n </SummaryItemInfo>\n <SummaryItemPercentage>{offer.percentage}%</SummaryItemPercentage>\n </MobileOfferCard>\n ))}\n </MobileOffersContainer>\n )}\n {totalPages > 1 && (\n <Pagination\n currentPage={currentPage}\n totalPages={totalPages}\n onPageChange={setCurrentPage}\n itemsPerPage={itemsPerPage}\n totalItems={sortedOffers.length}\n data-testid=\"top-offers-pagination\"\n />\n )}\n </TableSection>\n </PageContainer>\n );\n};\n","import { styled } from '@mui/material/styles';\nimport { Box, Typography } from '@mui/material';\nimport { ColorUtils } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const TopSection = styled(Box)`\n display: flex;\n gap: 24px;\n padding: 24px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border-radius: 8px;\n box-shadow: ${({ theme }) => theme.shadows[1]};\n\n @media (max-width: 767px) {\n flex-direction: column;\n padding: 16px;\n gap: 16px;\n }\n`;\n\nexport const ChartWrapper = styled(Box)`\n position: relative;\n width: 280px;\n height: 280px;\n flex-shrink: 0;\n\n @media (max-width: 767px) {\n width: 100%;\n height: 220px;\n }\n`;\n\nexport const DonutCenterOverlay = styled(Box)`\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n pointer-events: none;\n z-index: 1;\n width: 120px;\n`;\n\nexport const DonutCenterLabel = styled(Typography)`\n font-size: 0.75rem;\n line-height: 1.2;\n font-weight: 500;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const DonutCenterValue = styled(Typography)`\n margin-top: 2px;\n font-size: 1.25rem;\n line-height: 1.2;\n font-weight: 700;\n color: ${({ theme }) => theme.palette.text.primary};\n`;\n\nexport const DonutCenterTrend = styled(Typography)<{ direction: 'up' | 'down' | 'neutral' }>`\n margin-top: 2px;\n font-size: 0.875rem;\n line-height: 1.2;\n font-weight: 600;\n color: ${({ direction, theme }) => {\n if (direction === 'up') return theme.palette.success.main;\n if (direction === 'down') return theme.palette.error.main;\n return theme.palette.text.secondary;\n }};\n`;\n\nexport const SummaryContainer = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 12px;\n flex: 1;\n`;\n\nexport const SummaryItem = styled(Box)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 8px 12px;\n border-radius: 6px;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n`;\n\nexport const ColorDot = styled(Box)<{ dotColor: string }>`\n width: 12px;\n height: 12px;\n border-radius: 50%;\n background-color: ${({ dotColor }) => dotColor};\n flex-shrink: 0;\n`;\n\nexport const SummaryInfo = styled(Box)`\n display: flex;\n flex-direction: column;\n gap: 2px;\n flex: 1;\n`;\n\nexport const SummaryName = styled(Typography)`\n font-size: 0.875rem;\n font-weight: 500;\n`;\n\nexport const SummaryValue = styled(Typography)`\n font-size: 0.75rem;\n color: ${({ theme }) => theme.palette.text.secondary};\n`;\n\nexport const SummaryPercentage = styled(Typography)`\n font-size: 1rem;\n font-weight: 600;\n flex-shrink: 0;\n`;\n\nexport const DesktopTableContainer = styled(Box)`\n display: block;\n @media (max-width: 767px) {\n display: none;\n }\n`;\n\nexport const MobileOffersContainer = styled(Box)`\n display: none;\n @media (max-width: 767px) {\n display: flex;\n flex-direction: column;\n gap: 12px;\n }\n`;\n\nexport const MobileOfferCard = styled(Box)`\n display: flex;\n align-items: center;\n gap: 12px;\n padding: 16px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => theme.palette.divider};\n border-radius: 8px;\n`;\n","import { ColorUtils, styled } from '@nuskin/foundation-theme';\n\nconst { getGenomeColor } = ColorUtils;\n\nexport const FilterContainer = styled('div')`\n display: flex;\n gap: 12px;\n margin-bottom: 24px;\n flex-wrap: wrap;\n`;\n\nexport const FilterDropdown = styled('select')`\n min-width: 160px;\n height: 40px;\n padding: 8px 12px;\n background-color: ${({ theme }) => getGenomeColor(theme, 'N20')};\n border: 1px solid ${({ theme }) => getGenomeColor(theme, 'N40')};\n border-radius: 8px;\n font-size: 14px;\n font-weight: 400;\n color: ${({ theme }) => getGenomeColor(theme, 'N100')};\n cursor: pointer;\n outline: none;\n transition: all 0.2s ease;\n\n &:hover {\n background-color: ${({ theme }) => getGenomeColor(theme, 'N30')};\n }\n\n &:focus {\n border-color: ${({ theme }) => getGenomeColor(theme, 'A70')};\n box-shadow: 0 0 0 3px ${({ theme }) => getGenomeColor(theme, 'A20')};\n }\n\n &:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n`;\n\nexport const FilterLabel = styled('label')`\n display: flex;\n flex-direction: column;\n gap: 4px;\n font-size: 12px;\n font-weight: 500;\n color: ${({ theme }) => getGenomeColor(theme, 'N70')};\n`;\n","import React from 'react';\nimport { FilterContainer, FilterDropdown, FilterLabel } from './FilterBar.styled';\nimport type { FilterConfig } from './types';\nimport {\n getTranslation,\n ShoppingDashboardTranslationKeys as Keys,\n} from '../TranslationKeys/ShoppingDashboardTranslationKeys';\n\nexport interface FilterBarProps {\n readonly filters: FilterConfig[];\n readonly onChange: (filterKey: string, value: string) => void;\n}\n\nexport const FilterBar: React.FC<FilterBarProps> = ({ filters, onChange }) => {\n return (\n <FilterContainer data-testid=\"filter-bar\">\n {filters.map((filter) => (\n <FilterLabel key={filter.key} htmlFor={`filter-${filter.key}`}>\n {filter.label}\n <FilterDropdown\n id={`filter-${filter.key}`}\n value={filter.value}\n onChange={(e) => onChange(filter.key, e.target.value)}\n disabled={filter.disabled}\n aria-label={`${filter.label} ${getTranslation(Keys.ariaLabel.filterSuffix)}`}\n data-testid={`filter-dropdown-${filter.key}`}\n >\n {filter.options.map((option) => (\n <option key={option.value} value={option.value}>\n {option.label}\n </option>\n ))}\n </FilterDropdown>\n </FilterLabel>\n ))}\n </FilterContainer>\n );\n};\n","import type {\n DashboardStats,\n TopProduct,\n ConversionDataPoint,\n SignupDataPoint,\n CategoryRevenue,\n OrderHistory,\n SignupDetail,\n} from '../types.d';\n\nexport const mockStats: DashboardStats = {\n shopTitle: 'My NuSkin Shop',\n dateRange: {\n start: '2026-03-01',\n end: '2026-03-31',\n label: 'Mar 1 - Mar 31',\n },\n selectedMarket: 'all',\n metrics: {\n revenue: '$9,453',\n volume: '1,211',\n siteVisits: '17,935',\n conversionRate: '4.2%',\n },\n trend: {\n revenue: '+12.5%',\n volume: '+8.3%',\n siteVisits: '-2.1%',\n },\n};\n\nexport const mockTopProducts: TopProduct[] = [\n {\n id: 'prod-001',\n rank: 1,\n name: 'ageLOC LumiSpa',\n imageUrl: '',\n unitsSold: 342,\n revenue: 29580,\n volume: 245,\n trend: { units: '+15%', revenue: '+12%', volume: '+8%' },\n },\n {\n id: 'prod-002',\n rank: 2,\n name: 'Pharmanex LifePak',\n imageUrl: '',\n unitsSold: 287,\n revenue: 24395,\n volume: 198,\n trend: { units: '+8%', revenue: '+10%', volume: '+5%' },\n },\n {\n id: 'prod-003',\n rank: 3,\n name: 'ageLOC Meta',\n imageUrl: '',\n unitsSold: 256,\n revenue: 21760,\n volume: 176,\n trend: { units: '-3%', revenue: '-1%', volume: '-2%' },\n },\n {\n id: 'prod-004',\n rank: 4,\n name: 'Nu Skin 180 System',\n imageUrl: '',\n unitsSold: 198,\n revenue: 17820,\n volume: 142,\n trend: { units: '+22%', revenue: '+18%', volume: '+15%' },\n },\n {\n id: 'prod-005',\n rank: 5,\n name: 'Epoch Baobab Body Butter',\n imageUrl: '',\n unitsSold: 176,\n revenue: 8800,\n volume: 88,\n trend: { units: '+5%', revenue: '+3%', volume: '+2%' },\n },\n];\n\nexport const mockConversionData: ConversionDataPoint[] = Array.from({ length: 30 }, (_, i) => {\n const date = new Date('2026-03-01');\n date.setDate(date.getDate() + i);\n const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n return {\n date: `${months[date.getMonth()]} ${date.getDate()}`,\n rate: Number((4 + (i % 15) * 0.1).toFixed(2)),\n orders: 200 + ((i * 13) % 100),\n siteVisits: 4000 + ((i * 97) % 2000),\n };\n});\n\nexport const mockSignupData: SignupDataPoint[] = Array.from({ length: 30 }, (_, i) => {\n const date = new Date('2026-03-01');\n date.setDate(date.getDate() + i);\n const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n const total = 80 + ((i * 11) % 40);\n const members = Math.floor(total * 0.4);\n const retail = Math.floor(total * 0.35);\n const brandAffiliates = total - members - retail;\n return {\n date: `${months[date.getMonth()]} ${date.getDate()}`,\n total,\n members,\n retail,\n brandAffiliates,\n };\n});\n\nexport const mockCategories: CategoryRevenue[] = [\n {\n id: 'cat-001',\n name: 'Favorites',\n revenue: 45200,\n percentage: 29,\n color: '#C95D63',\n trend: { revenue: '+8%', units: '+10%' },\n },\n {\n id: 'cat-002',\n name: 'Daily Routine',\n revenue: 42100,\n percentage: 27,\n color: '#6C7A9B',\n trend: { revenue: '+12%', units: '+15%' },\n },\n {\n id: 'cat-003',\n name: 'Fit & Trim Body',\n revenue: 34300,\n percentage: 22,\n color: '#E8975E',\n trend: { revenue: '-3%', units: '-1%' },\n },\n {\n id: 'cat-004',\n name: 'Dull Skin',\n revenue: 24900,\n percentage: 16,\n color: '#5F8FC4',\n trend: { revenue: '+5%', units: '+7%' },\n },\n {\n id: 'cat-005',\n name: 'Acne',\n revenue: 9400,\n percentage: 6,\n color: '#A2C3B3',\n trend: { revenue: '+2%', units: '+3%' },\n },\n];\n\nexport const mockOrders: OrderHistory[] = Array.from({ length: 50 }, (_, i) => {\n const firstNames = ['Sarah', 'John', 'Emma', 'Michael', 'Olivia', 'William', 'Ava', 'James'];\n const lastNames = ['Smith', 'Johnson', 'Williams', 'Brown', 'Jones', 'Garcia', 'Miller', 'Davis'];\n const date = new Date('2026-03-31');\n date.setDate(date.getDate() - (i % 30));\n return {\n orderId: `ORD-${String(10000 + i).padStart(5, '0')}`,\n date: date.toLocaleDateString('en-US', { month: 'short', day: 'numeric', year: 'numeric' }),\n customerName: `${firstNames[i % firstNames.length]} ${lastNames[i % lastNames.length]}`,\n customerType: i % 3 === 0 ? 'Retail' : 'Member',\n items: (i % 5) + 1,\n total: Number((50 + ((i * 17) % 200) + (i % 10) * 0.1).toFixed(2)),\n bv: 30 + ((i * 9) % 150),\n };\n});\n\nexport const mockSignupDetails: SignupDetail[] = Array.from({ length: 30 }, (_, i) => {\n const firstNames = ['Alice', 'Bob', 'Carol', 'David', 'Eva', 'Frank', 'Grace', 'Henry'];\n const lastNames = ['Anderson', 'Baker', 'Clark', 'Davis', 'Evans', 'Fisher', 'Grant', 'Hall'];\n const types: ('Member' | 'Retail' | 'Brand Affiliate')[] = ['Member', 'Retail', 'Brand Affiliate'];\n const date = new Date('2026-03-31');\n date.setDate(date.getDate() - (i % 30));\n return {\n id: `SU-${String(1000 + i).padStart(4, '0')}`,\n name: `${firstNames[i % firstNames.length]} ${lastNames[i % lastNames.length]}`,\n date: date.toLocaleDateString('en-US', { month: 'short', day: 'numeric', year: 'numeric' }),\n type: types[i % types.length],\n email: `${firstNames[i % firstNames.length].toLowerCase()}.${lastNames[i % lastNames.length].toLowerCase()}@example.com`,\n status: i % 4 === 0 ? 'Pending' : 'Active',\n };\n});\n","/**\n * Mock data for the Product Offer Dashboard\n *\n * Used in Storybook stories and tests.\n */\nimport type { ProductOfferDashboardStats, TopPerformingOffer } from '../types.d';\n\n// Re-export existing shopping dashboard mock data for reused widgets\nexport { mockTopProducts, mockConversionData, mockOrders } from './mockDashboardData';\n\n/** Mock Product Offer Dashboard Stats */\nexport const mockProductOfferStats: ProductOfferDashboardStats = {\n shopTitle: 'Performance Overview',\n dateRange: {\n start: '2026-03-01',\n end: '2026-03-31',\n label: 'Mar 1 - Mar 31',\n },\n selectedMarket: 'all',\n metrics: {\n revenue: '$5,208',\n offersPurchased: '285',\n conversionRate: '4.2%',\n },\n trend: {\n revenue: '+2.3%',\n offersPurchased: '+3.7%',\n },\n};\n\n/** Mock Product Offer Stats with positive trend */\nexport const mockProductOfferStatsPositiveTrend: ProductOfferDashboardStats = {\n ...mockProductOfferStats,\n trend: {\n revenue: '+5.1%',\n offersPurchased: '+12.5%',\n },\n};\n\n/** Mock Product Offer Stats with negative trend */\nexport const mockProductOfferStatsNegativeTrend: ProductOfferDashboardStats = {\n ...mockProductOfferStats,\n trend: {\n revenue: '-1.8%',\n offersPurchased: '-3.7%',\n },\n};\n\n/** Mock Product Offer Stats with neutral trend */\nexport const mockProductOfferStatsNeutralTrend: ProductOfferDashboardStats = {\n ...mockProductOfferStats,\n trend: {\n revenue: '+0%',\n offersPurchased: '+0%',\n },\n};\n\n/** Mock Product Offer Stats with zero offers (edge case) */\nexport const mockProductOfferStatsZeroOffers: ProductOfferDashboardStats = {\n ...mockProductOfferStats,\n metrics: {\n ...mockProductOfferStats.metrics,\n offersPurchased: '0',\n },\n trend: {\n revenue: '+0%',\n offersPurchased: '+0%',\n },\n};\n\n/** Mock Top Performing Offers (5 items matching Figma) */\nexport const mockTopOffers: TopPerformingOffer[] = [\n {\n id: 'offer-1',\n name: 'Winter Skincare Bundle',\n revenue: 2800,\n percentage: 29,\n color: '#6B8E7B',\n trend: { revenue: '-4.2%' },\n },\n {\n id: 'offer-2',\n name: 'Supplement Starter Pack',\n revenue: 2500,\n percentage: 27,\n color: '#E8915A',\n trend: { revenue: '+3.1%' },\n },\n {\n id: 'offer-3',\n name: 'Holiday Special Bundle',\n revenue: 2100,\n percentage: 22,\n color: '#C75B5B',\n trend: { revenue: '-1.5%' },\n },\n {\n id: 'offer-4',\n name: 'LumiSpa Cleansing Kit',\n revenue: 1500,\n percentage: 16,\n color: '#5B8EC7',\n trend: { revenue: '+2.8%' },\n },\n {\n id: 'offer-5',\n name: 'Daily Wellness Bundle',\n revenue: 529,\n percentage: 6,\n color: '#9B8EC7',\n trend: { revenue: '+7.2%' },\n },\n];\n","/**\n * Market Constants\n *\n * Centralized market multipliers for revenue/volume calculations.\n */\n\nimport type { MarketOption } from '../types.d';\n\n/** Revenue and volume multipliers for each market */\nexport const MARKET_MULTIPLIERS: Record<MarketOption, number> = {\n all: 1,\n us: 1.2,\n ca: 0.8,\n jp: 1.5,\n kr: 0.9,\n au: 0.7,\n nz: 0.5,\n};\n\n/** Get multiplier for a specific market */\nexport function getMarketMultiplier(market: MarketOption): number {\n return MARKET_MULTIPLIERS[market] ?? 1;\n}\n\n/** Apply market multiplier to a value */\nexport function applyMarketMultiplier(value: number, market: MarketOption): number {\n return Math.round(value * getMarketMultiplier(market));\n}\n\n/** Get human-readable display name for market */\nexport function getMarketDisplayName(market: MarketOption): string {\n const names: Record<MarketOption, string> = {\n all: 'All Markets',\n us: 'US',\n ca: 'Canada',\n jp: 'Japan',\n kr: 'Korea',\n au: 'Australia',\n nz: 'New Zealand',\n };\n return names[market] ?? market;\n}\n"]}