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