@faststore/core 2.1.76 → 2.1.77

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 (149) hide show
  1. package/.turbo/turbo-build.log +4 -4
  2. package/package.json +4 -4
  3. package/.next/BUILD_ID +0 -1
  4. package/.next/build-manifest.json +0 -129
  5. package/.next/cache/.tsbuildinfo +0 -1
  6. package/.next/cache/config.json +0 -7
  7. package/.next/cache/eslint/.cache_1gneedd +0 -1
  8. package/.next/cache/next-server.js.nft.json +0 -1
  9. package/.next/cache/webpack/client-production/0.pack +0 -0
  10. package/.next/cache/webpack/client-production/index.pack +0 -0
  11. package/.next/cache/webpack/server-production/0.pack +0 -0
  12. package/.next/cache/webpack/server-production/index.pack +0 -0
  13. package/.next/export-marker.json +0 -1
  14. package/.next/images-manifest.json +0 -1
  15. package/.next/next-server.js.nft.json +0 -1
  16. package/.next/package.json +0 -1
  17. package/.next/prerender-manifest.json +0 -1
  18. package/.next/react-loadable-manifest.json +0 -44
  19. package/.next/required-server-files.json +0 -1
  20. package/.next/routes-manifest.json +0 -1
  21. package/.next/server/chunks/123.js +0 -58
  22. package/.next/server/chunks/143.js +0 -106
  23. package/.next/server/chunks/183.js +0 -94
  24. package/.next/server/chunks/184.js +0 -61
  25. package/.next/server/chunks/186.js +0 -113
  26. package/.next/server/chunks/247.js +0 -61
  27. package/.next/server/chunks/253.js +0 -509
  28. package/.next/server/chunks/269.js +0 -517
  29. package/.next/server/chunks/287.js +0 -58
  30. package/.next/server/chunks/289.js +0 -239
  31. package/.next/server/chunks/312.js +0 -697
  32. package/.next/server/chunks/350.js +0 -143
  33. package/.next/server/chunks/487.js +0 -9142
  34. package/.next/server/chunks/502.js +0 -626
  35. package/.next/server/chunks/576.js +0 -94
  36. package/.next/server/chunks/597.js +0 -211
  37. package/.next/server/chunks/650.js +0 -9142
  38. package/.next/server/chunks/676.js +0 -32
  39. package/.next/server/chunks/721.js +0 -650
  40. package/.next/server/chunks/74.js +0 -4054
  41. package/.next/server/chunks/81.js +0 -1254
  42. package/.next/server/chunks/825.js +0 -4039
  43. package/.next/server/chunks/854.js +0 -72
  44. package/.next/server/chunks/859.js +0 -959
  45. package/.next/server/chunks/886.js +0 -120
  46. package/.next/server/chunks/907.js +0 -1911
  47. package/.next/server/chunks/98.js +0 -124
  48. package/.next/server/chunks/font-manifest.json +0 -1
  49. package/.next/server/font-manifest.json +0 -1
  50. package/.next/server/middleware-build-manifest.js +0 -1
  51. package/.next/server/middleware-manifest.json +0 -6
  52. package/.next/server/middleware-react-loadable-manifest.js +0 -1
  53. package/.next/server/pages/404.js +0 -386
  54. package/.next/server/pages/404.js.nft.json +0 -1
  55. package/.next/server/pages/500.js +0 -388
  56. package/.next/server/pages/500.js.nft.json +0 -1
  57. package/.next/server/pages/[...slug].js +0 -1005
  58. package/.next/server/pages/[...slug].js.nft.json +0 -1
  59. package/.next/server/pages/[slug]/p.js +0 -2269
  60. package/.next/server/pages/[slug]/p.js.nft.json +0 -1
  61. package/.next/server/pages/_app.js +0 -280
  62. package/.next/server/pages/_app.js.nft.json +0 -1
  63. package/.next/server/pages/_document.js +0 -352
  64. package/.next/server/pages/_document.js.nft.json +0 -1
  65. package/.next/server/pages/_error.js +0 -164
  66. package/.next/server/pages/_error.js.nft.json +0 -1
  67. package/.next/server/pages/account.js +0 -363
  68. package/.next/server/pages/account.js.nft.json +0 -1
  69. package/.next/server/pages/api/graphql.js +0 -365
  70. package/.next/server/pages/api/graphql.js.nft.json +0 -1
  71. package/.next/server/pages/api/preview.js +0 -148
  72. package/.next/server/pages/api/preview.js.nft.json +0 -1
  73. package/.next/server/pages/checkout.js +0 -363
  74. package/.next/server/pages/checkout.js.nft.json +0 -1
  75. package/.next/server/pages/en-US/404.html +0 -81
  76. package/.next/server/pages/en-US/404.json +0 -1
  77. package/.next/server/pages/en-US/500.html +0 -81
  78. package/.next/server/pages/en-US/500.json +0 -1
  79. package/.next/server/pages/en-US/account.html +0 -81
  80. package/.next/server/pages/en-US/account.json +0 -1
  81. package/.next/server/pages/en-US/checkout.html +0 -81
  82. package/.next/server/pages/en-US/checkout.json +0 -1
  83. package/.next/server/pages/en-US/login.html +0 -81
  84. package/.next/server/pages/en-US/login.json +0 -1
  85. package/.next/server/pages/en-US/s.html +0 -81
  86. package/.next/server/pages/en-US/s.json +0 -1
  87. package/.next/server/pages/en-US.html +0 -81
  88. package/.next/server/pages/en-US.json +0 -1
  89. package/.next/server/pages/index.js +0 -439
  90. package/.next/server/pages/index.js.nft.json +0 -1
  91. package/.next/server/pages/login.js +0 -368
  92. package/.next/server/pages/login.js.nft.json +0 -1
  93. package/.next/server/pages/s.js +0 -466
  94. package/.next/server/pages/s.js.nft.json +0 -1
  95. package/.next/server/pages-manifest.json +0 -16
  96. package/.next/server/webpack-api-runtime.js +0 -229
  97. package/.next/server/webpack-runtime.js +0 -229
  98. package/.next/static/chunks/143.dd8a556e6957baa1.js +0 -1
  99. package/.next/static/chunks/209-6e47fc4ac0aa3c95.js +0 -1
  100. package/.next/static/chunks/495.0ecd099878b2a36d.js +0 -1
  101. package/.next/static/chunks/502.b14533723651e5a1.js +0 -1
  102. package/.next/static/chunks/548-6b23e7ad82cd22b9.js +0 -1
  103. package/.next/static/chunks/597.f8d0595b113c70af.js +0 -1
  104. package/.next/static/chunks/64.2f385ef39cd5877d.js +0 -1
  105. package/.next/static/chunks/651.7142f31ce1e052b3.js +0 -1
  106. package/.next/static/chunks/706-27e44adf980c12d5.js +0 -1
  107. package/.next/static/chunks/738-a5ff304828f20cbf.js +0 -1
  108. package/.next/static/chunks/741.52f7fb873418346f.js +0 -1
  109. package/.next/static/chunks/791-5b3d23f5b6100959.js +0 -1
  110. package/.next/static/chunks/98.97381d2021f86cd9.js +0 -1
  111. package/.next/static/chunks/framework-dfd14d7ce6600b03.js +0 -1
  112. package/.next/static/chunks/main-fd466221927468fd.js +0 -1
  113. package/.next/static/chunks/pages/404-14d27e3706f3d2c3.js +0 -1
  114. package/.next/static/chunks/pages/500-250ccf5c9626e451.js +0 -1
  115. package/.next/static/chunks/pages/[...slug]-bcfaf0c5d60b57a0.js +0 -1
  116. package/.next/static/chunks/pages/[slug]/p-d658bb643d6260e0.js +0 -1
  117. package/.next/static/chunks/pages/_app-b913aa15691acb2f.js +0 -1
  118. package/.next/static/chunks/pages/_error-a7a0c1d9bfbb4f38.js +0 -1
  119. package/.next/static/chunks/pages/account-d248acc931146694.js +0 -1
  120. package/.next/static/chunks/pages/checkout-97f6d6f36f041a6f.js +0 -1
  121. package/.next/static/chunks/pages/index-bdbfb082027ed2b7.js +0 -1
  122. package/.next/static/chunks/pages/login-b1bdf30c951bb60d.js +0 -1
  123. package/.next/static/chunks/pages/s-6f66f96321c19c5d.js +0 -1
  124. package/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +0 -1
  125. package/.next/static/chunks/webpack-6f8f102d8fa95ea0.js +0 -1
  126. package/.next/static/cs67eBCnPSOCetifTWNXq/_buildManifest.js +0 -1
  127. package/.next/static/cs67eBCnPSOCetifTWNXq/_ssgManifest.js +0 -1
  128. package/.next/static/css/20e4a3a45cdd65f4.css +0 -1
  129. package/.next/static/css/527e334fa69cf40a.css +0 -1
  130. package/.next/static/css/6e1a7434f061d0ef.css +0 -1
  131. package/.next/static/css/9e76fef1c9ca89af.css +0 -1
  132. package/.next/static/css/a2eefb25a4608343.css +0 -1
  133. package/.next/static/css/c110411bf3c3f5d1.css +0 -1
  134. package/.next/static/css/cb7d1fcea42fab9c.css +0 -1
  135. package/.next/static/css/dcc281598933766a.css +0 -1
  136. package/.next/static/css/df588bb98c0b0ca6.css +0 -1
  137. package/.next/static/css/e3b039e8f5daf95f.css +0 -1
  138. package/.next/trace +0 -79
  139. package/public/~partytown/debug/partytown-atomics.js +0 -556
  140. package/public/~partytown/debug/partytown-media.js +0 -374
  141. package/public/~partytown/debug/partytown-sandbox-sw.js +0 -543
  142. package/public/~partytown/debug/partytown-sw.js +0 -59
  143. package/public/~partytown/debug/partytown-ww-atomics.js +0 -1789
  144. package/public/~partytown/debug/partytown-ww-sw.js +0 -1781
  145. package/public/~partytown/debug/partytown.js +0 -72
  146. package/public/~partytown/partytown-atomics.js +0 -2
  147. package/public/~partytown/partytown-media.js +0 -2
  148. package/public/~partytown/partytown-sw.js +0 -2
  149. package/public/~partytown/partytown.js +0 -2
@@ -1,517 +0,0 @@
1
- "use strict";
2
- exports.id = 269;
3
- exports.ids = [269];
4
- exports.modules = {
5
-
6
- /***/ 2928:
7
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
8
-
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__(16689);
13
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
14
-
15
- const Skeleton = (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Skeleton({ testId = 'fs-skeleton', loading = true, shimmer = true, children, size, border, borderRadius, ...otherProps }, ref) {
16
- const styles = {
17
- width: size.width,
18
- height: size.height,
19
- };
20
- return loading ? (react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", { ref: ref, "data-fs-skeleton": true, "data-testid": testId, "data-fs-skeleton-border": border ? border : null, style: borderRadius ? { ...styles, borderRadius: borderRadius } : styles, ...otherProps }, shimmer && react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", { "data-fs-skeleton-shimmer": true }))) : (react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, children));
21
- });
22
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Skeleton);
23
- //# sourceMappingURL=Skeleton.js.map
24
-
25
- /***/ }),
26
-
27
- /***/ 89875:
28
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
29
-
30
-
31
- // EXPORTS
32
- __webpack_require__.d(__webpack_exports__, {
33
- "Z": () => (/* binding */ DiscountBadge_DiscountBadge)
34
- });
35
-
36
- // EXTERNAL MODULE: external "react"
37
- var external_react_ = __webpack_require__(16689);
38
- var external_react_default = /*#__PURE__*/__webpack_require__.n(external_react_);
39
- // EXTERNAL MODULE: ../components/dist/atoms/Badge/Badge.js
40
- var Badge = __webpack_require__(10044);
41
- ;// CONCATENATED MODULE: ../components/dist/molecules/DiscountBadge/useDiscountPercent.js
42
-
43
- const useDiscountPercent = (listPrice, spotPrice) => {
44
- return (0,external_react_.useMemo)(() => {
45
- const diff = listPrice - spotPrice;
46
- const discount = (diff * 100) / listPrice;
47
- return Math.round(discount);
48
- }, [spotPrice, listPrice]);
49
- };
50
- //# sourceMappingURL=useDiscountPercent.js.map
51
- ;// CONCATENATED MODULE: ../components/dist/molecules/DiscountBadge/DiscountBadge.js
52
-
53
-
54
-
55
- const DiscountBadge = ({ listPrice, spotPrice, thresholdLow = 15, thresholdHigh = 40, size, testId = 'fs-discount-badge', }) => {
56
- const discountPercent = useDiscountPercent(listPrice, spotPrice);
57
- if (discountPercent === 0) {
58
- return external_react_default().createElement((external_react_default()).Fragment, null);
59
- }
60
- const discountVariant = discountPercent <= thresholdLow
61
- ? 'low'
62
- : discountPercent <= thresholdHigh
63
- ? 'medium'
64
- : 'high';
65
- return (external_react_default().createElement(Badge/* default */.Z, { "data-fs-discount-badge": true, "data-fs-discount-badge-variant": discountVariant, size: size, "data-testid": testId },
66
- discountPercent,
67
- "% off"));
68
- };
69
- /* harmony default export */ const DiscountBadge_DiscountBadge = (DiscountBadge);
70
- //# sourceMappingURL=DiscountBadge.js.map
71
-
72
- /***/ }),
73
-
74
- /***/ 40783:
75
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
76
-
77
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
78
- /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
79
- /* harmony export */ });
80
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(16689);
81
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
82
- /* harmony import */ var ___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25045);
83
- /* harmony import */ var ___WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(82765);
84
- /* harmony import */ var _atoms_List__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41329);
85
-
86
-
87
-
88
- const Rating = (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Rating({ children, testId = 'fs-rating', length = 5, value = 0, icon, onChange, ...otherProps }, ref) {
89
- const [hover, setHover] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(0);
90
- const outlineProps = { 'data-fs-rating-icon-outline': true };
91
- const ratingIcon = react__WEBPACK_IMPORTED_MODULE_0___default().isValidElement(icon) ? icon : react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, { name: "Star" });
92
- return (react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_atoms_List__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z, { ref: ref, "data-fs-rating": true, "data-fs-rating-actionable": typeof onChange === 'function', "data-testid": testId, ...otherProps }, Array.from({ length }).map((_, index) => {
93
- const tempIndex = index + 1;
94
- const fillCheck = () => {
95
- if (tempIndex <= (hover || value)) {
96
- return 'full';
97
- }
98
- if (tempIndex - value > 0 && tempIndex - value < 1) {
99
- return 'partial';
100
- }
101
- return 'empty';
102
- };
103
- return (react__WEBPACK_IMPORTED_MODULE_0___default().createElement("li", { key: `rating-${index}`, "data-fs-rating-item": fillCheck(), "data-testid": `${testId}-item` }, onChange ? (react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z, { "data-fs-rating-button": true, icon: ratingIcon, size: "small", "aria-label": "rate", onClick: () => {
104
- onChange(tempIndex);
105
- }, onMouseEnter: () => setHover(tempIndex), onMouseLeave: () => setHover(value) })) : (react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null,
106
- react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", { "data-fs-rating-icon-wrapper": true }, ratingIcon),
107
- react__WEBPACK_IMPORTED_MODULE_0___default().isValidElement(icon) ? (react__WEBPACK_IMPORTED_MODULE_0___default().cloneElement(icon, outlineProps)) : (react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, { name: "Star", "data-fs-rating-icon-outline": true }))))));
108
- })));
109
- });
110
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Rating);
111
- //# sourceMappingURL=Rating.js.map
112
-
113
- /***/ }),
114
-
115
- /***/ 56475:
116
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
117
-
118
-
119
- // EXPORTS
120
- __webpack_require__.d(__webpack_exports__, {
121
- "Z": () => (/* reexport */ product_ProductCard_ProductCard)
122
- });
123
-
124
- // EXTERNAL MODULE: external "react"
125
- var external_react_ = __webpack_require__(16689);
126
- var external_react_default = /*#__PURE__*/__webpack_require__.n(external_react_);
127
- ;// CONCATENATED MODULE: ../components/dist/molecules/ProductCard/ProductCard.js
128
-
129
- const ProductCard = (0,external_react_.forwardRef)(function ProductCard({ testId = 'fs-product-card', variant = 'default', bordered = false, outOfStock, children, ...otherProps }, ref) {
130
- return (external_react_default().createElement("article", { ref: ref, "data-fs-product-card": outOfStock ? 'out-of-stock' : '', "data-fs-product-card-variant": variant, "data-fs-product-card-bordered": bordered, "data-testid": testId, ...otherProps }, children));
131
- });
132
- /* harmony default export */ const ProductCard_ProductCard = (ProductCard);
133
- //# sourceMappingURL=ProductCard.js.map
134
- ;// CONCATENATED MODULE: ../components/dist/molecules/ProductCard/ProductCardImage.js
135
-
136
- const ProductCardImage = (0,external_react_.forwardRef)(function ProductCardImage({ testId = 'fs-product-card-image', aspectRatio = 1, children, ...otherProps }, ref) {
137
- return (external_react_default().createElement("div", { ref: ref, "data-fs-product-card-image": true, "data-testid": testId, style: {
138
- '--fs-product-card-image-aspect-ratio': aspectRatio
139
- }, ...otherProps }, children));
140
- });
141
- /* harmony default export */ const ProductCard_ProductCardImage = (ProductCardImage);
142
- //# sourceMappingURL=ProductCardImage.js.map
143
- // EXTERNAL MODULE: ../components/dist/atoms/Link/Link.js
144
- var Link = __webpack_require__(87865);
145
- // EXTERNAL MODULE: ../components/dist/atoms/Price/Price.js
146
- var Price = __webpack_require__(57549);
147
- // EXTERNAL MODULE: ../components/dist/molecules/Rating/Rating.js
148
- var Rating = __webpack_require__(40783);
149
- // EXTERNAL MODULE: ../components/dist/atoms/Icon/Icon.js
150
- var Icon = __webpack_require__(25045);
151
- // EXTERNAL MODULE: ../components/dist/molecules/DiscountBadge/DiscountBadge.js + 1 modules
152
- var DiscountBadge = __webpack_require__(89875);
153
- // EXTERNAL MODULE: ../components/dist/atoms/Badge/Badge.js
154
- var Badge = __webpack_require__(10044);
155
- // EXTERNAL MODULE: ../components/dist/atoms/Button/Button.js
156
- var Button = __webpack_require__(57578);
157
- ;// CONCATENATED MODULE: ../components/dist/molecules/ProductCard/ProductCardContent.js
158
-
159
-
160
- const ProductCardContent = (0,external_react_.forwardRef)(function CardContent({ testId = 'fs-product-card-content', title, linkProps, price, outOfStock, outOfStockLabel = 'Out of stock', ratingValue, showDiscountBadge, buttonLabel = 'Add', onButtonClick, children, ...otherProps }, ref) {
161
- return (external_react_default().createElement("section", { ref: ref, "data-fs-product-card-content": true, "data-fs-product-card-badge": showDiscountBadge, "data-testid": testId, ...otherProps },
162
- external_react_default().createElement("div", { "data-fs-product-card-heading": true },
163
- external_react_default().createElement("h3", { "data-fs-product-card-title": true },
164
- external_react_default().createElement(Link/* default */.Z, { ...linkProps, title: title },
165
- external_react_default().createElement("span", null, title))),
166
- !outOfStock && (external_react_default().createElement("div", { "data-fs-product-card-prices": true },
167
- 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:" }),
168
- external_react_default().createElement(Price/* default */.Z, { value: price?.value ? price.value : 0, formatter: price?.formatter, testId: "price", "data-value": price?.value, variant: "spot", SRText: "Sale Price:" }))),
169
- ratingValue && (external_react_default().createElement(Rating/* default */.Z, { value: ratingValue, icon: external_react_default().createElement(Icon/* default */.Z, { name: "Star" }) }))),
170
- showDiscountBadge && !outOfStock && (external_react_default().createElement(DiscountBadge/* default */.Z, { listPrice: price?.listPrice ? price.listPrice : 0, spotPrice: price?.value ? price.value : 0 })),
171
- outOfStock && external_react_default().createElement(Badge/* default */.Z, null, outOfStockLabel),
172
- onButtonClick && !outOfStock && (external_react_default().createElement("div", { "data-fs-product-card-actions": true },
173
- external_react_default().createElement(Button/* default */.Z, { variant: "primary", icon: external_react_default().createElement(Icon/* default */.Z, { name: "ShoppingCart" }), iconPosition: "left", size: "small", onClick: onButtonClick }, buttonLabel)))));
174
- });
175
- /* harmony default export */ const ProductCard_ProductCardContent = (ProductCardContent);
176
- //# sourceMappingURL=ProductCardContent.js.map
177
- // EXTERNAL MODULE: ./node_modules/next/link.js
178
- var next_link = __webpack_require__(41664);
179
- var link_default = /*#__PURE__*/__webpack_require__.n(next_link);
180
- // EXTERNAL MODULE: ./src/components/ui/Image/index.ts + 2 modules
181
- var Image = __webpack_require__(79266);
182
- // EXTERNAL MODULE: ./src/sdk/product/useFormattedPrice.ts
183
- var useFormattedPrice = __webpack_require__(95346);
184
- // EXTERNAL MODULE: ./src/sdk/product/useProductLink.ts
185
- var useProductLink = __webpack_require__(49854);
186
- // EXTERNAL MODULE: external "react/jsx-runtime"
187
- var jsx_runtime_ = __webpack_require__(20997);
188
- ;// CONCATENATED MODULE: ./src/components/product/ProductCard/ProductCard.tsx
189
- const _excluded = ["product", "index", "bordered", "variant", "aspectRatio", "imgProps", "ratingValue", "buttonLabel", "onButtonClick", "showDiscountBadge"];
190
-
191
- 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; }
192
-
193
- 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; }
194
-
195
- 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; }
196
-
197
- 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; }
198
-
199
- 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; }
200
-
201
-
202
-
203
-
204
-
205
-
206
-
207
-
208
-
209
-
210
- function ProductCard_ProductCard_ProductCard(_ref) {
211
- let {
212
- product,
213
- index,
214
- bordered = true,
215
- variant = 'default',
216
- aspectRatio = 1,
217
- imgProps,
218
- ratingValue,
219
- buttonLabel = 'Add',
220
- onButtonClick,
221
- showDiscountBadge = true
222
- } = _ref,
223
- otherProps = _objectWithoutProperties(_ref, _excluded);
224
-
225
- const {
226
- sku,
227
- isVariantOf: {
228
- name
229
- },
230
- image: [img],
231
- offers: {
232
- lowPrice: spotPrice,
233
- offers: [{
234
- listPrice,
235
- availability
236
- }]
237
- }
238
- } = product;
239
-
240
- const linkProps = _objectSpread(_objectSpread({}, (0,useProductLink/* useProductLink */.w)({
241
- product,
242
- selectedOffer: 0,
243
- index
244
- })), {}, {
245
- as: (link_default()),
246
- passHref: true,
247
- legacyBehavior: false,
248
- prefetch: false
249
- });
250
-
251
- const outOfStock = (0,external_react_.useMemo)(() => availability !== 'https://schema.org/InStock', [availability]);
252
- return /*#__PURE__*/(0,jsx_runtime_.jsxs)(ProductCard_ProductCard, _objectSpread(_objectSpread({
253
- outOfStock: outOfStock,
254
- bordered: bordered,
255
- variant: variant,
256
- "data-fs-product-card-sku": sku
257
- }, otherProps), {}, {
258
- children: [/*#__PURE__*/jsx_runtime_.jsx(ProductCard_ProductCardImage, {
259
- aspectRatio: aspectRatio,
260
- children: /*#__PURE__*/jsx_runtime_.jsx(Image/* Image */.E, {
261
- src: img.url,
262
- alt: img.alternateName,
263
- sizes: `${imgProps?.sizes ?? '(max-width: 768px) 40vw, 30vw'}`,
264
- width: imgProps?.width ?? 360,
265
- height: Math.round((Number(imgProps?.height) || 360) / aspectRatio),
266
- loading: imgProps?.loading
267
- })
268
- }), /*#__PURE__*/jsx_runtime_.jsx(ProductCard_ProductCardContent, {
269
- title: name,
270
- price: {
271
- value: spotPrice,
272
- listPrice: listPrice,
273
- formatter: useFormattedPrice/* useFormattedPrice */.P
274
- },
275
- ratingValue: ratingValue,
276
- outOfStock: outOfStock,
277
- onButtonClick: onButtonClick,
278
- linkProps: linkProps,
279
- showDiscountBadge: showDiscountBadge
280
- })]
281
- }));
282
- }
283
-
284
- const fragment = "unknown";
285
- /* harmony default export */ const product_ProductCard_ProductCard = (/*#__PURE__*/(0,external_react_.memo)(ProductCard_ProductCard_ProductCard));
286
- ;// CONCATENATED MODULE: ./src/components/product/ProductCard/index.ts
287
-
288
-
289
- /***/ }),
290
-
291
- /***/ 73288:
292
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
293
-
294
-
295
- // EXPORTS
296
- __webpack_require__.d(__webpack_exports__, {
297
- "Z": () => (/* reexport */ ProductCardSkeleton_ProductCardSkeleton)
298
- });
299
-
300
- // EXTERNAL MODULE: ../components/dist/atoms/Skeleton/Skeleton.js
301
- var Skeleton = __webpack_require__(2928);
302
- // EXTERNAL MODULE: external "react/jsx-runtime"
303
- var jsx_runtime_ = __webpack_require__(20997);
304
- ;// CONCATENATED MODULE: ./src/components/skeletons/ProductCardSkeleton/ProductCardSkeleton.tsx
305
-
306
-
307
-
308
-
309
- function ProductCardSkeleton({
310
- bordered,
311
- sectioned,
312
- displayButton,
313
- aspectRatio = 1,
314
- variant = 'default'
315
- }) {
316
- return /*#__PURE__*/(0,jsx_runtime_.jsxs)("div", {
317
- "data-fs-product-card-skeleton": true,
318
- "data-fs-product-card-skeleton-variant": variant,
319
- "data-fs-product-card-skeleton-bordered": bordered,
320
- "data-fs-product-card-skeleton-sectioned": sectioned,
321
- children: [/*#__PURE__*/jsx_runtime_.jsx("div", {
322
- "data-fs-product-card-skeleton-image": true,
323
- style: {
324
- '--fs-product-card-skeleton-image-aspect-ratio': aspectRatio
325
- },
326
- children: /*#__PURE__*/jsx_runtime_.jsx(Skeleton/* default */.Z, {
327
- size: {
328
- width: '100%',
329
- height: '100%'
330
- }
331
- })
332
- }), /*#__PURE__*/(0,jsx_runtime_.jsxs)("div", {
333
- "data-fs-product-card-skeleton-content": true,
334
- children: [/*#__PURE__*/jsx_runtime_.jsx(Skeleton/* default */.Z, {
335
- "data-fs-product-card-skeleton-text": true,
336
- size: {
337
- width: '90%',
338
- height: '1.5rem'
339
- }
340
- }), /*#__PURE__*/jsx_runtime_.jsx(Skeleton/* default */.Z, {
341
- "data-fs-product-card-skeleton-text": true,
342
- size: {
343
- width: '70%',
344
- height: '1.5rem'
345
- }
346
- }), /*#__PURE__*/jsx_runtime_.jsx(Skeleton/* default */.Z, {
347
- "data-fs-product-card-skeleton-badge": true,
348
- size: {
349
- width: '6rem',
350
- height: '2rem'
351
- },
352
- border: "pill"
353
- }), displayButton && /*#__PURE__*/jsx_runtime_.jsx(Skeleton/* default */.Z, {
354
- "data-fs-product-card-skeleton-button": true,
355
- size: {
356
- width: '6rem',
357
- height: '2rem'
358
- },
359
- style: {
360
- columnGap: '.75rem'
361
- }
362
- })]
363
- })]
364
- });
365
- }
366
-
367
- /* harmony default export */ const ProductCardSkeleton_ProductCardSkeleton = (ProductCardSkeleton);
368
- ;// CONCATENATED MODULE: ./src/components/skeletons/ProductCardSkeleton/index.ts
369
-
370
-
371
- /***/ }),
372
-
373
- /***/ 18459:
374
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
375
-
376
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
377
- /* harmony export */ "K": () => (/* binding */ ITEMS_PER_SECTION),
378
- /* harmony export */ "g": () => (/* binding */ ITEMS_PER_PAGE)
379
- /* harmony export */ });
380
- const ITEMS_PER_PAGE = 12;
381
- const ITEMS_PER_SECTION = 5;
382
-
383
- /***/ }),
384
-
385
- /***/ 92953:
386
- /***/ ((module, __webpack_exports__, __webpack_require__) => {
387
-
388
- __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
389
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
390
- /* harmony export */ "p": () => (/* binding */ prefetchQuery)
391
- /* harmony export */ });
392
- /* harmony import */ var swr__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(15941);
393
- /* harmony import */ var _request__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(180);
394
- /* harmony import */ var _useQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(77732);
395
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([swr__WEBPACK_IMPORTED_MODULE_0__, _useQuery__WEBPACK_IMPORTED_MODULE_1__]);
396
- ([swr__WEBPACK_IMPORTED_MODULE_0__, _useQuery__WEBPACK_IMPORTED_MODULE_1__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
397
- const _excluded = ["cache"];
398
-
399
- 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; }
400
-
401
- 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; }
402
-
403
-
404
-
405
-
406
- const prefetchQuery = (operationName, variables, _ref) => {
407
- let {
408
- cache
409
- } = _ref,
410
- options = _objectWithoutProperties(_ref, _excluded);
411
-
412
- const key = (0,_useQuery__WEBPACK_IMPORTED_MODULE_1__/* .getKey */ .km)(operationName, variables);
413
-
414
- if (cache.get(key)) {
415
- return;
416
- }
417
-
418
- (0,swr__WEBPACK_IMPORTED_MODULE_0__.mutate)(key, (0,_request__WEBPACK_IMPORTED_MODULE_2__/* .request */ .W)(operationName, variables, options));
419
- };
420
- __webpack_async_result__();
421
- } catch(e) { __webpack_async_result__(e); } });
422
-
423
- /***/ }),
424
-
425
- /***/ 24867:
426
- /***/ ((module, __webpack_exports__, __webpack_require__) => {
427
-
428
- __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
429
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
430
- /* harmony export */ "BG": () => (/* binding */ useProductsQueryPrefetch),
431
- /* harmony export */ "kN": () => (/* binding */ useProductsQuery),
432
- /* harmony export */ "yb": () => (/* binding */ useLocalizedVariables)
433
- /* harmony export */ });
434
- /* unused harmony export query */
435
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(16689);
436
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
437
- /* harmony import */ var swr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(15941);
438
- /* harmony import */ var src_constants__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(18459);
439
- /* harmony import */ var _graphql_prefetchQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(92953);
440
- /* harmony import */ var _graphql_useQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(77732);
441
- /* harmony import */ var _session__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(97295);
442
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([swr__WEBPACK_IMPORTED_MODULE_1__, _graphql_prefetchQuery__WEBPACK_IMPORTED_MODULE_2__, _graphql_useQuery__WEBPACK_IMPORTED_MODULE_3__]);
443
- ([swr__WEBPACK_IMPORTED_MODULE_1__, _graphql_prefetchQuery__WEBPACK_IMPORTED_MODULE_2__, _graphql_useQuery__WEBPACK_IMPORTED_MODULE_3__] = __webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__);
444
- 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; }
445
-
446
- 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; }
447
-
448
- 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; }
449
-
450
-
451
-
452
-
453
-
454
-
455
-
456
- const query = "ProductsQuery";
457
-
458
- const toArray = x => Array.isArray(x) ? x : x ? [x] : [];
459
-
460
- const useLocalizedVariables = ({
461
- first,
462
- after,
463
- sort,
464
- term,
465
- selectedFacets
466
- }) => {
467
- const {
468
- channel,
469
- locale
470
- } = (0,_session__WEBPACK_IMPORTED_MODULE_4__/* .useSession */ .kP)();
471
- return (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => {
472
- const facets = toArray(selectedFacets);
473
- return {
474
- first: first ?? src_constants__WEBPACK_IMPORTED_MODULE_5__/* .ITEMS_PER_SECTION */ .K,
475
- after: after ?? '0',
476
- sort: sort ?? 'score_desc',
477
- term: term ?? '',
478
- selectedFacets: [...facets, {
479
- key: 'channel',
480
- value: channel ?? ''
481
- }, {
482
- key: 'locale',
483
- value: locale
484
- }]
485
- };
486
- }, [selectedFacets, first, after, sort, term, channel, locale]);
487
- };
488
- /**
489
- * Use this hook for fetching a list of products, like in search results and shelves
490
- */
491
-
492
- const useProductsQuery = (variables, options) => {
493
- const localizedVariables = useLocalizedVariables(variables);
494
- const {
495
- data
496
- } = (0,_graphql_useQuery__WEBPACK_IMPORTED_MODULE_3__/* .useQuery */ .aM)(query, localizedVariables, _objectSpread({
497
- fallbackData: null,
498
- suspense: true
499
- }, options));
500
- return data?.search?.products;
501
- };
502
- const useProductsQueryPrefetch = (variables, options) => {
503
- const localizedVariables = useLocalizedVariables(variables);
504
- const {
505
- cache
506
- } = (0,swr__WEBPACK_IMPORTED_MODULE_1__.useSWRConfig)();
507
- return (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(() => (0,_graphql_prefetchQuery__WEBPACK_IMPORTED_MODULE_2__/* .prefetchQuery */ .p)(query, localizedVariables, _objectSpread({
508
- cache
509
- }, options)), [localizedVariables, cache, options]);
510
- };
511
- __webpack_async_result__();
512
- } catch(e) { __webpack_async_result__(e); } });
513
-
514
- /***/ })
515
-
516
- };
517
- ;
@@ -1,58 +0,0 @@
1
- "use strict";
2
- exports.id = 287;
3
- exports.ids = [287];
4
- exports.modules = {
5
-
6
- /***/ 57216:
7
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
8
-
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__(16689);
13
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
14
-
15
- const Label = (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Label({ testId = 'fs-label', children, ...otherProps }, ref) {
16
- return (react__WEBPACK_IMPORTED_MODULE_0___default().createElement("label", { ref: ref, "data-fs-label": true, "data-testid": testId, ...otherProps }, children));
17
- });
18
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Label);
19
- //# sourceMappingURL=Label.js.map
20
-
21
- /***/ }),
22
-
23
- /***/ 28287:
24
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
25
-
26
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
27
- /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
28
- /* harmony export */ });
29
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(16689);
30
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
31
- /* harmony import */ var ___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(875);
32
- /* harmony import */ var ___WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57216);
33
- /* harmony import */ var ___WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(82765);
34
- /* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25045);
35
- /* harmony import */ var ___WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(57578);
36
-
37
-
38
- const InputField = ({ id, label, type = 'text', error, displayClearButton, actionable, buttonActionText = 'Apply', onSubmit, onClear, placeholder = ' ', // initializes with an empty space to style float label using `placeholder-shown`
39
- inputRef, disabled, value, testId = 'fs-input-field', ...otherProps }) => {
40
- const shouldDisplayError = !disabled && error && error !== '';
41
- const shouldDisplayButton = actionable && !disabled && value !== '';
42
- return (react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", { "data-fs-input-field": true, "data-fs-input-field-actionable": actionable, "data-fs-input-field-error": error && error !== '', "data-testid": testId },
43
- react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, { id: id, type: type, value: value, ref: inputRef, disabled: disabled, placeholder: placeholder, ...otherProps }),
44
- react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z, { htmlFor: id }, label),
45
- shouldDisplayButton &&
46
- (displayClearButton || error ? (react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z, { size: "small", "aria-label": "Clear Field", icon: react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, { name: "XCircle" }), onClick: () => {
47
- onClear?.();
48
- inputRef?.current?.focus();
49
- } })) : (react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, { variant: "tertiary", size: "small", onClick: onSubmit }, buttonActionText))),
50
- shouldDisplayError && (react__WEBPACK_IMPORTED_MODULE_0___default().createElement("span", { "data-fs-input-field-error-message": true }, error))));
51
- };
52
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (InputField);
53
- //# sourceMappingURL=InputField.js.map
54
-
55
- /***/ })
56
-
57
- };
58
- ;