@anker-in/headless-ui 1.1.33 → 1.1.34-alpha.1768461697532

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 (856) hide show
  1. package/dist/cjs/biz-components/AccordionCards/index.d.ts +3 -3
  2. package/dist/cjs/biz-components/ActiveShelf/index.d.ts +222 -0
  3. package/dist/cjs/biz-components/ActiveShelf/index.js +2 -0
  4. package/dist/cjs/biz-components/ActiveShelf/index.js.map +7 -0
  5. package/dist/cjs/biz-components/ActiveShelf/types.d.ts +22 -0
  6. package/dist/cjs/biz-components/ActiveShelf/types.js +2 -0
  7. package/dist/cjs/biz-components/ActiveShelf/types.js.map +7 -0
  8. package/dist/cjs/biz-components/AiuiProvider/index.d.ts +7 -0
  9. package/dist/cjs/biz-components/AiuiProvider/index.js +1 -1
  10. package/dist/cjs/biz-components/AiuiProvider/index.js.map +2 -2
  11. package/dist/cjs/biz-components/AnchorNavigation/index.d.ts +42 -0
  12. package/dist/cjs/biz-components/AnchorNavigation/index.js +2 -0
  13. package/dist/cjs/biz-components/AnchorNavigation/index.js.map +7 -0
  14. package/dist/cjs/biz-components/AnchorNavigation/useAnchorPosition.d.ts +2 -0
  15. package/dist/cjs/biz-components/AnchorNavigation/useAnchorPosition.js +2 -0
  16. package/dist/cjs/biz-components/AnchorNavigation/useAnchorPosition.js.map +7 -0
  17. package/dist/cjs/biz-components/AplusDesc/index.d.ts +3 -3
  18. package/dist/cjs/biz-components/BrandCardLink/BrandCardLink.d.ts +3 -3
  19. package/dist/cjs/biz-components/BrandCardLink/BrandCardLink.js +1 -1
  20. package/dist/cjs/biz-components/BrandCardLink/BrandCardLink.js.map +1 -1
  21. package/dist/cjs/biz-components/BrandEquity/BrandEquity.d.ts +3 -3
  22. package/dist/cjs/biz-components/BrandEquity/BrandEquity.js +1 -1
  23. package/dist/cjs/biz-components/BrandEquity/BrandEquity.js.map +3 -3
  24. package/dist/cjs/biz-components/BrandEquity/types.d.ts +1 -0
  25. package/dist/cjs/biz-components/BrandEquity/types.js +1 -1
  26. package/dist/cjs/biz-components/BrandEquity/types.js.map +1 -1
  27. package/dist/cjs/biz-components/BuyOneGetOneShelf/ProductCard.d.ts +74 -0
  28. package/dist/cjs/biz-components/BuyOneGetOneShelf/ProductCard.js +2 -0
  29. package/dist/cjs/biz-components/BuyOneGetOneShelf/ProductCard.js.map +7 -0
  30. package/dist/cjs/biz-components/BuyOneGetOneShelf/hooks/useBogoDataTransform.d.ts +36 -0
  31. package/dist/cjs/biz-components/BuyOneGetOneShelf/hooks/useBogoDataTransform.js +2 -0
  32. package/dist/cjs/biz-components/BuyOneGetOneShelf/hooks/useBogoDataTransform.js.map +7 -0
  33. package/dist/cjs/biz-components/BuyOneGetOneShelf/index.d.ts +193 -0
  34. package/dist/cjs/biz-components/BuyOneGetOneShelf/index.js +2 -0
  35. package/dist/cjs/biz-components/BuyOneGetOneShelf/index.js.map +7 -0
  36. package/dist/cjs/biz-components/Category/index.d.ts +3 -3
  37. package/dist/cjs/biz-components/CreativeModule/index.d.ts +3 -3
  38. package/dist/cjs/biz-components/DownLoad/index.d.ts +3 -3
  39. package/dist/cjs/biz-components/Evaluate/index.d.ts +3 -3
  40. package/dist/cjs/biz-components/EventSchedule/index.d.ts +63 -0
  41. package/dist/cjs/biz-components/EventSchedule/index.js +2 -0
  42. package/dist/cjs/biz-components/EventSchedule/index.js.map +7 -0
  43. package/dist/cjs/biz-components/Faq/Faq.d.ts +3 -3
  44. package/dist/cjs/biz-components/FeatureCards/FeatureCards.d.ts +3 -3
  45. package/dist/cjs/biz-components/FeatureShowcase/FeatureShowcase.d.ts +3 -3
  46. package/dist/cjs/biz-components/Features/index.d.ts +3 -3
  47. package/dist/cjs/biz-components/FootCharger/index.d.ts +3 -3
  48. package/dist/cjs/biz-components/FooterNavigation/index.d.ts +3 -3
  49. package/dist/cjs/biz-components/GiftBox/index.d.ts +3 -3
  50. package/dist/cjs/biz-components/Graphic/index.d.ts +3 -3
  51. package/dist/cjs/biz-components/GraphicAttractionBlock/index.d.ts +3 -3
  52. package/dist/cjs/biz-components/GraphicMore/index.d.ts +3 -3
  53. package/dist/cjs/biz-components/GraphicOverlay/GraphicOverlay.d.ts +3 -3
  54. package/dist/cjs/biz-components/HeaderNavigation/MobileSidebarMenu.js +1 -1
  55. package/dist/cjs/biz-components/HeaderNavigation/MobileSidebarMenu.js.map +3 -3
  56. package/dist/cjs/biz-components/HeaderNavigation/SidebarDropdown.js +1 -1
  57. package/dist/cjs/biz-components/HeaderNavigation/SidebarDropdown.js.map +2 -2
  58. package/dist/cjs/biz-components/HeaderNavigation/index.d.ts +3 -3
  59. package/dist/cjs/biz-components/HeroBanner/Countdown.js +1 -1
  60. package/dist/cjs/biz-components/HeroBanner/Countdown.js.map +2 -2
  61. package/dist/cjs/biz-components/HeroBanner/HeroBanner.d.ts +6 -3
  62. package/dist/cjs/biz-components/HeroBanner/HeroBanner.js +1 -1
  63. package/dist/cjs/biz-components/HeroBanner/HeroBanner.js.map +3 -3
  64. package/dist/cjs/biz-components/IPRedirect/RegionBanner.d.ts +37 -0
  65. package/dist/cjs/biz-components/IPRedirect/RegionBanner.js +60 -0
  66. package/dist/cjs/biz-components/IPRedirect/RegionBanner.js.map +7 -0
  67. package/dist/cjs/biz-components/IPRedirect/RegionSelectorModal.d.ts +47 -0
  68. package/dist/cjs/biz-components/IPRedirect/RegionSelectorModal.js +69 -0
  69. package/dist/cjs/biz-components/IPRedirect/RegionSelectorModal.js.map +7 -0
  70. package/dist/cjs/biz-components/IPRedirect/index.d.ts +9 -0
  71. package/dist/cjs/biz-components/IPRedirect/index.js +2 -0
  72. package/dist/cjs/biz-components/IPRedirect/index.js.map +7 -0
  73. package/dist/cjs/biz-components/IPRedirect/type.d.ts +36 -0
  74. package/dist/cjs/biz-components/IPRedirect/type.js +2 -0
  75. package/dist/cjs/biz-components/IPRedirect/type.js.map +7 -0
  76. package/dist/cjs/biz-components/IPRedirect/useAutoRedirect.d.ts +66 -0
  77. package/dist/cjs/biz-components/IPRedirect/useAutoRedirect.js +2 -0
  78. package/dist/cjs/biz-components/IPRedirect/useAutoRedirect.js.map +7 -0
  79. package/dist/cjs/biz-components/IPRedirect/useDetectedRegionRedirect.d.ts +51 -0
  80. package/dist/cjs/biz-components/IPRedirect/useDetectedRegionRedirect.js +2 -0
  81. package/dist/cjs/biz-components/IPRedirect/useDetectedRegionRedirect.js.map +7 -0
  82. package/dist/cjs/biz-components/IPRedirect/useIPRedirect.d.ts +42 -0
  83. package/dist/cjs/biz-components/IPRedirect/useIPRedirect.js +2 -0
  84. package/dist/cjs/biz-components/IPRedirect/useIPRedirect.js.map +7 -0
  85. package/dist/cjs/biz-components/IPRedirect/useRedirectBanner.d.ts +108 -0
  86. package/dist/cjs/biz-components/IPRedirect/useRedirectBanner.js +2 -0
  87. package/dist/cjs/biz-components/IPRedirect/useRedirectBanner.js.map +7 -0
  88. package/dist/cjs/biz-components/IPRedirect/useRegionRedirectManager.d.ts +152 -0
  89. package/dist/cjs/biz-components/IPRedirect/useRegionRedirectManager.js +2 -0
  90. package/dist/cjs/biz-components/IPRedirect/useRegionRedirectManager.js.map +7 -0
  91. package/dist/cjs/biz-components/IPRedirect/useSavedRegionRedirect.d.ts +51 -0
  92. package/dist/cjs/biz-components/IPRedirect/useSavedRegionRedirect.js +2 -0
  93. package/dist/cjs/biz-components/IPRedirect/useSavedRegionRedirect.js.map +7 -0
  94. package/dist/cjs/biz-components/IPRedirect/utils.d.ts +222 -0
  95. package/dist/cjs/biz-components/IPRedirect/utils.js +2 -0
  96. package/dist/cjs/biz-components/IPRedirect/utils.js.map +7 -0
  97. package/dist/cjs/biz-components/ImageOverlayShelf/index.d.ts +130 -0
  98. package/dist/cjs/biz-components/ImageOverlayShelf/index.js +2 -0
  99. package/dist/cjs/biz-components/ImageOverlayShelf/index.js.map +7 -0
  100. package/dist/cjs/biz-components/ImageTextFeature/ImageTextFeature.d.ts +3 -3
  101. package/dist/cjs/biz-components/ImageTextFeature/ImageTextFeature.js +1 -1
  102. package/dist/cjs/biz-components/ImageTextFeature/ImageTextFeature.js.map +3 -3
  103. package/dist/cjs/biz-components/ImageWithText/ImageWithText.d.ts +3 -3
  104. package/dist/cjs/biz-components/Ksp/index.d.ts +3 -3
  105. package/dist/cjs/biz-components/Listing/components/PaidShipping/index.d.ts +4 -4
  106. package/dist/cjs/biz-components/Listing/components/ProductCard/ProductDetail/BenefitsTab.d.ts +3 -3
  107. package/dist/cjs/biz-components/Listing/components/ProductCard/ProductDetail/ProductBundle/index.d.ts +3 -3
  108. package/dist/cjs/biz-components/Listing/components/ProductCard/ProductDetail/ProductExchangePurchase/index.d.ts +3 -3
  109. package/dist/cjs/biz-components/Listing/components/ProductCard/ProductDetail/ProductFreeGift/index.d.ts +3 -3
  110. package/dist/cjs/biz-components/Listing/components/ProductCard/ProductDetail/ProductHighlight/index.d.ts +3 -3
  111. package/dist/cjs/biz-components/Listing/components/ProductCard/ProductDetail/ProductOptions/index.d.ts +3 -3
  112. package/dist/cjs/biz-components/Listing/components/ProductCard/ProductGallery/index.d.ts +3 -3
  113. package/dist/cjs/biz-components/Listing/components/ProductCard/ProductSummary/index.d.ts +3 -3
  114. package/dist/cjs/biz-components/Listing/components/PurchaseBar/index.d.ts +3 -3
  115. package/dist/cjs/biz-components/Marquee/Marquee.d.ts +3 -3
  116. package/dist/cjs/biz-components/Marquee/Marquee.js +1 -1
  117. package/dist/cjs/biz-components/Marquee/Marquee.js.map +3 -3
  118. package/dist/cjs/biz-components/MarqueeReview/index.d.ts +3 -3
  119. package/dist/cjs/biz-components/Media/index.d.ts +32 -0
  120. package/dist/cjs/biz-components/Media/index.js +2 -0
  121. package/dist/cjs/biz-components/Media/index.js.map +7 -0
  122. package/dist/cjs/biz-components/MediaPlayerBase/index.d.ts +3 -3
  123. package/dist/cjs/biz-components/MediaPlayerMulti/index.d.ts +3 -3
  124. package/dist/cjs/biz-components/MediaPlayerSticky/index.d.ts +4 -4
  125. package/dist/cjs/biz-components/MediaPlayerSticky/types.d.ts +1 -0
  126. package/dist/cjs/biz-components/MediaPlayerSticky/types.js +1 -1
  127. package/dist/cjs/biz-components/MediaPlayerSticky/types.js.map +1 -1
  128. package/dist/cjs/biz-components/MediaSceneSwitcher/MediaSceneSwitcher.d.ts +3 -3
  129. package/dist/cjs/biz-components/MediaShelf/index.d.ts +216 -0
  130. package/dist/cjs/biz-components/MediaShelf/index.js +2 -0
  131. package/dist/cjs/biz-components/MediaShelf/index.js.map +7 -0
  132. package/dist/cjs/biz-components/MediaShelf/types.d.ts +22 -0
  133. package/dist/cjs/biz-components/MediaShelf/types.js +2 -0
  134. package/dist/cjs/biz-components/MediaShelf/types.js.map +7 -0
  135. package/dist/cjs/biz-components/MemberEquity/index.d.ts +3 -3
  136. package/dist/cjs/biz-components/MiniCart/index.d.ts +88 -0
  137. package/dist/cjs/biz-components/MiniCart/index.js +2 -0
  138. package/dist/cjs/biz-components/MiniCart/index.js.map +7 -0
  139. package/dist/cjs/biz-components/MultiLayoutGraphicBlock/MultiLayoutGraphicBlock.d.ts +3 -3
  140. package/dist/cjs/biz-components/ProductCompare/index.d.ts +3 -3
  141. package/dist/cjs/biz-components/ProductHero/ProductHero.d.ts +3 -3
  142. package/dist/cjs/biz-components/ProductNav/ProductNav.d.ts +3 -3
  143. package/dist/cjs/biz-components/PromotionalBar/index.d.ts +49 -0
  144. package/dist/cjs/biz-components/PromotionalBar/index.js +2 -0
  145. package/dist/cjs/biz-components/PromotionalBar/index.js.map +7 -0
  146. package/dist/cjs/biz-components/SecondaryBanner/index.d.ts +69 -0
  147. package/dist/cjs/biz-components/SecondaryBanner/index.js +2 -0
  148. package/dist/cjs/biz-components/SecondaryBanner/index.js.map +7 -0
  149. package/dist/cjs/biz-components/SelectStore/index.d.ts +3 -3
  150. package/dist/cjs/biz-components/ShelfDisplay/index.d.ts +3 -3
  151. package/dist/cjs/biz-components/ShelfDisplay/shelfDisplay.d.ts +0 -11
  152. package/dist/cjs/biz-components/ShelfDisplay/shelfDisplay.js +1 -1
  153. package/dist/cjs/biz-components/ShelfDisplay/shelfDisplay.js.map +3 -3
  154. package/dist/cjs/biz-components/Slogan/index.d.ts +3 -3
  155. package/dist/cjs/biz-components/Spacer/index.d.ts +3 -3
  156. package/dist/cjs/biz-components/Specs/index.d.ts +3 -3
  157. package/dist/cjs/biz-components/Specs/index.js +1 -1
  158. package/dist/cjs/biz-components/Specs/index.js.map +2 -2
  159. package/dist/cjs/biz-components/SpecsComparison/SpecsComparison.d.ts +3 -3
  160. package/dist/cjs/biz-components/TabWithImage/TabWithImage.d.ts +3 -3
  161. package/dist/cjs/biz-components/Tabs/Tabs.d.ts +3 -3
  162. package/dist/cjs/biz-components/TabsGroup/index.d.ts +3 -3
  163. package/dist/cjs/biz-components/TabsWithMedia/TabsWithMedia.d.ts +3 -3
  164. package/dist/cjs/biz-components/ThreeDCarousel/ThreeDCarousel.d.ts +3 -3
  165. package/dist/cjs/biz-components/Title/Countdown.d.ts +14 -0
  166. package/dist/cjs/biz-components/Title/Countdown.js +2 -0
  167. package/dist/cjs/biz-components/Title/Countdown.js.map +7 -0
  168. package/dist/cjs/biz-components/Title/index.d.ts +3 -3
  169. package/dist/cjs/biz-components/Title/index.js +1 -1
  170. package/dist/cjs/biz-components/Title/index.js.map +3 -3
  171. package/dist/cjs/biz-components/Title/types.d.ts +55 -0
  172. package/dist/cjs/biz-components/Title/types.js +1 -1
  173. package/dist/cjs/biz-components/Title/types.js.map +1 -1
  174. package/dist/cjs/biz-components/VideoFeature/VideoFeature.d.ts +3 -3
  175. package/dist/cjs/biz-components/WheelLottery/BaseModal.d.ts +55 -0
  176. package/dist/cjs/biz-components/WheelLottery/BaseModal.js +12 -0
  177. package/dist/cjs/biz-components/WheelLottery/BaseModal.js.map +7 -0
  178. package/dist/cjs/biz-components/WheelLottery/ChanceMethods.d.ts +30 -0
  179. package/dist/cjs/biz-components/WheelLottery/ChanceMethods.js +2 -0
  180. package/dist/cjs/biz-components/WheelLottery/ChanceMethods.js.map +7 -0
  181. package/dist/cjs/biz-components/WheelLottery/ErrorModal.d.ts +42 -0
  182. package/dist/cjs/biz-components/WheelLottery/ErrorModal.js +2 -0
  183. package/dist/cjs/biz-components/WheelLottery/ErrorModal.js.map +7 -0
  184. package/dist/cjs/biz-components/WheelLottery/MyRewardsModal.d.ts +91 -0
  185. package/dist/cjs/biz-components/WheelLottery/MyRewardsModal.js +2 -0
  186. package/dist/cjs/biz-components/WheelLottery/MyRewardsModal.js.map +7 -0
  187. package/dist/cjs/biz-components/WheelLottery/PrizePool.d.ts +26 -0
  188. package/dist/cjs/biz-components/WheelLottery/PrizePool.js +2 -0
  189. package/dist/cjs/biz-components/WheelLottery/PrizePool.js.map +7 -0
  190. package/dist/cjs/biz-components/WheelLottery/RulesModal.d.ts +43 -0
  191. package/dist/cjs/biz-components/WheelLottery/RulesModal.js +2 -0
  192. package/dist/cjs/biz-components/WheelLottery/RulesModal.js.map +7 -0
  193. package/dist/cjs/biz-components/WheelLottery/ShareModal.d.ts +74 -0
  194. package/dist/cjs/biz-components/WheelLottery/ShareModal.js +2 -0
  195. package/dist/cjs/biz-components/WheelLottery/ShareModal.js.map +7 -0
  196. package/dist/cjs/biz-components/WheelLottery/Wheel.d.ts +27 -0
  197. package/dist/cjs/biz-components/WheelLottery/Wheel.js +2 -0
  198. package/dist/cjs/biz-components/WheelLottery/Wheel.js.map +7 -0
  199. package/dist/cjs/biz-components/WheelLottery/WinnerModal.d.ts +25 -0
  200. package/dist/cjs/biz-components/WheelLottery/WinnerModal.js +2 -0
  201. package/dist/cjs/biz-components/WheelLottery/WinnerModal.js.map +7 -0
  202. package/dist/cjs/biz-components/WheelLottery/index.d.ts +52 -0
  203. package/dist/cjs/biz-components/WheelLottery/index.js +2 -0
  204. package/dist/cjs/biz-components/WheelLottery/index.js.map +7 -0
  205. package/dist/cjs/biz-components/WheelLottery/types.d.ts +1193 -0
  206. package/dist/cjs/biz-components/WheelLottery/types.js +2 -0
  207. package/dist/cjs/biz-components/WheelLottery/types.js.map +7 -0
  208. package/dist/cjs/biz-components/WhyChoose/WhyChoose.d.ts +3 -3
  209. package/dist/cjs/biz-components/index.d.ts +30 -2
  210. package/dist/cjs/biz-components/index.js +1 -1
  211. package/dist/cjs/biz-components/index.js.map +3 -3
  212. package/dist/cjs/components/badge.js +1 -1
  213. package/dist/cjs/components/badge.js.map +2 -2
  214. package/dist/cjs/components/index.d.ts +2 -0
  215. package/dist/cjs/components/index.js +1 -1
  216. package/dist/cjs/components/index.js.map +3 -3
  217. package/dist/cjs/components/paginator.d.ts +12 -0
  218. package/dist/cjs/components/paginator.js +7 -0
  219. package/dist/cjs/components/paginator.js.map +7 -0
  220. package/dist/cjs/components/progress.d.ts +46 -0
  221. package/dist/cjs/components/progress.js +2 -0
  222. package/dist/cjs/components/progress.js.map +7 -0
  223. package/dist/cjs/components/tabs.d.ts +2 -1
  224. package/dist/cjs/components/tabs.js +1 -1
  225. package/dist/cjs/components/tabs.js.map +2 -2
  226. package/dist/cjs/helpers/index.d.ts +1 -0
  227. package/dist/cjs/helpers/index.js +1 -1
  228. package/dist/cjs/helpers/index.js.map +3 -3
  229. package/dist/cjs/helpers/priceFormatting.d.ts +11 -0
  230. package/dist/cjs/helpers/priceFormatting.js +2 -0
  231. package/dist/cjs/helpers/priceFormatting.js.map +7 -0
  232. package/dist/cjs/shared/Styles.d.ts +5 -4
  233. package/dist/cjs/shared/Styles.js +1 -1
  234. package/dist/cjs/shared/Styles.js.map +3 -3
  235. package/dist/cjs/types/props.d.ts +0 -3
  236. package/dist/cjs/types/props.js +1 -1
  237. package/dist/cjs/types/props.js.map +1 -1
  238. package/dist/esm/biz-components/AccordionCards/index.d.ts +3 -3
  239. package/dist/esm/biz-components/ActiveShelf/index.d.ts +222 -0
  240. package/dist/esm/biz-components/ActiveShelf/index.js +2 -0
  241. package/dist/esm/biz-components/ActiveShelf/index.js.map +7 -0
  242. package/dist/esm/biz-components/ActiveShelf/types.d.ts +22 -0
  243. package/dist/esm/biz-components/ActiveShelf/types.js +1 -0
  244. package/dist/esm/biz-components/ActiveShelf/types.js.map +7 -0
  245. package/dist/esm/biz-components/AiuiProvider/index.d.ts +7 -0
  246. package/dist/esm/biz-components/AiuiProvider/index.js +1 -1
  247. package/dist/esm/biz-components/AiuiProvider/index.js.map +2 -2
  248. package/dist/esm/biz-components/AnchorNavigation/index.d.ts +42 -0
  249. package/dist/esm/biz-components/AnchorNavigation/index.js +2 -0
  250. package/dist/esm/biz-components/AnchorNavigation/index.js.map +7 -0
  251. package/dist/esm/biz-components/AnchorNavigation/useAnchorPosition.d.ts +2 -0
  252. package/dist/esm/biz-components/AnchorNavigation/useAnchorPosition.js +2 -0
  253. package/dist/esm/biz-components/AnchorNavigation/useAnchorPosition.js.map +7 -0
  254. package/dist/esm/biz-components/AplusDesc/index.d.ts +3 -3
  255. package/dist/esm/biz-components/BrandCardLink/BrandCardLink.d.ts +3 -3
  256. package/dist/esm/biz-components/BrandCardLink/BrandCardLink.js +1 -1
  257. package/dist/esm/biz-components/BrandCardLink/BrandCardLink.js.map +1 -1
  258. package/dist/esm/biz-components/BrandEquity/BrandEquity.d.ts +3 -3
  259. package/dist/esm/biz-components/BrandEquity/BrandEquity.js +1 -1
  260. package/dist/esm/biz-components/BrandEquity/BrandEquity.js.map +3 -3
  261. package/dist/esm/biz-components/BrandEquity/types.d.ts +1 -0
  262. package/dist/esm/biz-components/BuyOneGetOneShelf/ProductCard.d.ts +74 -0
  263. package/dist/esm/biz-components/BuyOneGetOneShelf/ProductCard.js +2 -0
  264. package/dist/esm/biz-components/BuyOneGetOneShelf/ProductCard.js.map +7 -0
  265. package/dist/esm/biz-components/BuyOneGetOneShelf/hooks/useBogoDataTransform.d.ts +36 -0
  266. package/dist/esm/biz-components/BuyOneGetOneShelf/hooks/useBogoDataTransform.js +2 -0
  267. package/dist/esm/biz-components/BuyOneGetOneShelf/hooks/useBogoDataTransform.js.map +7 -0
  268. package/dist/esm/biz-components/BuyOneGetOneShelf/index.d.ts +193 -0
  269. package/dist/esm/biz-components/BuyOneGetOneShelf/index.js +2 -0
  270. package/dist/esm/biz-components/BuyOneGetOneShelf/index.js.map +7 -0
  271. package/dist/esm/biz-components/Category/index.d.ts +3 -3
  272. package/dist/esm/biz-components/CreativeModule/index.d.ts +3 -3
  273. package/dist/esm/biz-components/DownLoad/index.d.ts +3 -3
  274. package/dist/esm/biz-components/Evaluate/index.d.ts +3 -3
  275. package/dist/esm/biz-components/EventSchedule/index.d.ts +63 -0
  276. package/dist/esm/biz-components/EventSchedule/index.js +2 -0
  277. package/dist/esm/biz-components/EventSchedule/index.js.map +7 -0
  278. package/dist/esm/biz-components/Faq/Faq.d.ts +3 -3
  279. package/dist/esm/biz-components/FeatureCards/FeatureCards.d.ts +3 -3
  280. package/dist/esm/biz-components/FeatureShowcase/FeatureShowcase.d.ts +3 -3
  281. package/dist/esm/biz-components/Features/index.d.ts +3 -3
  282. package/dist/esm/biz-components/FootCharger/index.d.ts +3 -3
  283. package/dist/esm/biz-components/FooterNavigation/index.d.ts +3 -3
  284. package/dist/esm/biz-components/GiftBox/index.d.ts +3 -3
  285. package/dist/esm/biz-components/Graphic/index.d.ts +3 -3
  286. package/dist/esm/biz-components/GraphicAttractionBlock/index.d.ts +3 -3
  287. package/dist/esm/biz-components/GraphicMore/index.d.ts +3 -3
  288. package/dist/esm/biz-components/GraphicOverlay/GraphicOverlay.d.ts +3 -3
  289. package/dist/esm/biz-components/HeaderNavigation/MobileSidebarMenu.js +1 -1
  290. package/dist/esm/biz-components/HeaderNavigation/MobileSidebarMenu.js.map +3 -3
  291. package/dist/esm/biz-components/HeaderNavigation/SidebarDropdown.js +1 -1
  292. package/dist/esm/biz-components/HeaderNavigation/SidebarDropdown.js.map +2 -2
  293. package/dist/esm/biz-components/HeaderNavigation/index.d.ts +3 -3
  294. package/dist/esm/biz-components/HeroBanner/Countdown.js +1 -1
  295. package/dist/esm/biz-components/HeroBanner/Countdown.js.map +2 -2
  296. package/dist/esm/biz-components/HeroBanner/HeroBanner.d.ts +6 -3
  297. package/dist/esm/biz-components/HeroBanner/HeroBanner.js +1 -1
  298. package/dist/esm/biz-components/HeroBanner/HeroBanner.js.map +3 -3
  299. package/dist/esm/biz-components/IPRedirect/RegionBanner.d.ts +37 -0
  300. package/dist/esm/biz-components/IPRedirect/RegionBanner.js +60 -0
  301. package/dist/esm/biz-components/IPRedirect/RegionBanner.js.map +7 -0
  302. package/dist/esm/biz-components/IPRedirect/RegionSelectorModal.d.ts +47 -0
  303. package/dist/esm/biz-components/IPRedirect/RegionSelectorModal.js +69 -0
  304. package/dist/esm/biz-components/IPRedirect/RegionSelectorModal.js.map +7 -0
  305. package/dist/esm/biz-components/IPRedirect/index.d.ts +9 -0
  306. package/dist/esm/biz-components/IPRedirect/index.js +2 -0
  307. package/dist/esm/biz-components/IPRedirect/index.js.map +7 -0
  308. package/dist/esm/biz-components/IPRedirect/type.d.ts +36 -0
  309. package/dist/esm/biz-components/IPRedirect/type.js +1 -0
  310. package/dist/esm/biz-components/IPRedirect/type.js.map +7 -0
  311. package/dist/esm/biz-components/IPRedirect/useAutoRedirect.d.ts +66 -0
  312. package/dist/esm/biz-components/IPRedirect/useAutoRedirect.js +2 -0
  313. package/dist/esm/biz-components/IPRedirect/useAutoRedirect.js.map +7 -0
  314. package/dist/esm/biz-components/IPRedirect/useDetectedRegionRedirect.d.ts +51 -0
  315. package/dist/esm/biz-components/IPRedirect/useDetectedRegionRedirect.js +2 -0
  316. package/dist/esm/biz-components/IPRedirect/useDetectedRegionRedirect.js.map +7 -0
  317. package/dist/esm/biz-components/IPRedirect/useIPRedirect.d.ts +42 -0
  318. package/dist/esm/biz-components/IPRedirect/useIPRedirect.js +2 -0
  319. package/dist/esm/biz-components/IPRedirect/useIPRedirect.js.map +7 -0
  320. package/dist/esm/biz-components/IPRedirect/useRedirectBanner.d.ts +108 -0
  321. package/dist/esm/biz-components/IPRedirect/useRedirectBanner.js +2 -0
  322. package/dist/esm/biz-components/IPRedirect/useRedirectBanner.js.map +7 -0
  323. package/dist/esm/biz-components/IPRedirect/useRegionRedirectManager.d.ts +152 -0
  324. package/dist/esm/biz-components/IPRedirect/useRegionRedirectManager.js +2 -0
  325. package/dist/esm/biz-components/IPRedirect/useRegionRedirectManager.js.map +7 -0
  326. package/dist/esm/biz-components/IPRedirect/useSavedRegionRedirect.d.ts +51 -0
  327. package/dist/esm/biz-components/IPRedirect/useSavedRegionRedirect.js +2 -0
  328. package/dist/esm/biz-components/IPRedirect/useSavedRegionRedirect.js.map +7 -0
  329. package/dist/esm/biz-components/IPRedirect/utils.d.ts +222 -0
  330. package/dist/esm/biz-components/IPRedirect/utils.js +2 -0
  331. package/dist/esm/biz-components/IPRedirect/utils.js.map +7 -0
  332. package/dist/esm/biz-components/ImageOverlayShelf/index.d.ts +130 -0
  333. package/dist/esm/biz-components/ImageOverlayShelf/index.js +2 -0
  334. package/dist/esm/biz-components/ImageOverlayShelf/index.js.map +7 -0
  335. package/dist/esm/biz-components/ImageTextFeature/ImageTextFeature.d.ts +3 -3
  336. package/dist/esm/biz-components/ImageTextFeature/ImageTextFeature.js +1 -1
  337. package/dist/esm/biz-components/ImageTextFeature/ImageTextFeature.js.map +3 -3
  338. package/dist/esm/biz-components/ImageWithText/ImageWithText.d.ts +3 -3
  339. package/dist/esm/biz-components/Ksp/index.d.ts +3 -3
  340. package/dist/esm/biz-components/Listing/components/PaidShipping/index.d.ts +4 -4
  341. package/dist/esm/biz-components/Listing/components/ProductCard/ProductDetail/BenefitsTab.d.ts +3 -3
  342. package/dist/esm/biz-components/Listing/components/ProductCard/ProductDetail/ProductBundle/index.d.ts +3 -3
  343. package/dist/esm/biz-components/Listing/components/ProductCard/ProductDetail/ProductExchangePurchase/index.d.ts +3 -3
  344. package/dist/esm/biz-components/Listing/components/ProductCard/ProductDetail/ProductFreeGift/index.d.ts +3 -3
  345. package/dist/esm/biz-components/Listing/components/ProductCard/ProductDetail/ProductHighlight/index.d.ts +3 -3
  346. package/dist/esm/biz-components/Listing/components/ProductCard/ProductDetail/ProductOptions/index.d.ts +3 -3
  347. package/dist/esm/biz-components/Listing/components/ProductCard/ProductGallery/index.d.ts +3 -3
  348. package/dist/esm/biz-components/Listing/components/ProductCard/ProductSummary/index.d.ts +3 -3
  349. package/dist/esm/biz-components/Listing/components/PurchaseBar/index.d.ts +3 -3
  350. package/dist/esm/biz-components/Marquee/Marquee.d.ts +3 -3
  351. package/dist/esm/biz-components/Marquee/Marquee.js +1 -1
  352. package/dist/esm/biz-components/Marquee/Marquee.js.map +3 -3
  353. package/dist/esm/biz-components/MarqueeReview/index.d.ts +3 -3
  354. package/dist/esm/biz-components/Media/index.d.ts +32 -0
  355. package/dist/esm/biz-components/Media/index.js +2 -0
  356. package/dist/esm/biz-components/Media/index.js.map +7 -0
  357. package/dist/esm/biz-components/MediaPlayerBase/index.d.ts +3 -3
  358. package/dist/esm/biz-components/MediaPlayerMulti/index.d.ts +3 -3
  359. package/dist/esm/biz-components/MediaPlayerSticky/index.d.ts +4 -4
  360. package/dist/esm/biz-components/MediaPlayerSticky/types.d.ts +1 -0
  361. package/dist/esm/biz-components/MediaSceneSwitcher/MediaSceneSwitcher.d.ts +3 -3
  362. package/dist/esm/biz-components/MediaShelf/index.d.ts +216 -0
  363. package/dist/esm/biz-components/MediaShelf/index.js +2 -0
  364. package/dist/esm/biz-components/MediaShelf/index.js.map +7 -0
  365. package/dist/esm/biz-components/MediaShelf/types.d.ts +22 -0
  366. package/dist/esm/biz-components/MediaShelf/types.js +1 -0
  367. package/dist/esm/biz-components/MediaShelf/types.js.map +7 -0
  368. package/dist/esm/biz-components/MemberEquity/index.d.ts +3 -3
  369. package/dist/esm/biz-components/MiniCart/index.d.ts +88 -0
  370. package/dist/esm/biz-components/MiniCart/index.js +2 -0
  371. package/dist/esm/biz-components/MiniCart/index.js.map +7 -0
  372. package/dist/esm/biz-components/MultiLayoutGraphicBlock/MultiLayoutGraphicBlock.d.ts +3 -3
  373. package/dist/esm/biz-components/ProductCompare/index.d.ts +3 -3
  374. package/dist/esm/biz-components/ProductHero/ProductHero.d.ts +3 -3
  375. package/dist/esm/biz-components/ProductNav/ProductNav.d.ts +3 -3
  376. package/dist/esm/biz-components/PromotionalBar/index.d.ts +49 -0
  377. package/dist/esm/biz-components/PromotionalBar/index.js +2 -0
  378. package/dist/esm/biz-components/PromotionalBar/index.js.map +7 -0
  379. package/dist/esm/biz-components/SecondaryBanner/index.d.ts +69 -0
  380. package/dist/esm/biz-components/SecondaryBanner/index.js +2 -0
  381. package/dist/esm/biz-components/SecondaryBanner/index.js.map +7 -0
  382. package/dist/esm/biz-components/SelectStore/index.d.ts +3 -3
  383. package/dist/esm/biz-components/ShelfDisplay/index.d.ts +3 -3
  384. package/dist/esm/biz-components/ShelfDisplay/shelfDisplay.d.ts +0 -11
  385. package/dist/esm/biz-components/ShelfDisplay/shelfDisplay.js +1 -1
  386. package/dist/esm/biz-components/ShelfDisplay/shelfDisplay.js.map +3 -3
  387. package/dist/esm/biz-components/Slogan/index.d.ts +3 -3
  388. package/dist/esm/biz-components/Spacer/index.d.ts +3 -3
  389. package/dist/esm/biz-components/Specs/index.d.ts +3 -3
  390. package/dist/esm/biz-components/Specs/index.js +1 -1
  391. package/dist/esm/biz-components/Specs/index.js.map +2 -2
  392. package/dist/esm/biz-components/SpecsComparison/SpecsComparison.d.ts +3 -3
  393. package/dist/esm/biz-components/TabWithImage/TabWithImage.d.ts +3 -3
  394. package/dist/esm/biz-components/Tabs/Tabs.d.ts +3 -3
  395. package/dist/esm/biz-components/TabsGroup/index.d.ts +3 -3
  396. package/dist/esm/biz-components/TabsWithMedia/TabsWithMedia.d.ts +3 -3
  397. package/dist/esm/biz-components/ThreeDCarousel/ThreeDCarousel.d.ts +3 -3
  398. package/dist/esm/biz-components/Title/Countdown.d.ts +14 -0
  399. package/dist/esm/biz-components/Title/Countdown.js +2 -0
  400. package/dist/esm/biz-components/Title/Countdown.js.map +7 -0
  401. package/dist/esm/biz-components/Title/index.d.ts +3 -3
  402. package/dist/esm/biz-components/Title/index.js +1 -1
  403. package/dist/esm/biz-components/Title/index.js.map +3 -3
  404. package/dist/esm/biz-components/Title/types.d.ts +55 -0
  405. package/dist/esm/biz-components/VideoFeature/VideoFeature.d.ts +3 -3
  406. package/dist/esm/biz-components/WheelLottery/BaseModal.d.ts +55 -0
  407. package/dist/esm/biz-components/WheelLottery/BaseModal.js +12 -0
  408. package/dist/esm/biz-components/WheelLottery/BaseModal.js.map +7 -0
  409. package/dist/esm/biz-components/WheelLottery/ChanceMethods.d.ts +30 -0
  410. package/dist/esm/biz-components/WheelLottery/ChanceMethods.js +2 -0
  411. package/dist/esm/biz-components/WheelLottery/ChanceMethods.js.map +7 -0
  412. package/dist/esm/biz-components/WheelLottery/ErrorModal.d.ts +42 -0
  413. package/dist/esm/biz-components/WheelLottery/ErrorModal.js +2 -0
  414. package/dist/esm/biz-components/WheelLottery/ErrorModal.js.map +7 -0
  415. package/dist/esm/biz-components/WheelLottery/MyRewardsModal.d.ts +91 -0
  416. package/dist/esm/biz-components/WheelLottery/MyRewardsModal.js +2 -0
  417. package/dist/esm/biz-components/WheelLottery/MyRewardsModal.js.map +7 -0
  418. package/dist/esm/biz-components/WheelLottery/PrizePool.d.ts +26 -0
  419. package/dist/esm/biz-components/WheelLottery/PrizePool.js +2 -0
  420. package/dist/esm/biz-components/WheelLottery/PrizePool.js.map +7 -0
  421. package/dist/esm/biz-components/WheelLottery/RulesModal.d.ts +43 -0
  422. package/dist/esm/biz-components/WheelLottery/RulesModal.js +2 -0
  423. package/dist/esm/biz-components/WheelLottery/RulesModal.js.map +7 -0
  424. package/dist/esm/biz-components/WheelLottery/ShareModal.d.ts +74 -0
  425. package/dist/esm/biz-components/WheelLottery/ShareModal.js +2 -0
  426. package/dist/esm/biz-components/WheelLottery/ShareModal.js.map +7 -0
  427. package/dist/esm/biz-components/WheelLottery/Wheel.d.ts +27 -0
  428. package/dist/esm/biz-components/WheelLottery/Wheel.js +2 -0
  429. package/dist/esm/biz-components/WheelLottery/Wheel.js.map +7 -0
  430. package/dist/esm/biz-components/WheelLottery/WinnerModal.d.ts +25 -0
  431. package/dist/esm/biz-components/WheelLottery/WinnerModal.js +2 -0
  432. package/dist/esm/biz-components/WheelLottery/WinnerModal.js.map +7 -0
  433. package/dist/esm/biz-components/WheelLottery/index.d.ts +52 -0
  434. package/dist/esm/biz-components/WheelLottery/index.js +2 -0
  435. package/dist/esm/biz-components/WheelLottery/index.js.map +7 -0
  436. package/dist/esm/biz-components/WheelLottery/types.d.ts +1193 -0
  437. package/dist/esm/biz-components/WheelLottery/types.js +2 -0
  438. package/dist/esm/biz-components/WheelLottery/types.js.map +7 -0
  439. package/dist/esm/biz-components/WhyChoose/WhyChoose.d.ts +3 -3
  440. package/dist/esm/biz-components/index.d.ts +30 -2
  441. package/dist/esm/biz-components/index.js +1 -1
  442. package/dist/esm/biz-components/index.js.map +3 -3
  443. package/dist/esm/components/badge.js +1 -1
  444. package/dist/esm/components/badge.js.map +2 -2
  445. package/dist/esm/components/index.d.ts +2 -0
  446. package/dist/esm/components/index.js +1 -1
  447. package/dist/esm/components/index.js.map +2 -2
  448. package/dist/esm/components/paginator.d.ts +12 -0
  449. package/dist/esm/components/paginator.js +7 -0
  450. package/dist/esm/components/paginator.js.map +7 -0
  451. package/dist/esm/components/progress.d.ts +46 -0
  452. package/dist/esm/components/progress.js +2 -0
  453. package/dist/esm/components/progress.js.map +7 -0
  454. package/dist/esm/components/tabs.d.ts +2 -1
  455. package/dist/esm/components/tabs.js +1 -1
  456. package/dist/esm/components/tabs.js.map +2 -2
  457. package/dist/esm/helpers/index.d.ts +1 -0
  458. package/dist/esm/helpers/index.js +1 -1
  459. package/dist/esm/helpers/index.js.map +3 -3
  460. package/dist/esm/helpers/priceFormatting.d.ts +11 -0
  461. package/dist/esm/helpers/priceFormatting.js +2 -0
  462. package/dist/esm/helpers/priceFormatting.js.map +7 -0
  463. package/dist/esm/shared/Styles.d.ts +5 -4
  464. package/dist/esm/shared/Styles.js +1 -1
  465. package/dist/esm/shared/Styles.js.map +3 -3
  466. package/dist/esm/types/props.d.ts +0 -3
  467. package/dist/tokens/base.css +4 -3
  468. package/dist/tokens/eufy.css +1 -0
  469. package/dist/tokens/soundcore.css +4 -3
  470. package/package.json +8 -3
  471. package/style.css +4915 -126
  472. package/tailwind.config.js +19 -2
  473. package/dist/cjs/stories/HeroBanner.stories.d.ts +0 -28
  474. package/dist/cjs/stories/HeroBanner.stories.js +0 -11
  475. package/dist/cjs/stories/HeroBanner.stories.js.map +0 -7
  476. package/dist/cjs/stories/InlineVideo.stories.d.ts +0 -37
  477. package/dist/cjs/stories/InlineVideo.stories.js +0 -164
  478. package/dist/cjs/stories/InlineVideo.stories.js.map +0 -7
  479. package/dist/cjs/stories/MarqueeReview.stories.d.ts +0 -72
  480. package/dist/cjs/stories/MarqueeReview.stories.js +0 -19
  481. package/dist/cjs/stories/MarqueeReview.stories.js.map +0 -7
  482. package/dist/cjs/stories/MediaSceneSwitcher.stories.d.ts +0 -47
  483. package/dist/cjs/stories/MediaSceneSwitcher.stories.js +0 -2
  484. package/dist/cjs/stories/MediaSceneSwitcher.stories.js.map +0 -7
  485. package/dist/cjs/stories/MemberEquity.stories.d.ts +0 -9
  486. package/dist/cjs/stories/MemberEquity.stories.js +0 -31
  487. package/dist/cjs/stories/MemberEquity.stories.js.map +0 -7
  488. package/dist/cjs/stories/MultiLayoutGraphicBlock.stories.d.ts +0 -9
  489. package/dist/cjs/stories/MultiLayoutGraphicBlock.stories.js +0 -2
  490. package/dist/cjs/stories/MultiLayoutGraphicBlock.stories.js.map +0 -7
  491. package/dist/cjs/stories/ProductNav.stories.d.ts +0 -55
  492. package/dist/cjs/stories/ProductNav.stories.js +0 -2
  493. package/dist/cjs/stories/ProductNav.stories.js.map +0 -7
  494. package/dist/cjs/stories/ThreeDCarousel.stories.d.ts +0 -27
  495. package/dist/cjs/stories/ThreeDCarousel.stories.js +0 -118
  496. package/dist/cjs/stories/ThreeDCarousel.stories.js.map +0 -7
  497. package/dist/cjs/stories/accordionCards.stories.d.ts +0 -38
  498. package/dist/cjs/stories/accordionCards.stories.js +0 -2
  499. package/dist/cjs/stories/accordionCards.stories.js.map +0 -7
  500. package/dist/cjs/stories/alert.stories.d.ts +0 -27
  501. package/dist/cjs/stories/alert.stories.js +0 -2
  502. package/dist/cjs/stories/alert.stories.js.map +0 -7
  503. package/dist/cjs/stories/avatar.stories.d.ts +0 -39
  504. package/dist/cjs/stories/avatar.stories.js +0 -2
  505. package/dist/cjs/stories/avatar.stories.js.map +0 -7
  506. package/dist/cjs/stories/badge.stories.d.ts +0 -96
  507. package/dist/cjs/stories/badge.stories.js +0 -2
  508. package/dist/cjs/stories/badge.stories.js.map +0 -7
  509. package/dist/cjs/stories/bizTabs.stories.d.ts +0 -7
  510. package/dist/cjs/stories/bizTabs.stories.js +0 -2
  511. package/dist/cjs/stories/bizTabs.stories.js.map +0 -7
  512. package/dist/cjs/stories/board.stories.d.ts +0 -6
  513. package/dist/cjs/stories/board.stories.js +0 -2
  514. package/dist/cjs/stories/board.stories.js.map +0 -7
  515. package/dist/cjs/stories/brandEquity.stories.d.ts +0 -16
  516. package/dist/cjs/stories/brandEquity.stories.js +0 -2
  517. package/dist/cjs/stories/brandEquity.stories.js.map +0 -7
  518. package/dist/cjs/stories/brandStrip.stories.d.ts +0 -12
  519. package/dist/cjs/stories/brandStrip.stories.js +0 -2
  520. package/dist/cjs/stories/brandStrip.stories.js.map +0 -7
  521. package/dist/cjs/stories/button.stories.d.ts +0 -56
  522. package/dist/cjs/stories/button.stories.js +0 -2
  523. package/dist/cjs/stories/button.stories.js.map +0 -7
  524. package/dist/cjs/stories/card.stories.d.ts +0 -27
  525. package/dist/cjs/stories/card.stories.js +0 -2
  526. package/dist/cjs/stories/card.stories.js.map +0 -7
  527. package/dist/cjs/stories/carousel.stories.d.ts +0 -8
  528. package/dist/cjs/stories/carousel.stories.js +0 -2
  529. package/dist/cjs/stories/carousel.stories.js.map +0 -7
  530. package/dist/cjs/stories/category.stories.d.ts +0 -17
  531. package/dist/cjs/stories/category.stories.js +0 -2
  532. package/dist/cjs/stories/category.stories.js.map +0 -7
  533. package/dist/cjs/stories/checkbox.stories.d.ts +0 -46
  534. package/dist/cjs/stories/checkbox.stories.js +0 -2
  535. package/dist/cjs/stories/checkbox.stories.js.map +0 -7
  536. package/dist/cjs/stories/container.stories.d.ts +0 -28
  537. package/dist/cjs/stories/container.stories.js +0 -15
  538. package/dist/cjs/stories/container.stories.js.map +0 -7
  539. package/dist/cjs/stories/cpnBanner.stories.d.ts +0 -14
  540. package/dist/cjs/stories/cpnBanner.stories.js +0 -2
  541. package/dist/cjs/stories/cpnBanner.stories.js.map +0 -7
  542. package/dist/cjs/stories/cpnCountdown.stories.d.ts +0 -12
  543. package/dist/cjs/stories/cpnCountdown.stories.js +0 -2
  544. package/dist/cjs/stories/cpnCountdown.stories.js.map +0 -7
  545. package/dist/cjs/stories/cpnNavigation.stories.d.ts +0 -14
  546. package/dist/cjs/stories/cpnNavigation.stories.js +0 -2
  547. package/dist/cjs/stories/cpnNavigation.stories.js.map +0 -7
  548. package/dist/cjs/stories/cpnProductcard.stories.d.ts +0 -14
  549. package/dist/cjs/stories/cpnProductcard.stories.js +0 -2
  550. package/dist/cjs/stories/cpnProductcard.stories.js.map +0 -7
  551. package/dist/cjs/stories/cpnTitle.stories.d.ts +0 -14
  552. package/dist/cjs/stories/cpnTitle.stories.js +0 -2
  553. package/dist/cjs/stories/cpnTitle.stories.js.map +0 -7
  554. package/dist/cjs/stories/creativeModule.stories.d.ts +0 -19
  555. package/dist/cjs/stories/creativeModule.stories.js +0 -2
  556. package/dist/cjs/stories/creativeModule.stories.js.map +0 -7
  557. package/dist/cjs/stories/dialog.stories.d.ts +0 -20
  558. package/dist/cjs/stories/dialog.stories.js +0 -2
  559. package/dist/cjs/stories/dialog.stories.js.map +0 -7
  560. package/dist/cjs/stories/drawer.stories.d.ts +0 -20
  561. package/dist/cjs/stories/drawer.stories.js +0 -2
  562. package/dist/cjs/stories/drawer.stories.js.map +0 -7
  563. package/dist/cjs/stories/drop-down.stories.d.ts +0 -16
  564. package/dist/cjs/stories/drop-down.stories.js +0 -2
  565. package/dist/cjs/stories/drop-down.stories.js.map +0 -7
  566. package/dist/cjs/stories/evaluate.stories.d.ts +0 -16
  567. package/dist/cjs/stories/evaluate.stories.js +0 -2
  568. package/dist/cjs/stories/evaluate.stories.js.map +0 -7
  569. package/dist/cjs/stories/faq.stories.d.ts +0 -21
  570. package/dist/cjs/stories/faq.stories.js +0 -2
  571. package/dist/cjs/stories/faq.stories.js.map +0 -7
  572. package/dist/cjs/stories/featureCards.stories.d.ts +0 -30
  573. package/dist/cjs/stories/featureCards.stories.js +0 -61
  574. package/dist/cjs/stories/featureCards.stories.js.map +0 -7
  575. package/dist/cjs/stories/featureShowcase.stories.d.ts +0 -29
  576. package/dist/cjs/stories/featureShowcase.stories.js +0 -44
  577. package/dist/cjs/stories/featureShowcase.stories.js.map +0 -7
  578. package/dist/cjs/stories/graphic.stories.d.ts +0 -64
  579. package/dist/cjs/stories/graphic.stories.js +0 -2
  580. package/dist/cjs/stories/graphic.stories.js.map +0 -7
  581. package/dist/cjs/stories/graphicAttractionBlock.stories.d.ts +0 -6
  582. package/dist/cjs/stories/graphicAttractionBlock.stories.js +0 -2
  583. package/dist/cjs/stories/graphicAttractionBlock.stories.js.map +0 -7
  584. package/dist/cjs/stories/grid.stories.d.ts +0 -22
  585. package/dist/cjs/stories/grid.stories.js +0 -13
  586. package/dist/cjs/stories/grid.stories.js.map +0 -7
  587. package/dist/cjs/stories/heading.stories.d.ts +0 -84
  588. package/dist/cjs/stories/heading.stories.js +0 -15
  589. package/dist/cjs/stories/heading.stories.js.map +0 -7
  590. package/dist/cjs/stories/imageTextFeature.stories.d.ts +0 -28
  591. package/dist/cjs/stories/imageTextFeature.stories.js +0 -50
  592. package/dist/cjs/stories/imageTextFeature.stories.js.map +0 -7
  593. package/dist/cjs/stories/imageWithText.stories.d.ts +0 -51
  594. package/dist/cjs/stories/imageWithText.stories.js +0 -84
  595. package/dist/cjs/stories/imageWithText.stories.js.map +0 -7
  596. package/dist/cjs/stories/input-number.stories.d.ts +0 -39
  597. package/dist/cjs/stories/input-number.stories.js +0 -2
  598. package/dist/cjs/stories/input-number.stories.js.map +0 -7
  599. package/dist/cjs/stories/input.stories.d.ts +0 -35
  600. package/dist/cjs/stories/input.stories.js +0 -2
  601. package/dist/cjs/stories/input.stories.js.map +0 -7
  602. package/dist/cjs/stories/ksp.stories.d.ts +0 -63
  603. package/dist/cjs/stories/ksp.stories.js +0 -128
  604. package/dist/cjs/stories/ksp.stories.js.map +0 -7
  605. package/dist/cjs/stories/link.stories.d.ts +0 -69
  606. package/dist/cjs/stories/link.stories.js +0 -2
  607. package/dist/cjs/stories/link.stories.js.map +0 -7
  608. package/dist/cjs/stories/marquee.stories.d.ts +0 -30
  609. package/dist/cjs/stories/marquee.stories.js +0 -2
  610. package/dist/cjs/stories/marquee.stories.js.map +0 -7
  611. package/dist/cjs/stories/mediaplayerBase.stories.d.ts +0 -6
  612. package/dist/cjs/stories/mediaplayerBase.stories.js +0 -2
  613. package/dist/cjs/stories/mediaplayerBase.stories.js.map +0 -7
  614. package/dist/cjs/stories/mediaplayerMulti.stories.d.ts +0 -16
  615. package/dist/cjs/stories/mediaplayerMulti.stories.js +0 -2
  616. package/dist/cjs/stories/mediaplayerMulti.stories.js.map +0 -7
  617. package/dist/cjs/stories/picture.stories.d.ts +0 -23
  618. package/dist/cjs/stories/picture.stories.js +0 -9
  619. package/dist/cjs/stories/picture.stories.js.map +0 -7
  620. package/dist/cjs/stories/popover.stories.d.ts +0 -17
  621. package/dist/cjs/stories/popover.stories.js +0 -2
  622. package/dist/cjs/stories/popover.stories.js.map +0 -7
  623. package/dist/cjs/stories/productCompare.stories.d.ts +0 -54
  624. package/dist/cjs/stories/productCompare.stories.js +0 -54
  625. package/dist/cjs/stories/productCompare.stories.js.map +0 -7
  626. package/dist/cjs/stories/productHero.stories.d.ts +0 -29
  627. package/dist/cjs/stories/productHero.stories.js +0 -50
  628. package/dist/cjs/stories/productHero.stories.js.map +0 -7
  629. package/dist/cjs/stories/radio.stories.d.ts +0 -39
  630. package/dist/cjs/stories/radio.stories.js +0 -2
  631. package/dist/cjs/stories/radio.stories.js.map +0 -7
  632. package/dist/cjs/stories/shelfDisplay.stories.d.ts +0 -16
  633. package/dist/cjs/stories/shelfDisplay.stories.js +0 -2
  634. package/dist/cjs/stories/shelfDisplay.stories.js.map +0 -7
  635. package/dist/cjs/stories/skeleton.stories.d.ts +0 -20
  636. package/dist/cjs/stories/skeleton.stories.js +0 -2
  637. package/dist/cjs/stories/skeleton.stories.js.map +0 -7
  638. package/dist/cjs/stories/slogan.stories.d.ts +0 -20
  639. package/dist/cjs/stories/slogan.stories.js +0 -6
  640. package/dist/cjs/stories/slogan.stories.js.map +0 -7
  641. package/dist/cjs/stories/specs.stories.d.ts +0 -13
  642. package/dist/cjs/stories/specs.stories.js +0 -57
  643. package/dist/cjs/stories/specs.stories.js.map +0 -7
  644. package/dist/cjs/stories/specsComparison.stories.d.ts +0 -28
  645. package/dist/cjs/stories/specsComparison.stories.js +0 -105
  646. package/dist/cjs/stories/specsComparison.stories.js.map +0 -7
  647. package/dist/cjs/stories/tabWithImage.stories.d.ts +0 -28
  648. package/dist/cjs/stories/tabWithImage.stories.js +0 -53
  649. package/dist/cjs/stories/tabWithImage.stories.js.map +0 -7
  650. package/dist/cjs/stories/tabs.stories.d.ts +0 -373
  651. package/dist/cjs/stories/tabs.stories.js +0 -2
  652. package/dist/cjs/stories/tabs.stories.js.map +0 -7
  653. package/dist/cjs/stories/tabsWithMedia.stories.d.ts +0 -28
  654. package/dist/cjs/stories/tabsWithMedia.stories.js +0 -68
  655. package/dist/cjs/stories/tabsWithMedia.stories.js.map +0 -7
  656. package/dist/cjs/stories/text.stories.d.ts +0 -86
  657. package/dist/cjs/stories/text.stories.js +0 -21
  658. package/dist/cjs/stories/text.stories.js.map +0 -7
  659. package/dist/cjs/stories/videoFeature.stories.d.ts +0 -29
  660. package/dist/cjs/stories/videoFeature.stories.js +0 -56
  661. package/dist/cjs/stories/videoFeature.stories.js.map +0 -7
  662. package/dist/cjs/stories/whychoose.stories.d.ts +0 -21
  663. package/dist/cjs/stories/whychoose.stories.js +0 -2
  664. package/dist/cjs/stories/whychoose.stories.js.map +0 -7
  665. package/dist/esm/stories/HeroBanner.stories.d.ts +0 -28
  666. package/dist/esm/stories/HeroBanner.stories.js +0 -11
  667. package/dist/esm/stories/HeroBanner.stories.js.map +0 -7
  668. package/dist/esm/stories/InlineVideo.stories.d.ts +0 -37
  669. package/dist/esm/stories/InlineVideo.stories.js +0 -164
  670. package/dist/esm/stories/InlineVideo.stories.js.map +0 -7
  671. package/dist/esm/stories/MarqueeReview.stories.d.ts +0 -72
  672. package/dist/esm/stories/MarqueeReview.stories.js +0 -19
  673. package/dist/esm/stories/MarqueeReview.stories.js.map +0 -7
  674. package/dist/esm/stories/MediaSceneSwitcher.stories.d.ts +0 -47
  675. package/dist/esm/stories/MediaSceneSwitcher.stories.js +0 -2
  676. package/dist/esm/stories/MediaSceneSwitcher.stories.js.map +0 -7
  677. package/dist/esm/stories/MemberEquity.stories.d.ts +0 -9
  678. package/dist/esm/stories/MemberEquity.stories.js +0 -31
  679. package/dist/esm/stories/MemberEquity.stories.js.map +0 -7
  680. package/dist/esm/stories/MultiLayoutGraphicBlock.stories.d.ts +0 -9
  681. package/dist/esm/stories/MultiLayoutGraphicBlock.stories.js +0 -2
  682. package/dist/esm/stories/MultiLayoutGraphicBlock.stories.js.map +0 -7
  683. package/dist/esm/stories/ProductNav.stories.d.ts +0 -55
  684. package/dist/esm/stories/ProductNav.stories.js +0 -2
  685. package/dist/esm/stories/ProductNav.stories.js.map +0 -7
  686. package/dist/esm/stories/ThreeDCarousel.stories.d.ts +0 -27
  687. package/dist/esm/stories/ThreeDCarousel.stories.js +0 -118
  688. package/dist/esm/stories/ThreeDCarousel.stories.js.map +0 -7
  689. package/dist/esm/stories/accordionCards.stories.d.ts +0 -38
  690. package/dist/esm/stories/accordionCards.stories.js +0 -2
  691. package/dist/esm/stories/accordionCards.stories.js.map +0 -7
  692. package/dist/esm/stories/alert.stories.d.ts +0 -27
  693. package/dist/esm/stories/alert.stories.js +0 -2
  694. package/dist/esm/stories/alert.stories.js.map +0 -7
  695. package/dist/esm/stories/avatar.stories.d.ts +0 -39
  696. package/dist/esm/stories/avatar.stories.js +0 -2
  697. package/dist/esm/stories/avatar.stories.js.map +0 -7
  698. package/dist/esm/stories/badge.stories.d.ts +0 -96
  699. package/dist/esm/stories/badge.stories.js +0 -2
  700. package/dist/esm/stories/badge.stories.js.map +0 -7
  701. package/dist/esm/stories/bizTabs.stories.d.ts +0 -7
  702. package/dist/esm/stories/bizTabs.stories.js +0 -2
  703. package/dist/esm/stories/bizTabs.stories.js.map +0 -7
  704. package/dist/esm/stories/board.stories.d.ts +0 -6
  705. package/dist/esm/stories/board.stories.js +0 -2
  706. package/dist/esm/stories/board.stories.js.map +0 -7
  707. package/dist/esm/stories/brandEquity.stories.d.ts +0 -16
  708. package/dist/esm/stories/brandEquity.stories.js +0 -2
  709. package/dist/esm/stories/brandEquity.stories.js.map +0 -7
  710. package/dist/esm/stories/brandStrip.stories.d.ts +0 -12
  711. package/dist/esm/stories/brandStrip.stories.js +0 -2
  712. package/dist/esm/stories/brandStrip.stories.js.map +0 -7
  713. package/dist/esm/stories/button.stories.d.ts +0 -56
  714. package/dist/esm/stories/button.stories.js +0 -2
  715. package/dist/esm/stories/button.stories.js.map +0 -7
  716. package/dist/esm/stories/card.stories.d.ts +0 -27
  717. package/dist/esm/stories/card.stories.js +0 -2
  718. package/dist/esm/stories/card.stories.js.map +0 -7
  719. package/dist/esm/stories/carousel.stories.d.ts +0 -8
  720. package/dist/esm/stories/carousel.stories.js +0 -2
  721. package/dist/esm/stories/carousel.stories.js.map +0 -7
  722. package/dist/esm/stories/category.stories.d.ts +0 -17
  723. package/dist/esm/stories/category.stories.js +0 -2
  724. package/dist/esm/stories/category.stories.js.map +0 -7
  725. package/dist/esm/stories/checkbox.stories.d.ts +0 -46
  726. package/dist/esm/stories/checkbox.stories.js +0 -2
  727. package/dist/esm/stories/checkbox.stories.js.map +0 -7
  728. package/dist/esm/stories/container.stories.d.ts +0 -28
  729. package/dist/esm/stories/container.stories.js +0 -15
  730. package/dist/esm/stories/container.stories.js.map +0 -7
  731. package/dist/esm/stories/cpnBanner.stories.d.ts +0 -14
  732. package/dist/esm/stories/cpnBanner.stories.js +0 -2
  733. package/dist/esm/stories/cpnBanner.stories.js.map +0 -7
  734. package/dist/esm/stories/cpnCountdown.stories.d.ts +0 -12
  735. package/dist/esm/stories/cpnCountdown.stories.js +0 -2
  736. package/dist/esm/stories/cpnCountdown.stories.js.map +0 -7
  737. package/dist/esm/stories/cpnNavigation.stories.d.ts +0 -14
  738. package/dist/esm/stories/cpnNavigation.stories.js +0 -2
  739. package/dist/esm/stories/cpnNavigation.stories.js.map +0 -7
  740. package/dist/esm/stories/cpnProductcard.stories.d.ts +0 -14
  741. package/dist/esm/stories/cpnProductcard.stories.js +0 -2
  742. package/dist/esm/stories/cpnProductcard.stories.js.map +0 -7
  743. package/dist/esm/stories/cpnTitle.stories.d.ts +0 -14
  744. package/dist/esm/stories/cpnTitle.stories.js +0 -2
  745. package/dist/esm/stories/cpnTitle.stories.js.map +0 -7
  746. package/dist/esm/stories/creativeModule.stories.d.ts +0 -19
  747. package/dist/esm/stories/creativeModule.stories.js +0 -2
  748. package/dist/esm/stories/creativeModule.stories.js.map +0 -7
  749. package/dist/esm/stories/dialog.stories.d.ts +0 -20
  750. package/dist/esm/stories/dialog.stories.js +0 -2
  751. package/dist/esm/stories/dialog.stories.js.map +0 -7
  752. package/dist/esm/stories/drawer.stories.d.ts +0 -20
  753. package/dist/esm/stories/drawer.stories.js +0 -2
  754. package/dist/esm/stories/drawer.stories.js.map +0 -7
  755. package/dist/esm/stories/drop-down.stories.d.ts +0 -16
  756. package/dist/esm/stories/drop-down.stories.js +0 -2
  757. package/dist/esm/stories/drop-down.stories.js.map +0 -7
  758. package/dist/esm/stories/evaluate.stories.d.ts +0 -16
  759. package/dist/esm/stories/evaluate.stories.js +0 -2
  760. package/dist/esm/stories/evaluate.stories.js.map +0 -7
  761. package/dist/esm/stories/faq.stories.d.ts +0 -21
  762. package/dist/esm/stories/faq.stories.js +0 -2
  763. package/dist/esm/stories/faq.stories.js.map +0 -7
  764. package/dist/esm/stories/featureCards.stories.d.ts +0 -30
  765. package/dist/esm/stories/featureCards.stories.js +0 -61
  766. package/dist/esm/stories/featureCards.stories.js.map +0 -7
  767. package/dist/esm/stories/featureShowcase.stories.d.ts +0 -29
  768. package/dist/esm/stories/featureShowcase.stories.js +0 -44
  769. package/dist/esm/stories/featureShowcase.stories.js.map +0 -7
  770. package/dist/esm/stories/graphic.stories.d.ts +0 -64
  771. package/dist/esm/stories/graphic.stories.js +0 -2
  772. package/dist/esm/stories/graphic.stories.js.map +0 -7
  773. package/dist/esm/stories/graphicAttractionBlock.stories.d.ts +0 -6
  774. package/dist/esm/stories/graphicAttractionBlock.stories.js +0 -2
  775. package/dist/esm/stories/graphicAttractionBlock.stories.js.map +0 -7
  776. package/dist/esm/stories/grid.stories.d.ts +0 -22
  777. package/dist/esm/stories/grid.stories.js +0 -13
  778. package/dist/esm/stories/grid.stories.js.map +0 -7
  779. package/dist/esm/stories/heading.stories.d.ts +0 -84
  780. package/dist/esm/stories/heading.stories.js +0 -15
  781. package/dist/esm/stories/heading.stories.js.map +0 -7
  782. package/dist/esm/stories/imageTextFeature.stories.d.ts +0 -28
  783. package/dist/esm/stories/imageTextFeature.stories.js +0 -50
  784. package/dist/esm/stories/imageTextFeature.stories.js.map +0 -7
  785. package/dist/esm/stories/imageWithText.stories.d.ts +0 -51
  786. package/dist/esm/stories/imageWithText.stories.js +0 -84
  787. package/dist/esm/stories/imageWithText.stories.js.map +0 -7
  788. package/dist/esm/stories/input-number.stories.d.ts +0 -39
  789. package/dist/esm/stories/input-number.stories.js +0 -2
  790. package/dist/esm/stories/input-number.stories.js.map +0 -7
  791. package/dist/esm/stories/input.stories.d.ts +0 -35
  792. package/dist/esm/stories/input.stories.js +0 -2
  793. package/dist/esm/stories/input.stories.js.map +0 -7
  794. package/dist/esm/stories/ksp.stories.d.ts +0 -63
  795. package/dist/esm/stories/ksp.stories.js +0 -128
  796. package/dist/esm/stories/ksp.stories.js.map +0 -7
  797. package/dist/esm/stories/link.stories.d.ts +0 -69
  798. package/dist/esm/stories/link.stories.js +0 -2
  799. package/dist/esm/stories/link.stories.js.map +0 -7
  800. package/dist/esm/stories/marquee.stories.d.ts +0 -30
  801. package/dist/esm/stories/marquee.stories.js +0 -2
  802. package/dist/esm/stories/marquee.stories.js.map +0 -7
  803. package/dist/esm/stories/mediaplayerBase.stories.d.ts +0 -6
  804. package/dist/esm/stories/mediaplayerBase.stories.js +0 -2
  805. package/dist/esm/stories/mediaplayerBase.stories.js.map +0 -7
  806. package/dist/esm/stories/mediaplayerMulti.stories.d.ts +0 -16
  807. package/dist/esm/stories/mediaplayerMulti.stories.js +0 -2
  808. package/dist/esm/stories/mediaplayerMulti.stories.js.map +0 -7
  809. package/dist/esm/stories/picture.stories.d.ts +0 -23
  810. package/dist/esm/stories/picture.stories.js +0 -9
  811. package/dist/esm/stories/picture.stories.js.map +0 -7
  812. package/dist/esm/stories/popover.stories.d.ts +0 -17
  813. package/dist/esm/stories/popover.stories.js +0 -2
  814. package/dist/esm/stories/popover.stories.js.map +0 -7
  815. package/dist/esm/stories/productCompare.stories.d.ts +0 -54
  816. package/dist/esm/stories/productCompare.stories.js +0 -54
  817. package/dist/esm/stories/productCompare.stories.js.map +0 -7
  818. package/dist/esm/stories/productHero.stories.d.ts +0 -29
  819. package/dist/esm/stories/productHero.stories.js +0 -50
  820. package/dist/esm/stories/productHero.stories.js.map +0 -7
  821. package/dist/esm/stories/radio.stories.d.ts +0 -39
  822. package/dist/esm/stories/radio.stories.js +0 -2
  823. package/dist/esm/stories/radio.stories.js.map +0 -7
  824. package/dist/esm/stories/shelfDisplay.stories.d.ts +0 -16
  825. package/dist/esm/stories/shelfDisplay.stories.js +0 -2
  826. package/dist/esm/stories/shelfDisplay.stories.js.map +0 -7
  827. package/dist/esm/stories/skeleton.stories.d.ts +0 -20
  828. package/dist/esm/stories/skeleton.stories.js +0 -2
  829. package/dist/esm/stories/skeleton.stories.js.map +0 -7
  830. package/dist/esm/stories/slogan.stories.d.ts +0 -20
  831. package/dist/esm/stories/slogan.stories.js +0 -6
  832. package/dist/esm/stories/slogan.stories.js.map +0 -7
  833. package/dist/esm/stories/specs.stories.d.ts +0 -13
  834. package/dist/esm/stories/specs.stories.js +0 -57
  835. package/dist/esm/stories/specs.stories.js.map +0 -7
  836. package/dist/esm/stories/specsComparison.stories.d.ts +0 -28
  837. package/dist/esm/stories/specsComparison.stories.js +0 -105
  838. package/dist/esm/stories/specsComparison.stories.js.map +0 -7
  839. package/dist/esm/stories/tabWithImage.stories.d.ts +0 -28
  840. package/dist/esm/stories/tabWithImage.stories.js +0 -53
  841. package/dist/esm/stories/tabWithImage.stories.js.map +0 -7
  842. package/dist/esm/stories/tabs.stories.d.ts +0 -373
  843. package/dist/esm/stories/tabs.stories.js +0 -2
  844. package/dist/esm/stories/tabs.stories.js.map +0 -7
  845. package/dist/esm/stories/tabsWithMedia.stories.d.ts +0 -28
  846. package/dist/esm/stories/tabsWithMedia.stories.js +0 -68
  847. package/dist/esm/stories/tabsWithMedia.stories.js.map +0 -7
  848. package/dist/esm/stories/text.stories.d.ts +0 -86
  849. package/dist/esm/stories/text.stories.js +0 -21
  850. package/dist/esm/stories/text.stories.js.map +0 -7
  851. package/dist/esm/stories/videoFeature.stories.d.ts +0 -29
  852. package/dist/esm/stories/videoFeature.stories.js +0 -56
  853. package/dist/esm/stories/videoFeature.stories.js.map +0 -7
  854. package/dist/esm/stories/whychoose.stories.d.ts +0 -21
  855. package/dist/esm/stories/whychoose.stories.js +0 -2
  856. package/dist/esm/stories/whychoose.stories.js.map +0 -7
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/biz-components/Media/index.tsx"],
4
+ "sourcesContent": ["'use client'\n\nimport React from 'react'\nimport { useMediaQuery } from 'react-responsive'\nimport { Picture } from '../../components/index.js'\nimport type { Media as MediaType } from '../../types/props.js'\nimport { cn } from '../../helpers/index.js'\n\nexport interface MediaProps extends React.HTMLAttributes<HTMLDivElement> {\n /** PC\u7AEF\u5A92\u4F53 */\n pcImage?: MediaType\n /** \u5E73\u677F\u7AEF\u5A92\u4F53 */\n padImage?: MediaType\n /** \u79FB\u52A8\u7AEF\u5A92\u4F53 */\n mobileImage?: MediaType\n /** \u89C6\u9891\u7C7B\u540D */\n videoClassName?: string\n /** \u56FE\u7247\u7C7B\u540D */\n imgClassName?: string\n /** \u662F\u5426\u9759\u97F3\u64AD\u653E\uFF08\u4EC5\u89C6\u9891\uFF09 */\n muted?: boolean\n /** \u662F\u5426\u5FAA\u73AF\u64AD\u653E\uFF08\u4EC5\u89C6\u9891\uFF09 */\n loop?: boolean\n /** \u662F\u5426\u5185\u8054\u64AD\u653E\uFF08\u4EC5\u89C6\u9891\uFF09 */\n playsInline?: boolean\n /** \u662F\u5426\u81EA\u52A8\u64AD\u653E\uFF08\u4EC5\u89C6\u9891\uFF09 */\n autoPlay?: boolean\n /** \u89C6\u9891\u9884\u89C8\u56FE */\n poster?: string\n}\n\n/**\n * Media - \u667A\u80FD\u5A92\u4F53\u7EC4\u4EF6\n *\n * @description \u6839\u636E\u5A92\u4F53\u7C7B\u578B\u81EA\u52A8\u9009\u62E9\u4F7F\u7528 video \u6807\u7B7E\u6216 Picture \u7EC4\u4EF6\n * \u652F\u6301\u54CD\u5E94\u5F0F\u5A92\u4F53\u6E90\uFF0C\u5982\u679C\u4EFB\u610F\u5A92\u4F53\u7C7B\u578B\u662F\u89C6\u9891\uFF0C\u5219\u4F7F\u7528 video \u6807\u7B7E\u6E32\u67D3\n */\nconst Media = React.forwardRef<HTMLDivElement, MediaProps>(\n (\n {\n pcImage,\n padImage,\n mobileImage,\n className,\n videoClassName,\n imgClassName,\n muted = true,\n loop = true,\n playsInline = true,\n autoPlay = true,\n poster,\n ...props\n },\n ref\n ) => {\n // \u54CD\u5E94\u5F0F\u67E5\u8BE2\n const isMobile = useMediaQuery({ query: '(max-width: 768px)' })\n const isPad = useMediaQuery({ query: '(max-width: 1024px)' })\n\n // \u68C0\u67E5\u662F\u5426\u6709\u4EFB\u4F55\u5A92\u4F53\u662F\u89C6\u9891\u7C7B\u578B\n const hasVideo = [pcImage, padImage, mobileImage].some(media => media?.mimeType === 'video/mp4')\n\n // \u83B7\u53D6\u5F53\u524D\u8BBE\u5907\u5BF9\u5E94\u7684\u5A92\u4F53\n const currentMedia = isMobile ? mobileImage : isPad ? padImage || mobileImage : pcImage\n\n // \u83B7\u53D6\u89C6\u9891\u6E90\u548C\u6D77\u62A5\u56FE\u7247\n const videoSrc = currentMedia?.mimeType === 'video/mp4' ? currentMedia.url : undefined\n const imagePoster = poster || (currentMedia?.mimeType !== 'video/mp4' ? currentMedia?.url : undefined)\n\n return (\n <div ref={ref} className={cn('media-wrapper', className)} {...props}>\n {hasVideo ? (\n <video\n src={videoSrc}\n poster={imagePoster}\n className={cn('size-full object-cover', videoClassName)}\n muted={muted}\n loop={loop}\n playsInline={playsInline}\n autoPlay={autoPlay}\n aria-label={currentMedia?.alt || ''}\n />\n ) : (\n <Picture\n className=\"size-full\"\n imgClassName={cn('size-full object-cover', imgClassName)}\n alt={pcImage?.alt || ''}\n source={`${pcImage?.url || ''} , ${padImage?.url ?? (mobileImage?.url || '')} 1024, ${mobileImage?.url || ''} 767`}\n />\n )}\n </div>\n )\n }\n)\n\nMedia.displayName = 'Media'\n\nexport default Media\n"],
5
+ "mappings": "ukBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,aAAAE,IAAA,eAAAC,EAAAH,GAwEU,IAAAI,EAAA,6BAtEVC,EAAkB,oBAClBC,EAA8B,4BAC9BC,EAAwB,qCAExBC,EAAmB,kCA+BnB,MAAMC,EAAQ,EAAAC,QAAM,WAClB,CACE,CACE,QAAAC,EACA,SAAAC,EACA,YAAAC,EACA,UAAAC,EACA,eAAAC,EACA,aAAAC,EACA,MAAAC,EAAQ,GACR,KAAAC,EAAO,GACP,YAAAC,EAAc,GACd,SAAAC,EAAW,GACX,OAAAC,EACA,GAAGC,CACL,EACAC,IACG,CAEH,MAAMC,KAAW,iBAAc,CAAE,MAAO,oBAAqB,CAAC,EACxDC,KAAQ,iBAAc,CAAE,MAAO,qBAAsB,CAAC,EAGtDC,EAAW,CAACf,EAASC,EAAUC,CAAW,EAAE,KAAKc,GAASA,GAAO,WAAa,WAAW,EAGzFC,EAAeJ,EAAWX,EAAcY,EAAQb,GAAYC,EAAcF,EAG1EkB,EAAWD,GAAc,WAAa,YAAcA,EAAa,IAAM,OACvEE,EAAcT,IAAWO,GAAc,WAAa,YAAcA,GAAc,IAAM,QAE5F,SACE,OAAC,OAAI,IAAKL,EAAK,aAAW,MAAG,gBAAiBT,CAAS,EAAI,GAAGQ,EAC3D,SAAAI,KACC,OAAC,SACC,IAAKG,EACL,OAAQC,EACR,aAAW,MAAG,yBAA0Bf,CAAc,EACtD,MAAOE,EACP,KAAMC,EACN,YAAaC,EACb,SAAUC,EACV,aAAYQ,GAAc,KAAO,GACnC,KAEA,OAAC,WACC,UAAU,YACV,gBAAc,MAAG,yBAA0BZ,CAAY,EACvD,IAAKL,GAAS,KAAO,GACrB,OAAQ,GAAGA,GAAS,KAAO,EAAE,MAAMC,GAAU,MAAQC,GAAa,KAAO,GAAG,UAAUA,GAAa,KAAO,EAAE,OAC9G,EAEJ,CAEJ,CACF,EAEAJ,EAAM,YAAc,QAEpB,IAAOP,EAAQO",
6
+ "names": ["Media_exports", "__export", "Media_default", "__toCommonJS", "import_jsx_runtime", "import_react", "import_react_responsive", "import_components", "import_helpers", "Media", "React", "pcImage", "padImage", "mobileImage", "className", "videoClassName", "imgClassName", "muted", "loop", "playsInline", "autoPlay", "poster", "props", "ref", "isMobile", "isPad", "hasVideo", "media", "currentMedia", "videoSrc", "imagePoster"]
7
+ }
@@ -1,6 +1,6 @@
1
1
  import type { MediaPlayerBaseProps } from './types.js';
2
- declare const _default: import("react").ForwardRefExoticComponent<Omit<Omit<MediaPlayerBaseProps & import("react").RefAttributes<HTMLDivElement>, keyof import("../../shared/Styles.js").StylesProps> & Partial<import("../../shared/Styles.js").StylesProps & import("../../shared/Styles.js").ContainerProps> & {
3
- className?: string;
4
- data?: Record<string, any>;
2
+ declare const _default: import("react").ForwardRefExoticComponent<Omit<MediaPlayerBaseProps & import("react").RefAttributes<HTMLDivElement> & {
3
+ style?: string | React.CSSProperties;
4
+ container?: import("../../shared/Styles.js").ContainerProps["container"];
5
5
  }, "ref"> & import("react").RefAttributes<any>>;
6
6
  export default _default;
@@ -1,6 +1,6 @@
1
1
  import type { MediaPlayerMultiProps } from './types.js';
2
- declare const _default: import("react").ForwardRefExoticComponent<Omit<Omit<MediaPlayerMultiProps & import("react").RefAttributes<HTMLDivElement>, keyof import("../../shared/Styles.js").StylesProps> & Partial<import("../../shared/Styles.js").StylesProps & import("../../shared/Styles.js").ContainerProps> & {
3
- className?: string;
4
- data?: Record<string, any>;
2
+ declare const _default: import("react").ForwardRefExoticComponent<Omit<MediaPlayerMultiProps & import("react").RefAttributes<HTMLDivElement> & {
3
+ style?: string | React.CSSProperties;
4
+ container?: import("../../shared/Styles.js").ContainerProps["container"];
5
5
  }, "ref"> & import("react").RefAttributes<any>>;
6
6
  export default _default;
@@ -1,9 +1,9 @@
1
1
  import React from 'react';
2
2
  import type { MediaPlayerBaseProps } from './types.js';
3
- declare const _default: React.ForwardRefExoticComponent<Omit<Omit<MediaPlayerBaseProps & React.RefAttributes<{
3
+ declare const _default: React.ForwardRefExoticComponent<Omit<MediaPlayerBaseProps & React.RefAttributes<{
4
4
  mediaPlayerStickyRef: HTMLDivElement;
5
- }>, keyof import("../../shared/Styles.js").StylesProps> & Partial<import("../../shared/Styles.js").StylesProps & import("../../shared/Styles.js").ContainerProps> & {
6
- className?: string;
7
- data?: Record<string, any>;
5
+ }> & {
6
+ style?: string | React.CSSProperties;
7
+ container?: import("../../shared/Styles.js").ContainerProps["container"];
8
8
  }, "ref"> & React.RefAttributes<any>>;
9
9
  export default _default;
@@ -18,4 +18,5 @@ export interface MediaPlayerBaseProps extends ComponentCommonProps {
18
18
  youtubeMobileId?: string;
19
19
  components?: MediaPlayerComponent[];
20
20
  };
21
+ wrapperClassName?: string;
21
22
  }
@@ -1,2 +1,2 @@
1
- "use strict";var i=Object.defineProperty;var m=Object.getOwnPropertyDescriptor;var n=Object.getOwnPropertyNames;var s=Object.prototype.hasOwnProperty;var y=(o,e,p,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of n(e))!s.call(o,t)&&t!==p&&i(o,t,{get:()=>e[t],enumerable:!(r=m(e,t))||r.enumerable});return o};var a=o=>y(i({},"__esModule",{value:!0}),o);var d={};module.exports=a(d);
1
+ "use strict";var p=Object.defineProperty;var m=Object.getOwnPropertyDescriptor;var s=Object.getOwnPropertyNames;var n=Object.prototype.hasOwnProperty;var a=(o,e,i,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of s(e))!n.call(o,t)&&t!==i&&p(o,t,{get:()=>e[t],enumerable:!(r=m(e,t))||r.enumerable});return o};var y=o=>a(p({},"__esModule",{value:!0}),o);var d={};module.exports=y(d);
2
2
  //# sourceMappingURL=types.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/biz-components/MediaPlayerSticky/types.ts"],
4
- "sourcesContent": ["import type { ComponentCommonProps, Shape, Theme, Video, Img } from '../../types/props.js'\nimport type { BrandEquityProps } from '../BrandEquity/types.js'\nimport type { MemberEquityProps } from '../MemberEquity/types.js'\n\nexport type MediaPlayerComponent = BrandEquityProps | MemberEquityProps\n\nexport interface MediaPlayerBaseProps extends ComponentCommonProps {\n data: {\n shape?: Shape\n theme?: Theme\n title?: string\n videoTitle?: string\n btnText?: string\n img?: Img\n mobImg?: Img\n video?: Video\n mobVideo?: Video\n isYouTube?: boolean\n youtubePcId: string\n youtubeMobileId?: string\n components?: MediaPlayerComponent[]\n }\n}\n"],
4
+ "sourcesContent": ["import type { ComponentCommonProps, Shape, Theme, Video, Img } from '../../types/props.js'\nimport type { BrandEquityProps } from '../BrandEquity/types.js'\nimport type { MemberEquityProps } from '../MemberEquity/types.js'\n\nexport type MediaPlayerComponent = BrandEquityProps | MemberEquityProps\n\nexport interface MediaPlayerBaseProps extends ComponentCommonProps {\n data: {\n shape?: Shape\n theme?: Theme\n title?: string\n videoTitle?: string\n btnText?: string\n img?: Img\n mobImg?: Img\n video?: Video\n mobVideo?: Video\n isYouTube?: boolean\n youtubePcId: string\n youtubeMobileId?: string\n components?: MediaPlayerComponent[]\n }\n wrapperClassName?: string\n}\n"],
5
5
  "mappings": "+WAAA,IAAAA,EAAA,kBAAAC,EAAAD",
6
6
  "names": ["types_exports", "__toCommonJS"]
7
7
  }
@@ -1,7 +1,7 @@
1
1
  import type { MediaSceneSwitcherProps } from './types.js';
2
2
  import 'swiper/css';
3
- declare const _default: import("react").ForwardRefExoticComponent<Omit<Omit<MediaSceneSwitcherProps & import("react").RefAttributes<HTMLDivElement>, keyof import("../../shared/Styles.js").StylesProps> & Partial<import("../../shared/Styles.js").StylesProps & import("../../shared/Styles.js").ContainerProps> & {
4
- className?: string;
5
- data?: Record<string, any>;
3
+ declare const _default: import("react").ForwardRefExoticComponent<Omit<MediaSceneSwitcherProps & import("react").RefAttributes<HTMLDivElement> & {
4
+ style?: string | React.CSSProperties;
5
+ container?: import("../../shared/Styles.js").ContainerProps["container"];
6
6
  }, "ref"> & import("react").RefAttributes<any>>;
7
7
  export default _default;
@@ -0,0 +1,216 @@
1
+ import * as React from 'react';
2
+ import 'swiper/css';
3
+ import 'swiper/css/navigation';
4
+ import type { ButtonFunctionType, CopyConfig } from './types.js';
5
+ import type { BadgeProps } from '../../components/badge.js';
6
+ /**
7
+ * 语义化类名
8
+ */
9
+ type MediaShelfSemanticName = 'root' | 'title' | 'description' | 'productCard' | 'productCardImage' | 'productTitle' | 'productDescription' | 'productPriceLabel' | 'productPrice' | 'buttonGroup' | 'secondaryButton' | 'primaryButton' | 'stockBar';
10
+ /**
11
+ * Code Channel 配置 - 折扣前缀
12
+ */
13
+ export type CodeChannelConfig = string;
14
+ /**
15
+ * 库存展示模式
16
+ */
17
+ export type StockDisplayMode = 'always' | 'never' | 'below-quantity' | 'below-percentage';
18
+ /**
19
+ * MediaShelf Context 配置接口
20
+ */
21
+ export interface MediaShelfContextConfig {
22
+ /** Code Channel 配置 - 折扣前缀 */
23
+ codeChannel?: CodeChannelConfig;
24
+ /** 是否展示会员价格 */
25
+ showMemberPrice?: boolean;
26
+ /** 是否展示折扣标签 */
27
+ showDiscount?: boolean;
28
+ /** 是否展示标签系统 */
29
+ showTags?: boolean;
30
+ /** 库存展示模式 */
31
+ stockDisplayMode?: StockDisplayMode;
32
+ /** 库存阈值(当模式为 below-quantity 或 below-percentage 时使用) */
33
+ stockThreshold?: number;
34
+ /** 是否展示原价(删除线价格) */
35
+ showOriginalPrice?: boolean;
36
+ }
37
+ /**
38
+ * MediaShelf Context 值接口
39
+ */
40
+ interface MediaShelfContextValue extends MediaShelfContextConfig {
41
+ /** 点击了解更多回调 */
42
+ onLearnMore?: (product: ProductCardData) => void;
43
+ /** 点击立即购买回调 */
44
+ onShopNow?: (product: ProductCardData) => void;
45
+ /** 点击加入购物车回调 */
46
+ onAddToCart?: (product: ProductCardData) => void;
47
+ /** 语义化类名 */
48
+ classNames?: Partial<Record<MediaShelfSemanticName, string>>;
49
+ /** 了解更多按钮文本 */
50
+ secondaryButtonText?: string;
51
+ secondaryButtonFun?: ButtonFunctionType;
52
+ /** 立即购买按钮文本 */
53
+ primaryButtonText?: string;
54
+ primaryButtonFun?: ButtonFunctionType;
55
+ /** 文案配置 */
56
+ copy: CopyConfig;
57
+ }
58
+ /**
59
+ * 使用 MediaShelf Context 的 Hook
60
+ */
61
+ export declare const useMediaShelfContext: () => MediaShelfContextValue;
62
+ /**
63
+ * 基础产品数据接口(来自外部数据源)
64
+ */
65
+ export interface BaseProductData {
66
+ sku: string;
67
+ name: string;
68
+ image: string;
69
+ value: string;
70
+ handle: string;
71
+ shopify_id: string;
72
+ custom_name?: string;
73
+ custom_description?: string;
74
+ custom_image?: string;
75
+ custom_link?: string;
76
+ }
77
+ /**
78
+ * Shopify 变体数据接口
79
+ */
80
+ export interface VariantData {
81
+ /**
82
+ * 产品描述
83
+ */
84
+ description?: string;
85
+ /**
86
+ * 变体id
87
+ */
88
+ variantId: string;
89
+ /**
90
+ * 产品链接, 点击图片的时候跳转到该链接
91
+ */
92
+ listingLink: string;
93
+ /**
94
+ * 原价
95
+ */
96
+ originalPrice: string;
97
+ /**
98
+ * 现价
99
+ */
100
+ price: string;
101
+ /**
102
+ * 价格上面展示的标签文本
103
+ */
104
+ priceLabel?: string;
105
+ /**
106
+ * 总库存
107
+ */
108
+ totalInventory: number;
109
+ /**
110
+ * 可用库存数量
111
+ */
112
+ quantityAvailable: number;
113
+ /**
114
+ * 是否可售
115
+ */
116
+ availableForSale: boolean;
117
+ /**
118
+ * tags 列表(会员价,折扣,new, hot等标签信息)
119
+ */
120
+ tags: Array<{
121
+ label: string;
122
+ variant: BadgeProps['variant'];
123
+ promotionalType?: BadgeProps['promotionalType'];
124
+ }>;
125
+ /**
126
+ * 通用折扣数据,包括折扣title, 类型和值
127
+ */
128
+ coupon: any;
129
+ }
130
+ /**
131
+ * 完整的产品卡片数据接口
132
+ */
133
+ export interface ProductCardData extends BaseProductData, VariantData {
134
+ }
135
+ /**
136
+ * 产品分组Tab数据接口
137
+ */
138
+ export interface ProductTab {
139
+ /** Tab ID */
140
+ id: string;
141
+ /** Tab 标题 */
142
+ tab: string;
143
+ /** 该分组下的产品数据 */
144
+ data: ProductCardData[];
145
+ }
146
+ /**
147
+ * MediaShelf 业务组件数据接口
148
+ */
149
+ export interface MediaShelfData {
150
+ theme?: 'light' | 'dark';
151
+ /** 组件标题 */
152
+ title?: string;
153
+ /** 组件描述 */
154
+ description?: string;
155
+ /** 分组产品Tab列表 */
156
+ productsTab?: ProductTab[];
157
+ /** 是否显示 Tab(默认:true) */
158
+ isShowTab?: boolean;
159
+ /** 了解更多按钮文本 */
160
+ secondaryButtonText?: string;
161
+ secondaryButtonFun: ButtonFunctionType;
162
+ /** 立即购买按钮文本 */
163
+ primaryButtonText?: string;
164
+ primaryButtonFun: ButtonFunctionType;
165
+ /** Code Channel 配置 - 折扣前缀 */
166
+ codeChannel?: CodeChannelConfig;
167
+ /** 是否展示会员价格 */
168
+ showMemberPrice?: boolean;
169
+ /** 是否展示折扣标签 */
170
+ showDiscount?: boolean;
171
+ /** 是否展示标签系统 */
172
+ showTags?: boolean;
173
+ /** 库存展示模式 */
174
+ stockDisplayMode?: StockDisplayMode;
175
+ /** 库存阈值(当模式为 below-quantity 或 below-percentage 时使用) */
176
+ stockThreshold?: number;
177
+ /**
178
+ * 库存文本模板,支持 {count} 占位符
179
+ */
180
+ stockDisplayText?: string;
181
+ /** 是否展示原价(删除线价格) */
182
+ showOriginalPrice?: boolean;
183
+ /** 文案配置 */
184
+ copy?: CopyConfig;
185
+ /**
186
+ * 产品列表(当不使用 Tab 分组时可直接传入产品列表)
187
+ */
188
+ productsCard: ProductCardData[];
189
+ }
190
+ export interface MediaShelfProps extends React.HTMLAttributes<HTMLDivElement> {
191
+ /** 业务数据 */
192
+ data: MediaShelfData;
193
+ /** 点击了解更多回调 */
194
+ onLearnMore?: (product: ProductCardData) => void;
195
+ /** 点击立即购买回调 */
196
+ onShopNow?: (product: ProductCardData) => void;
197
+ /** 点击加入购物车回调 */
198
+ onAddToCart?: (product: ProductCardData) => void;
199
+ /** 语义化类名 */
200
+ classNames?: Partial<Record<MediaShelfSemanticName, string>>;
201
+ }
202
+ /**
203
+ * 产品卡片组件
204
+ */
205
+ declare const ProductCard: React.ForwardRefExoticComponent<{
206
+ product: ProductCardData;
207
+ className?: string;
208
+ } & React.RefAttributes<HTMLDivElement>>;
209
+ /**
210
+ * MediaShelf - 媒体货架
211
+ *
212
+ * @description 能够实时显示商品库存信息和会员价的货架,支持响应式布局和多种配置选项
213
+ */
214
+ declare const MediaShelf: React.ForwardRefExoticComponent<MediaShelfProps & React.RefAttributes<HTMLDivElement>>;
215
+ export default MediaShelf;
216
+ export { ProductCard };
@@ -0,0 +1,2 @@
1
+ "use strict";"use client";var I=Object.create;var C=Object.defineProperty;var O=Object.getOwnPropertyDescriptor;var q=Object.getOwnPropertyNames;var R=Object.getPrototypeOf,j=Object.prototype.hasOwnProperty;var G=(e,a)=>{for(var n in a)C(e,n,{get:a[n],enumerable:!0})},D=(e,a,n,d)=>{if(a&&typeof a=="object"||typeof a=="function")for(let o of q(a))!j.call(e,o)&&o!==n&&C(e,o,{get:()=>a[o],enumerable:!(d=O(a,o))||d.enumerable});return e};var W=(e,a,n)=>(n=e!=null?I(R(e)):{},D(a||!e||!e.__esModule?C(n,"default",{value:e,enumerable:!0}):n,e)),Z=e=>D(C({},"__esModule",{value:!0}),e);var X={};G(X,{ProductCard:()=>w,default:()=>U,useMediaShelfContext:()=>B});module.exports=Z(X);var t=require("react/jsx-runtime"),m=W(require("react")),r=require("../../helpers/index.js"),i=require("../../components/index.js"),k=require("swiper/react"),z=require("swiper/modules"),ee=require("swiper/css"),te=require("swiper/css/navigation");const J=({disabled:e})=>(0,t.jsxs)("svg",{width:"56",height:"56",viewBox:"0 0 56 56",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:" lg-desktop:size-[56px] laptop:block hidden size-[40px]",children:[(0,t.jsx)("path",{d:"M0 28C0 43.464 12.536 56 28 56C43.464 56 56 43.464 56 28C56 12.536 43.464 0 28 0C12.536 0 0 12.536 0 28Z",fill:"black",fillOpacity:e?"0.2":"0.6"}),(0,t.jsx)("path",{d:"M31 22L25 28L31 34",stroke:"white",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})]}),K=({disabled:e})=>(0,t.jsxs)("svg",{width:"56",height:"56",viewBox:"0 0 56 56",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:"lg-desktop:size-[56px] laptop:block hidden size-[40px]",children:[(0,t.jsx)("path",{d:"M0 28C0 12.536 12.536 0 28 0C43.464 0 56 12.536 56 28C56 43.464 43.464 56 28 56C12.536 56 0 43.464 0 28Z",fill:"black",fillOpacity:e?"0.2":"0.6"}),(0,t.jsx)("path",{d:"M25 22L31 28L25 34",stroke:"white",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})]});function Q(e,a,n,d){if(e===void 0)return!0;switch(e){case"always":return!0;case"never":return!1;case"below-quantity":return a===void 0?!0:n<=a;case"below-percentage":return a===void 0?!0:n/d<=a;default:return!0}}const L=m.createContext(null),B=()=>{const e=m.useContext(L);if(!e)throw new Error("useMediaShelfContext must be used within an MediaShelfProvider");return e},w=m.forwardRef(({product:e,className:a},n)=>{let{stockDisplayMode:d,stockThreshold:o,onLearnMore:c,onShopNow:s,onAddToCart:b,classNames:u,secondaryButtonText:g,primaryButtonText:h,secondaryButtonFun:f,primaryButtonFun:y,showOriginalPrice:T,copy:v}=B();const S=m.useMemo(()=>{const l=(e?.quantityAvailable??0)/(e?.totalInventory??1)*100;return l===0&&e.availableForSale?Math.round(Math.random()*5+1):l},[e?.availableForSale,e?.quantityAvailable,e?.totalInventory]),x=l=>{if(l)switch(l){case"buyNow":s?.(e);break;case"addCart":b?.(e);break;case"learnMore":c?.(e);break;default:break}};return(0,t.jsxs)(i.Card,{ref:n,className:(0,r.cn)("desktop:min-h-[512px] lg-desktop:min-h-[534px] flex min-h-[458px] min-w-[296px] flex-col overflow-hidden",e.custom_link?"cursor-pointer":"",a,u?.productCard),children:[(0,t.jsxs)("div",{className:"desktop:h-[240px] relative h-[200px] shrink-0 overflow-hidden",children:[(0,t.jsx)("div",{className:"absolute inset-0 ",children:(0,t.jsx)("a",{href:e.custom_link||e.listingLink,children:(0,t.jsx)(i.Picture,{source:e.custom_image||e.image,alt:e.name,className:(0,r.cn)("h-full",u?.productCardImage),imgClassName:"h-full object-cover object-center"})})}),(0,t.jsx)("div",{className:"lg-desktop:h-[28px] absolute left-4 top-4 h-[24px]",children:e.tags?.map((l,N)=>(0,t.jsx)(i.Badge,{size:"sm",variant:l.variant||"outline",className:(0,r.cn)("mr-1"),promotionalType:l.promotionalType,children:l.label},N))})]}),(0,t.jsxs)(i.CardContent,{className:"desktop:p-6 flex h-[calc(100%-240px)] grow flex-col justify-between p-4",children:[(0,t.jsxs)("div",{className:"mb-6 flex-1",children:[(0,t.jsx)(i.Heading,{as:"h3",size:2,className:(0,r.cn)("text-info-primary mb-1 line-clamp-2 font-semibold tracking-tight",u?.productTitle),children:e.custom_name||e.name}),(e.custom_description||e?.description)&&(0,t.jsx)(i.Text,{size:2,className:(0,r.cn)("text-info-primary line-clamp-1 font-semibold",u?.productDescription),html:e.custom_description||e.description})]}),Q(d,o,e?.quantityAvailable??0,e?.totalInventory??0)&&(0,t.jsxs)("div",{"data-total":e?.totalInventory??0,"data-available":e?.quantityAvailable??0,className:"space-y-2",children:[(0,t.jsx)(i.Progress,{value:S,max:100,min:0,size:"base",variant:"default","aria-label":"stock progress",classNames:{progressBar:"transition-all duration-300 ease-in-out"}}),(0,t.jsx)(i.Text,{size:3,className:"text-info-tertiary text-[14px]",children:v?.stockDisplayText?.replace("{count}",String(e?.quantityAvailable))})]}),(0,t.jsx)(t.Fragment,{children:e?.priceLabel&&e?.availableForSale&&(0,t.jsx)(i.Text,{size:4,className:(0,r.cn)("text-marketing-1 mt-2",u?.productPriceLabel),children:e.priceLabel})}),(0,t.jsx)("div",{className:(0,r.cn)("mb-6",u?.productPrice),children:(0,t.jsx)("div",{className:"flex items-baseline gap-2",children:e.availableForSale?(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(i.Heading,{size:2,className:"text-info-primary",as:"h6",children:e.price}),T&&e.originalPrice&&(0,t.jsx)(i.Heading,{size:2,className:"text-info-tertiary line-through",as:"h6",children:e.originalPrice})]}):(0,t.jsx)(i.Heading,{size:2,className:"text-info-tertiary",children:v?.outOfStockLabel??"Sold Out"})})}),(0,t.jsxs)("div",{className:(0,r.cn)("tablet:gap-3 mb-4 flex gap-2",u?.buttonGroup),children:[g&&(0,t.jsx)(i.Button,{variant:"secondary",size:"base",className:"",onClick:l=>x(f),disabled:!e.availableForSale&&f!=="learnMore",children:g}),h&&(0,t.jsx)(i.Button,{variant:"primary",size:"base",className:"",onClick:l=>x(y),disabled:!e.availableForSale&&y!=="learnMore",children:h})]})]})]})});w.displayName="ProductCard";const P=m.forwardRef(({products:e,className:a},n)=>{const{copy:d}=B(),[o,c]=m.useState({isBeginning:!0,isEnd:!1});return e?.length===0?null:(0,t.jsx)("div",{ref:n,className:a,children:(0,t.jsxs)("div",{className:"relative",children:[(0,t.jsx)(k.Swiper,{modules:[z.Navigation],spaceBetween:16,slidesPerView:"auto",autoHeight:!0,navigation:{nextEl:".swiper-button-next-custom",prevEl:".swiper-button-prev-custom"},onSwiper:s=>{c({isBeginning:s.isBeginning,isEnd:s.isEnd})},onSlideChange:s=>{c({isBeginning:s.isBeginning,isEnd:s.isEnd})},className:"!overflow-visible",breakpoints:{0:{spaceBetween:12,slidesPerView:1},768:{spaceBetween:12,slidesPerView:e.length<=2?2:2.3},1024:{spaceBetween:16,slidesPerView:Math.min(3,e.length)}},children:e.map((s,b)=>(0,t.jsx)(k.SwiperSlide,{className:"tablet:h-[428px] desktop:!h-[464px] lg-desktop:!h-[561px] tablet:!max-w-[50%] h-[428px] overflow-hidden",children:(0,t.jsx)(w,{product:s,className:"box-border w-full max-w-full"})},s.shopify_id+"-"+s.sku||b))}),(0,t.jsx)("button",{className:(0,r.cn)("swiper-button-prev-custom tablet:block absolute left-4 top-1/2 z-10 hidden -translate-y-1/2",{"tablet:hidden":e.length<=2}),"aria-label":d?.previousSlideLabel,disabled:o.isBeginning,children:(0,t.jsx)(J,{disabled:o.isBeginning})}),(0,t.jsx)("button",{className:(0,r.cn)("swiper-button-next-custom tablet:block absolute right-4 top-1/2 z-10 hidden -translate-y-1/2",{"tablet:hidden":e.length<=2}),"aria-label":d?.nextSlideLabel,disabled:o.isEnd,children:(0,t.jsx)(K,{disabled:o.isEnd})})]})})});P.displayName="ProductsList";const F=m.forwardRef(({className:e,data:a,onLearnMore:n,onShopNow:d,onAddToCart:o,classNames:c,...s},b)=>{const{theme:u="light",codeChannel:g,showMemberPrice:h=!0,showDiscount:f=!0,showTags:y=!0,stockDisplayMode:T,stockThreshold:v,showOriginalPrice:S=!0,secondaryButtonText:x,primaryButtonText:l,secondaryButtonFun:N,primaryButtonFun:E,isShowTab:_=!0,copy:H}=a,V={codeChannel:g,showMemberPrice:h,showDiscount:f,showTags:y,stockDisplayMode:T,stockThreshold:v,showOriginalPrice:S,onLearnMore:n,onShopNow:d,onAddToCart:o,classNames:c,secondaryButtonText:x,secondaryButtonFun:N,primaryButtonText:l,primaryButtonFun:E,copy:H||{}},A=a.productsTab&&a.productsTab.length>0,M=_&&A;return(0,t.jsx)(L.Provider,{value:V,children:(0,t.jsxs)("div",{ref:b,className:(0,r.cn)("w-full",{"aiui-dark":u==="dark"},e,c?.root),...s,children:[a.title&&(0,t.jsx)(i.Heading,{as:"h2",html:a.title,size:4,className:(0,r.cn)("text-info-primary mb-4",c?.title)}),a.description&&(0,t.jsx)(i.Text,{size:3,as:"p",html:a.description,className:(0,r.cn)("text-info-primary mb-6",c?.description)}),(0,t.jsxs)(i.Tabs,{defaultValue:a.productsTab?.[0]?.id,className:"w-full",children:[M&&(0,t.jsx)(i.TabsList,{className:"mb-6",children:a.productsTab?.map(p=>(0,t.jsx)(i.TabsTrigger,{value:p.id,children:p.tab},"tab-"+p.id))}),M?a.productsTab?.map(p=>(0,t.jsx)(i.TabsContent,{value:p.id,children:(0,t.jsx)(P,{products:p.data})},"tab-content-"+p.id)):(0,t.jsx)(P,{products:a.productsCard})]})]})})});F.displayName="MediaShelf";var U=F;
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/biz-components/MediaShelf/index.tsx"],
4
+ "sourcesContent": ["'use client'\n\nimport * as React from 'react'\nimport { cn } from '../../helpers/index.js'\nimport {\n Button,\n Badge,\n Card,\n CardContent,\n Picture,\n Text,\n Heading,\n Tabs,\n TabsList,\n TabsTrigger,\n TabsContent,\n Progress,\n} from '../../components/index.js'\n\nimport { Swiper, SwiperSlide } from 'swiper/react'\nimport { Navigation } from 'swiper/modules'\n\n// Import Swiper styles\nimport 'swiper/css'\nimport 'swiper/css/navigation'\nimport type { ButtonFunctionType, CopyConfig } from './types.js'\n\nimport type { BadgeProps } from '../../components/badge.js'\n\n/**\n * \u8BED\u4E49\u5316\u7C7B\u540D\n */\ntype MediaShelfSemanticName =\n | 'root'\n | 'title'\n | 'description'\n | 'productCard'\n | 'productCardImage'\n | 'productTitle'\n | 'productDescription'\n | 'productPriceLabel'\n | 'productPrice'\n | 'buttonGroup'\n | 'secondaryButton'\n | 'primaryButton'\n | 'stockBar'\n\nconst PrevIcon = ({ disabled }: { disabled: boolean }) => (\n <svg\n width=\"56\"\n height=\"56\"\n viewBox=\"0 0 56 56\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className=\" lg-desktop:size-[56px] laptop:block hidden size-[40px]\"\n >\n <path\n d=\"M0 28C0 43.464 12.536 56 28 56C43.464 56 56 43.464 56 28C56 12.536 43.464 0 28 0C12.536 0 0 12.536 0 28Z\"\n fill=\"black\"\n fillOpacity={disabled ? '0.2' : '0.6'}\n />\n <path d=\"M31 22L25 28L31 34\" stroke=\"white\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n </svg>\n)\n\nconst NextIcon = ({ disabled }: { disabled: boolean }) => (\n <svg\n width=\"56\"\n height=\"56\"\n viewBox=\"0 0 56 56\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className=\"lg-desktop:size-[56px] laptop:block hidden size-[40px]\"\n >\n <path\n d=\"M0 28C0 12.536 12.536 0 28 0C43.464 0 56 12.536 56 28C56 43.464 43.464 56 28 56C12.536 56 0 43.464 0 28Z\"\n fill=\"black\"\n fillOpacity={disabled ? '0.2' : '0.6'}\n />\n <path d=\"M25 22L31 28L25 34\" stroke=\"white\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n </svg>\n)\n\n/**\n * Code Channel \u914D\u7F6E - \u6298\u6263\u524D\u7F00\n */\nexport type CodeChannelConfig = string\n\n/**\n * \u5E93\u5B58\u5C55\u793A\u6A21\u5F0F\n */\nexport type StockDisplayMode = 'always' | 'never' | 'below-quantity' | 'below-percentage'\n\n/**\n * \u5224\u65AD\u662F\u5426\u5E94\u8BE5\u663E\u793A\u5E93\u5B58\u4FE1\u606F\n * @param stockDisplayMode \u5E93\u5B58\u5C55\u793A\u6A21\u5F0F\n * @param stockThreshold \u5E93\u5B58\u9608\u503C\uFF08\u5F53\u6A21\u5F0F\u4E3A below-quantity \u6216 below-percentage \u65F6\u4F7F\u7528\uFF09\n * @param variant \u53D8\u4F53\u6570\u636E\n * @returns \u662F\u5426\u663E\u793A\u5E93\u5B58\u4FE1\u606F\n */\nfunction shouldShowStock(\n stockDisplayMode: StockDisplayMode | undefined,\n stockThreshold: number | undefined,\n quantityAvailable: number,\n totalInventory: number\n): boolean {\n // \u672A\u914D\u7F6E\u65F6\u9ED8\u8BA4\u663E\u793A\n if (stockDisplayMode === undefined) {\n return true\n }\n\n // \u6839\u636E\u5C55\u793A\u6A21\u5F0F\u5224\u65AD\n switch (stockDisplayMode) {\n case 'always':\n // \u603B\u662F\u663E\u793A\n return true\n\n case 'never':\n // \u6C38\u4E0D\u663E\u793A\n return false\n\n case 'below-quantity':\n // \u5F53\u5E93\u5B58\u6570\u91CF\u4F4E\u4E8E\u9608\u503C\u65F6\u663E\u793A\n if (stockThreshold === undefined) {\n return true // \u6CA1\u6709\u8BBE\u7F6E\u9608\u503C\u65F6\u9ED8\u8BA4\u663E\u793A\n }\n\n return quantityAvailable <= stockThreshold\n\n case 'below-percentage':\n // \u5F53\u5E93\u5B58\u767E\u5206\u6BD4\u4F4E\u4E8E\u9608\u503C\u65F6\u663E\u793A\n if (stockThreshold === undefined) {\n return true // \u6CA1\u6709\u8BBE\u7F6E\u9608\u503C\u65F6\u9ED8\u8BA4\u663E\u793A\n }\n return quantityAvailable / totalInventory <= stockThreshold\n\n default:\n // \u672A\u77E5\u6A21\u5F0F\u65F6\u9ED8\u8BA4\u663E\u793A\n return true\n }\n}\n\n/**\n * MediaShelf Context \u914D\u7F6E\u63A5\u53E3\n */\nexport interface MediaShelfContextConfig {\n /** Code Channel \u914D\u7F6E - \u6298\u6263\u524D\u7F00 */\n codeChannel?: CodeChannelConfig\n /** \u662F\u5426\u5C55\u793A\u4F1A\u5458\u4EF7\u683C */\n showMemberPrice?: boolean\n /** \u662F\u5426\u5C55\u793A\u6298\u6263\u6807\u7B7E */\n showDiscount?: boolean\n /** \u662F\u5426\u5C55\u793A\u6807\u7B7E\u7CFB\u7EDF */\n showTags?: boolean\n /** \u5E93\u5B58\u5C55\u793A\u6A21\u5F0F */\n stockDisplayMode?: StockDisplayMode\n /** \u5E93\u5B58\u9608\u503C\uFF08\u5F53\u6A21\u5F0F\u4E3A below-quantity \u6216 below-percentage \u65F6\u4F7F\u7528\uFF09 */\n stockThreshold?: number\n /** \u662F\u5426\u5C55\u793A\u539F\u4EF7\uFF08\u5220\u9664\u7EBF\u4EF7\u683C\uFF09 */\n showOriginalPrice?: boolean\n /** \u7528\u6237\u72B6\u6001 */\n}\n\n/**\n * MediaShelf Context \u503C\u63A5\u53E3\n */\ninterface MediaShelfContextValue extends MediaShelfContextConfig {\n /** \u70B9\u51FB\u4E86\u89E3\u66F4\u591A\u56DE\u8C03 */\n onLearnMore?: (product: ProductCardData) => void\n /** \u70B9\u51FB\u7ACB\u5373\u8D2D\u4E70\u56DE\u8C03 */\n onShopNow?: (product: ProductCardData) => void\n /** \u70B9\u51FB\u52A0\u5165\u8D2D\u7269\u8F66\u56DE\u8C03 */\n onAddToCart?: (product: ProductCardData) => void\n /** \u8BED\u4E49\u5316\u7C7B\u540D */\n classNames?: Partial<Record<MediaShelfSemanticName, string>>\n /** \u4E86\u89E3\u66F4\u591A\u6309\u94AE\u6587\u672C */\n secondaryButtonText?: string\n secondaryButtonFun?: ButtonFunctionType\n /** \u7ACB\u5373\u8D2D\u4E70\u6309\u94AE\u6587\u672C */\n primaryButtonText?: string\n primaryButtonFun?: ButtonFunctionType\n /** \u6587\u6848\u914D\u7F6E */\n copy: CopyConfig\n}\n\n/**\n * MediaShelf Context\n */\nconst MediaShelfContext = React.createContext<MediaShelfContextValue | null>(null)\n\n/**\n * \u4F7F\u7528 MediaShelf Context \u7684 Hook\n */\nexport const useMediaShelfContext = () => {\n const context = React.useContext(MediaShelfContext)\n if (!context) {\n throw new Error('useMediaShelfContext must be used within an MediaShelfProvider')\n }\n return context\n}\n\n/**\n * \u57FA\u7840\u4EA7\u54C1\u6570\u636E\u63A5\u53E3\uFF08\u6765\u81EA\u5916\u90E8\u6570\u636E\u6E90\uFF09\n */\nexport interface BaseProductData {\n sku: string\n name: string\n image: string\n value: string\n handle: string\n shopify_id: string\n custom_name?: string\n custom_description?: string\n custom_image?: string\n custom_link?: string\n}\n\n/**\n * Shopify \u53D8\u4F53\u6570\u636E\u63A5\u53E3\n */\nexport interface VariantData {\n /**\n * \u4EA7\u54C1\u63CF\u8FF0\n */\n description?: string\n /**\n * \u53D8\u4F53id\n */\n variantId: string\n\n /**\n * \u4EA7\u54C1\u94FE\u63A5, \u70B9\u51FB\u56FE\u7247\u7684\u65F6\u5019\u8DF3\u8F6C\u5230\u8BE5\u94FE\u63A5\n */\n listingLink: string\n /**\n * \u539F\u4EF7\n */\n originalPrice: string\n /**\n * \u73B0\u4EF7\n */\n price: string\n /**\n * \u4EF7\u683C\u4E0A\u9762\u5C55\u793A\u7684\u6807\u7B7E\u6587\u672C\n */\n priceLabel?: string\n /**\n * \u603B\u5E93\u5B58\n */\n totalInventory: number\n /**\n * \u53EF\u7528\u5E93\u5B58\u6570\u91CF\n */\n quantityAvailable: number\n /**\n * \u662F\u5426\u53EF\u552E\n */\n availableForSale: boolean\n\n /**\n * tags \u5217\u8868(\u4F1A\u5458\u4EF7\uFF0C\u6298\u6263\uFF0Cnew, hot\u7B49\u6807\u7B7E\u4FE1\u606F)\n */\n tags: Array<{\n label: string\n variant: BadgeProps['variant']\n promotionalType?: BadgeProps['promotionalType']\n }>\n /**\n * \u901A\u7528\u6298\u6263\u6570\u636E\uFF0C\u5305\u62EC\u6298\u6263title, \u7C7B\u578B\u548C\u503C\n */\n coupon: any\n}\n\n/**\n * \u5B8C\u6574\u7684\u4EA7\u54C1\u5361\u7247\u6570\u636E\u63A5\u53E3\n */\nexport interface ProductCardData extends BaseProductData, VariantData {}\n\n/**\n * \u4EA7\u54C1\u5206\u7EC4Tab\u6570\u636E\u63A5\u53E3\n */\nexport interface ProductTab {\n /** Tab ID */\n id: string\n /** Tab \u6807\u9898 */\n tab: string\n /** \u8BE5\u5206\u7EC4\u4E0B\u7684\u4EA7\u54C1\u6570\u636E */\n data: ProductCardData[]\n}\n\n/**\n * MediaShelf \u4E1A\u52A1\u7EC4\u4EF6\u6570\u636E\u63A5\u53E3\n */\nexport interface MediaShelfData {\n theme?: 'light' | 'dark'\n /** \u7EC4\u4EF6\u6807\u9898 */\n title?: string\n /** \u7EC4\u4EF6\u63CF\u8FF0 */\n description?: string\n /** \u5206\u7EC4\u4EA7\u54C1Tab\u5217\u8868 */\n productsTab?: ProductTab[]\n /** \u662F\u5426\u663E\u793A Tab\uFF08\u9ED8\u8BA4\uFF1Atrue\uFF09 */\n isShowTab?: boolean\n /** \u4E86\u89E3\u66F4\u591A\u6309\u94AE\u6587\u672C */\n secondaryButtonText?: string\n secondaryButtonFun: ButtonFunctionType\n /** \u7ACB\u5373\u8D2D\u4E70\u6309\u94AE\u6587\u672C */\n primaryButtonText?: string\n primaryButtonFun: ButtonFunctionType\n /** Code Channel \u914D\u7F6E - \u6298\u6263\u524D\u7F00 */\n codeChannel?: CodeChannelConfig\n /** \u662F\u5426\u5C55\u793A\u4F1A\u5458\u4EF7\u683C */\n showMemberPrice?: boolean\n /** \u662F\u5426\u5C55\u793A\u6298\u6263\u6807\u7B7E */\n showDiscount?: boolean\n /** \u662F\u5426\u5C55\u793A\u6807\u7B7E\u7CFB\u7EDF */\n showTags?: boolean\n /** \u5E93\u5B58\u5C55\u793A\u6A21\u5F0F */\n stockDisplayMode?: StockDisplayMode\n /** \u5E93\u5B58\u9608\u503C\uFF08\u5F53\u6A21\u5F0F\u4E3A below-quantity \u6216 below-percentage \u65F6\u4F7F\u7528\uFF09 */\n stockThreshold?: number\n /**\n * \u5E93\u5B58\u6587\u672C\u6A21\u677F\uFF0C\u652F\u6301 {count} \u5360\u4F4D\u7B26\n */\n stockDisplayText?: string\n /** \u662F\u5426\u5C55\u793A\u539F\u4EF7\uFF08\u5220\u9664\u7EBF\u4EF7\u683C\uFF09 */\n showOriginalPrice?: boolean\n /** \u6587\u6848\u914D\u7F6E */\n copy?: CopyConfig\n /**\n * \u4EA7\u54C1\u5217\u8868\uFF08\u5F53\u4E0D\u4F7F\u7528 Tab \u5206\u7EC4\u65F6\u53EF\u76F4\u63A5\u4F20\u5165\u4EA7\u54C1\u5217\u8868\uFF09\n */\n productsCard: ProductCardData[]\n}\n\nexport interface MediaShelfProps extends React.HTMLAttributes<HTMLDivElement> {\n /** \u4E1A\u52A1\u6570\u636E */\n data: MediaShelfData\n /** \u70B9\u51FB\u4E86\u89E3\u66F4\u591A\u56DE\u8C03 */\n onLearnMore?: (product: ProductCardData) => void\n /** \u70B9\u51FB\u7ACB\u5373\u8D2D\u4E70\u56DE\u8C03 */\n onShopNow?: (product: ProductCardData) => void\n /** \u70B9\u51FB\u52A0\u5165\u8D2D\u7269\u8F66\u56DE\u8C03 */\n onAddToCart?: (product: ProductCardData) => void\n /** \u8BED\u4E49\u5316\u7C7B\u540D */\n classNames?: Partial<Record<MediaShelfSemanticName, string>>\n}\n\n/**\n * \u4EA7\u54C1\u5361\u7247\u7EC4\u4EF6\n */\nconst ProductCard = React.forwardRef<\n HTMLDivElement,\n {\n product: ProductCardData\n className?: string\n }\n>(({ product, className }, ref) => {\n let {\n stockDisplayMode,\n stockThreshold,\n onLearnMore,\n onShopNow,\n onAddToCart,\n classNames,\n secondaryButtonText,\n primaryButtonText,\n secondaryButtonFun,\n primaryButtonFun,\n showOriginalPrice,\n copy,\n } = useMediaShelfContext()\n\n const stockPercentage = React.useMemo(() => {\n const result = ((product?.quantityAvailable ?? 0) / (product?.totalInventory ?? 1)) * 100\n if (result === 0 && product.availableForSale) {\n // \u53EF\u552E\u4F46\u5E93\u5B58\u4E3A0\u65F6\uFF0C\u968F\u673A\u663E\u793A1-5%\u7684\u5E93\u5B58\u8FDB\u5EA6\n return Math.round(Math.random() * 5 + 1)\n }\n return result\n }, [product?.availableForSale, product?.quantityAvailable, product?.totalInventory])\n\n // \u6839\u636E\u6309\u94AE\u529F\u80FD\u7C7B\u578B\u8C03\u7528\u76F8\u5E94\u7684\u56DE\u8C03\u51FD\u6570\n const handleButtonClick = (buttonFun?: ButtonFunctionType) => {\n if (!buttonFun) return\n\n switch (buttonFun) {\n case 'buyNow':\n onShopNow?.(product)\n break\n case 'addCart':\n onAddToCart?.(product)\n break\n case 'learnMore':\n onLearnMore?.(product)\n break\n default:\n break\n }\n }\n\n return (\n <Card\n ref={ref}\n className={cn(\n 'desktop:min-h-[512px] lg-desktop:min-h-[534px] flex min-h-[458px] min-w-[296px] flex-col overflow-hidden',\n product.custom_link ? 'cursor-pointer' : '',\n className,\n classNames?.productCard\n )}\n >\n {/* \u56FE\u7247\u533A\u57DF */}\n <div className=\"desktop:h-[240px] relative h-[200px] shrink-0 overflow-hidden\">\n {/* \u80CC\u666F\u56FE\u7247 */}\n <div className=\"absolute inset-0 \">\n <a href={product.custom_link || product.listingLink}>\n <Picture\n source={product.custom_image || product.image}\n alt={product.name}\n className={cn('h-full', classNames?.productCardImage)}\n imgClassName=\"h-full object-cover object-center\"\n />\n </a>\n </div>\n\n {/* \u6807\u7B7E\u533A\u57DF */}\n <div className=\"lg-desktop:h-[28px] absolute left-4 top-4 h-[24px]\">\n {product.tags?.map((tag, index) => (\n <Badge\n key={index}\n size=\"sm\"\n variant={(tag.variant as any) || 'outline'}\n className={cn('mr-1')}\n promotionalType={tag.promotionalType}\n >\n {tag.label}\n </Badge>\n ))}\n </div>\n </div>\n\n {/* \u5185\u5BB9\u533A\u57DF */}\n <CardContent className=\"desktop:p-6 flex h-[calc(100%-240px)] grow flex-col justify-between p-4\">\n {/* \u4EA7\u54C1\u6807\u9898\u548C\u526F\u6807\u9898 */}\n <div className=\"mb-6 flex-1\">\n <Heading\n as=\"h3\"\n size={2}\n className={cn('text-info-primary mb-1 line-clamp-2 font-semibold tracking-tight', classNames?.productTitle)}\n >\n {product.custom_name || product.name}\n </Heading>\n {(product.custom_description || product?.description) && (\n <Text\n size={2}\n className={cn('text-info-primary line-clamp-1 font-semibold', classNames?.productDescription)}\n html={product.custom_description || product.description}\n />\n )}\n </div>\n\n {/* \u5E93\u5B58\u4FE1\u606F */}\n {shouldShowStock(\n stockDisplayMode,\n stockThreshold,\n product?.quantityAvailable ?? 0,\n product?.totalInventory ?? 0\n ) && (\n <div\n data-total={product?.totalInventory ?? 0}\n data-available={product?.quantityAvailable ?? 0}\n className=\"space-y-2\"\n >\n <Progress\n value={stockPercentage}\n max={100}\n min={0}\n size=\"base\"\n variant=\"default\"\n aria-label=\"stock progress\"\n classNames={{\n progressBar: 'transition-all duration-300 ease-in-out',\n }}\n />\n <Text size={3} className=\"text-info-tertiary text-[14px]\">\n {copy?.stockDisplayText?.replace('{count}', String(product?.quantityAvailable))}\n </Text>\n </div>\n )}\n\n {/** \u4EF7\u683C\u6807\u7B7E */}\n <>\n {product?.priceLabel && product?.availableForSale && (\n <Text size={4} className={cn('text-marketing-1 mt-2', classNames?.productPriceLabel)}>\n {product.priceLabel}\n </Text>\n )}\n </>\n {/* \u4EF7\u683C\u533A\u57DF */}\n <div className={cn('mb-6', classNames?.productPrice)}>\n <div className=\"flex items-baseline gap-2\">\n {product.availableForSale ? (\n <>\n <Heading size={2} className=\"text-info-primary\" as=\"h6\">\n {product.price}\n </Heading>\n {showOriginalPrice && product.originalPrice && (\n <Heading size={2} className=\"text-info-tertiary line-through\" as=\"h6\">\n {product.originalPrice}\n </Heading>\n )}\n </>\n ) : (\n <Heading size={2} className=\"text-info-tertiary\">\n {copy?.outOfStockLabel ?? 'Sold Out'}\n </Heading>\n )}\n </div>\n </div>\n\n {/* \u6309\u94AE\u533A\u57DF */}\n <div className={cn('tablet:gap-3 mb-4 flex gap-2', classNames?.buttonGroup)}>\n {secondaryButtonText && (\n <Button\n variant=\"secondary\"\n size=\"base\"\n className=\"\"\n onClick={e => handleButtonClick(secondaryButtonFun)}\n disabled={!product.availableForSale && secondaryButtonFun !== 'learnMore'}\n >\n {secondaryButtonText}\n </Button>\n )}\n {primaryButtonText && (\n <Button\n variant=\"primary\"\n size=\"base\"\n className=\"\"\n onClick={e => handleButtonClick(primaryButtonFun)}\n disabled={!product.availableForSale && primaryButtonFun !== 'learnMore'}\n >\n {primaryButtonText}\n </Button>\n )}\n </div>\n </CardContent>\n </Card>\n )\n})\nProductCard.displayName = 'ProductCard'\n\n/**\n * \u4EA7\u54C1\u5217\u8868\u7EC4\u4EF6 - \u4F7F\u7528 Swiper \u6A2A\u5411\u6ED1\u52A8\u5E03\u5C40\n */\nconst ProductsList = React.forwardRef<\n HTMLDivElement,\n {\n products: ProductCardData[]\n className?: string\n }\n>(({ products, className }, ref) => {\n const { copy } = useMediaShelfContext()\n // Swiper \u5BFC\u822A\u72B6\u6001\n const [swiperState, setSwiperState] = React.useState({\n isBeginning: true,\n isEnd: false,\n })\n\n if (products?.length === 0) {\n return null\n }\n\n return (\n <div ref={ref} className={className}>\n {/* Swiper \u6A2A\u5411\u6ED1\u52A8\u5E03\u5C40 */}\n <div className=\"relative\">\n <Swiper\n modules={[Navigation]}\n spaceBetween={16}\n slidesPerView=\"auto\"\n autoHeight={true}\n navigation={{\n nextEl: '.swiper-button-next-custom',\n prevEl: '.swiper-button-prev-custom',\n }}\n onSwiper={swiper => {\n setSwiperState({\n isBeginning: swiper.isBeginning,\n isEnd: swiper.isEnd,\n })\n }}\n onSlideChange={swiper => {\n setSwiperState({\n isBeginning: swiper.isBeginning,\n isEnd: swiper.isEnd,\n })\n }}\n className=\"!overflow-visible\"\n breakpoints={{\n 0: {\n spaceBetween: 12,\n slidesPerView: 1,\n },\n 768: {\n spaceBetween: 12,\n slidesPerView: products.length <= 2 ? 2 : 2.3,\n },\n 1024: {\n spaceBetween: 16,\n slidesPerView: Math.min(3, products.length),\n },\n }}\n >\n {products.map((product, index) => (\n <SwiperSlide\n key={product.shopify_id + '-' + product.sku || index}\n className=\"tablet:h-[428px] desktop:!h-[464px] lg-desktop:!h-[561px] tablet:!max-w-[50%] h-[428px] overflow-hidden\"\n >\n <ProductCard product={product} className=\"box-border w-full max-w-full\" />\n </SwiperSlide>\n ))}\n </Swiper>\n\n {/* \u81EA\u5B9A\u4E49\u5BFC\u822A\u6309\u94AE */}\n <button\n className={cn('swiper-button-prev-custom tablet:block absolute left-4 top-1/2 z-10 hidden -translate-y-1/2', {\n 'tablet:hidden': products.length <= 2,\n })}\n aria-label={copy?.previousSlideLabel}\n disabled={swiperState.isBeginning}\n >\n <PrevIcon disabled={swiperState.isBeginning} />\n </button>\n <button\n className={cn(\n 'swiper-button-next-custom tablet:block absolute right-4 top-1/2 z-10 hidden -translate-y-1/2',\n {\n 'tablet:hidden': products.length <= 2,\n }\n )}\n aria-label={copy?.nextSlideLabel}\n disabled={swiperState.isEnd}\n >\n <NextIcon disabled={swiperState.isEnd} />\n </button>\n </div>\n </div>\n )\n})\n\nProductsList.displayName = 'ProductsList'\n\n/**\n * MediaShelf - \u5A92\u4F53\u8D27\u67B6\n *\n * @description \u80FD\u591F\u5B9E\u65F6\u663E\u793A\u5546\u54C1\u5E93\u5B58\u4FE1\u606F\u548C\u4F1A\u5458\u4EF7\u7684\u8D27\u67B6\uFF0C\u652F\u6301\u54CD\u5E94\u5F0F\u5E03\u5C40\u548C\u591A\u79CD\u914D\u7F6E\u9009\u9879\n */\nconst MediaShelf = React.forwardRef<HTMLDivElement, MediaShelfProps>(\n ({ className, data, onLearnMore, onShopNow, onAddToCart, classNames, ...props }, ref) => {\n // \u4ECE data \u4E2D\u89E3\u6784\u914D\u7F6E\u9879\uFF0C\u5E76\u8BBE\u7F6E\u9ED8\u8BA4\u503C\n const {\n theme = 'light',\n codeChannel,\n showMemberPrice = true,\n showDiscount = true,\n showTags = true,\n stockDisplayMode,\n stockThreshold,\n showOriginalPrice = true,\n secondaryButtonText,\n primaryButtonText,\n secondaryButtonFun,\n primaryButtonFun,\n isShowTab = true,\n copy,\n } = data\n\n // \u6784\u5EFA copy \u914D\u7F6E\uFF0C\u4F7F\u7528\u4F20\u5165\u7684 copy \u914D\u7F6E\n const finalCopy: CopyConfig = copy || {}\n\n // \u6784\u5EFA Context \u503C\n const contextValue: MediaShelfContextValue = {\n codeChannel,\n showMemberPrice,\n showDiscount,\n showTags,\n stockDisplayMode,\n stockThreshold,\n showOriginalPrice,\n onLearnMore,\n onShopNow,\n onAddToCart,\n classNames,\n secondaryButtonText,\n secondaryButtonFun,\n primaryButtonText,\n primaryButtonFun,\n copy: finalCopy,\n }\n\n // \u83B7\u53D6\u8981\u663E\u793A\u7684\u4EA7\u54C1\u6570\u636E\n const hasTabData = data.productsTab && data.productsTab.length > 0\n const shouldShowTab = isShowTab && hasTabData\n\n return (\n <MediaShelfContext.Provider value={contextValue}>\n <div\n ref={ref}\n className={cn(\n 'w-full',\n {\n 'aiui-dark': theme === 'dark',\n },\n className,\n classNames?.root\n )}\n {...props}\n >\n {/* \u6807\u9898\u533A\u57DF */}\n {data.title && (\n <Heading as=\"h2\" html={data.title} size={4} className={cn('text-info-primary mb-4', classNames?.title)} />\n )}\n {data.description && (\n <Text\n size={3}\n as=\"p\"\n html={data.description}\n className={cn('text-info-primary mb-6', classNames?.description)}\n />\n )}\n\n {/* \u4EA7\u54C1\u5C55\u793A\u533A\u57DF */}\n\n <Tabs defaultValue={data.productsTab?.[0]?.id} className=\"w-full\">\n {shouldShowTab && (\n <TabsList className=\"mb-6\">\n {data.productsTab?.map(tab => (\n <TabsTrigger key={'tab-' + tab.id} value={tab.id}>\n {tab.tab}\n </TabsTrigger>\n ))}\n </TabsList>\n )}\n {shouldShowTab ? (\n data.productsTab?.map(tab => (\n <TabsContent key={'tab-content-' + tab.id} value={tab.id}>\n <ProductsList products={tab.data} />\n </TabsContent>\n ))\n ) : (\n <ProductsList products={data.productsCard} />\n )}\n </Tabs>\n </div>\n </MediaShelfContext.Provider>\n )\n }\n)\n\nMediaShelf.displayName = 'MediaShelf'\nexport default MediaShelf\nexport { ProductCard }\n"],
5
+ "mappings": "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",
6
+ "names": ["MediaShelf_exports", "__export", "ProductCard", "MediaShelf_default", "useMediaShelfContext", "__toCommonJS", "import_jsx_runtime", "React", "import_helpers", "import_components", "import_react", "import_modules", "import_css", "import_navigation", "PrevIcon", "disabled", "NextIcon", "shouldShowStock", "stockDisplayMode", "stockThreshold", "quantityAvailable", "totalInventory", "MediaShelfContext", "context", "product", "className", "ref", "onLearnMore", "onShopNow", "onAddToCart", "classNames", "secondaryButtonText", "primaryButtonText", "secondaryButtonFun", "primaryButtonFun", "showOriginalPrice", "copy", "stockPercentage", "result", "handleButtonClick", "buttonFun", "tag", "index", "e", "ProductsList", "products", "swiperState", "setSwiperState", "swiper", "MediaShelf", "data", "props", "theme", "codeChannel", "showMemberPrice", "showDiscount", "showTags", "isShowTab", "contextValue", "hasTabData", "shouldShowTab", "tab"]
7
+ }
@@ -0,0 +1,22 @@
1
+ /**
2
+ * 按钮功能类型
3
+ */
4
+ export type ButtonFunctionType = 'buyNow' | 'addCart' | 'learnMore';
5
+ /**
6
+ * MediaShelf 文案配置接口
7
+ * 注意:secondaryButtonText 和 shopNowText 作为高频属性保持在 data 的直接属性中
8
+ */
9
+ export interface CopyConfig {
10
+ /** Plus会员价格标签文本 */
11
+ plusMemberPriceLabel?: string;
12
+ /** 会员价格标签文本 */
13
+ memberPriceLabel?: string;
14
+ /** 库存显示文案模板,支持 {count} 占位符 */
15
+ stockDisplayText?: string;
16
+ /** 上一页滑动按钮的无障碍标签(MediaShelf 专用) */
17
+ previousSlideLabel?: string;
18
+ /** 下一页滑动按钮的无障碍标签(MediaShelf 专用) */
19
+ nextSlideLabel?: string;
20
+ discountLabel?: string;
21
+ outOfStockLabel?: string;
22
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var n=Object.defineProperty;var s=Object.getOwnPropertyDescriptor;var a=Object.getOwnPropertyNames;var l=Object.prototype.hasOwnProperty;var b=(t,e,o,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of a(e))!l.call(t,r)&&r!==o&&n(t,r,{get:()=>e[r],enumerable:!(i=s(e,r))||i.enumerable});return t};var g=t=>b(n({},"__esModule",{value:!0}),t);var p={};module.exports=g(p);
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/biz-components/MediaShelf/types.ts"],
4
+ "sourcesContent": ["/**\n * \u6309\u94AE\u529F\u80FD\u7C7B\u578B\n */\nexport type ButtonFunctionType = 'buyNow' | 'addCart' | 'learnMore'\n\n/**\n * MediaShelf \u6587\u6848\u914D\u7F6E\u63A5\u53E3\n * \u6CE8\u610F\uFF1AsecondaryButtonText \u548C shopNowText \u4F5C\u4E3A\u9AD8\u9891\u5C5E\u6027\u4FDD\u6301\u5728 data \u7684\u76F4\u63A5\u5C5E\u6027\u4E2D\n */\nexport interface CopyConfig {\n /** Plus\u4F1A\u5458\u4EF7\u683C\u6807\u7B7E\u6587\u672C */\n plusMemberPriceLabel?: string\n /** \u4F1A\u5458\u4EF7\u683C\u6807\u7B7E\u6587\u672C */\n memberPriceLabel?: string\n\n /** \u5E93\u5B58\u663E\u793A\u6587\u6848\u6A21\u677F\uFF0C\u652F\u6301 {count} \u5360\u4F4D\u7B26 */\n stockDisplayText?: string\n\n /** \u4E0A\u4E00\u9875\u6ED1\u52A8\u6309\u94AE\u7684\u65E0\u969C\u788D\u6807\u7B7E\uFF08MediaShelf \u4E13\u7528\uFF09 */\n previousSlideLabel?: string\n /** \u4E0B\u4E00\u9875\u6ED1\u52A8\u6309\u94AE\u7684\u65E0\u969C\u788D\u6807\u7B7E\uFF08MediaShelf \u4E13\u7528\uFF09 */\n nextSlideLabel?: string\n\n discountLabel?: string\n outOfStockLabel?: string\n}\n"],
5
+ "mappings": "+WAAA,IAAAA,EAAA,kBAAAC,EAAAD",
6
+ "names": ["types_exports", "__toCommonJS"]
7
+ }
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
2
  import type { MemberEquityProps } from './types.js';
3
- declare const _default: React.ForwardRefExoticComponent<Omit<MemberEquityProps, keyof import("../../shared/Styles.js").StylesProps> & Partial<import("../../shared/Styles.js").StylesProps & import("../../shared/Styles.js").ContainerProps> & {
4
- className?: string;
5
- data?: Record<string, any>;
3
+ declare const _default: React.ForwardRefExoticComponent<MemberEquityProps & {
4
+ style?: string | React.CSSProperties;
5
+ container?: import("../../shared/Styles.js").ContainerProps["container"];
6
6
  } & React.RefAttributes<any>>;
7
7
  export default _default;
@@ -0,0 +1,88 @@
1
+ import * as React from 'react';
2
+ export type MiniCartSemanticName = 'root' | 'content' | 'productImage' | 'productTag' | 'cartInfo' | 'cartTitle' | 'cartDescription' | 'priceSection' | 'totalPrice' | 'originalPrice' | 'saveAmount' | 'actionButton' | 'itemsGrid' | 'itemGridContainer' | 'gridItem' | 'gridItemOverlay' | 'expandButton' | 'congratsMessage';
3
+ /**
4
+ * 文案配置
5
+ */
6
+ export interface MiniCartCopy {
7
+ emptyCart: string;
8
+ description: string;
9
+ total: string;
10
+ itemsInCart: string;
11
+ totalWithCoupon: string;
12
+ clickToView: string;
13
+ buyNowText: string;
14
+ }
15
+ /**
16
+ * MiniCart 业务组件数据接口
17
+ */
18
+ export interface MiniCartData {
19
+ /** 文案配置 */
20
+ copy?: MiniCartCopy;
21
+ theme?: 'light' | 'dark';
22
+ /** 地区代码,用于价格格式化 */
23
+ locale?: string;
24
+ }
25
+ type Cart = {
26
+ id: string;
27
+ checkoutUrl: string;
28
+ lineItems: Array<{
29
+ id: string;
30
+ quantity: number;
31
+ merchandise: {
32
+ id: string;
33
+ sku: string;
34
+ image: {
35
+ url: string;
36
+ altText: string | null;
37
+ };
38
+ };
39
+ }>;
40
+ cost: {
41
+ totalAmount: {
42
+ amount: string;
43
+ currencyCode: string;
44
+ };
45
+ subtotalAmount?: {
46
+ amount: string;
47
+ currencyCode: string;
48
+ };
49
+ };
50
+ };
51
+ export interface MiniCartProps extends React.HTMLAttributes<HTMLDivElement> {
52
+ /** 业务数据 */
53
+ data: MiniCartData;
54
+ /**
55
+ * 各部分的自定义样式类名
56
+ */
57
+ classNames?: Partial<Record<MiniCartSemanticName, string>>;
58
+ /**
59
+ * 产品信息(用于主要展示的产品)
60
+ */
61
+ cart: Cart;
62
+ /**
63
+ * 删除商品项的回调函数
64
+ * @param id 商品 ID
65
+ * @param cart 购物车数据
66
+ * @returns
67
+ */
68
+ onRemoveItem?: (id: string, cart: Cart) => void;
69
+ /**
70
+ * 点击结算按钮的回调函数
71
+ * @param cart
72
+ * @returns
73
+ */
74
+ onCheckout?: (cart: Cart) => void;
75
+ /**
76
+ * 点击click to view的回调函数
77
+ * @param cart
78
+ * @returns
79
+ */
80
+ onClickToView?: (cart: Cart) => void;
81
+ }
82
+ /**
83
+ * MiniCart - 迷你购物车
84
+ *
85
+ * @description 迷你购物车(Mini Cart)是一个常见的电商UI组件,通常在用户浏览商品时以底部悬浮的形式出现,允许用户快速查看、编辑购物车内容而不离开当前页面,同时可以承载满赠,满减等活动。
86
+ */
87
+ declare const MiniCart: React.ForwardRefExoticComponent<MiniCartProps & React.RefAttributes<HTMLDivElement>>;
88
+ export default MiniCart;
@@ -0,0 +1,2 @@
1
+ "use strict";"use client";var K=Object.create;var f=Object.defineProperty;var Q=Object.getOwnPropertyDescriptor;var X=Object.getOwnPropertyNames;var _=Object.getPrototypeOf,tt=Object.prototype.hasOwnProperty;var et=(i,e)=>{for(var n in e)f(i,n,{get:e[n],enumerable:!0})},P=(i,e,n,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of X(e))!tt.call(i,s)&&s!==n&&f(i,s,{get:()=>e[s],enumerable:!(a=Q(e,s))||a.enumerable});return i};var ot=(i,e,n)=>(n=i!=null?K(_(i)):{},P(e||!i||!i.__esModule?f(n,"default",{value:i,enumerable:!0}):n,i)),it=i=>P(f({},"__esModule",{value:!0}),i);var at={};et(at,{default:()=>rt});module.exports=it(at);var t=require("react/jsx-runtime"),N=ot(require("react")),o=require("../../helpers/index.js"),x=require("../../helpers/priceFormatting.js"),j=require("../../components/index.js"),d=require("../../components/index.js"),h=require("../../components/index.js");const H=N.forwardRef(({className:i,classNames:e={},data:n,cart:a,onRemoveItem:s,onCheckout:S,onClickToView:D,...E},V)=>{const{copy:c,theme:T="dark",locale:b="us"}=n||{},R=c?.emptyCart||"Your Cart is Empty",M=c?.description||'Add one more to get <span style="color: var(--brand-color)">50% <span> off',W=c?.itemsInCart||"You have selected ${count} items",$=c?.total||"Total ${total}",nt=c?.totalWithCoupon||"total: ${total} (${subtotal})",G=c?.clickToView||"Click to view cart",q=c?.buyNowText||"Buy Now",p=a?.lineItems||[],L=p.reduce((l,r)=>l+(r?.quantity||0),0),U=L===0,m=parseFloat(a?.cost?.subtotalAmount?.amount||"0")||0,u=parseFloat(a?.cost?.totalAmount?.amount||"0")||0,v=a?.cost?.totalAmount?.currencyCode||a?.cost?.subtotalAmount?.currencyCode||"USD",I=m>u?m-u:0,C=N.useRef(null),[w,F]=N.useState(!1),z=l=>{if(C.current){const r=C.current,k=100;r.scrollBy({left:l==="right"?k:-k,behavior:"smooth"})}},y=({className:l})=>(0,t.jsx)("svg",{className:l,width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:(0,t.jsx)("path",{d:"M6 4L10 8L6 12",stroke:"currentColor",strokeWidth:"1.33",strokeLinecap:"round",strokeLinejoin:"round"})}),O=({className:l})=>(0,t.jsx)("svg",{className:l,width:"20",height:"20",viewBox:"0 0 20 20",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:(0,t.jsx)("path",{d:"M2.5 5H17.5M8.33333 9.16667V14.1667M11.6667 9.16667V14.1667M3.33333 5L4.16667 16.6667C4.16667 17.1087 4.34226 17.5326 4.65482 17.8452C4.96738 18.1577 5.39131 18.3333 5.83333 18.3333H14.1667C14.6087 18.3333 15.0326 18.1577 15.3452 17.8452C15.6577 17.5326 15.8333 17.1087 15.8333 16.6667L16.6667 5M7.5 5V2.5C7.5 2.27899 7.5878 2.06702 7.74408 1.91074C7.90036 1.75446 8.11232 1.66667 8.33333 1.66667H11.6667C11.8877 1.66667 12.0996 1.75446 12.2559 1.91074C12.4122 2.06702 12.5 2.27899 12.5 2.5V5",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),Y=l=>p.length?(0,t.jsxs)("div",{className:(0,o.cn)("bg-muted flex gap-1 rounded-lg p-1",e?.itemsGrid),children:[p.length>0&&(0,t.jsx)("button",{onClick:()=>z("left"),className:(0,o.cn)("border-border laptop:flex hover:bg-muted-foreground/10 laptop:flex hidden size-12 shrink-0 items-center justify-center rounded-lg transition-colors",e?.expandButton),"aria-label":"Scroll left to see more items",children:(0,t.jsx)(y,{className:"size-4 rotate-180"})}),(0,t.jsx)("div",{ref:C,className:(0,o.cn)("scrollbar-hide laptop:gap-1 laptop:max-w-[240px] flex w-full gap-1 overflow-x-auto [-ms-overflow-style:none] [scrollbar-width:none] [&::-webkit-scrollbar]:hidden",e?.itemGridContainer),children:p.filter(r=>r&&r.id).map(r=>{const A=(r.merchandise||{}).image||{},B=A.url,Z=A.altText||"Product image";return(0,t.jsxs)("div",{className:(0,o.cn)("laptop:size-12 group relative size-16 shrink-0 rounded-lg bg-white",e?.gridItem),children:[B&&(0,t.jsx)("img",{src:B,alt:Z,className:"size-full rounded-lg object-cover",onError:J=>{J.currentTarget.style.display="none"}}),(0,t.jsx)("span",{role:"button",onClick:()=>s?.(r.id,a),className:"laptop:hidden absolute right-[2px] top-[2px]","aria-label":"delete",children:(0,t.jsxs)("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[(0,t.jsx)("rect",{x:"1.33301",y:"1.33301",width:"13.3333",height:"13.3333",rx:"6.66667",fill:"white"}),(0,t.jsx)("path",{d:"M5.37705 5.28896C5.57234 5.09402 5.88839 5.09442 6.08347 5.28965L8.08602 7.29358L10.0906 5.28896C10.2858 5.09402 10.6026 5.09395 10.7977 5.28896C10.9928 5.48418 10.9926 5.80078 10.7977 5.99607L8.79312 8.00069L10.7964 10.0053C10.9913 10.2007 10.9909 10.5179 10.7957 10.7131C10.6005 10.908 10.2844 10.9074 10.0893 10.7124L8.08602 8.7078L6.08347 10.7103C5.88821 10.9056 5.57155 10.9057 5.37636 10.7103C5.18148 10.515 5.18132 10.1984 5.37636 10.0032L7.37891 8.00069L5.37636 5.99676C5.18119 5.80143 5.18181 5.48423 5.37705 5.28896Z",fill:"#767880"})]})}),r.quantity>1&&(0,t.jsx)("div",{className:"bg-brand-0 laptop:size-4 absolute bottom-0 right-0 flex size-4 items-center justify-center rounded-full",children:(0,t.jsx)(d.Text,{className:"text-sm",children:r.quantity})}),(0,t.jsx)("div",{className:(0,o.cn)("laptop:flex absolute inset-0 hidden items-center justify-center rounded-lg bg-black/60 opacity-0 transition-opacity group-hover:opacity-100",e?.gridItemOverlay),children:(0,t.jsx)("button",{onClick:()=>s?.(r.id,a),className:"flex items-center justify-center rounded-full bg-white/20 p-1 transition-colors hover:bg-white/30","aria-label":"Remove item",children:(0,t.jsx)(O,{className:"laptop:size-3 size-4 text-white"})})})]},r.id)})}),p.length>0&&(0,t.jsx)("button",{onClick:()=>z("right"),className:(0,o.cn)("border-border laptop:flex hover:bg-muted-foreground/10 laptop:flex hidden size-12 shrink-0 items-center justify-center rounded-lg transition-colors",e?.expandButton),"aria-label":"Scroll right to see more items",children:(0,t.jsx)(y,{className:"size-4"})})]}):null,g=!U&&p.length>0;return(0,t.jsx)("div",{ref:V,className:(0,o.cn)("bg-background text-info-primary tablet:px-6 laptop:px-12 desktop:px-12 lg-desktop:px-[128px] laptop:py-[16px] flex w-full px-4 py-[12px]","flex-col items-stretch gap-3","laptop:flex-row laptop:items-center laptop:justify-around",g?"laptop:items-start laptop:gap-4":"laptop:items-center laptop:gap-4","tablet:gap-6 laptop:gap-8",i,e?.root,{"aiui-dark":T==="dark"}),...E,children:(0,t.jsxs)("div",{className:(0,o.cn)("laptop:flex-row flex w-full flex-col gap-4","laptop:flex-1 laptop:items-start","tablet:gap-6 laptop:gap-8",e?.content),children:[(0,t.jsxs)("div",{className:"laptop:flex-1 flex w-full flex-col",children:[(0,t.jsx)("div",{className:(0,o.cn)("tablet:gap-2 flex flex-col gap-1",e?.cartInfo),children:g?(0,t.jsxs)("div",{className:"flex w-full items-center gap-2",children:[(0,t.jsx)(h.Heading,{size:2,as:"h3",className:(0,o.cn)("",e?.cartTitle),children:W.replace("${count}",(L||0).toString())}),(0,t.jsxs)("button",{onClick:()=>{window.innerWidth<1025?F(!w):D?.(a)},className:(0,o.cn)("flex items-center gap-1 text-base font-semibold",e?.expandButton),children:[(0,t.jsx)(h.Heading,{as:"h6",size:1,className:"laptop:block hidden text-base",children:G}),(0,t.jsx)(y,{className:(0,o.cn)("size-4 transition-transform",w?"laptop:rotate-0 -rotate-90":"laptop:rotate-0 rotate-90")})]})]}):(0,t.jsx)(h.Heading,{as:"h3",className:(0,o.cn)("tablet:text-2xl text-xl font-semibold",e?.cartTitle),children:R})}),(0,t.jsx)("div",{children:M&&(0,t.jsx)(d.Text,{className:(0,o.cn)("mini-cart-description",e?.cartDescription),html:M})})]}),g&&(0,t.jsx)("div",{className:(0,o.cn)("laptop:block",w?"block":"hidden"),children:Y(T)}),g&&(0,t.jsx)("hr",{className:"laptop:hidden border-lines w-full border-t"}),(0,t.jsxs)("div",{className:(0,o.cn)("tablet:gap-6 laptop:justify-end flex flex-row items-center justify-between gap-4",e?.priceSection),children:[(0,t.jsxs)("div",{className:"flex flex-col items-end gap-1",children:[(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)(d.Text,{className:(0,o.cn)("tablet:text-2xl whitespace-nowrap text-xl font-semibold",e?.totalPrice),children:$.replace("${total}",(0,x.formatPrice)({amount:u,currencyCode:v,locale:b})||"")}),(m||0)>(u||0)&&(0,t.jsx)(d.Text,{className:(0,o.cn)("tablet:text-2xl whitespace-nowrap text-xl font-semibold line-through",e?.originalPrice),children:(0,x.formatPrice)({amount:m,currencyCode:v,locale:b})||""})]}),(I||0)>0&&(0,t.jsxs)(d.Text,{className:(0,o.cn)("w-full text-right text-xl font-semibold",e?.saveAmount),children:["Save ",(0,x.formatPrice)({amount:I,currencyCode:v,locale:b})||""]})]}),(0,t.jsx)(j.Button,{onClick:()=>S?.(a),className:(0,o.cn)("whitespace-nowrap",e?.actionButton),children:q})]})]})})});H.displayName="MiniCart";var rt=H;
2
+ //# sourceMappingURL=index.js.map