@faststore/core 2.2.33 → 2.2.34
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/.turbo/turbo-build.log +1 -1
- package/.turbo/turbo-test.log +6 -6
- package/package.json +2 -2
- package/src/components/ThirdPartyScripts/GoogleTagManager.tsx +1 -1
- package/src/components/ThirdPartyScripts/ThirdPartyScripts.tsx +15 -9
- package/.next/BUILD_ID +0 -1
- package/.next/build-manifest.json +0 -126
- package/.next/cache/.tsbuildinfo +0 -1
- package/.next/cache/config.json +0 -7
- package/.next/cache/eslint/.cache_1gneedd +0 -1
- package/.next/cache/next-server.js.nft.json +0 -1
- 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/export-marker.json +0 -1
- package/.next/images-manifest.json +0 -1
- package/.next/next-server.js.nft.json +0 -1
- package/.next/package.json +0 -1
- package/.next/prerender-manifest.json +0 -1
- package/.next/react-loadable-manifest.json +0 -47
- package/.next/required-server-files.json +0 -1
- package/.next/routes-manifest.json +0 -1
- package/.next/server/chunks/117.js +0 -430
- package/.next/server/chunks/177.js +0 -125
- package/.next/server/chunks/183.js +0 -121
- 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 -200
- package/.next/server/chunks/386.js +0 -200
- package/.next/server/chunks/390.js +0 -550
- package/.next/server/chunks/398.js +0 -610
- package/.next/server/chunks/52.js +0 -4007
- package/.next/server/chunks/53.js +0 -61
- package/.next/server/chunks/574.js +0 -145
- package/.next/server/chunks/576.js +0 -121
- package/.next/server/chunks/585.js +0 -640
- package/.next/server/chunks/676.js +0 -32
- package/.next/server/chunks/693.js +0 -58
- package/.next/server/chunks/732.js +0 -1880
- package/.next/server/chunks/74.js +0 -4066
- package/.next/server/chunks/779.js +0 -58
- package/.next/server/chunks/817.js +0 -4007
- package/.next/server/chunks/825.js +0 -4074
- package/.next/server/chunks/854.js +0 -72
- package/.next/server/chunks/859.js +0 -959
- package/.next/server/chunks/863.js +0 -111
- package/.next/server/chunks/979.js +0 -1303
- package/.next/server/chunks/98.js +0 -163
- package/.next/server/chunks/988.js +0 -211
- package/.next/server/chunks/font-manifest.json +0 -1
- package/.next/server/font-manifest.json +0 -1
- package/.next/server/middleware-build-manifest.js +0 -1
- package/.next/server/middleware-manifest.json +0 -6
- package/.next/server/middleware-react-loadable-manifest.js +0 -1
- package/.next/server/pages/404.js +0 -391
- package/.next/server/pages/404.js.nft.json +0 -1
- package/.next/server/pages/500.js +0 -395
- package/.next/server/pages/500.js.nft.json +0 -1
- package/.next/server/pages/[...slug].js +0 -1084
- package/.next/server/pages/[...slug].js.nft.json +0 -1
- package/.next/server/pages/[slug]/p.js +0 -2271
- package/.next/server/pages/[slug]/p.js.nft.json +0 -1
- package/.next/server/pages/_app.js +0 -287
- package/.next/server/pages/_app.js.nft.json +0 -1
- package/.next/server/pages/_document.js +0 -365
- package/.next/server/pages/_document.js.nft.json +0 -1
- package/.next/server/pages/_error.js +0 -164
- package/.next/server/pages/_error.js.nft.json +0 -1
- package/.next/server/pages/account.js +0 -370
- package/.next/server/pages/account.js.nft.json +0 -1
- package/.next/server/pages/api/graphql.js +0 -464
- package/.next/server/pages/api/graphql.js.nft.json +0 -1
- package/.next/server/pages/api/health/live.js +0 -31
- package/.next/server/pages/api/health/live.js.nft.json +0 -1
- package/.next/server/pages/api/health/ready.js +0 -31
- package/.next/server/pages/api/health/ready.js.nft.json +0 -1
- package/.next/server/pages/api/preview.js +0 -137
- package/.next/server/pages/api/preview.js.nft.json +0 -1
- package/.next/server/pages/checkout.js +0 -370
- package/.next/server/pages/checkout.js.nft.json +0 -1
- package/.next/server/pages/en-US/404.html +0 -81
- package/.next/server/pages/en-US/404.json +0 -1
- package/.next/server/pages/en-US/500.html +0 -81
- package/.next/server/pages/en-US/500.json +0 -1
- package/.next/server/pages/en-US/account.html +0 -81
- package/.next/server/pages/en-US/account.json +0 -1
- package/.next/server/pages/en-US/checkout.html +0 -81
- package/.next/server/pages/en-US/checkout.json +0 -1
- package/.next/server/pages/en-US/login.html +0 -81
- package/.next/server/pages/en-US/login.json +0 -1
- package/.next/server/pages/en-US/s.html +0 -81
- package/.next/server/pages/en-US/s.json +0 -1
- package/.next/server/pages/en-US.html +0 -90
- package/.next/server/pages/en-US.json +0 -1
- package/.next/server/pages/index.js +0 -439
- package/.next/server/pages/index.js.nft.json +0 -1
- package/.next/server/pages/login.js +0 -382
- package/.next/server/pages/login.js.nft.json +0 -1
- package/.next/server/pages/s.js +0 -554
- package/.next/server/pages/s.js.nft.json +0 -1
- package/.next/server/pages-manifest.json +0 -18
- package/.next/server/webpack-api-runtime.js +0 -229
- package/.next/server/webpack-runtime.js +0 -229
- package/.next/static/JRq4v3MrJM0drwdq94NMb/_buildManifest.js +0 -1
- package/.next/static/JRq4v3MrJM0drwdq94NMb/_ssgManifest.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-a09ccc622ec96daa.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/742-e32d18d91fe6f08b.js +0 -1
- package/.next/static/chunks/783-a67df4e98c1ac27b.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-6763ce07878a1456.js +0 -1
- package/.next/static/chunks/pages/500-0f4374f30595d27c.js +0 -1
- package/.next/static/chunks/pages/[...slug]-111f89162eff5029.js +0 -1
- package/.next/static/chunks/pages/[slug]/p-46e7cb105136dc7a.js +0 -1
- package/.next/static/chunks/pages/_app-fea7ed14d8f4d0c6.js +0 -1
- package/.next/static/chunks/pages/_error-a7a0c1d9bfbb4f38.js +0 -1
- package/.next/static/chunks/pages/account-9eb6fab139286c66.js +0 -1
- package/.next/static/chunks/pages/checkout-7cd7b110c7cf2f10.js +0 -1
- package/.next/static/chunks/pages/index-3d5c756be5ce8fc7.js +0 -1
- package/.next/static/chunks/pages/login-5fd09e6402f47896.js +0 -1
- package/.next/static/chunks/pages/s-8e32a9b170819fa9.js +0 -1
- package/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +0 -1
- package/.next/static/chunks/webpack-4ccaf6613cbd7224.js +0 -1
- package/.next/static/css/29868543c76bc6fd.css +0 -1
- package/.next/static/css/527e334fa69cf40a.css +0 -1
- package/.next/static/css/5d1f64b61ea581f4.css +0 -1
- package/.next/static/css/6a7fdc5a21fbead5.css +0 -1
- package/.next/static/css/723835bce380750d.css +0 -1
- package/.next/static/css/a2eefb25a4608343.css +0 -1
- package/.next/static/css/cb7d1fcea42fab9c.css +0 -1
- package/.next/static/css/d7bbfbd552f407e9.css +0 -1
- package/.next/static/css/df588bb98c0b0ca6.css +0 -1
- package/.next/static/css/dfbdb0f27fd64782.css +0 -1
- package/.next/static/css/e84fc497732ea596.css +0 -1
- package/.next/trace +0 -78
- package/public/~partytown/debug/partytown-atomics.js +0 -556
- package/public/~partytown/debug/partytown-media.js +0 -374
- package/public/~partytown/debug/partytown-sandbox-sw.js +0 -543
- package/public/~partytown/debug/partytown-sw.js +0 -59
- package/public/~partytown/debug/partytown-ww-atomics.js +0 -1789
- package/public/~partytown/debug/partytown-ww-sw.js +0 -1781
- package/public/~partytown/debug/partytown.js +0 -72
- package/public/~partytown/partytown-atomics.js +0 -2
- package/public/~partytown/partytown-media.js +0 -2
- package/public/~partytown/partytown-sw.js +0 -2
- package/public/~partytown/partytown.js +0 -2
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"../../node_modules/next/dist/client/index.js -> ../pages/_app": {
|
|
3
|
-
"id": 2741,
|
|
4
|
-
"files": [
|
|
5
|
-
"static/chunks/741.52f7fb873418346f.js"
|
|
6
|
-
]
|
|
7
|
-
},
|
|
8
|
-
"../../node_modules/next/dist/client/index.js -> ../pages/_error": {
|
|
9
|
-
"id": 9651,
|
|
10
|
-
"files": [
|
|
11
|
-
"static/chunks/651.7142f31ce1e052b3.js"
|
|
12
|
-
]
|
|
13
|
-
},
|
|
14
|
-
"../components/cms/GlobalSections.tsx -> src/components/cart/CartSidebar": {
|
|
15
|
-
"id": 6585,
|
|
16
|
-
"files": [
|
|
17
|
-
"static/css/e84fc497732ea596.css",
|
|
18
|
-
"static/chunks/585.4c5d40fc6a72a611.js"
|
|
19
|
-
]
|
|
20
|
-
},
|
|
21
|
-
"../components/cms/GlobalSections.tsx -> src/components/region/RegionModal": {
|
|
22
|
-
"id": 5988,
|
|
23
|
-
"files": [
|
|
24
|
-
"static/css/cb7d1fcea42fab9c.css",
|
|
25
|
-
"static/chunks/988.afda042dd9ba11d1.js"
|
|
26
|
-
]
|
|
27
|
-
},
|
|
28
|
-
"../components/search/SearchInput/SearchInput.tsx -> src/components/search/SearchDropdown": {
|
|
29
|
-
"id": 1251,
|
|
30
|
-
"files": [
|
|
31
|
-
"static/chunks/251.1c79f06f2a2814b1.js"
|
|
32
|
-
]
|
|
33
|
-
},
|
|
34
|
-
"../components/sections/ProductGallery/Overrides.tsx -> src/components/search/Filter/FilterSlider": {
|
|
35
|
-
"id": 1386,
|
|
36
|
-
"files": [
|
|
37
|
-
"static/css/6a7fdc5a21fbead5.css",
|
|
38
|
-
"static/chunks/386.d01e0db26c523f0f.js"
|
|
39
|
-
]
|
|
40
|
-
},
|
|
41
|
-
"../components/ui/ProductGallery/ProductGallery.tsx -> ./ProductGalleryPage": {
|
|
42
|
-
"id": 2800,
|
|
43
|
-
"files": [
|
|
44
|
-
"static/chunks/800.ee4f8b9622001e8c.js"
|
|
45
|
-
]
|
|
46
|
-
}
|
|
47
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":1,"config":{"env":{},"webpackDevMiddleware":null,"eslint":{"ignoreDuringBuilds":false},"typescript":{"ignoreBuildErrors":false,"tsconfigPath":"tsconfig.json"},"distDir":".next","cleanDistDir":true,"assetPrefix":"","configOrigin":"next.config.js","useFileSystemPublicRoutes":true,"generateEtags":true,"pageExtensions":["tsx","ts","jsx","js"],"target":"server","poweredByHeader":true,"compress":true,"analyticsId":"","images":{"deviceSizes":[360,540,768,1280,1440],"imageSizes":[34,68,154,320],"path":"/_next/image","loader":"default","domains":["storeframework.vtexassets.com"],"disableStaticImages":false,"minimumCacheTTL":60,"formats":["image/webp"],"dangerouslyAllowSVG":false,"contentSecurityPolicy":"script-src 'none'; frame-src 'none'; sandbox;","remotePatterns":[],"unoptimized":false},"devIndicators":{"buildActivity":true,"buildActivityPosition":"bottom-right"},"onDemandEntries":{"maxInactiveAge":15000,"pagesBufferLength":2},"amp":{"canonicalBase":""},"basePath":"","sassOptions":{"additionalData":"@import \"src/customizations/src/styles/custom-mixins.scss\";"},"trailingSlash":false,"i18n":{"locales":["en-US"],"defaultLocale":"en-US"},"productionBrowserSourceMaps":false,"optimizeFonts":true,"excludeDefaultMomentLocales":true,"serverRuntimeConfig":{},"publicRuntimeConfig":{},"reactStrictMode":false,"httpAgentOptions":{"keepAlive":true},"outputFileTracing":true,"staticPageGenerationTimeout":60,"swcMinify":false,"experimental":{"optimisticClientCache":true,"manualClientBasePath":false,"legacyBrowsers":true,"browsersListForSwc":false,"newNextLinkBehavior":false,"cpus":3,"sharedPool":true,"profiling":false,"isrFlushToDisk":true,"workerThreads":false,"pageEnv":false,"optimizeCss":false,"nextScriptWorkers":false,"scrollRestoration":true,"externalDir":false,"disableOptimizedLoading":false,"gzipSize":true,"swcFileReading":true,"craCompat":false,"esmExternals":true,"appDir":false,"isrMemoryCacheSize":52428800,"serverComponents":false,"fullySpecified":false,"outputFileTracingRoot":"","swcTraceProfiling":false,"forceSwcTransforms":false,"largePageDataBytes":128000,"adjustFontFallbacks":false,"trustHostHeader":false},"configFileName":"next.config.js"},"appDir":"/home/runner/work/faststore/faststore/packages/core","files":[".next/routes-manifest.json",".next/server/pages-manifest.json",".next/build-manifest.json",".next/prerender-manifest.json",".next/server/middleware-manifest.json",".next/react-loadable-manifest.json",".next/server/font-manifest.json",".next/BUILD_ID"],"ignore":["node_modules/next/dist/compiled/@ampproject/toolbox-optimizer/**/*"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"pages404":true,"basePath":"","redirects":[{"source":"/:path+/","destination":"/:path+","locale":false,"internal":true,"statusCode":308,"regex":"^(?:/((?:[^/]+?)(?:/(?:[^/]+?))*))/$"}],"headers":[],"dynamicRoutes":[{"page":"/[slug]/p","regex":"^/([^/]+?)/p(?:/)?$","routeKeys":{"slug":"slug"},"namedRegex":"^/(?<slug>[^/]+?)/p(?:/)?$"},{"page":"/[...slug]","regex":"^/(.+?)(?:/)?$","routeKeys":{"slug":"slug"},"namedRegex":"^/(?<slug>.+?)(?:/)?$"}],"staticRoutes":[{"page":"/","regex":"^/(?:/)?$","routeKeys":{},"namedRegex":"^/(?:/)?$"},{"page":"/404","regex":"^/404(?:/)?$","routeKeys":{},"namedRegex":"^/404(?:/)?$"},{"page":"/500","regex":"^/500(?:/)?$","routeKeys":{},"namedRegex":"^/500(?:/)?$"},{"page":"/account","regex":"^/account(?:/)?$","routeKeys":{},"namedRegex":"^/account(?:/)?$"},{"page":"/checkout","regex":"^/checkout(?:/)?$","routeKeys":{},"namedRegex":"^/checkout(?:/)?$"},{"page":"/login","regex":"^/login(?:/)?$","routeKeys":{},"namedRegex":"^/login(?:/)?$"},{"page":"/s","regex":"^/s(?:/)?$","routeKeys":{},"namedRegex":"^/s(?:/)?$"}],"dataRoutes":[{"page":"/","dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/index.json$"},{"page":"/404","dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/404.json$"},{"page":"/500","dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/500.json$"},{"page":"/account","dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/account.json$"},{"page":"/checkout","dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/checkout.json$"},{"page":"/login","dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/login.json$"},{"page":"/s","dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/s.json$"},{"page":"/[slug]/p","routeKeys":{"slug":"slug"},"dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/([^/]+?)/p\\.json$","namedDataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/(?<slug>[^/]+?)/p\\.json$"},{"page":"/[...slug]","routeKeys":{"slug":"slug"},"dataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/(.+?)\\.json$","namedDataRouteRegex":"^/_next/data/JRq4v3MrJM0drwdq94NMb/(?<slug>.+?)\\.json$"}],"i18n":{"locales":["en-US"],"defaultLocale":"en-US"},"rewrites":[]}
|
|
@@ -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__(4272);
|
|
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
|
-
;
|