@faststore/core 2.0.105-alpha.0 → 2.0.106-alpha.0

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 (153) hide show
  1. package/.next/BUILD_ID +1 -0
  2. package/.next/build-manifest.json +99 -0
  3. package/.next/cache/.tsbuildinfo +1 -0
  4. package/.next/cache/config.json +7 -0
  5. package/.next/cache/eslint/.cache_1gneedd +1 -0
  6. package/.next/cache/next-server.js.nft.json +1 -0
  7. package/.next/cache/webpack/client-production/0.pack +0 -0
  8. package/.next/cache/webpack/client-production/index.pack +0 -0
  9. package/.next/cache/webpack/server-production/0.pack +0 -0
  10. package/.next/cache/webpack/server-production/index.pack +0 -0
  11. package/.next/export-marker.json +1 -0
  12. package/.next/images-manifest.json +1 -0
  13. package/.next/next-server.js.nft.json +1 -0
  14. package/.next/package.json +1 -0
  15. package/.next/prerender-manifest.json +1 -0
  16. package/.next/react-loadable-manifest.json +43 -0
  17. package/.next/required-server-files.json +1 -0
  18. package/.next/routes-manifest.json +1 -0
  19. package/.next/server/chunks/120.js +435 -0
  20. package/.next/server/chunks/123.js +58 -0
  21. package/.next/server/chunks/1394.js +3801 -0
  22. package/.next/server/chunks/1597.js +151 -0
  23. package/.next/server/chunks/1608.js +515 -0
  24. package/.next/server/chunks/2154.js +206 -0
  25. package/.next/server/chunks/247.js +61 -0
  26. package/.next/server/chunks/2502.js +617 -0
  27. package/.next/server/chunks/2914.js +95 -0
  28. package/.next/server/chunks/2922.js +7293 -0
  29. package/.next/server/chunks/3264.js +67 -0
  30. package/.next/server/chunks/3431.js +7241 -0
  31. package/.next/server/chunks/350.js +142 -0
  32. package/.next/server/chunks/3746.js +237 -0
  33. package/.next/server/chunks/3898.js +240 -0
  34. package/.next/server/chunks/4312.js +674 -0
  35. package/.next/server/chunks/4371.js +1473 -0
  36. package/.next/server/chunks/5098.js +124 -0
  37. package/.next/server/chunks/5576.js +72 -0
  38. package/.next/server/chunks/6280.js +322 -0
  39. package/.next/server/chunks/6465.js +91 -0
  40. package/.next/server/chunks/676.js +32 -0
  41. package/.next/server/chunks/6859.js +959 -0
  42. package/.next/server/chunks/6881.js +320 -0
  43. package/.next/server/chunks/6898.js +149 -0
  44. package/.next/server/chunks/7104.js +196 -0
  45. package/.next/server/chunks/7181.js +658 -0
  46. package/.next/server/chunks/7183.js +72 -0
  47. package/.next/server/chunks/7992.js +570 -0
  48. package/.next/server/chunks/8098.js +246 -0
  49. package/.next/server/chunks/810.js +432 -0
  50. package/.next/server/chunks/8287.js +58 -0
  51. package/.next/server/chunks/9143.js +106 -0
  52. package/.next/server/chunks/9557.js +117 -0
  53. package/.next/server/chunks/9854.js +72 -0
  54. package/.next/server/chunks/font-manifest.json +1 -0
  55. package/.next/server/font-manifest.json +1 -0
  56. package/.next/server/middleware-build-manifest.js +1 -0
  57. package/.next/server/middleware-manifest.json +6 -0
  58. package/.next/server/middleware-react-loadable-manifest.js +1 -0
  59. package/.next/server/pages/404.js.nft.json +1 -0
  60. package/.next/server/pages/500.js.nft.json +1 -0
  61. package/.next/server/pages/[...slug].js +671 -0
  62. package/.next/server/pages/[...slug].js.nft.json +1 -0
  63. package/.next/server/pages/[slug]/p.js +2327 -0
  64. package/.next/server/pages/[slug]/p.js.nft.json +1 -0
  65. package/.next/server/pages/_app.js +2368 -0
  66. package/.next/server/pages/_app.js.nft.json +1 -0
  67. package/.next/server/pages/_document.js +304 -0
  68. package/.next/server/pages/_document.js.nft.json +1 -0
  69. package/.next/server/pages/_error.js +164 -0
  70. package/.next/server/pages/_error.js.nft.json +1 -0
  71. package/.next/server/pages/account.js.nft.json +1 -0
  72. package/.next/server/pages/api/graphql.js +315 -0
  73. package/.next/server/pages/api/graphql.js.nft.json +1 -0
  74. package/.next/server/pages/api/preview.js +118 -0
  75. package/.next/server/pages/api/preview.js.nft.json +1 -0
  76. package/.next/server/pages/checkout.js.nft.json +1 -0
  77. package/.next/server/pages/en-US/404.html +81 -0
  78. package/.next/server/pages/en-US/500.html +81 -0
  79. package/.next/server/pages/en-US/account.html +81 -0
  80. package/.next/server/pages/en-US/checkout.html +81 -0
  81. package/.next/server/pages/en-US/login.html +81 -0
  82. package/.next/server/pages/en-US/s.html +81 -0
  83. package/.next/server/pages/en-US.html +81 -0
  84. package/.next/server/pages/en-US.json +1 -0
  85. package/.next/server/pages/index.js +428 -0
  86. package/.next/server/pages/index.js.nft.json +1 -0
  87. package/.next/server/pages/login.js.nft.json +1 -0
  88. package/.next/server/pages/s.js.nft.json +1 -0
  89. package/.next/server/pages-manifest.json +16 -0
  90. package/.next/server/webpack-api-runtime.js +229 -0
  91. package/.next/server/webpack-runtime.js +229 -0
  92. package/.next/static/78q0IAs7tpB_rHHIDEdG9/_buildManifest.js +1 -0
  93. package/.next/static/78q0IAs7tpB_rHHIDEdG9/_ssgManifest.js +1 -0
  94. package/.next/static/chunks/143.dd8a556e6957baa1.js +1 -0
  95. package/.next/static/chunks/264-6dc2258a751b3d74.js +1 -0
  96. package/.next/static/chunks/351-a4e28d64f48c5269.js +1 -0
  97. package/.next/static/chunks/54.3965c4cb1b3f985c.js +1 -0
  98. package/.next/static/chunks/597.43467badf5c82358.js +1 -0
  99. package/.next/static/chunks/608.59e69b83f35d9c44.js +1 -0
  100. package/.next/static/chunks/651.7142f31ce1e052b3.js +1 -0
  101. package/.next/static/chunks/686.14ab3eb175c23970.js +1 -0
  102. package/.next/static/chunks/741.52f7fb873418346f.js +1 -0
  103. package/.next/static/chunks/781-e1b538e051ff4c3e.js +1 -0
  104. package/.next/static/chunks/98.97381d2021f86cd9.js +1 -0
  105. package/.next/static/chunks/996.64460309250b214c.js +1 -0
  106. package/.next/static/chunks/framework-dfd14d7ce6600b03.js +1 -0
  107. package/.next/static/chunks/main-9746772201fe3ac1.js +1 -0
  108. package/.next/static/chunks/pages/404-ba608a2a9f0c420a.js +1 -0
  109. package/.next/static/chunks/pages/500-910883c20541d9ce.js +1 -0
  110. package/.next/static/chunks/pages/[...slug]-ec85cc3d8b3622ad.js +1 -0
  111. package/.next/static/chunks/pages/[slug]/p-1c7d20c6807d3dbc.js +1 -0
  112. package/.next/static/chunks/pages/_app-4656b49f263e86d4.js +1 -0
  113. package/.next/static/chunks/pages/_error-a7a0c1d9bfbb4f38.js +1 -0
  114. package/.next/static/chunks/pages/account-b8fc5222ffe89b60.js +1 -0
  115. package/.next/static/chunks/pages/checkout-f8cb7cb22225ef9d.js +1 -0
  116. package/.next/static/chunks/pages/index-9ea3f7868f5ed138.js +1 -0
  117. package/.next/static/chunks/pages/login-33954810b200eca8.js +1 -0
  118. package/.next/static/chunks/pages/s-ba2868e14fedb65b.js +1 -0
  119. package/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +1 -0
  120. package/.next/static/chunks/webpack-3587f79b2eaad6ba.js +1 -0
  121. package/.next/static/css/1024849ea6421e1e.css +1 -0
  122. package/.next/static/css/43d61b402f41569b.css +1 -0
  123. package/.next/static/css/6507cb48401e73a4.css +1 -0
  124. package/.next/static/css/8d4cc2151b8e3693.css +1 -0
  125. package/.next/static/css/8ea129ea90e49e98.css +1 -0
  126. package/.next/static/css/db63ea05e98cb7e8.css +1 -0
  127. package/.next/static/css/dcd034ec6c716e5c.css +1 -0
  128. package/.next/static/media/brandless-neutral.76ddf63a.png +0 -0
  129. package/.next/trace +64 -0
  130. package/.turbo/turbo-build.log +6 -6
  131. package/CHANGELOG.md +6 -0
  132. package/package.json +4 -4
  133. package/public/~partytown/debug/partytown-atomics.js +556 -0
  134. package/public/~partytown/debug/partytown-media.js +374 -0
  135. package/public/~partytown/debug/partytown-sandbox-sw.js +543 -0
  136. package/public/~partytown/debug/partytown-sw.js +59 -0
  137. package/public/~partytown/debug/partytown-ww-atomics.js +1789 -0
  138. package/public/~partytown/debug/partytown-ww-sw.js +1781 -0
  139. package/public/~partytown/debug/partytown.js +72 -0
  140. package/public/~partytown/partytown-atomics.js +2 -0
  141. package/public/~partytown/partytown-media.js +2 -0
  142. package/public/~partytown/partytown-sw.js +2 -0
  143. package/public/~partytown/partytown.js +2 -0
  144. package/src/components/common/Navbar/navlinks.module.scss +1 -1
  145. package/src/components/region/RegionButton/RegionButton.tsx +0 -1
  146. package/src/components/region/{RegionInput/RegionInput.tsx → RegionModal/RegionModal.tsx} +15 -25
  147. package/src/components/region/RegionModal/index.ts +1 -2
  148. package/src/components/region/Region.stories.mdx +0 -199
  149. package/src/components/region/RegionInput/index.ts +0 -1
  150. package/src/components/region/RegionModal/RegionalizationModal.stories.mdx +0 -174
  151. package/src/components/region/RegionModal/RegionalizationModal.tsx +0 -12
  152. package/src/components/region/RegionModal/RegionalizationModalContent.tsx +0 -42
  153. package/src/components/region/RegionModal/regionalization-modal-body.module.scss +0 -25
@@ -0,0 +1,617 @@
1
+ exports.id = 2502;
2
+ exports.ids = [2502];
3
+ exports.modules = {
4
+
5
+ /***/ 2502:
6
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
7
+
8
+ "use strict";
9
+ // ESM COMPAT FLAG
10
+ __webpack_require__.r(__webpack_exports__);
11
+
12
+ // EXPORTS
13
+ __webpack_require__.d(__webpack_exports__, {
14
+ "default": () => (/* reexport */ cart_CartSidebar_CartSidebar)
15
+ });
16
+
17
+ // EXTERNAL MODULE: ./node_modules/@faststore/sdk/dist/analytics/sendAnalyticsEvent.js
18
+ var sendAnalyticsEvent = __webpack_require__(8460);
19
+ // EXTERNAL MODULE: external "react"
20
+ var external_react_ = __webpack_require__(6689);
21
+ var external_react_default = /*#__PURE__*/__webpack_require__.n(external_react_);
22
+ // EXTERNAL MODULE: ../components/dist/hooks/useFadeEffect.js
23
+ var useFadeEffect = __webpack_require__(6074);
24
+ // EXTERNAL MODULE: ../components/dist/hooks/UIProvider.js
25
+ var UIProvider = __webpack_require__(395);
26
+ // EXTERNAL MODULE: ../components/dist/organisms/SlideOver/SlideOver.js
27
+ var SlideOver = __webpack_require__(1021);
28
+ // EXTERNAL MODULE: ../components/dist/organisms/SlideOver/SlideOverHeader.js
29
+ var SlideOverHeader = __webpack_require__(9648);
30
+ // EXTERNAL MODULE: ../components/dist/atoms/Badge/Badge.js
31
+ var Badge = __webpack_require__(44);
32
+ // EXTERNAL MODULE: ../components/dist/molecules/Alert/Alert.js
33
+ var Alert = __webpack_require__(6970);
34
+ ;// CONCATENATED MODULE: ../components/dist/organisms/CartSidebar/CartSidebar.js
35
+
36
+
37
+ function CartSidebar({ testId = 'fs-cart-sidebar', title = 'Your Cart', size = 'partial', direction = 'rightSide', totalItems, children, alertIcon, alertText, onClose, }) {
38
+ const { fade, fadeOut } = (0,useFadeEffect/* useFadeEffect */.b)();
39
+ const { closeCart } = (0,UIProvider/* useUI */.l)();
40
+ return (external_react_default().createElement(SlideOver/* default */.Z, { "data-fs-cart-sidebar": true, isOpen: true, fade: fade, onDismiss: fadeOut, size: size, direction: direction, onTransitionEnd: () => fade === 'out' && closeCart(), testId: testId },
41
+ external_react_default().createElement(SlideOverHeader/* default */.Z, { closeBtnProps: { testId: 'fs-cart-sidebar-button-close' }, onClose: () => {
42
+ onClose();
43
+ fadeOut();
44
+ } },
45
+ external_react_default().createElement("h2", { "data-fs-cart-sidebar-title": true },
46
+ title,
47
+ external_react_default().createElement(Badge/* default */.Z, { variant: "info" }, totalItems))),
48
+ alertText && external_react_default().createElement(Alert/* default */.Z, { icon: alertIcon }, alertText),
49
+ children));
50
+ }
51
+ /* harmony default export */ const CartSidebar_CartSidebar = (CartSidebar);
52
+ //# sourceMappingURL=CartSidebar.js.map
53
+ // EXTERNAL MODULE: ../components/dist/atoms/List/List.js
54
+ var List = __webpack_require__(1329);
55
+ ;// CONCATENATED MODULE: ../components/dist/organisms/CartSidebar/CartSidebarList.js
56
+
57
+
58
+ function CartSidebarList({ children }) {
59
+ return external_react_default().createElement(List/* default */.Z, { "data-fs-cart-sidebar-list": true }, children);
60
+ }
61
+ /* harmony default export */ const CartSidebar_CartSidebarList = (CartSidebarList);
62
+ //# sourceMappingURL=CartSidebarList.js.map
63
+ ;// CONCATENATED MODULE: ../components/dist/organisms/CartSidebar/CartSidebarFooter.js
64
+
65
+ function CartSidebarFooter({ children }) {
66
+ return external_react_default().createElement("footer", { "data-fs-cart-sidebar-footer": true }, children);
67
+ }
68
+ /* harmony default export */ const CartSidebar_CartSidebarFooter = (CartSidebarFooter);
69
+ //# sourceMappingURL=CartSidebarFooter.js.map
70
+ // EXTERNAL MODULE: ../components/dist/atoms/Button/Button.js + 1 modules
71
+ var Button = __webpack_require__(4842);
72
+ // EXTERNAL MODULE: ../components/dist/atoms/Icon/Icon.js
73
+ var Icon = __webpack_require__(5045);
74
+ // EXTERNAL MODULE: ./src/sdk/cart/index.ts
75
+ var sdk_cart = __webpack_require__(7566);
76
+ // EXTERNAL MODULE: ./faststore.config.js
77
+ var faststore_config = __webpack_require__(7183);
78
+ var faststore_config_default = /*#__PURE__*/__webpack_require__.n(faststore_config);
79
+ ;// CONCATENATED MODULE: ./src/sdk/cart/useCheckoutButton.ts
80
+
81
+
82
+ const useCheckoutButton = () => {
83
+ const {
84
+ isValidating,
85
+ id
86
+ } = (0,sdk_cart/* useCart */.jD)();
87
+
88
+ const onClick = e => {
89
+ e.preventDefault();
90
+
91
+ if (!isValidating && id) {
92
+ window.location.href = `${(faststore_config_default()).checkoutUrl}?orderFormId=${id}`;
93
+ }
94
+ };
95
+
96
+ return {
97
+ onClick,
98
+ disabled: isValidating,
99
+ 'data-testid': 'checkout-button'
100
+ };
101
+ };
102
+ // EXTERNAL MODULE: ./src/sdk/session/index.ts
103
+ var session = __webpack_require__(5971);
104
+ ;// CONCATENATED MODULE: ../components/dist/molecules/Gift/Gift.js
105
+
106
+ const Gift = (0,external_react_.forwardRef)(function Gift({ icon, testId = 'fs-gift', children, ...otherProps }, ref) {
107
+ const iconProps = { "data-fs-gift-icon": true };
108
+ const giftIcon = external_react_default().isValidElement(icon) ? external_react_default().cloneElement(icon, iconProps) : icon;
109
+ return (external_react_default().createElement("div", { ref: ref, "data-fs-gift": true, "data-testid": testId, ...otherProps },
110
+ external_react_default().isValidElement(giftIcon) && giftIcon,
111
+ external_react_default().createElement("div", { "data-fs-gift-wrapper": true }, children)));
112
+ });
113
+ /* harmony default export */ const Gift_Gift = (Gift);
114
+ //# sourceMappingURL=Gift.js.map
115
+ ;// CONCATENATED MODULE: ../components/dist/molecules/Gift/GiftImage.js
116
+
117
+ const GiftImage = (0,external_react_.forwardRef)(function GiftImage({ testId = 'fs-gift-image', children, ...otherProps }, ref) {
118
+ return (external_react_default().createElement("div", { ref: ref, "data-fs-gift-image": true, "data-testid": testId, ...otherProps }, children));
119
+ });
120
+ /* harmony default export */ const Gift_GiftImage = (GiftImage);
121
+ //# sourceMappingURL=GiftImage.js.map
122
+ // EXTERNAL MODULE: ../components/dist/atoms/Price/Price.js
123
+ var Price = __webpack_require__(7549);
124
+ ;// CONCATENATED MODULE: ../components/dist/molecules/Gift/GiftContent.js
125
+
126
+
127
+ const GiftContent = (0,external_react_.forwardRef)(function GiftContent({ price, productName, titleMessage = 'Get a', badgeLabel = 'Free', testId = 'fs-gift-content', ...otherProps }, ref) {
128
+ return (external_react_default().createElement("section", { ref: ref, "data-fs-gift-content": true, "data-testid": testId, ...otherProps },
129
+ external_react_default().createElement("h3", { "data-fs-gift-product-title": true },
130
+ titleMessage,
131
+ " ",
132
+ productName),
133
+ external_react_default().createElement("span", { "data-fs-gift-product-summary": true },
134
+ external_react_default().createElement(Price/* default */.Z, { value: price?.listPrice ? price.listPrice : 0, formatter: price?.formatter, testId: "list-price", "data-value": price?.listPrice, variant: "listing", SRText: "Original price:" }),
135
+ external_react_default().createElement(Badge/* default */.Z, null, badgeLabel))));
136
+ });
137
+ /* harmony default export */ const Gift_GiftContent = (GiftContent);
138
+ //# sourceMappingURL=GiftContent.js.map
139
+ // EXTERNAL MODULE: ./src/components/ui/Image/index.ts + 3 modules
140
+ var Image = __webpack_require__(2154);
141
+ // EXTERNAL MODULE: ./src/sdk/product/useFormattedPrice.ts
142
+ var useFormattedPrice = __webpack_require__(5346);
143
+ // EXTERNAL MODULE: external "react/jsx-runtime"
144
+ var jsx_runtime_ = __webpack_require__(997);
145
+ ;// CONCATENATED MODULE: ./src/components/ui/Gift/Gift.tsx
146
+ const _excluded = ["item"];
147
+
148
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
149
+
150
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
151
+
152
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
153
+
154
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
155
+
156
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
157
+
158
+
159
+
160
+
161
+
162
+
163
+
164
+ function Gift_Gift_Gift(_ref) {
165
+ let {
166
+ item
167
+ } = _ref,
168
+ otherProps = _objectWithoutProperties(_ref, _excluded);
169
+
170
+ return /*#__PURE__*/(0,jsx_runtime_.jsxs)(Gift_Gift, _objectSpread(_objectSpread({
171
+ icon: /*#__PURE__*/jsx_runtime_.jsx(Icon/* default */.Z, {
172
+ "data-fs-gift-icon": true,
173
+ name: "Tag",
174
+ width: 18,
175
+ height: 18
176
+ })
177
+ }, otherProps), {}, {
178
+ children: [/*#__PURE__*/jsx_runtime_.jsx(Gift_GiftImage, {
179
+ children: /*#__PURE__*/jsx_runtime_.jsx(Image/* Image */.E, {
180
+ src: item.itemOffered.image[0].url,
181
+ alt: item.itemOffered.image[0].alternateName,
182
+ width: 89,
183
+ height: 89
184
+ })
185
+ }), /*#__PURE__*/jsx_runtime_.jsx(Gift_GiftContent, {
186
+ productName: item.itemOffered.isVariantOf.name,
187
+ price: {
188
+ value: item.price,
189
+ listPrice: item.listPrice,
190
+ formatter: useFormattedPrice/* useFormattedPrice */.P
191
+ }
192
+ })]
193
+ }));
194
+ }
195
+
196
+ /* harmony default export */ const ui_Gift_Gift = (Gift_Gift_Gift);
197
+ ;// CONCATENATED MODULE: ./src/components/ui/Gift/index.ts
198
+
199
+ // EXTERNAL MODULE: ../components/dist/molecules/IconButton/IconButton.js
200
+ var IconButton = __webpack_require__(2765);
201
+ // EXTERNAL MODULE: ../components/dist/molecules/QuantitySelector/QuantitySelector.js
202
+ var QuantitySelector = __webpack_require__(123);
203
+ ;// CONCATENATED MODULE: ../components/dist/molecules/CartItem/CartItem.js
204
+
205
+
206
+ const CartItem = (0,external_react_.forwardRef)(function CartItem({ testId = 'fs-cart-item', price, quantity, unavailable, onQuantityChange, children, removeBtnProps, ...otherProps }, ref) {
207
+ return (external_react_default().createElement("article", { ref: ref, "data-fs-cart-item": unavailable ? 'unavailable' : 'true', "data-testid": testId, ...otherProps },
208
+ external_react_default().createElement("div", { "data-fs-cart-item-content": true }, children),
209
+ external_react_default().createElement(IconButton/* default */.Z, { "data-fs-cart-item-remove-button": true, icon: external_react_default().createElement(Icon/* default */.Z, { name: "XCircle" }), "aria-label": "Remove", ...removeBtnProps }),
210
+ external_react_default().createElement("div", { "data-fs-cart-item-actions": true },
211
+ external_react_default().createElement(QuantitySelector/* default */.Z, { min: 1, initial: quantity, onChange: onQuantityChange }),
212
+ external_react_default().createElement("span", { "data-fs-cart-item-prices": true },
213
+ external_react_default().createElement(Price/* default */.Z, { value: price?.listPrice ? price.listPrice : 0, formatter: price?.formatter, variant: "listing", SRText: "Original price:" }),
214
+ external_react_default().createElement(Price/* default */.Z, { value: price?.value ? price.value : 0, formatter: price?.formatter, variant: "spot", SRText: "Price:" })))));
215
+ });
216
+ /* harmony default export */ const CartItem_CartItem = (CartItem);
217
+ //# sourceMappingURL=CartItem.js.map
218
+ ;// CONCATENATED MODULE: ../components/dist/molecules/CartItem/CartItemImage.js
219
+
220
+ const CartItemImage = (0,external_react_.forwardRef)(function CartItemImage({ testId = 'fs-cart-item-image', children, ...otherProps }, ref) {
221
+ return (external_react_default().createElement("div", { ref: ref, "data-fs-cart-item-image": true, "data-testid": testId, ...otherProps }, children));
222
+ });
223
+ /* harmony default export */ const CartItem_CartItemImage = (CartItemImage);
224
+ //# sourceMappingURL=CartItemImage.js.map
225
+ ;// CONCATENATED MODULE: ../components/dist/molecules/CartItem/CartItemSummary.js
226
+
227
+ const CartItemSummary = (0,external_react_.forwardRef)(function CartItemSummary({ testId = 'fs-cart-item-summary', title, activeVariations = [], children, ...otherProps }, ref) {
228
+ return (external_react_default().createElement("div", { ref: ref, "data-fs-cart-item-summary": true, "data-testid": testId, ...otherProps },
229
+ external_react_default().createElement("div", { "data-fs-cart-item-title": true }, title),
230
+ activeVariations.length > 0 && (external_react_default().createElement("div", { "data-fs-cart-item-skus": true }, activeVariations.map(({ label, option }) => (external_react_default().createElement("p", { key: label },
231
+ label,
232
+ ": ",
233
+ external_react_default().createElement("span", null, option)))))),
234
+ children));
235
+ });
236
+ /* harmony default export */ const CartItem_CartItemSummary = (CartItemSummary);
237
+ //# sourceMappingURL=CartItemSummary.js.map
238
+ ;// CONCATENATED MODULE: ./src/sdk/cart/useRemoveButton.ts
239
+
240
+
241
+
242
+
243
+ const useRemoveButton = item => {
244
+ const {
245
+ currency: {
246
+ code
247
+ }
248
+ } = (0,session/* useSession */.kP)();
249
+ const onClick = (0,external_react_.useCallback)(e => {
250
+ e.preventDefault();
251
+
252
+ if (!item) {
253
+ return;
254
+ }
255
+
256
+ (0,sendAnalyticsEvent/* sendAnalyticsEvent */._)({
257
+ name: 'remove_from_cart',
258
+ params: {
259
+ currency: code,
260
+ value: item.price * item.quantity,
261
+ // TODO: In the future, we can explore more robust ways of calculating the value (gift items, discounts, etc.).
262
+ items: [{
263
+ item_id: item.itemOffered.isVariantOf.productGroupID,
264
+ item_name: item.itemOffered.isVariantOf.name,
265
+ item_brand: item.itemOffered.brand.name,
266
+ item_variant: item.itemOffered.sku,
267
+ quantity: item.quantity,
268
+ price: item.price,
269
+ discount: item.listPrice - item.price,
270
+ currency: code,
271
+ item_variant_name: item.itemOffered.name,
272
+ product_reference_id: item.itemOffered.gtin
273
+ }]
274
+ }
275
+ });
276
+ sdk_cart/* cartStore.removeItem */.i8.removeItem(item.id);
277
+ }, [code, item]);
278
+ return {
279
+ onClick,
280
+ 'data-testid': 'remove-from-cart-button',
281
+ 'data-sku': item?.itemOffered.sku
282
+ };
283
+ };
284
+ ;// CONCATENATED MODULE: ./src/components/cart/CartItem/CartItem.tsx
285
+
286
+
287
+
288
+
289
+
290
+
291
+
292
+
293
+
294
+
295
+
296
+ function useCartItemEvent() {
297
+ const {
298
+ currency: {
299
+ code
300
+ }
301
+ } = (0,session/* useSession */.kP)();
302
+ const sendCartItemEvent = (0,external_react_.useCallback)((item, quantity) => {
303
+ const quantityDelta = quantity - item.quantity;
304
+ return (0,sendAnalyticsEvent/* sendAnalyticsEvent */._)({
305
+ name: quantityDelta > 0 ? 'add_to_cart' : 'remove_from_cart',
306
+ params: {
307
+ currency: code,
308
+ // TODO: In the future, we can explore more robust ways of
309
+ // calculating the value (gift items, discounts, etc.).
310
+ value: item.price * Math.abs(quantityDelta),
311
+ items: [{
312
+ item_id: item.itemOffered.isVariantOf.productGroupID,
313
+ item_name: item.itemOffered.isVariantOf.name,
314
+ item_brand: item.itemOffered.brand.name,
315
+ item_variant: item.itemOffered.sku,
316
+ quantity: Math.abs(quantityDelta),
317
+ price: item.price,
318
+ discount: item.listPrice - item.price,
319
+ currency: code,
320
+ item_variant_name: item.itemOffered.name,
321
+ product_reference_id: item.itemOffered.gtin
322
+ }]
323
+ }
324
+ });
325
+ }, [code]);
326
+ return (0,external_react_.useMemo)(() => ({
327
+ sendCartItemEvent
328
+ }), [sendCartItemEvent]);
329
+ }
330
+
331
+ function CartItem_CartItem_CartItem({
332
+ item
333
+ }) {
334
+ const btnProps = useRemoveButton(item);
335
+ const {
336
+ sendCartItemEvent
337
+ } = useCartItemEvent();
338
+ const onQuantityChange = (0,external_react_.useCallback)(quantity => {
339
+ sendCartItemEvent(item, quantity);
340
+ sdk_cart/* cartStore.updateItemQuantity */.i8.updateItemQuantity(item.id, quantity);
341
+ }, [item, sendCartItemEvent]);
342
+ const skuActiveVariants = item.itemOffered.isVariantOf.skuVariants.activeVariations;
343
+ const activeVariations = Object.keys(skuActiveVariants).map(key => ({
344
+ label: key,
345
+ option: skuActiveVariants[key]
346
+ }));
347
+ return /*#__PURE__*/(0,jsx_runtime_.jsxs)(CartItem_CartItem, {
348
+ price: {
349
+ value: item.price,
350
+ listPrice: item.listPrice,
351
+ formatter: useFormattedPrice/* useFormattedPrice */.P
352
+ },
353
+ quantity: item.quantity,
354
+ onQuantityChange: onQuantityChange,
355
+ removeBtnProps: btnProps,
356
+ "data-sku": item.itemOffered.sku,
357
+ "data-seller": item.seller.identifier,
358
+ children: [/*#__PURE__*/jsx_runtime_.jsx(CartItem_CartItemImage, {
359
+ children: /*#__PURE__*/jsx_runtime_.jsx(Image/* Image */.E, {
360
+ src: item.itemOffered.image[0].url,
361
+ alt: item.itemOffered.image[0].alternateName,
362
+ width: 56,
363
+ height: 56
364
+ })
365
+ }), /*#__PURE__*/jsx_runtime_.jsx(CartItem_CartItemSummary, {
366
+ title: item.itemOffered.isVariantOf.name,
367
+ activeVariations: activeVariations
368
+ })]
369
+ });
370
+ }
371
+
372
+ /* harmony default export */ const cart_CartItem_CartItem = (CartItem_CartItem_CartItem);
373
+ ;// CONCATENATED MODULE: ./src/components/cart/CartItem/index.ts
374
+
375
+ // EXTERNAL MODULE: ./src/components/ui/EmptyState/index.ts + 1 modules
376
+ var EmptyState = __webpack_require__(9509);
377
+ ;// CONCATENATED MODULE: ./src/components/cart/EmptyCart/EmptyCart.tsx
378
+
379
+
380
+
381
+
382
+
383
+ function EmptyCart({
384
+ onDismiss
385
+ }) {
386
+ return /*#__PURE__*/(0,jsx_runtime_.jsxs)(EmptyState/* default */.Z, {
387
+ children: [/*#__PURE__*/(0,jsx_runtime_.jsxs)("header", {
388
+ "data-fs-empty-state-title": true,
389
+ children: [/*#__PURE__*/jsx_runtime_.jsx(Icon/* default */.Z, {
390
+ name: "ShoppingCart",
391
+ width: 56,
392
+ height: 56,
393
+ weight: "thin"
394
+ }), /*#__PURE__*/jsx_runtime_.jsx("p", {
395
+ children: "Your Cart is empty"
396
+ })]
397
+ }), /*#__PURE__*/jsx_runtime_.jsx(Button/* default */.Z, {
398
+ onClick: onDismiss,
399
+ variant: "secondary",
400
+ children: "Start Shopping"
401
+ })]
402
+ });
403
+ }
404
+
405
+ /* harmony default export */ const EmptyCart_EmptyCart = (EmptyCart);
406
+ ;// CONCATENATED MODULE: ./src/components/cart/EmptyCart/index.ts
407
+
408
+ ;// CONCATENATED MODULE: ../components/dist/molecules/OrderSummary/OrderSummary.js
409
+
410
+
411
+ const OrderSummary = (0,external_react_.forwardRef)(function OrderSummary({ testId = 'fs-order-summary', subtotalLabel, subtotalValue, discountLabel = 'Discount', discountValue, totalLabel = 'Total', totalValue, ...otherProps }, ref) {
412
+ return (external_react_default().createElement(List/* default */.Z, { ref: ref, "data-fs-order-summary": true, "data-testid": testId, ...otherProps },
413
+ subtotalValue ? (external_react_default().createElement("li", { "data-fs-order-summary-subtotal": true },
414
+ external_react_default().createElement("span", { "data-fs-order-summary-subtotal-label": true, "data-testid": `${testId}-subtotal-label` }, subtotalLabel),
415
+ external_react_default().createElement("span", { "data-fs-order-summary-subtotal-value": true, "data-testid": `${testId}-subtotal-value` }, subtotalValue))) : null,
416
+ discountValue ? (external_react_default().createElement("li", { "data-fs-order-summary-discount": true },
417
+ external_react_default().createElement("span", { "data-fs-order-summary-discount-label": true, "data-testid": `${testId}-discount-label` }, discountLabel),
418
+ external_react_default().createElement("span", { "data-fs-order-summary-discount-value": true, "data-testid": `${testId}-discount-value` }, discountValue))) : null,
419
+ external_react_default().createElement("li", { "data-fs-order-summary-total": true },
420
+ external_react_default().createElement("span", { "data-fs-order-summary-total-label": true, "data-testid": `${testId}-total-label` }, totalLabel),
421
+ external_react_default().createElement("span", { "data-fs-order-summary-total-value": true, "data-testid": `${testId}-total-value` }, totalValue))));
422
+ });
423
+ /* harmony default export */ const OrderSummary_OrderSummary = (OrderSummary);
424
+ //# sourceMappingURL=OrderSummary.js.map
425
+ ;// CONCATENATED MODULE: ./src/components/cart/OrderSummary/OrderSummary.tsx
426
+
427
+
428
+
429
+
430
+
431
+
432
+ function OrderSummary_OrderSummary_OrderSummary({
433
+ subTotal,
434
+ total,
435
+ numberOfItems,
436
+ checkoutButton
437
+ }) {
438
+ const discount = subTotal - total;
439
+ const formattedDiscount = (0,useFormattedPrice/* useFormattedPrice */.P)(discount);
440
+ return /*#__PURE__*/(0,jsx_runtime_.jsxs)(jsx_runtime_.Fragment, {
441
+ children: [/*#__PURE__*/jsx_runtime_.jsx(OrderSummary_OrderSummary, {
442
+ subtotalLabel: `Subtotal (${numberOfItems} products)`,
443
+ subtotalValue: (0,useFormattedPrice/* useFormattedPrice */.P)(subTotal),
444
+ discountValue: discount > 0 ? `-${formattedDiscount}` : undefined,
445
+ totalValue: (0,useFormattedPrice/* useFormattedPrice */.P)(total)
446
+ }), checkoutButton]
447
+ });
448
+ }
449
+
450
+ /* harmony default export */ const cart_OrderSummary_OrderSummary = (OrderSummary_OrderSummary_OrderSummary);
451
+ ;// CONCATENATED MODULE: ./src/components/cart/OrderSummary/index.ts
452
+
453
+ ;// CONCATENATED MODULE: ./src/components/cart/CartSidebar/CartSidebar.tsx
454
+ function CartSidebar_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
455
+
456
+ function CartSidebar_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? CartSidebar_ownKeys(Object(source), !0).forEach(function (key) { CartSidebar_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : CartSidebar_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
457
+
458
+ function CartSidebar_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
459
+
460
+
461
+
462
+
463
+
464
+
465
+
466
+
467
+
468
+
469
+
470
+
471
+
472
+
473
+
474
+
475
+ function CartSidebar_CartSidebar_CartSidebar() {
476
+ const {
477
+ currency
478
+ } = (0,session/* useSession */.kP)();
479
+ const btnProps = useCheckoutButton();
480
+ const cart = (0,sdk_cart/* useCart */.jD)();
481
+ const {
482
+ closeCart
483
+ } = (0,UIProvider/* useUI */.l)();
484
+ const {
485
+ fadeOut
486
+ } = (0,useFadeEffect/* useFadeEffect */.b)();
487
+ const {
488
+ items,
489
+ gifts,
490
+ totalItems,
491
+ isValidating,
492
+ subTotal,
493
+ total
494
+ } = cart;
495
+ const isEmpty = items.length === 0;
496
+ (0,external_react_.useEffect)(() => {
497
+ (0,sendAnalyticsEvent/* sendAnalyticsEvent */._)({
498
+ name: 'view_cart',
499
+ params: {
500
+ currency: currency.code,
501
+ value: total,
502
+ items: items.concat(gifts).map(item => ({
503
+ item_id: item.itemOffered.isVariantOf.productGroupID,
504
+ item_name: item.itemOffered.isVariantOf.name,
505
+ item_brand: item.itemOffered.brand.name,
506
+ item_variant: item.itemOffered.sku,
507
+ quantity: item.quantity,
508
+ price: item.price,
509
+ discount: item.listPrice - item.price,
510
+ currency: currency.code,
511
+ item_variant_name: item.itemOffered.name,
512
+ product_reference_id: item.itemOffered.gtin
513
+ }))
514
+ }
515
+ }); // eslint-disable-next-line react-hooks/exhaustive-deps
516
+ }, []);
517
+ return /*#__PURE__*/jsx_runtime_.jsx(CartSidebar_CartSidebar, {
518
+ totalItems: totalItems,
519
+ alertIcon: /*#__PURE__*/jsx_runtime_.jsx(Icon/* default */.Z, {
520
+ name: "Truck"
521
+ }),
522
+ alertText: "Free shipping starts at $300",
523
+ onClose: fadeOut,
524
+ children: isEmpty ? /*#__PURE__*/jsx_runtime_.jsx(EmptyCart_EmptyCart, {
525
+ onDismiss: closeCart
526
+ }) : /*#__PURE__*/(0,jsx_runtime_.jsxs)(jsx_runtime_.Fragment, {
527
+ children: [/*#__PURE__*/(0,jsx_runtime_.jsxs)(CartSidebar_CartSidebarList, {
528
+ children: [items.map(item => /*#__PURE__*/jsx_runtime_.jsx("li", {
529
+ children: /*#__PURE__*/jsx_runtime_.jsx(cart_CartItem_CartItem, {
530
+ item: item
531
+ })
532
+ }, item.id)), gifts.length > 0 && /*#__PURE__*/jsx_runtime_.jsx(jsx_runtime_.Fragment, {
533
+ children: gifts.map(item => /*#__PURE__*/jsx_runtime_.jsx("li", {
534
+ children: /*#__PURE__*/jsx_runtime_.jsx(ui_Gift_Gift, {
535
+ item: item
536
+ })
537
+ }, item.id))
538
+ })]
539
+ }), /*#__PURE__*/jsx_runtime_.jsx(CartSidebar_CartSidebarFooter, {
540
+ children: /*#__PURE__*/jsx_runtime_.jsx(cart_OrderSummary_OrderSummary, {
541
+ subTotal: subTotal,
542
+ total: total,
543
+ numberOfItems: totalItems,
544
+ checkoutButton: /*#__PURE__*/jsx_runtime_.jsx(Button/* default */.Z, CartSidebar_objectSpread(CartSidebar_objectSpread({
545
+ variant: "primary",
546
+ icon: !isValidating && /*#__PURE__*/jsx_runtime_.jsx(Icon/* default */.Z, {
547
+ name: "ArrowRight",
548
+ width: 18,
549
+ height: 18
550
+ }),
551
+ iconPosition: "right"
552
+ }, btnProps), {}, {
553
+ children: isValidating ? 'Loading...' : 'Checkout'
554
+ }))
555
+ })
556
+ })]
557
+ })
558
+ });
559
+ }
560
+
561
+ /* harmony default export */ const cart_CartSidebar_CartSidebar = (CartSidebar_CartSidebar_CartSidebar);
562
+ ;// CONCATENATED MODULE: ./src/components/cart/CartSidebar/index.ts
563
+
564
+
565
+ /***/ }),
566
+
567
+ /***/ 9509:
568
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
569
+
570
+ "use strict";
571
+
572
+ // EXPORTS
573
+ __webpack_require__.d(__webpack_exports__, {
574
+ "Z": () => (/* reexport */ EmptyState_EmptyState)
575
+ });
576
+
577
+ // EXTERNAL MODULE: ./src/components/ui/EmptyState/empty-state.module.scss
578
+ var empty_state_module = __webpack_require__(8098);
579
+ var empty_state_module_default = /*#__PURE__*/__webpack_require__.n(empty_state_module);
580
+ // EXTERNAL MODULE: external "react/jsx-runtime"
581
+ var jsx_runtime_ = __webpack_require__(997);
582
+ ;// CONCATENATED MODULE: ./src/components/ui/EmptyState/EmptyState.tsx
583
+
584
+
585
+
586
+ function EmptyState({
587
+ children,
588
+ variant = 'default'
589
+ }) {
590
+ return /*#__PURE__*/jsx_runtime_.jsx("section", {
591
+ className: (empty_state_module_default()).fsEmptyState,
592
+ "data-fs-empty-state": true,
593
+ "data-fs-empty-state-variant": variant,
594
+ children: children
595
+ });
596
+ }
597
+
598
+ /* harmony default export */ const EmptyState_EmptyState = (EmptyState);
599
+ ;// CONCATENATED MODULE: ./src/components/ui/EmptyState/index.ts
600
+
601
+
602
+ /***/ }),
603
+
604
+ /***/ 8098:
605
+ /***/ ((module) => {
606
+
607
+ // Exports
608
+ module.exports = {
609
+ "fs-empty-state": "empty-state_fs-empty-state__F7Xul",
610
+ "fsEmptyState": "empty-state_fs-empty-state__F7Xul"
611
+ };
612
+
613
+
614
+ /***/ })
615
+
616
+ };
617
+ ;