@faststore/core 2.0.116-alpha.0 → 2.0.118-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.next/BUILD_ID +1 -0
- package/.next/build-manifest.json +99 -0
- package/.next/cache/.tsbuildinfo +1 -0
- package/.next/cache/config.json +7 -0
- package/.next/cache/eslint/.cache_1gneedd +1 -0
- package/.next/cache/next-server.js.nft.json +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/export-marker.json +1 -0
- package/.next/images-manifest.json +1 -0
- package/.next/next-server.js.nft.json +1 -0
- package/.next/package.json +1 -0
- package/.next/prerender-manifest.json +1 -0
- package/.next/react-loadable-manifest.json +42 -0
- package/.next/required-server-files.json +1 -0
- package/.next/routes-manifest.json +1 -0
- package/.next/server/chunks/120.js +435 -0
- package/.next/server/chunks/123.js +58 -0
- package/.next/server/chunks/1394.js +3801 -0
- package/.next/server/chunks/1597.js +151 -0
- package/.next/server/chunks/1608.js +515 -0
- package/.next/server/chunks/2154.js +206 -0
- package/.next/server/chunks/247.js +61 -0
- package/.next/server/chunks/2502.js +584 -0
- package/.next/server/chunks/2914.js +95 -0
- package/.next/server/chunks/2922.js +7293 -0
- package/.next/server/chunks/3264.js +67 -0
- package/.next/server/chunks/3431.js +7241 -0
- package/.next/server/chunks/350.js +142 -0
- package/.next/server/chunks/3746.js +250 -0
- package/.next/server/chunks/3898.js +240 -0
- package/.next/server/chunks/4312.js +674 -0
- package/.next/server/chunks/4371.js +1424 -0
- package/.next/server/chunks/5098.js +124 -0
- package/.next/server/chunks/5335.js +544 -0
- package/.next/server/chunks/5576.js +79 -0
- package/.next/server/chunks/6280.js +322 -0
- package/.next/server/chunks/6465.js +91 -0
- package/.next/server/chunks/676.js +32 -0
- package/.next/server/chunks/6859.js +959 -0
- package/.next/server/chunks/6881.js +320 -0
- package/.next/server/chunks/6898.js +149 -0
- package/.next/server/chunks/7104.js +235 -0
- package/.next/server/chunks/7181.js +664 -0
- package/.next/server/chunks/7183.js +79 -0
- package/.next/server/chunks/8098.js +246 -0
- package/.next/server/chunks/810.js +432 -0
- package/.next/server/chunks/8287.js +58 -0
- package/.next/server/chunks/9143.js +106 -0
- package/.next/server/chunks/9557.js +119 -0
- package/.next/server/chunks/9854.js +72 -0
- package/.next/server/chunks/font-manifest.json +1 -0
- package/.next/server/font-manifest.json +1 -0
- package/.next/server/middleware-build-manifest.js +1 -0
- package/.next/server/middleware-manifest.json +6 -0
- package/.next/server/middleware-react-loadable-manifest.js +1 -0
- package/.next/server/pages/404.js.nft.json +1 -0
- package/.next/server/pages/500.js.nft.json +1 -0
- package/.next/server/pages/[...slug].js +666 -0
- package/.next/server/pages/[...slug].js.nft.json +1 -0
- package/.next/server/pages/[slug]/p.js +2327 -0
- package/.next/server/pages/[slug]/p.js.nft.json +1 -0
- package/.next/server/pages/_app.js +2454 -0
- package/.next/server/pages/_app.js.nft.json +1 -0
- package/.next/server/pages/_document.js +304 -0
- package/.next/server/pages/_document.js.nft.json +1 -0
- package/.next/server/pages/_error.js +164 -0
- package/.next/server/pages/_error.js.nft.json +1 -0
- package/.next/server/pages/account.js.nft.json +1 -0
- package/.next/server/pages/api/graphql.js +315 -0
- package/.next/server/pages/api/graphql.js.nft.json +1 -0
- package/.next/server/pages/api/preview.js +118 -0
- package/.next/server/pages/api/preview.js.nft.json +1 -0
- package/.next/server/pages/checkout.js.nft.json +1 -0
- package/.next/server/pages/en-US/404.html +81 -0
- package/.next/server/pages/en-US/500.html +81 -0
- package/.next/server/pages/en-US/account.html +81 -0
- package/.next/server/pages/en-US/checkout.html +81 -0
- package/.next/server/pages/en-US/login.html +81 -0
- package/.next/server/pages/en-US/s.html +81 -0
- package/.next/server/pages/en-US.html +81 -0
- package/.next/server/pages/en-US.json +1 -0
- package/.next/server/pages/index.js +475 -0
- package/.next/server/pages/index.js.nft.json +1 -0
- package/.next/server/pages/login.js.nft.json +1 -0
- package/.next/server/pages/s.js.nft.json +1 -0
- package/.next/server/pages-manifest.json +16 -0
- package/.next/server/webpack-api-runtime.js +229 -0
- package/.next/server/webpack-runtime.js +229 -0
- package/.next/static/chunks/143.dd8a556e6957baa1.js +1 -0
- package/.next/static/chunks/170.79b2f8527e327bca.js +1 -0
- package/.next/static/chunks/264-5b07911df63b8601.js +1 -0
- package/.next/static/chunks/351-a4e28d64f48c5269.js +1 -0
- package/.next/static/chunks/54.e6562383f8a1dfe7.js +1 -0
- package/.next/static/chunks/597.fc79494903e8bb84.js +1 -0
- package/.next/static/chunks/608.59e69b83f35d9c44.js +1 -0
- package/.next/static/chunks/651.7142f31ce1e052b3.js +1 -0
- package/.next/static/chunks/741.52f7fb873418346f.js +1 -0
- package/.next/static/chunks/781-e1b538e051ff4c3e.js +1 -0
- package/.next/static/chunks/98.97381d2021f86cd9.js +1 -0
- package/.next/static/chunks/996.98e590872c51f815.js +1 -0
- package/.next/static/chunks/framework-dfd14d7ce6600b03.js +1 -0
- package/.next/static/chunks/main-9746772201fe3ac1.js +1 -0
- package/.next/static/chunks/pages/404-3637ef83b3359df7.js +1 -0
- package/.next/static/chunks/pages/500-910883c20541d9ce.js +1 -0
- package/.next/static/chunks/pages/[...slug]-29d3b81ee0953846.js +1 -0
- package/.next/static/chunks/pages/[slug]/p-9b24055cb30ee7a8.js +1 -0
- package/.next/static/chunks/pages/_app-4aeb21d72aeea9b7.js +1 -0
- package/.next/static/chunks/pages/_error-a7a0c1d9bfbb4f38.js +1 -0
- package/.next/static/chunks/pages/account-b8fc5222ffe89b60.js +1 -0
- package/.next/static/chunks/pages/checkout-f8cb7cb22225ef9d.js +1 -0
- package/.next/static/chunks/pages/index-d48285f48d2a66ea.js +1 -0
- package/.next/static/chunks/pages/login-45cc84352bac2408.js +1 -0
- package/.next/static/chunks/pages/s-ba2868e14fedb65b.js +1 -0
- package/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +1 -0
- package/.next/static/chunks/webpack-f725b61675603493.js +1 -0
- package/.next/static/css/1f987650dd4e39d0.css +1 -0
- package/.next/static/css/3a57acf6e411f24d.css +1 -0
- package/.next/static/css/4abccf9803c3c356.css +1 -0
- package/.next/static/css/502746c995f64cce.css +1 -0
- package/.next/static/css/6507cb48401e73a4.css +1 -0
- package/.next/static/css/6f4d3e91f1d161a8.css +1 -0
- package/.next/static/media/brandless-neutral.76ddf63a.png +0 -0
- package/.next/static/vmkgl19jDr5XASw3dFJg7/_buildManifest.js +1 -0
- package/.next/static/vmkgl19jDr5XASw3dFJg7/_ssgManifest.js +1 -0
- package/.next/trace +64 -0
- package/.turbo/turbo-build.log +8 -8
- package/CHANGELOG.md +10 -0
- package/package.json +5 -5
- package/public/~partytown/debug/partytown-atomics.js +556 -0
- package/public/~partytown/debug/partytown-media.js +374 -0
- package/public/~partytown/debug/partytown-sandbox-sw.js +543 -0
- package/public/~partytown/debug/partytown-sw.js +59 -0
- package/public/~partytown/debug/partytown-ww-atomics.js +1789 -0
- package/public/~partytown/debug/partytown-ww-sw.js +1781 -0
- package/public/~partytown/debug/partytown.js +72 -0
- package/public/~partytown/partytown-atomics.js +2 -0
- package/public/~partytown/partytown-media.js +2 -0
- package/public/~partytown/partytown-sw.js +2 -0
- package/public/~partytown/partytown.js +2 -0
- package/src/Layout.tsx +1 -1
- package/src/components/{common → navigation}/Navbar/Navbar.tsx +35 -26
- package/src/components/navigation/Navbar/index.ts +1 -0
- package/src/components/{common/Navbar/NavLinks.tsx → navigation/NavbarLinks/NavbarLinks.tsx} +21 -19
- package/src/components/navigation/NavbarLinks/index.ts +1 -0
- package/src/components/{common/Navbar → navigation/NavbarSlider}/NavbarSlider.tsx +18 -21
- package/src/components/navigation/NavbarSlider/index.ts +1 -0
- package/src/components/common/Navbar/NavLinks.stories.mdx +0 -122
- package/src/components/common/Navbar/Navbar.stories.mdx +0 -179
- package/src/components/common/Navbar/NavbarSlider.stories.mdx +0 -108
- package/src/components/common/Navbar/index.ts +0 -3
- package/src/components/common/Navbar/navbar-slider.module.scss +0 -53
- package/src/components/common/Navbar/navbar.module.scss +0 -204
- package/src/components/common/Navbar/navlinks.module.scss +0 -96
- package/src/sdk/ui/useScrollDirection.ts +0 -31
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
exports.id = 2154;
|
|
3
|
+
exports.ids = [2154];
|
|
4
|
+
exports.modules = {
|
|
5
|
+
|
|
6
|
+
/***/ 2154:
|
|
7
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
// EXPORTS
|
|
11
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
12
|
+
"E": () => (/* reexport */ Image_Image)
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
// EXTERNAL MODULE: external "react"
|
|
16
|
+
var external_react_ = __webpack_require__(6689);
|
|
17
|
+
// EXTERNAL MODULE: ./node_modules/next/future/image.js
|
|
18
|
+
var future_image = __webpack_require__(1608);
|
|
19
|
+
var image_default = /*#__PURE__*/__webpack_require__.n(future_image);
|
|
20
|
+
// EXTERNAL MODULE: ./faststore.config.js
|
|
21
|
+
var faststore_config = __webpack_require__(7183);
|
|
22
|
+
var faststore_config_default = /*#__PURE__*/__webpack_require__.n(faststore_config);
|
|
23
|
+
;// CONCATENATED MODULE: ./src/components/ui/Image/thumborUrlBuilder.ts
|
|
24
|
+
|
|
25
|
+
const THUMBOR_SERVER = `https://${(faststore_config_default()).api.storeId}.vtexassets.com`;
|
|
26
|
+
|
|
27
|
+
const cropSection = ({
|
|
28
|
+
left,
|
|
29
|
+
top,
|
|
30
|
+
right,
|
|
31
|
+
bottom
|
|
32
|
+
}) => `${left}x${top}:${right}x${bottom}`;
|
|
33
|
+
|
|
34
|
+
function filtersURIComponent(filters) {
|
|
35
|
+
const elements = ['filters'];
|
|
36
|
+
Object.keys(filters).forEach(name => {
|
|
37
|
+
const parameters = filters[name];
|
|
38
|
+
let stringParameters; // If we have several parameters, they were passed as an array
|
|
39
|
+
// and now they need to be comma separated, otherwise there is just one to convert to a string
|
|
40
|
+
|
|
41
|
+
if (Array.isArray(parameters)) {
|
|
42
|
+
stringParameters = parameters.join(',');
|
|
43
|
+
} // If true, we don't even need to do anything, we just have an empty string and insert ()
|
|
44
|
+
// Ex: {grayscale: true} => grayscale()
|
|
45
|
+
else if (parameters === true) {
|
|
46
|
+
stringParameters = '';
|
|
47
|
+
} else {
|
|
48
|
+
stringParameters = String(parameters);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
elements.push(`${name}(${stringParameters})`);
|
|
52
|
+
});
|
|
53
|
+
return elements.join(':');
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
const urlBuilder = (baseUrl, options) => {
|
|
57
|
+
const preSizeComponents = [THUMBOR_SERVER, 'unsafe'];
|
|
58
|
+
const postSizeComponents = []; // Add the trim parameter after unsafe if appliable
|
|
59
|
+
|
|
60
|
+
options.trim && preSizeComponents.push('trim'); // Add the crop parameter if any
|
|
61
|
+
|
|
62
|
+
options.manualCrop && preSizeComponents.push(cropSection(options.manualCrop)); // Add the fit-in parameter after crop if appliable
|
|
63
|
+
|
|
64
|
+
options.fitIn && preSizeComponents.push('fit-in'); // Adds the horizontal alignement after the size
|
|
65
|
+
|
|
66
|
+
postSizeComponents.push(options.horizontalAlign ?? 'center'); // Adds the vertical alignement after the size
|
|
67
|
+
|
|
68
|
+
postSizeComponents.push(options.verticalAlign ?? 'middle'); // Adds the smart parameter if appliable
|
|
69
|
+
|
|
70
|
+
options.smart && postSizeComponents.push('smart'); // Compile the filters and add them right before the URI
|
|
71
|
+
|
|
72
|
+
const {
|
|
73
|
+
filters
|
|
74
|
+
} = options;
|
|
75
|
+
filters && postSizeComponents.push(filtersURIComponent(filters)); // Finally, adds the real image uri
|
|
76
|
+
|
|
77
|
+
postSizeComponents.push(encodeURIComponent(baseUrl));
|
|
78
|
+
return (width, height) => {
|
|
79
|
+
// Adds the final size parameter
|
|
80
|
+
let finalSize = '';
|
|
81
|
+
|
|
82
|
+
if (options.flipHorizontal) {
|
|
83
|
+
finalSize += '-';
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
finalSize += `${width}x`;
|
|
87
|
+
|
|
88
|
+
if (options.flipVertical) {
|
|
89
|
+
finalSize += '-';
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
finalSize += `${height}`;
|
|
93
|
+
return [...preSizeComponents, finalSize, ...postSizeComponents].join('/');
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
;// CONCATENATED MODULE: ./src/components/ui/Image/useImage.ts
|
|
97
|
+
const _excluded = ["src", "width", "height", "options"];
|
|
98
|
+
|
|
99
|
+
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; }
|
|
100
|
+
|
|
101
|
+
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; }
|
|
102
|
+
|
|
103
|
+
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; }
|
|
104
|
+
|
|
105
|
+
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; }
|
|
106
|
+
|
|
107
|
+
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; }
|
|
108
|
+
|
|
109
|
+
|
|
110
|
+
|
|
111
|
+
const FACTORS = [1, 2, 3];
|
|
112
|
+
const LARGE_FACTOR = FACTORS[FACTORS.length - 1];
|
|
113
|
+
const useImage = _ref => {
|
|
114
|
+
let {
|
|
115
|
+
src: baseUrl,
|
|
116
|
+
width,
|
|
117
|
+
height,
|
|
118
|
+
options = {}
|
|
119
|
+
} = _ref,
|
|
120
|
+
rest = _objectWithoutProperties(_ref, _excluded);
|
|
121
|
+
|
|
122
|
+
const {
|
|
123
|
+
srcSet,
|
|
124
|
+
src
|
|
125
|
+
} = (0,external_react_.useMemo)(() => {
|
|
126
|
+
const builder = urlBuilder(baseUrl, options);
|
|
127
|
+
const srcs = FACTORS.map(factor => {
|
|
128
|
+
const rescaledWidth = width * factor;
|
|
129
|
+
return `${builder(rescaledWidth, height * factor)} ${rescaledWidth}w`;
|
|
130
|
+
});
|
|
131
|
+
return {
|
|
132
|
+
src: builder(width * LARGE_FACTOR, height * LARGE_FACTOR),
|
|
133
|
+
srcSet: srcs.join(', ')
|
|
134
|
+
};
|
|
135
|
+
}, [height, options, baseUrl, width]);
|
|
136
|
+
return _objectSpread({
|
|
137
|
+
src,
|
|
138
|
+
srcSet,
|
|
139
|
+
width: `${width}px`,
|
|
140
|
+
height: `${height}px`
|
|
141
|
+
}, rest);
|
|
142
|
+
};
|
|
143
|
+
// EXTERNAL MODULE: external "react/jsx-runtime"
|
|
144
|
+
var jsx_runtime_ = __webpack_require__(997);
|
|
145
|
+
;// CONCATENATED MODULE: ./src/components/ui/Image/Image.tsx
|
|
146
|
+
const Image_excluded = ["src", "width", "height", "quality"];
|
|
147
|
+
|
|
148
|
+
function Image_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
149
|
+
|
|
150
|
+
function Image_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? Image_ownKeys(Object(source), !0).forEach(function (key) { Image_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : Image_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
151
|
+
|
|
152
|
+
function Image_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
153
|
+
|
|
154
|
+
function Image_objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = Image_objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
155
|
+
|
|
156
|
+
function Image_objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
157
|
+
|
|
158
|
+
|
|
159
|
+
|
|
160
|
+
// Next loader function does not handle all props as height and options,
|
|
161
|
+
// so we use the useImage hook to handle the custom thumbor loader (VTEX CDN) along with unoptimized prop
|
|
162
|
+
// https://nextjs.org/docs/api-reference/next/image#loader
|
|
163
|
+
|
|
164
|
+
|
|
165
|
+
|
|
166
|
+
function Image(_ref) {
|
|
167
|
+
let {
|
|
168
|
+
src,
|
|
169
|
+
width,
|
|
170
|
+
height,
|
|
171
|
+
quality
|
|
172
|
+
} = _ref,
|
|
173
|
+
otherProps = Image_objectWithoutProperties(_ref, Image_excluded);
|
|
174
|
+
|
|
175
|
+
const {
|
|
176
|
+
src: thumborSrc,
|
|
177
|
+
alt
|
|
178
|
+
} = useImage(Image_objectSpread({
|
|
179
|
+
src: String(src),
|
|
180
|
+
width: Number(width),
|
|
181
|
+
height: Number(height),
|
|
182
|
+
options: quality ? {
|
|
183
|
+
filters: {
|
|
184
|
+
quality
|
|
185
|
+
}
|
|
186
|
+
} : undefined
|
|
187
|
+
}, otherProps));
|
|
188
|
+
return /*#__PURE__*/jsx_runtime_.jsx((image_default()), Image_objectSpread({
|
|
189
|
+
"data-fs-image": true,
|
|
190
|
+
unoptimized: true,
|
|
191
|
+
src: thumborSrc,
|
|
192
|
+
width: width,
|
|
193
|
+
height: height,
|
|
194
|
+
alt: alt
|
|
195
|
+
}, otherProps));
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
Image.displayName = 'Image';
|
|
199
|
+
/* harmony default export */ const Image_Image = (/*#__PURE__*/(0,external_react_.memo)(Image));
|
|
200
|
+
;// CONCATENATED MODULE: ./src/components/ui/Image/index.ts
|
|
201
|
+
|
|
202
|
+
|
|
203
|
+
/***/ })
|
|
204
|
+
|
|
205
|
+
};
|
|
206
|
+
;
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
exports.id = 247;
|
|
3
|
+
exports.ids = [247];
|
|
4
|
+
exports.modules = {
|
|
5
|
+
|
|
6
|
+
/***/ 7549:
|
|
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
|
+
/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(2691);
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
const Price = (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Price({ value, as: Component = 'span', variant = 'selling', testId = 'fs-price', formatter = (price) => price, SRText, ...otherProps }, ref) {
|
|
18
|
+
const formattedPrice = formatter(value, variant);
|
|
19
|
+
return (react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Component, { ref: ref, "data-fs-price": true, "data-fs-price-variant": variant, "data-testid": testId, ...otherProps },
|
|
20
|
+
SRText && react__WEBPACK_IMPORTED_MODULE_0___default().createElement(___WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, { text: SRText }),
|
|
21
|
+
formattedPrice));
|
|
22
|
+
});
|
|
23
|
+
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Price);
|
|
24
|
+
//# sourceMappingURL=Price.js.map
|
|
25
|
+
|
|
26
|
+
/***/ }),
|
|
27
|
+
|
|
28
|
+
/***/ 5346:
|
|
29
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
30
|
+
|
|
31
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
32
|
+
/* harmony export */ "P": () => (/* binding */ useFormattedPrice)
|
|
33
|
+
/* harmony export */ });
|
|
34
|
+
/* unused harmony export usePriceFormatter */
|
|
35
|
+
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6689);
|
|
36
|
+
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
|
|
37
|
+
/* harmony import */ var _session__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(5971);
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
const usePriceFormatter = ({
|
|
41
|
+
decimals
|
|
42
|
+
} = {}) => {
|
|
43
|
+
const {
|
|
44
|
+
currency,
|
|
45
|
+
locale
|
|
46
|
+
} = (0,_session__WEBPACK_IMPORTED_MODULE_1__/* .useSession */ .kP)();
|
|
47
|
+
return (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(price => Intl.NumberFormat(locale, {
|
|
48
|
+
style: 'currency',
|
|
49
|
+
currency: currency.code,
|
|
50
|
+
minimumFractionDigits: decimals ? 2 : 0
|
|
51
|
+
}).format(price), [currency.code, locale, decimals]);
|
|
52
|
+
};
|
|
53
|
+
const useFormattedPrice = price => {
|
|
54
|
+
const formatter = usePriceFormatter();
|
|
55
|
+
return (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => formatter(price), [formatter, price]);
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
/***/ })
|
|
59
|
+
|
|
60
|
+
};
|
|
61
|
+
;
|