@faststore/core 3.0.21 → 3.0.24
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.
- package/.next/BUILD_ID +1 -1
- package/.next/build-manifest.json +89 -90
- package/.next/cache/.tsbuildinfo +1 -1
- package/.next/cache/config.json +7 -0
- package/.next/cache/eslint/.cache_1gneedd +1 -0
- package/.next/cache/webpack/client-production/0.pack +0 -0
- package/.next/cache/webpack/client-production/index.pack +0 -0
- package/.next/cache/webpack/server-production/0.pack +0 -0
- package/.next/cache/webpack/server-production/index.pack +0 -0
- package/.next/images-manifest.json +1 -1
- package/.next/next-minimal-server.js.nft.json +1 -0
- package/.next/next-server.js.nft.json +1 -1
- package/.next/prerender-manifest.js +1 -0
- package/.next/prerender-manifest.json +1 -1
- package/.next/react-loadable-manifest.json +18 -18
- package/.next/required-server-files.json +1 -1
- package/.next/routes-manifest.json +1 -1
- package/.next/server/chunks/119.js +1 -0
- package/.next/server/chunks/12.js +1 -0
- package/.next/server/chunks/187.js +1 -0
- package/.next/server/chunks/202.js +1 -0
- package/.next/server/chunks/24.js +1 -0
- package/.next/server/chunks/242.js +1 -0
- package/.next/server/chunks/247.js +1 -0
- package/.next/server/chunks/344.js +1 -0
- package/.next/server/chunks/404.js +1 -434
- package/.next/server/chunks/414.js +1 -0
- package/.next/server/chunks/484.js +1 -0
- package/.next/server/chunks/493.js +1 -0
- package/.next/server/chunks/498.js +1 -0
- package/.next/server/chunks/540.js +1 -0
- package/.next/server/chunks/57.js +1 -434
- package/.next/server/chunks/624.js +1 -0
- package/.next/server/chunks/640.js +6 -0
- package/.next/server/chunks/646.js +292 -0
- package/.next/server/chunks/659.js +9 -0
- package/.next/server/chunks/679.js +1 -0
- package/.next/server/chunks/693.js +1 -58
- package/.next/server/chunks/694.js +1 -0
- package/.next/server/chunks/779.js +1 -58
- package/.next/server/chunks/82.js +8 -0
- package/.next/server/chunks/857.js +1 -0
- package/.next/server/chunks/859.js +4 -957
- package/.next/server/chunks/881.js +1 -0
- package/.next/server/chunks/917.js +1 -0
- package/.next/server/chunks/936.js +1 -0
- package/.next/server/chunks/96.js +1 -0
- package/.next/server/chunks/997.js +1 -0
- package/.next/server/functions-config-manifest.json +1 -0
- package/.next/server/middleware-build-manifest.js +1 -1
- package/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/.next/server/next-font-manifest.js +1 -0
- package/.next/server/next-font-manifest.json +1 -0
- package/.next/server/pages/404.js +1 -391
- package/.next/server/pages/404.js.nft.json +1 -1
- package/.next/server/pages/500.js +1 -395
- package/.next/server/pages/500.js.nft.json +1 -1
- package/.next/server/pages/[...slug].js +1 -1076
- package/.next/server/pages/[...slug].js.nft.json +1 -1
- package/.next/server/pages/[slug]/p.js +1 -2265
- package/.next/server/pages/[slug]/p.js.nft.json +1 -1
- package/.next/server/pages/_app.js +1 -301
- package/.next/server/pages/_app.js.nft.json +1 -1
- package/.next/server/pages/_document.js +1 -363
- package/.next/server/pages/_document.js.nft.json +1 -1
- package/.next/server/pages/_error.js +1 -164
- package/.next/server/pages/_error.js.nft.json +1 -1
- package/.next/server/pages/account.js +1 -370
- package/.next/server/pages/account.js.nft.json +1 -1
- package/.next/server/pages/api/graphql.js +1 -2999
- package/.next/server/pages/api/graphql.js.nft.json +1 -1
- package/.next/server/pages/api/health/live.js +1 -31
- package/.next/server/pages/api/health/live.js.nft.json +1 -1
- package/.next/server/pages/api/health/ready.js +1 -31
- package/.next/server/pages/api/health/ready.js.nft.json +1 -1
- package/.next/server/pages/api/preview.js +1 -137
- package/.next/server/pages/api/preview.js.nft.json +1 -1
- package/.next/server/pages/checkout.js +1 -370
- package/.next/server/pages/checkout.js.nft.json +1 -1
- package/.next/server/pages/en-US/404.html +2 -2
- package/.next/server/pages/en-US/404.json +1 -1
- package/.next/server/pages/en-US/500.html +2 -2
- package/.next/server/pages/en-US/500.json +1 -1
- package/.next/server/pages/en-US/account.html +2 -2
- package/.next/server/pages/en-US/account.json +1 -1
- package/.next/server/pages/en-US/checkout.html +2 -2
- package/.next/server/pages/en-US/checkout.json +1 -1
- package/.next/server/pages/en-US/login.html +2 -2
- package/.next/server/pages/en-US/login.json +1 -1
- package/.next/server/pages/en-US/s.html +2 -2
- package/.next/server/pages/en-US/s.json +1 -1
- package/.next/server/pages/en-US.html +5 -5
- package/.next/server/pages/en-US.json +1 -1
- package/.next/server/pages/index.js +1 -439
- package/.next/server/pages/index.js.nft.json +1 -1
- package/.next/server/pages/login.js +1 -382
- package/.next/server/pages/login.js.nft.json +1 -1
- package/.next/server/pages/s.js +1 -554
- package/.next/server/pages/s.js.nft.json +1 -1
- package/.next/server/pages-manifest.json +1 -18
- package/.next/server/webpack-api-runtime.js +1 -229
- package/.next/server/webpack-runtime.js +1 -229
- package/.next/static/BDE9eB7mQJSFb7BXO3vSi/_buildManifest.js +1 -0
- package/.next/static/chunks/104-407fa6e31258582b.js +1 -0
- package/.next/static/chunks/161-b39fe2f79ff7bc85.js +1 -0
- package/.next/static/chunks/202.c7d8a71173edecfb.js +1 -0
- package/.next/static/chunks/217.01bc0ad07edd6f1b.js +1 -0
- package/.next/static/chunks/247.6f1391104a867395.js +1 -0
- package/.next/static/chunks/484.b82b73b1d8c37e02.js +1 -0
- package/.next/static/chunks/540.6c62d2536d42a1e0.js +1 -0
- package/.next/static/chunks/575-853fb8b1ba4ce8c4.js +14 -0
- package/.next/static/chunks/624.d3de62b4562a33f3.js +1 -0
- package/.next/static/chunks/629-c74f247bd29420a5.js +1 -0
- package/.next/static/chunks/65.da22595d53beae76.js +1 -0
- package/.next/static/chunks/758.b53ee01b506973e0.js +1 -0
- package/.next/static/chunks/857.d2299cfe995af21d.js +1 -0
- package/.next/static/chunks/framework-8e279965036b6169.js +33 -0
- package/.next/static/chunks/main-6f63f6746cc029db.js +1 -0
- package/.next/static/chunks/pages/404-1334d11ab8467b3d.js +1 -0
- package/.next/static/chunks/pages/500-449c5bd51f98423f.js +1 -0
- package/.next/static/chunks/pages/[...slug]-bcaf61b01157d8cb.js +1 -0
- package/.next/static/chunks/pages/[slug]/p-be3f544bf3a14d18.js +1 -0
- package/.next/static/chunks/pages/_app-4df2b21628950d8a.js +68 -0
- package/.next/static/chunks/pages/_error-fbf331a03642b495.js +1 -0
- package/.next/static/chunks/pages/account-dbc5c028225cd1ac.js +1 -0
- package/.next/static/chunks/pages/checkout-29ae2c37eaf172e1.js +1 -0
- package/.next/static/chunks/pages/index-cd109119d65df8e3.js +1 -0
- package/.next/static/chunks/pages/login-c4d2c856008df5ac.js +1 -0
- package/.next/static/chunks/pages/s-26e475975386c51a.js +1 -0
- package/.next/static/chunks/webpack-b4a2fdf4ef127bb7.js +1 -0
- package/.next/static/css/0d45c82d8887a269.css +1 -0
- package/.next/static/css/211c7542af66d8b4.css +1 -0
- package/.next/static/css/{df588bb98c0b0ca6.css → 2980acad3f8e1028.css} +1 -1
- package/.next/static/css/4c4d90eb8cb1d2b7.css +1 -0
- package/.next/static/css/821a5219786be653.css +1 -0
- package/.next/static/css/96e3fddf695d6aa9.css +1 -0
- package/.next/static/css/{6a7fdc5a21fbead5.css → b9d9ba1b04f3160d.css} +1 -1
- package/.next/static/css/cff9aafa16fccc9c.css +1 -0
- package/.next/static/css/{a2eefb25a4608343.css → d586715f4f707df4.css} +1 -1
- package/.next/static/css/{cb7d1fcea42fab9c.css → e32410b31c666cb2.css} +1 -1
- package/.next/trace +91 -80
- package/.turbo/turbo-build.log +1 -3
- package/.turbo/turbo-lint.log +2 -0
- package/.turbo/turbo-test.log +23 -0
- package/@generated/graphql.ts +0 -12
- package/@generated/persisted-documents.json +13 -0
- package/@generated/schema.graphql +1055 -0
- package/faststore.config.default.js +1 -0
- package/package.json +9 -9
- package/src/pages/api/preview.ts +4 -1
- package/src/server/options.ts +1 -0
- package/.next/cache/eslint/.cache_abdhua +0 -1
- package/.next/cache/next-server.js.nft.json +0 -1
- package/.next/cache/webpack/client-development/0.pack +0 -0
- package/.next/cache/webpack/client-development/1.pack +0 -0
- package/.next/cache/webpack/client-development/2.pack +0 -0
- package/.next/cache/webpack/client-development/index.pack +0 -0
- package/.next/cache/webpack/client-development/index.pack.old +0 -0
- package/.next/cache/webpack/client-production/1.pack +0 -0
- package/.next/cache/webpack/client-production/2.pack +0 -0
- package/.next/cache/webpack/client-production/index.pack.old +0 -0
- package/.next/cache/webpack/server-development/0.pack +0 -0
- package/.next/cache/webpack/server-development/1.pack +0 -0
- package/.next/cache/webpack/server-development/2.pack +0 -0
- package/.next/cache/webpack/server-development/3.pack +0 -0
- package/.next/cache/webpack/server-development/4.pack +0 -0
- package/.next/cache/webpack/server-development/index.pack +0 -0
- package/.next/cache/webpack/server-development/index.pack.old +0 -0
- package/.next/cache/webpack/server-production/1.pack +0 -0
- package/.next/cache/webpack/server-production/2.pack +0 -0
- package/.next/cache/webpack/server-production/index.pack.old +0 -0
- package/.next/server/chunks/117.js +0 -430
- package/.next/server/chunks/177.js +0 -125
- package/.next/server/chunks/183.js +0 -122
- package/.next/server/chunks/184.js +0 -61
- package/.next/server/chunks/289.js +0 -240
- package/.next/server/chunks/312.js +0 -678
- package/.next/server/chunks/350.js +0 -2834
- package/.next/server/chunks/386.js +0 -200
- package/.next/server/chunks/390.js +0 -550
- package/.next/server/chunks/398.js +0 -611
- package/.next/server/chunks/53.js +0 -61
- package/.next/server/chunks/574.js +0 -145
- package/.next/server/chunks/576.js +0 -122
- package/.next/server/chunks/585.js +0 -640
- package/.next/server/chunks/676.js +0 -32
- package/.next/server/chunks/732.js +0 -1881
- package/.next/server/chunks/74.js +0 -4066
- package/.next/server/chunks/825.js +0 -4074
- package/.next/server/chunks/854.js +0 -72
- package/.next/server/chunks/863.js +0 -111
- package/.next/server/chunks/979.js +0 -1305
- package/.next/server/chunks/98.js +0 -163
- package/.next/server/chunks/988.js +0 -211
- package/.next/static/HI-kc1kjNIbFyFsZCeDEA/_buildManifest.js +0 -1
- package/.next/static/chunks/223-cb77217cce52d45c.js +0 -1
- package/.next/static/chunks/251.1c79f06f2a2814b1.js +0 -1
- package/.next/static/chunks/386.d01e0db26c523f0f.js +0 -1
- package/.next/static/chunks/400-d4daabcd57b2ea80.js +0 -1
- package/.next/static/chunks/469-7259b855711d4ad3.js +0 -1
- package/.next/static/chunks/574.70612be06fd1365f.js +0 -1
- package/.next/static/chunks/585.4c5d40fc6a72a611.js +0 -1
- package/.next/static/chunks/651.7142f31ce1e052b3.js +0 -1
- package/.next/static/chunks/741.52f7fb873418346f.js +0 -1
- package/.next/static/chunks/783-fbcb7a3216c40744.js +0 -1
- package/.next/static/chunks/800.ee4f8b9622001e8c.js +0 -1
- package/.next/static/chunks/98.40c7e17d9de4eb8f.js +0 -1
- package/.next/static/chunks/988.afda042dd9ba11d1.js +0 -1
- package/.next/static/chunks/framework-dfd14d7ce6600b03.js +0 -1
- package/.next/static/chunks/main-e4e873ee741162eb.js +0 -1
- package/.next/static/chunks/pages/404-2240f0b22db2d370.js +0 -1
- package/.next/static/chunks/pages/500-c0580e3299329874.js +0 -1
- package/.next/static/chunks/pages/[...slug]-3eed3497c887fae5.js +0 -1
- package/.next/static/chunks/pages/[slug]/p-e1df08570f34a0d8.js +0 -1
- package/.next/static/chunks/pages/_app-30b9666307e4b3b1.js +0 -1
- package/.next/static/chunks/pages/_error-319451dea77827a6.js +0 -1
- package/.next/static/chunks/pages/account-b35bcbef719765f3.js +0 -1
- package/.next/static/chunks/pages/checkout-55bd56ade4408cbe.js +0 -1
- package/.next/static/chunks/pages/index-2506749e45c335bf.js +0 -1
- package/.next/static/chunks/pages/login-3f94bff1503b4fdc.js +0 -1
- package/.next/static/chunks/pages/s-2374cff2e39ed624.js +0 -1
- package/.next/static/chunks/webpack-af94306e71c4459d.js +0 -1
- package/.next/static/css/29868543c76bc6fd.css +0 -1
- package/.next/static/css/527e334fa69cf40a.css +0 -1
- package/.next/static/css/723835bce380750d.css +0 -1
- package/.next/static/css/d7bbfbd552f407e9.css +0 -1
- package/.next/static/css/dfbdb0f27fd64782.css +0 -1
- package/.next/static/css/e84fc497732ea596.css +0 -1
- package/.turbo/turbo-dev.log +0 -45
- /package/.next/static/{HI-kc1kjNIbFyFsZCeDEA → BDE9eB7mQJSFb7BXO3vSi}/_ssgManifest.js +0 -0
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -1,430 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
exports.id = 117;
|
|
3
|
-
exports.ids = [117];
|
|
4
|
-
exports.modules = {
|
|
5
|
-
|
|
6
|
-
/***/ 792:
|
|
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__(6689);
|
|
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
|
-
/***/ 2946:
|
|
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__(6689);
|
|
38
|
-
var external_react_default = /*#__PURE__*/__webpack_require__.n(external_react_);
|
|
39
|
-
// EXTERNAL MODULE: ../components/dist/esm/atoms/Badge/Badge.js
|
|
40
|
-
var Badge = __webpack_require__(276);
|
|
41
|
-
;// CONCATENATED MODULE: ../components/dist/esm/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/esm/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
|
-
/***/ 3024:
|
|
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__(6689);
|
|
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__(2614);
|
|
83
|
-
/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7041);
|
|
84
|
-
/* harmony import */ var _atoms_List__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(4564);
|
|
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
|
-
/***/ 8553:
|
|
116
|
-
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
// EXPORTS
|
|
120
|
-
__webpack_require__.d(__webpack_exports__, {
|
|
121
|
-
"Z": () => (/* binding */ product_ProductCard_ProductCard)
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
// UNUSED EXPORTS: fragment
|
|
125
|
-
|
|
126
|
-
// EXTERNAL MODULE: external "react"
|
|
127
|
-
var external_react_ = __webpack_require__(6689);
|
|
128
|
-
var external_react_default = /*#__PURE__*/__webpack_require__.n(external_react_);
|
|
129
|
-
;// CONCATENATED MODULE: ../components/dist/esm/molecules/ProductCard/ProductCard.js
|
|
130
|
-
|
|
131
|
-
const ProductCard = (0,external_react_.forwardRef)(function ProductCard({ testId = 'fs-product-card', variant = 'default', bordered = false, outOfStock, children, ...otherProps }, ref) {
|
|
132
|
-
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));
|
|
133
|
-
});
|
|
134
|
-
/* harmony default export */ const ProductCard_ProductCard = (ProductCard);
|
|
135
|
-
//# sourceMappingURL=ProductCard.js.map
|
|
136
|
-
;// CONCATENATED MODULE: ../components/dist/esm/molecules/ProductCard/ProductCardImage.js
|
|
137
|
-
|
|
138
|
-
const ProductCardImage = (0,external_react_.forwardRef)(function ProductCardImage({ testId = 'fs-product-card-image', aspectRatio = 1, children, ...otherProps }, ref) {
|
|
139
|
-
return (external_react_default().createElement("div", { ref: ref, "data-fs-product-card-image": true, "data-testid": testId, style: {
|
|
140
|
-
'--fs-product-card-image-aspect-ratio': aspectRatio
|
|
141
|
-
}, ...otherProps }, children));
|
|
142
|
-
});
|
|
143
|
-
/* harmony default export */ const ProductCard_ProductCardImage = (ProductCardImage);
|
|
144
|
-
//# sourceMappingURL=ProductCardImage.js.map
|
|
145
|
-
// EXTERNAL MODULE: ../components/dist/esm/atoms/Link/Link.js
|
|
146
|
-
var Link = __webpack_require__(727);
|
|
147
|
-
// EXTERNAL MODULE: ../components/dist/esm/atoms/Price/Price.js
|
|
148
|
-
var Price = __webpack_require__(9767);
|
|
149
|
-
// EXTERNAL MODULE: ../components/dist/esm/molecules/Rating/Rating.js
|
|
150
|
-
var Rating = __webpack_require__(3024);
|
|
151
|
-
// EXTERNAL MODULE: ../components/dist/esm/atoms/Icon/Icon.js
|
|
152
|
-
var Icon = __webpack_require__(2614);
|
|
153
|
-
// EXTERNAL MODULE: ../components/dist/esm/molecules/DiscountBadge/DiscountBadge.js + 1 modules
|
|
154
|
-
var DiscountBadge = __webpack_require__(2946);
|
|
155
|
-
// EXTERNAL MODULE: ../components/dist/esm/atoms/Badge/Badge.js
|
|
156
|
-
var Badge = __webpack_require__(276);
|
|
157
|
-
// EXTERNAL MODULE: ../components/dist/esm/atoms/Button/Button.js
|
|
158
|
-
var Button = __webpack_require__(3339);
|
|
159
|
-
;// CONCATENATED MODULE: ../components/dist/esm/molecules/ProductCard/ProductCardContent.js
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
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) {
|
|
163
|
-
const listPrice = price?.listPrice ?? 0;
|
|
164
|
-
const sellingPrice = price?.value ?? 0;
|
|
165
|
-
return (external_react_default().createElement("section", { ref: ref, "data-fs-product-card-content": true, "data-fs-product-card-badge": showDiscountBadge, "data-testid": testId, ...otherProps },
|
|
166
|
-
external_react_default().createElement("div", { "data-fs-product-card-heading": true },
|
|
167
|
-
external_react_default().createElement("h3", { "data-fs-product-card-title": true },
|
|
168
|
-
external_react_default().createElement(Link/* default */.Z, { ...linkProps, title: title },
|
|
169
|
-
external_react_default().createElement("span", null, title))),
|
|
170
|
-
!outOfStock && (external_react_default().createElement("div", { "data-fs-product-card-prices": true }, sellingPrice !== listPrice
|
|
171
|
-
? (external_react_default().createElement((external_react_default()).Fragment, null,
|
|
172
|
-
external_react_default().createElement(Price/* default */.Z, { value: listPrice, formatter: price?.formatter, testId: "list-price", "data-value": listPrice, variant: "listing", SRText: "Original price:" }),
|
|
173
|
-
external_react_default().createElement(Price/* default */.Z, { value: sellingPrice, formatter: price?.formatter, testId: "price", "data-value": sellingPrice, variant: "spot", SRText: "Sale Price:" })))
|
|
174
|
-
: (external_react_default().createElement(Price/* default */.Z, { value: sellingPrice, formatter: price?.formatter, testId: "price", "data-value": sellingPrice, variant: "spot", SRText: "Sale Price:" })))),
|
|
175
|
-
ratingValue && (external_react_default().createElement(Rating/* default */.Z, { value: ratingValue, icon: external_react_default().createElement(Icon/* default */.Z, { name: "Star" }) }))),
|
|
176
|
-
showDiscountBadge && !outOfStock && (external_react_default().createElement(DiscountBadge/* default */.Z, { listPrice: price?.listPrice ? price.listPrice : 0, spotPrice: price?.value ? price.value : 0 })),
|
|
177
|
-
outOfStock && external_react_default().createElement(Badge/* default */.Z, null, outOfStockLabel),
|
|
178
|
-
onButtonClick && !outOfStock && (external_react_default().createElement("div", { "data-fs-product-card-actions": true },
|
|
179
|
-
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)))));
|
|
180
|
-
});
|
|
181
|
-
/* harmony default export */ const ProductCard_ProductCardContent = (ProductCardContent);
|
|
182
|
-
//# sourceMappingURL=ProductCardContent.js.map
|
|
183
|
-
// EXTERNAL MODULE: ./node_modules/next/link.js
|
|
184
|
-
var next_link = __webpack_require__(1664);
|
|
185
|
-
var link_default = /*#__PURE__*/__webpack_require__.n(next_link);
|
|
186
|
-
// EXTERNAL MODULE: ./src/components/ui/Image/Image.tsx + 1 modules
|
|
187
|
-
var Image = __webpack_require__(5731);
|
|
188
|
-
// EXTERNAL MODULE: ./src/sdk/product/useFormattedPrice.ts
|
|
189
|
-
var useFormattedPrice = __webpack_require__(5346);
|
|
190
|
-
// EXTERNAL MODULE: ./src/sdk/product/useProductLink.ts
|
|
191
|
-
var useProductLink = __webpack_require__(9854);
|
|
192
|
-
// EXTERNAL MODULE: external "react/jsx-runtime"
|
|
193
|
-
var jsx_runtime_ = __webpack_require__(997);
|
|
194
|
-
;// CONCATENATED MODULE: ./src/components/product/ProductCard/ProductCard.tsx
|
|
195
|
-
const _excluded = ["product", "index", "bordered", "variant", "aspectRatio", "imgProps", "ratingValue", "buttonLabel", "onButtonClick", "showDiscountBadge"];
|
|
196
|
-
|
|
197
|
-
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; }
|
|
198
|
-
|
|
199
|
-
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; }
|
|
200
|
-
|
|
201
|
-
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; }
|
|
202
|
-
|
|
203
|
-
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; }
|
|
204
|
-
|
|
205
|
-
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; }
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
function ProductCard_ProductCard_ProductCard(_ref) {
|
|
217
|
-
let {
|
|
218
|
-
product,
|
|
219
|
-
index,
|
|
220
|
-
bordered = true,
|
|
221
|
-
variant = 'default',
|
|
222
|
-
aspectRatio = 1,
|
|
223
|
-
imgProps,
|
|
224
|
-
ratingValue,
|
|
225
|
-
buttonLabel = 'Add',
|
|
226
|
-
onButtonClick,
|
|
227
|
-
showDiscountBadge = true
|
|
228
|
-
} = _ref,
|
|
229
|
-
otherProps = _objectWithoutProperties(_ref, _excluded);
|
|
230
|
-
|
|
231
|
-
const {
|
|
232
|
-
sku,
|
|
233
|
-
isVariantOf: {
|
|
234
|
-
name
|
|
235
|
-
},
|
|
236
|
-
image: [img],
|
|
237
|
-
offers: {
|
|
238
|
-
lowPrice: spotPrice,
|
|
239
|
-
offers: [{
|
|
240
|
-
listPrice,
|
|
241
|
-
availability
|
|
242
|
-
}]
|
|
243
|
-
}
|
|
244
|
-
} = product;
|
|
245
|
-
|
|
246
|
-
const linkProps = _objectSpread(_objectSpread({}, (0,useProductLink/* useProductLink */.w)({
|
|
247
|
-
product,
|
|
248
|
-
selectedOffer: 0,
|
|
249
|
-
index
|
|
250
|
-
})), {}, {
|
|
251
|
-
as: (link_default()),
|
|
252
|
-
passHref: true,
|
|
253
|
-
legacyBehavior: false,
|
|
254
|
-
prefetch: false
|
|
255
|
-
});
|
|
256
|
-
|
|
257
|
-
const outOfStock = (0,external_react_.useMemo)(() => availability !== 'https://schema.org/InStock', [availability]);
|
|
258
|
-
return /*#__PURE__*/(0,jsx_runtime_.jsxs)(ProductCard_ProductCard, _objectSpread(_objectSpread({
|
|
259
|
-
outOfStock: outOfStock,
|
|
260
|
-
bordered: bordered,
|
|
261
|
-
variant: variant,
|
|
262
|
-
"data-fs-product-card-sku": sku
|
|
263
|
-
}, otherProps), {}, {
|
|
264
|
-
children: [/*#__PURE__*/jsx_runtime_.jsx(ProductCard_ProductCardImage, {
|
|
265
|
-
aspectRatio: aspectRatio,
|
|
266
|
-
children: /*#__PURE__*/jsx_runtime_.jsx(Image/* default */.Z, {
|
|
267
|
-
src: img.url,
|
|
268
|
-
alt: img.alternateName,
|
|
269
|
-
sizes: `${imgProps?.sizes ?? '(max-width: 768px) 40vw, 30vw'}`,
|
|
270
|
-
width: imgProps?.width ?? 360,
|
|
271
|
-
height: Math.round((Number(imgProps?.height) || 360) / aspectRatio),
|
|
272
|
-
loading: imgProps?.loading
|
|
273
|
-
})
|
|
274
|
-
}), /*#__PURE__*/jsx_runtime_.jsx(ProductCard_ProductCardContent, {
|
|
275
|
-
title: name,
|
|
276
|
-
price: {
|
|
277
|
-
value: spotPrice,
|
|
278
|
-
listPrice: listPrice,
|
|
279
|
-
formatter: useFormattedPrice/* useFormattedPrice */.P
|
|
280
|
-
},
|
|
281
|
-
ratingValue: ratingValue,
|
|
282
|
-
outOfStock: outOfStock,
|
|
283
|
-
onButtonClick: onButtonClick,
|
|
284
|
-
linkProps: linkProps,
|
|
285
|
-
showDiscountBadge: showDiscountBadge
|
|
286
|
-
})]
|
|
287
|
-
}));
|
|
288
|
-
}
|
|
289
|
-
|
|
290
|
-
const fragment = "unknown";
|
|
291
|
-
/* harmony default export */ const product_ProductCard_ProductCard = (/*#__PURE__*/(0,external_react_.memo)(ProductCard_ProductCard_ProductCard));
|
|
292
|
-
|
|
293
|
-
/***/ }),
|
|
294
|
-
|
|
295
|
-
/***/ 6531:
|
|
296
|
-
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
297
|
-
|
|
298
|
-
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
299
|
-
/* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
|
|
300
|
-
/* harmony export */ });
|
|
301
|
-
/* harmony import */ var _faststore_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(792);
|
|
302
|
-
/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(997);
|
|
303
|
-
/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
function ProductCardSkeleton({
|
|
309
|
-
bordered,
|
|
310
|
-
sectioned,
|
|
311
|
-
displayButton,
|
|
312
|
-
aspectRatio = 1,
|
|
313
|
-
variant = 'default'
|
|
314
|
-
}) {
|
|
315
|
-
return /*#__PURE__*/(0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
|
|
316
|
-
"data-fs-product-card-skeleton": true,
|
|
317
|
-
"data-fs-product-card-skeleton-variant": variant,
|
|
318
|
-
"data-fs-product-card-skeleton-bordered": bordered,
|
|
319
|
-
"data-fs-product-card-skeleton-sectioned": sectioned,
|
|
320
|
-
children: [/*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
|
|
321
|
-
"data-fs-product-card-skeleton-image": true,
|
|
322
|
-
style: {
|
|
323
|
-
'--fs-product-card-skeleton-image-aspect-ratio': aspectRatio
|
|
324
|
-
},
|
|
325
|
-
children: /*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_faststore_ui__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, {
|
|
326
|
-
size: {
|
|
327
|
-
width: '100%',
|
|
328
|
-
height: '100%'
|
|
329
|
-
}
|
|
330
|
-
})
|
|
331
|
-
}), /*#__PURE__*/(0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
|
|
332
|
-
"data-fs-product-card-skeleton-content": true,
|
|
333
|
-
children: [/*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_faststore_ui__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, {
|
|
334
|
-
"data-fs-product-card-skeleton-text": true,
|
|
335
|
-
size: {
|
|
336
|
-
width: '90%',
|
|
337
|
-
height: '1.5rem'
|
|
338
|
-
}
|
|
339
|
-
}), /*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_faststore_ui__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, {
|
|
340
|
-
"data-fs-product-card-skeleton-text": true,
|
|
341
|
-
size: {
|
|
342
|
-
width: '70%',
|
|
343
|
-
height: '1.5rem'
|
|
344
|
-
}
|
|
345
|
-
}), /*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_faststore_ui__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, {
|
|
346
|
-
"data-fs-product-card-skeleton-badge": true,
|
|
347
|
-
size: {
|
|
348
|
-
width: '6rem',
|
|
349
|
-
height: '2rem'
|
|
350
|
-
},
|
|
351
|
-
border: "pill"
|
|
352
|
-
}), displayButton && /*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_faststore_ui__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, {
|
|
353
|
-
"data-fs-product-card-skeleton-button": true,
|
|
354
|
-
size: {
|
|
355
|
-
width: '6rem',
|
|
356
|
-
height: '2rem'
|
|
357
|
-
},
|
|
358
|
-
style: {
|
|
359
|
-
columnGap: '.75rem'
|
|
360
|
-
}
|
|
361
|
-
})]
|
|
362
|
-
})]
|
|
363
|
-
});
|
|
364
|
-
}
|
|
365
|
-
|
|
366
|
-
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ProductCardSkeleton);
|
|
367
|
-
|
|
368
|
-
/***/ }),
|
|
369
|
-
|
|
370
|
-
/***/ 8459:
|
|
371
|
-
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
372
|
-
|
|
373
|
-
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
374
|
-
/* harmony export */ "K": () => (/* binding */ ITEMS_PER_SECTION),
|
|
375
|
-
/* harmony export */ "g": () => (/* binding */ ITEMS_PER_PAGE)
|
|
376
|
-
/* harmony export */ });
|
|
377
|
-
const ITEMS_PER_PAGE = 12;
|
|
378
|
-
const ITEMS_PER_SECTION = 5;
|
|
379
|
-
|
|
380
|
-
/***/ }),
|
|
381
|
-
|
|
382
|
-
/***/ 2523:
|
|
383
|
-
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
384
|
-
|
|
385
|
-
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
386
|
-
/* harmony export */ "y": () => (/* binding */ useLocalizedVariables)
|
|
387
|
-
/* harmony export */ });
|
|
388
|
-
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6689);
|
|
389
|
-
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
|
|
390
|
-
/* harmony import */ var _session__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7295);
|
|
391
|
-
/* harmony import */ var src_constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(8459);
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
const toArray = x => Array.isArray(x) ? x : x ? [x] : [];
|
|
397
|
-
|
|
398
|
-
const useLocalizedVariables = ({
|
|
399
|
-
first,
|
|
400
|
-
after,
|
|
401
|
-
sort,
|
|
402
|
-
term,
|
|
403
|
-
selectedFacets
|
|
404
|
-
}) => {
|
|
405
|
-
const {
|
|
406
|
-
channel,
|
|
407
|
-
locale
|
|
408
|
-
} = (0,_session__WEBPACK_IMPORTED_MODULE_1__/* .useSession */ .kP)();
|
|
409
|
-
return (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => {
|
|
410
|
-
const facets = toArray(selectedFacets);
|
|
411
|
-
return {
|
|
412
|
-
first: first ?? src_constants__WEBPACK_IMPORTED_MODULE_2__/* .ITEMS_PER_SECTION */ .K,
|
|
413
|
-
after: after ?? '0',
|
|
414
|
-
sort: sort ?? 'score_desc',
|
|
415
|
-
term: term ?? '',
|
|
416
|
-
selectedFacets: [...facets, {
|
|
417
|
-
key: 'channel',
|
|
418
|
-
value: channel ?? ''
|
|
419
|
-
}, {
|
|
420
|
-
key: 'locale',
|
|
421
|
-
value: locale
|
|
422
|
-
}]
|
|
423
|
-
};
|
|
424
|
-
}, [selectedFacets, first, after, sort, term, channel, locale]);
|
|
425
|
-
};
|
|
426
|
-
|
|
427
|
-
/***/ })
|
|
428
|
-
|
|
429
|
-
};
|
|
430
|
-
;
|
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
exports.id = 177;
|
|
3
|
-
exports.ids = [177];
|
|
4
|
-
exports.modules = {
|
|
5
|
-
|
|
6
|
-
/***/ 6652:
|
|
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 */ "l": () => (/* binding */ useUI)
|
|
12
|
-
/* harmony export */ });
|
|
13
|
-
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6689);
|
|
14
|
-
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
|
|
15
|
-
|
|
16
|
-
const reducer = (state, action) => {
|
|
17
|
-
const { type } = action;
|
|
18
|
-
switch (type) {
|
|
19
|
-
case 'open': {
|
|
20
|
-
const { payload } = action;
|
|
21
|
-
document.body.classList.add('no-scroll');
|
|
22
|
-
return {
|
|
23
|
-
...state,
|
|
24
|
-
[payload]: true,
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
case 'close': {
|
|
28
|
-
const { payload } = action;
|
|
29
|
-
document.body.classList.remove('no-scroll');
|
|
30
|
-
return {
|
|
31
|
-
...state,
|
|
32
|
-
[payload]: false,
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
case 'pushToast': {
|
|
36
|
-
const isDuplicate = state.toasts.some((existingToast) => existingToast.message === action.payload.message &&
|
|
37
|
-
existingToast.status === action.payload.status);
|
|
38
|
-
if (isDuplicate) {
|
|
39
|
-
return state;
|
|
40
|
-
}
|
|
41
|
-
return {
|
|
42
|
-
...state,
|
|
43
|
-
toasts: [...state.toasts, action.payload],
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
case 'popToast': {
|
|
47
|
-
return {
|
|
48
|
-
...state,
|
|
49
|
-
toasts: state.toasts.slice(1),
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
default:
|
|
53
|
-
throw new Error(`Action ${type} not implemented`);
|
|
54
|
-
}
|
|
55
|
-
};
|
|
56
|
-
const initializer = () => ({
|
|
57
|
-
cart: false,
|
|
58
|
-
modal: false,
|
|
59
|
-
navbar: false,
|
|
60
|
-
filter: false,
|
|
61
|
-
toasts: [],
|
|
62
|
-
});
|
|
63
|
-
const UIContext = (0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)(undefined);
|
|
64
|
-
function UIProvider({ children }) {
|
|
65
|
-
const [ui, dispatch] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useReducer)(reducer, undefined, initializer);
|
|
66
|
-
const callbacks = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => ({
|
|
67
|
-
openFilter: () => dispatch({ type: 'open', payload: 'filter' }),
|
|
68
|
-
closeFilter: () => dispatch({ type: 'close', payload: 'filter' }),
|
|
69
|
-
openNavbar: () => dispatch({ type: 'open', payload: 'navbar' }),
|
|
70
|
-
closeNavbar: () => dispatch({ type: 'close', payload: 'navbar' }),
|
|
71
|
-
openCart: () => dispatch({ type: 'open', payload: 'cart' }),
|
|
72
|
-
closeCart: () => dispatch({ type: 'close', payload: 'cart' }),
|
|
73
|
-
openModal: () => dispatch({ type: 'open', payload: 'modal' }),
|
|
74
|
-
closeModal: () => dispatch({ type: 'close', payload: 'modal' }),
|
|
75
|
-
pushToast: (toast) => dispatch({ type: 'pushToast', payload: toast }),
|
|
76
|
-
popToast: () => dispatch({ type: 'popToast' }),
|
|
77
|
-
}), []);
|
|
78
|
-
const value = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => ({
|
|
79
|
-
...ui,
|
|
80
|
-
...callbacks,
|
|
81
|
-
}), [callbacks, ui]);
|
|
82
|
-
return react__WEBPACK_IMPORTED_MODULE_0___default().createElement(UIContext.Provider, { value: value }, children);
|
|
83
|
-
}
|
|
84
|
-
function useUI() {
|
|
85
|
-
const context = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(UIContext);
|
|
86
|
-
if (context === undefined) {
|
|
87
|
-
throw new Error('Missing UI context on React tree');
|
|
88
|
-
}
|
|
89
|
-
return context;
|
|
90
|
-
}
|
|
91
|
-
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (UIProvider);
|
|
92
|
-
//# sourceMappingURL=UIProvider.js.map
|
|
93
|
-
|
|
94
|
-
/***/ }),
|
|
95
|
-
|
|
96
|
-
/***/ 4950:
|
|
97
|
-
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
98
|
-
|
|
99
|
-
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
100
|
-
/* harmony export */ "Wg": () => (/* binding */ unwrap),
|
|
101
|
-
/* harmony export */ "re": () => (/* binding */ wrap),
|
|
102
|
-
/* harmony export */ "vi": () => (/* binding */ ANALYTICS_EVENT_TYPE)
|
|
103
|
-
/* harmony export */ });
|
|
104
|
-
/* unused harmony export STORE_EVENT_PREFIX */
|
|
105
|
-
const STORE_EVENT_PREFIX = 'store:';
|
|
106
|
-
const ANALYTICS_EVENT_TYPE = 'AnalyticsEvent';
|
|
107
|
-
const wrap = (event) => ({
|
|
108
|
-
name: ANALYTICS_EVENT_TYPE,
|
|
109
|
-
params: {
|
|
110
|
-
...event,
|
|
111
|
-
name: `${STORE_EVENT_PREFIX}${event.name}`,
|
|
112
|
-
},
|
|
113
|
-
});
|
|
114
|
-
const unwrap = (event) => {
|
|
115
|
-
return {
|
|
116
|
-
...event.params,
|
|
117
|
-
name: event.params.name.slice(STORE_EVENT_PREFIX.length, event.params.name.length),
|
|
118
|
-
};
|
|
119
|
-
};
|
|
120
|
-
//# sourceMappingURL=wrap.js.map
|
|
121
|
-
|
|
122
|
-
/***/ })
|
|
123
|
-
|
|
124
|
-
};
|
|
125
|
-
;
|