@faststore/core 2.2.0-alpha.1 → 2.2.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. package/.turbo/turbo-build.log +2 -2
  2. package/.turbo/turbo-test.log +9 -9
  3. package/index.ts +2 -0
  4. package/package.json +2 -2
  5. package/src/components/sections/CrossSellingShelf/CrossSellingShelf.tsx +0 -1
  6. package/.next/BUILD_ID +0 -1
  7. package/.next/build-manifest.json +0 -129
  8. package/.next/cache/.tsbuildinfo +0 -1
  9. package/.next/cache/config.json +0 -7
  10. package/.next/cache/eslint/.cache_1gneedd +0 -1
  11. package/.next/cache/next-server.js.nft.json +0 -1
  12. package/.next/cache/webpack/client-production/0.pack +0 -0
  13. package/.next/cache/webpack/client-production/index.pack +0 -0
  14. package/.next/cache/webpack/server-production/0.pack +0 -0
  15. package/.next/cache/webpack/server-production/index.pack +0 -0
  16. package/.next/export-marker.json +0 -1
  17. package/.next/images-manifest.json +0 -1
  18. package/.next/next-server.js.nft.json +0 -1
  19. package/.next/package.json +0 -1
  20. package/.next/prerender-manifest.json +0 -1
  21. package/.next/react-loadable-manifest.json +0 -44
  22. package/.next/required-server-files.json +0 -1
  23. package/.next/routes-manifest.json +0 -1
  24. package/.next/server/chunks/112.js +0 -2055
  25. package/.next/server/chunks/177.js +0 -120
  26. package/.next/server/chunks/183.js +0 -94
  27. package/.next/server/chunks/184.js +0 -61
  28. package/.next/server/chunks/186.js +0 -113
  29. package/.next/server/chunks/289.js +0 -242
  30. package/.next/server/chunks/312.js +0 -697
  31. package/.next/server/chunks/350.js +0 -200
  32. package/.next/server/chunks/483.js +0 -651
  33. package/.next/server/chunks/52.js +0 -4007
  34. package/.next/server/chunks/53.js +0 -61
  35. package/.next/server/chunks/530.js +0 -626
  36. package/.next/server/chunks/574.js +0 -126
  37. package/.next/server/chunks/576.js +0 -94
  38. package/.next/server/chunks/647.js +0 -433
  39. package/.next/server/chunks/676.js +0 -32
  40. package/.next/server/chunks/693.js +0 -58
  41. package/.next/server/chunks/71.js +0 -1296
  42. package/.next/server/chunks/74.js +0 -4062
  43. package/.next/server/chunks/753.js +0 -554
  44. package/.next/server/chunks/779.js +0 -58
  45. package/.next/server/chunks/817.js +0 -4007
  46. package/.next/server/chunks/825.js +0 -4039
  47. package/.next/server/chunks/854.js +0 -72
  48. package/.next/server/chunks/859.js +0 -959
  49. package/.next/server/chunks/98.js +0 -144
  50. package/.next/server/chunks/988.js +0 -211
  51. package/.next/server/chunks/font-manifest.json +0 -1
  52. package/.next/server/font-manifest.json +0 -1
  53. package/.next/server/middleware-build-manifest.js +0 -1
  54. package/.next/server/middleware-manifest.json +0 -6
  55. package/.next/server/middleware-react-loadable-manifest.js +0 -1
  56. package/.next/server/pages/404.js +0 -386
  57. package/.next/server/pages/404.js.nft.json +0 -1
  58. package/.next/server/pages/500.js +0 -388
  59. package/.next/server/pages/500.js.nft.json +0 -1
  60. package/.next/server/pages/[...slug].js +0 -1127
  61. package/.next/server/pages/[...slug].js.nft.json +0 -1
  62. package/.next/server/pages/[slug]/p.js +0 -2251
  63. package/.next/server/pages/[slug]/p.js.nft.json +0 -1
  64. package/.next/server/pages/_app.js +0 -280
  65. package/.next/server/pages/_app.js.nft.json +0 -1
  66. package/.next/server/pages/_document.js +0 -374
  67. package/.next/server/pages/_document.js.nft.json +0 -1
  68. package/.next/server/pages/_error.js +0 -164
  69. package/.next/server/pages/_error.js.nft.json +0 -1
  70. package/.next/server/pages/account.js +0 -363
  71. package/.next/server/pages/account.js.nft.json +0 -1
  72. package/.next/server/pages/api/graphql.js +0 -450
  73. package/.next/server/pages/api/graphql.js.nft.json +0 -1
  74. package/.next/server/pages/api/health/live.js +0 -31
  75. package/.next/server/pages/api/health/live.js.nft.json +0 -1
  76. package/.next/server/pages/api/health/ready.js +0 -31
  77. package/.next/server/pages/api/health/ready.js.nft.json +0 -1
  78. package/.next/server/pages/api/preview.js +0 -148
  79. package/.next/server/pages/api/preview.js.nft.json +0 -1
  80. package/.next/server/pages/checkout.js +0 -363
  81. package/.next/server/pages/checkout.js.nft.json +0 -1
  82. package/.next/server/pages/en-US/404.html +0 -81
  83. package/.next/server/pages/en-US/404.json +0 -1
  84. package/.next/server/pages/en-US/500.html +0 -81
  85. package/.next/server/pages/en-US/500.json +0 -1
  86. package/.next/server/pages/en-US/account.html +0 -81
  87. package/.next/server/pages/en-US/account.json +0 -1
  88. package/.next/server/pages/en-US/checkout.html +0 -81
  89. package/.next/server/pages/en-US/checkout.json +0 -1
  90. package/.next/server/pages/en-US/login.html +0 -81
  91. package/.next/server/pages/en-US/login.json +0 -1
  92. package/.next/server/pages/en-US/s.html +0 -81
  93. package/.next/server/pages/en-US/s.json +0 -1
  94. package/.next/server/pages/en-US.html +0 -81
  95. package/.next/server/pages/en-US.json +0 -1
  96. package/.next/server/pages/index.js +0 -439
  97. package/.next/server/pages/index.js.nft.json +0 -1
  98. package/.next/server/pages/login.js +0 -368
  99. package/.next/server/pages/login.js.nft.json +0 -1
  100. package/.next/server/pages/s.js +0 -548
  101. package/.next/server/pages/s.js.nft.json +0 -1
  102. package/.next/server/pages-manifest.json +0 -18
  103. package/.next/server/webpack-api-runtime.js +0 -229
  104. package/.next/server/webpack-runtime.js +0 -229
  105. package/.next/static/chunks/148.3bb7e05cc5d1c1c4.js +0 -1
  106. package/.next/static/chunks/238-86838f629f3d0aa4.js +0 -1
  107. package/.next/static/chunks/243-ef9e49ef3df579c0.js +0 -1
  108. package/.next/static/chunks/530.848b014622932b93.js +0 -1
  109. package/.next/static/chunks/548-ab84e9e8b49413ab.js +0 -1
  110. package/.next/static/chunks/574.d13dd0afe15cd635.js +0 -1
  111. package/.next/static/chunks/651.7142f31ce1e052b3.js +0 -1
  112. package/.next/static/chunks/709.daf1eddebf1e7952.js +0 -1
  113. package/.next/static/chunks/738-67a288ca3569cdbb.js +0 -1
  114. package/.next/static/chunks/741.52f7fb873418346f.js +0 -1
  115. package/.next/static/chunks/932-33f45603c7d12a4b.js +0 -1
  116. package/.next/static/chunks/98.1632997dfd4d3a52.js +0 -1
  117. package/.next/static/chunks/988.d10040040cdfebbb.js +0 -1
  118. package/.next/static/chunks/framework-dfd14d7ce6600b03.js +0 -1
  119. package/.next/static/chunks/main-fd466221927468fd.js +0 -1
  120. package/.next/static/chunks/pages/404-af78f7cd1d3c1f60.js +0 -1
  121. package/.next/static/chunks/pages/500-f6346ca5f9dc4fef.js +0 -1
  122. package/.next/static/chunks/pages/[...slug]-362204c7e0b533cf.js +0 -1
  123. package/.next/static/chunks/pages/[slug]/p-885042c4b2b4f8ed.js +0 -1
  124. package/.next/static/chunks/pages/_app-6d0e6ab9a4dd8106.js +0 -1
  125. package/.next/static/chunks/pages/_error-a7a0c1d9bfbb4f38.js +0 -1
  126. package/.next/static/chunks/pages/account-05bd79fb78365e88.js +0 -1
  127. package/.next/static/chunks/pages/checkout-c973786e68f25a39.js +0 -1
  128. package/.next/static/chunks/pages/index-79b05b0071c02fff.js +0 -1
  129. package/.next/static/chunks/pages/login-8deb9243376b6aa1.js +0 -1
  130. package/.next/static/chunks/pages/s-e1bb00f8de6a386e.js +0 -1
  131. package/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +0 -1
  132. package/.next/static/chunks/webpack-88d120cefa1c4c09.js +0 -1
  133. package/.next/static/css/20e4a3a45cdd65f4.css +0 -1
  134. package/.next/static/css/4b7138899cd07c63.css +0 -1
  135. package/.next/static/css/527e334fa69cf40a.css +0 -1
  136. package/.next/static/css/6e1a7434f061d0ef.css +0 -1
  137. package/.next/static/css/9e76fef1c9ca89af.css +0 -1
  138. package/.next/static/css/a2eefb25a4608343.css +0 -1
  139. package/.next/static/css/cb7d1fcea42fab9c.css +0 -1
  140. package/.next/static/css/df588bb98c0b0ca6.css +0 -1
  141. package/.next/static/css/e3b039e8f5daf95f.css +0 -1
  142. package/.next/static/css/f0e2d1b8832e935d.css +0 -1
  143. package/.next/static/wPqgZ8bYrPY473PZzuIX_/_buildManifest.js +0 -1
  144. package/.next/static/wPqgZ8bYrPY473PZzuIX_/_ssgManifest.js +0 -1
  145. package/.next/trace +0 -80
  146. package/public/~partytown/debug/partytown-atomics.js +0 -556
  147. package/public/~partytown/debug/partytown-media.js +0 -374
  148. package/public/~partytown/debug/partytown-sandbox-sw.js +0 -543
  149. package/public/~partytown/debug/partytown-sw.js +0 -59
  150. package/public/~partytown/debug/partytown-ww-atomics.js +0 -1789
  151. package/public/~partytown/debug/partytown-ww-sw.js +0 -1781
  152. package/public/~partytown/debug/partytown.js +0 -72
  153. package/public/~partytown/partytown-atomics.js +0 -2
  154. package/public/~partytown/partytown-media.js +0 -2
  155. package/public/~partytown/partytown-sw.js +0 -2
  156. package/public/~partytown/partytown.js +0 -2
@@ -1,120 +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
- return {
37
- ...state,
38
- toasts: [...state.toasts, action.payload],
39
- };
40
- }
41
- case 'popToast': {
42
- return {
43
- ...state,
44
- toasts: state.toasts.slice(1),
45
- };
46
- }
47
- default:
48
- throw new Error(`Action ${type} not implemented`);
49
- }
50
- };
51
- const initializer = () => ({
52
- cart: false,
53
- modal: false,
54
- navbar: false,
55
- filter: false,
56
- toasts: [],
57
- });
58
- const UIContext = (0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)(undefined);
59
- function UIProvider({ children }) {
60
- const [ui, dispatch] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useReducer)(reducer, undefined, initializer);
61
- const callbacks = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => ({
62
- openFilter: () => dispatch({ type: 'open', payload: 'filter' }),
63
- closeFilter: () => dispatch({ type: 'close', payload: 'filter' }),
64
- openNavbar: () => dispatch({ type: 'open', payload: 'navbar' }),
65
- closeNavbar: () => dispatch({ type: 'close', payload: 'navbar' }),
66
- openCart: () => dispatch({ type: 'open', payload: 'cart' }),
67
- closeCart: () => dispatch({ type: 'close', payload: 'cart' }),
68
- openModal: () => dispatch({ type: 'open', payload: 'modal' }),
69
- closeModal: () => dispatch({ type: 'close', payload: 'modal' }),
70
- pushToast: (toast) => dispatch({ type: 'pushToast', payload: toast }),
71
- popToast: () => dispatch({ type: 'popToast' }),
72
- }), []);
73
- const value = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => ({
74
- ...ui,
75
- ...callbacks,
76
- }), [callbacks, ui]);
77
- return react__WEBPACK_IMPORTED_MODULE_0___default().createElement(UIContext.Provider, { value: value }, children);
78
- }
79
- function useUI() {
80
- const context = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(UIContext);
81
- if (context === undefined) {
82
- throw new Error('Missing UI context on React tree');
83
- }
84
- return context;
85
- }
86
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (UIProvider);
87
- //# sourceMappingURL=UIProvider.js.map
88
-
89
- /***/ }),
90
-
91
- /***/ 4950:
92
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
93
-
94
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
95
- /* harmony export */ "Wg": () => (/* binding */ unwrap),
96
- /* harmony export */ "re": () => (/* binding */ wrap),
97
- /* harmony export */ "vi": () => (/* binding */ ANALYTICS_EVENT_TYPE)
98
- /* harmony export */ });
99
- /* unused harmony export STORE_EVENT_PREFIX */
100
- const STORE_EVENT_PREFIX = 'store:';
101
- const ANALYTICS_EVENT_TYPE = 'AnalyticsEvent';
102
- const wrap = (event) => ({
103
- name: ANALYTICS_EVENT_TYPE,
104
- params: {
105
- ...event,
106
- name: `${STORE_EVENT_PREFIX}${event.name}`,
107
- },
108
- });
109
- const unwrap = (event) => {
110
- return {
111
- ...event.params,
112
- name: event.params.name.slice(STORE_EVENT_PREFIX.length, event.params.name.length),
113
- };
114
- };
115
- //# sourceMappingURL=wrap.js.map
116
-
117
- /***/ })
118
-
119
- };
120
- ;
@@ -1,94 +0,0 @@
1
- exports.id = 183;
2
- exports.ids = [183];
3
- exports.modules = {
4
-
5
- /***/ 7183:
6
- /***/ ((module) => {
7
-
8
- module.exports = {
9
- seo: {
10
- title: 'FastStore Starter',
11
- description: 'Fast Demo Store',
12
- titleTemplate: '%s | FastStore',
13
- author: 'Store Framework'
14
- },
15
- // Theming
16
- theme: 'custom-theme',
17
- // Ecommerce Platform
18
- platform: 'vtex',
19
- // Platform specific configs for API
20
- api: {
21
- storeId: 'storeframework',
22
- workspace: 'master',
23
- environment: 'vtexcommercestable',
24
- hideUnavailableItems: false,
25
- incrementAddress: true
26
- },
27
- // Default session
28
- session: {
29
- currency: {
30
- code: 'USD',
31
- symbol: '$'
32
- },
33
- locale: 'en-US',
34
- channel: '{"salesChannel":"1","regionId":""}',
35
- country: 'USA',
36
- deliveryMode: null,
37
- addressType: null,
38
- postalCode: null,
39
- geoCoordinates: null,
40
- person: null
41
- },
42
- // Default cart
43
- cart: {
44
- id: '',
45
- items: [],
46
- messages: [],
47
- shouldSplitItem: true
48
- },
49
- // Production URLs
50
- storeUrl: 'https://vtexfaststore.com',
51
- secureSubdomain: 'https://secure.vtexfaststore.com',
52
- checkoutUrl: 'https://secure.vtexfaststore.com/checkout',
53
- loginUrl: 'https://secure.vtexfaststore.com/api/io/login',
54
- accountUrl: 'https://secure.vtexfaststore.com/api/io/account',
55
- // Preview redirects
56
- previewRedirects: {
57
- home: '/',
58
- plp: '/office',
59
- search: '/s?q=headphone',
60
- pdp: '/apple-magic-mouse/p'
61
- },
62
- // Lighthouse CI
63
- lighthouse: {
64
- server: process.env.BASE_SITE_URL || 'http://localhost:3000',
65
- pages: {
66
- home: '/',
67
- pdp: '/apple-magic-mouse/p',
68
- collection: '/office'
69
- }
70
- },
71
- // E2E CI
72
- cypress: {
73
- pages: {
74
- home: '/',
75
- pdp: '/apple-magic-mouse/p',
76
- collection: '/office',
77
- collection_2: '/technology',
78
- collection_filtered: '/office/?category-1=office&marca=acer&facets=category-1%2Cmarca',
79
- search: '/s?q=orange'
80
- }
81
- },
82
- analytics: {
83
- // https://developers.google.com/tag-platform/tag-manager/web#standard_web_page_installation,
84
- gtmContainerId: 'GTM-PGHZ95N'
85
- },
86
- experimental: {
87
- enableCypressExtension: false
88
- }
89
- };
90
-
91
- /***/ })
92
-
93
- };
94
- ;
@@ -1,61 +0,0 @@
1
- "use strict";
2
- exports.id = 184;
3
- exports.ids = [184];
4
- exports.modules = {
5
-
6
- /***/ 5184:
7
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
8
-
9
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
10
- /* harmony export */ "m": () => (/* binding */ useViewItemListEvent)
11
- /* harmony export */ });
12
- /* harmony import */ var _faststore_sdk__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1072);
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
- /* harmony import */ var src_sdk_session__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7295);
16
-
17
-
18
-
19
- const useViewItemListEvent = ({
20
- products,
21
- title,
22
- page,
23
- pageSize
24
- }) => {
25
- const {
26
- currency: {
27
- code
28
- }
29
- } = (0,src_sdk_session__WEBPACK_IMPORTED_MODULE_1__/* .useSession */ .kP)();
30
- const sendViewItemListEvent = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(() => {
31
- (0,_faststore_sdk__WEBPACK_IMPORTED_MODULE_2__/* .sendAnalyticsEvent */ ._)({
32
- name: 'view_item_list',
33
- params: {
34
- item_list_name: title,
35
- item_list_id: title,
36
- items: products.map(({
37
- node: product
38
- }, index) => ({
39
- item_id: product.isVariantOf.productGroupID,
40
- item_name: product.isVariantOf.name,
41
- item_brand: product.brand.name,
42
- item_variant: product.sku,
43
- price: product.offers.offers[0].price,
44
- index: page * pageSize + index + 1,
45
- discount: product.offers.offers[0].listPrice - product.offers.offers[0].price,
46
- currency: code,
47
- item_variant_name: product.name,
48
- product_reference_id: product.gtin
49
- }))
50
- }
51
- });
52
- }, [code, products, title, page, pageSize]);
53
- return {
54
- sendViewItemListEvent
55
- };
56
- };
57
-
58
- /***/ })
59
-
60
- };
61
- ;
@@ -1,113 +0,0 @@
1
- exports.id = 186;
2
- exports.ids = [186];
3
- exports.modules = {
4
-
5
- /***/ 6133:
6
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
7
-
8
- "use strict";
9
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
10
- /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
11
- /* harmony export */ });
12
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6689);
13
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
14
-
15
- function EmptyState({ testId = 'fs-empty-state', title, titleIcon, variant = 'default', bkgColor = 'default', children, ...otherProps }) {
16
- return (react__WEBPACK_IMPORTED_MODULE_0___default().createElement("section", { "data-fs-empty-state": true, "data-fs-empty-state-variant": variant, "data-fs-empty-state-bkg-color": bkgColor, "data-fs-content": "empty-state", "data-testid": testId, ...otherProps },
17
- title && (react__WEBPACK_IMPORTED_MODULE_0___default().createElement("header", { "data-fs-empty-state-title": true },
18
- titleIcon && react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, titleIcon),
19
- react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", null, title))),
20
- children));
21
- }
22
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (EmptyState);
23
- //# sourceMappingURL=EmptyState.js.map
24
-
25
- /***/ }),
26
-
27
- /***/ 1186:
28
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
29
-
30
- "use strict";
31
-
32
- // EXPORTS
33
- __webpack_require__.d(__webpack_exports__, {
34
- "Z": () => (/* reexport */ sections_EmptyState_EmptyState)
35
- });
36
-
37
- // EXTERNAL MODULE: ./src/components/sections/Section/index.ts
38
- var Section = __webpack_require__(7067);
39
- // EXTERNAL MODULE: ./src/components/sections/EmptyState/section.module.scss
40
- var section_module = __webpack_require__(6791);
41
- var section_module_default = /*#__PURE__*/__webpack_require__.n(section_module);
42
- // EXTERNAL MODULE: ../components/dist/esm/organisms/EmptyState/EmptyState.js
43
- var EmptyState = __webpack_require__(6133);
44
- // EXTERNAL MODULE: ./src/utils/overrides.ts
45
- var overrides = __webpack_require__(9104);
46
- ;// CONCATENATED MODULE: ./src/customizations/components/overrides/EmptyState.tsx
47
- // This is an example of how it can be used on the starter.
48
- const SECTION = 'EmptyState';
49
- const override = {
50
- section: SECTION
51
- };
52
-
53
- ;// CONCATENATED MODULE: ./src/components/sections/EmptyState/Overrides.tsx
54
-
55
-
56
-
57
- const {
58
- EmptyState: Overrides_EmptyState
59
- } = (0,overrides/* getSectionOverrides */.f)({
60
- EmptyState: EmptyState/* default */.Z
61
- }, override);
62
-
63
- // EXTERNAL MODULE: external "react/jsx-runtime"
64
- var jsx_runtime_ = __webpack_require__(997);
65
- ;// CONCATENATED MODULE: ./src/components/sections/EmptyState/EmptyState.tsx
66
- 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; }
67
-
68
- 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; }
69
-
70
- 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; }
71
-
72
-
73
-
74
-
75
-
76
-
77
- function EmptyState_EmptyState({
78
- title = Overrides_EmptyState.props.title,
79
- titleIcon = Overrides_EmptyState.props.titleIcon,
80
- children
81
- }) {
82
- return /*#__PURE__*/jsx_runtime_.jsx(Section/* default */.Z, {
83
- className: `${(section_module_default()).section} section-empty-state`,
84
- children: /*#__PURE__*/jsx_runtime_.jsx(Overrides_EmptyState.Component, _objectSpread(_objectSpread({
85
- bkgColor: "light"
86
- }, Overrides_EmptyState.props), {}, {
87
- title: title,
88
- titleIcon: titleIcon,
89
- children: children
90
- }))
91
- });
92
- }
93
-
94
- /* harmony default export */ const sections_EmptyState_EmptyState = (EmptyState_EmptyState);
95
- ;// CONCATENATED MODULE: ./src/components/sections/EmptyState/index.ts
96
-
97
-
98
- /***/ }),
99
-
100
- /***/ 6791:
101
- /***/ ((module) => {
102
-
103
- // Exports
104
- module.exports = {
105
- "section": "section_section__TgowL",
106
- "load": "section_load__F5rqW"
107
- };
108
-
109
-
110
- /***/ })
111
-
112
- };
113
- ;
@@ -1,242 +0,0 @@
1
- "use strict";
2
- exports.id = 289;
3
- exports.ids = [289];
4
- exports.modules = {
5
-
6
- /***/ 7266:
7
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
8
-
9
-
10
- // EXPORTS
11
- __webpack_require__.d(__webpack_exports__, {
12
- "Z": () => (/* reexport */ product_ProductGrid_ProductGrid)
13
- });
14
-
15
- // EXTERNAL MODULE: external "react"
16
- var external_react_ = __webpack_require__(6689);
17
- var external_react_default = /*#__PURE__*/__webpack_require__.n(external_react_);
18
- ;// CONCATENATED MODULE: ../components/dist/esm/organisms/ProductGrid/ProductGrid.js
19
-
20
- const ProductGrid = (0,external_react_.forwardRef)(function ProductGridItem({ testId = 'fs-product-grid', children, ...otherProps }, ref) {
21
- return (external_react_default().createElement("ul", { ref: ref, "data-fs-product-grid": true, ...otherProps }, children));
22
- });
23
- /* harmony default export */ const ProductGrid_ProductGrid = (ProductGrid);
24
- //# sourceMappingURL=ProductGrid.js.map
25
- ;// CONCATENATED MODULE: ../components/dist/esm/organisms/ProductGrid/ProductGridItem.js
26
-
27
- const ProductGridItem = (0,external_react_.forwardRef)(function ProductGridItem({ testId = 'fs-product-grid-item', children, ...otherProps }, ref) {
28
- return (external_react_default().createElement("li", { ref: ref, "data-fs-product-grid-item": true, ...otherProps }, children));
29
- });
30
- /* harmony default export */ const ProductGrid_ProductGridItem = (ProductGridItem);
31
- //# sourceMappingURL=ProductGridItem.js.map
32
- // EXTERNAL MODULE: ./src/components/skeletons/ProductGridSkeleton/index.ts + 1 modules
33
- var ProductGridSkeleton = __webpack_require__(9913);
34
- // EXTERNAL MODULE: ./src/components/sections/ProductGallery/Overrides.tsx + 2 modules
35
- var Overrides = __webpack_require__(217);
36
- // EXTERNAL MODULE: external "react/jsx-runtime"
37
- var jsx_runtime_ = __webpack_require__(997);
38
- ;// CONCATENATED MODULE: ./src/components/product/ProductGrid/ProductGrid.tsx
39
- 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; }
40
-
41
- 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; }
42
-
43
- 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; }
44
-
45
-
46
-
47
-
48
-
49
-
50
-
51
- function ProductGrid_ProductGrid_ProductGrid({
52
- products,
53
- page,
54
- pageSize,
55
- productCard: {
56
- showDiscountBadge = Overrides/* __experimentalProductCard.props.showDiscountBadge */.zM.props.showDiscountBadge,
57
- bordered = Overrides/* __experimentalProductCard.props.bordered */.zM.props.bordered
58
- } = {}
59
- }) {
60
- const aspectRatio = 1;
61
- return /*#__PURE__*/jsx_runtime_.jsx(ProductGridSkeleton/* default */.Z, {
62
- aspectRatio: aspectRatio,
63
- loading: products.length === 0,
64
- children: /*#__PURE__*/jsx_runtime_.jsx(ProductGrid_ProductGrid, {
65
- children: products.map(({
66
- node: product
67
- }, idx) => /*#__PURE__*/jsx_runtime_.jsx(ProductGrid_ProductGridItem, {
68
- children: /*#__PURE__*/jsx_runtime_.jsx(Overrides/* __experimentalProductCard.Component */.zM.Component, _objectSpread(_objectSpread({
69
- aspectRatio: aspectRatio,
70
- imgProps: {
71
- width: 150,
72
- height: 150,
73
- sizes: '30vw'
74
- }
75
- }, Overrides/* __experimentalProductCard.props */.zM.props), {}, {
76
- bordered: showDiscountBadge,
77
- showDiscountBadge: bordered,
78
- product: product,
79
- index: pageSize * page + idx + 1
80
- }))
81
- }, `${product.id}`))
82
- })
83
- });
84
- }
85
-
86
- /* harmony default export */ const product_ProductGrid_ProductGrid = (/*#__PURE__*/(0,external_react_.memo)(ProductGrid_ProductGrid_ProductGrid));
87
- ;// CONCATENATED MODULE: ./src/components/product/ProductGrid/index.ts
88
-
89
-
90
- /***/ }),
91
-
92
- /***/ 5289:
93
- /***/ ((module, __webpack_exports__, __webpack_require__) => {
94
-
95
- __webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
96
- __webpack_require__.r(__webpack_exports__);
97
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
98
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
99
- /* harmony export */ });
100
- /* harmony import */ var src_components_product_ProductGrid__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7266);
101
- /* harmony import */ var src_sdk_search_Sentinel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1566);
102
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6689);
103
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_2__);
104
- /* harmony import */ var src_sdk_product_usePageProductsQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(8934);
105
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(997);
106
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__);
107
- var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([src_sdk_product_usePageProductsQuery__WEBPACK_IMPORTED_MODULE_3__]);
108
- src_sdk_product_usePageProductsQuery__WEBPACK_IMPORTED_MODULE_3__ = (__webpack_async_dependencies__.then ? (await __webpack_async_dependencies__)() : __webpack_async_dependencies__)[0];
109
-
110
-
111
-
112
-
113
-
114
-
115
-
116
-
117
- function ProductGalleryPage({
118
- page,
119
- title,
120
- productCard,
121
- itemsPerPage
122
- }) {
123
- const {
124
- data
125
- } = (0,src_sdk_product_usePageProductsQuery__WEBPACK_IMPORTED_MODULE_3__/* .useGalleryPage */ .__)(page);
126
- const products = data?.search?.products?.edges ?? [];
127
- return /*#__PURE__*/(0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__.jsxs)(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__.Fragment, {
128
- children: [/*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__.jsx(src_sdk_search_Sentinel__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, {
129
- products: products,
130
- page: page,
131
- pageSize: itemsPerPage,
132
- title: title
133
- }), /*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__.jsx(src_components_product_ProductGrid__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z, {
134
- products: products,
135
- page: page,
136
- pageSize: itemsPerPage,
137
- productCard: productCard
138
- })]
139
- });
140
- }
141
-
142
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (/*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_2__.memo)(ProductGalleryPage));
143
- __webpack_async_result__();
144
- } catch(e) { __webpack_async_result__(e); } });
145
-
146
- /***/ }),
147
-
148
- /***/ 1566:
149
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
150
-
151
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
152
- /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
153
- /* harmony export */ });
154
- /* harmony import */ var _faststore_sdk__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(3221);
155
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6689);
156
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
157
- /* harmony import */ var react_intersection_observer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(9785);
158
- /* harmony import */ var react_intersection_observer__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_intersection_observer__WEBPACK_IMPORTED_MODULE_1__);
159
- /* harmony import */ var next_router__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1853);
160
- /* harmony import */ var next_router__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(next_router__WEBPACK_IMPORTED_MODULE_2__);
161
- /* harmony import */ var _analytics_hooks_useViewItemListEvent__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(5184);
162
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(997);
163
- /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__);
164
-
165
-
166
-
167
-
168
-
169
-
170
-
171
- // Adds/Replaces ?page= to the querystring of the page
172
- const replacePagination = (page, router) => {
173
- const url = new URL(window.location.href); // In case the page argument already matches the target page
174
-
175
- if (url.searchParams.get('page') === page) {
176
- return;
177
- } // Set ?page= parameter and replace route
178
-
179
-
180
- url.searchParams.set('page', page);
181
- router.replace(url, undefined, {
182
- shallow: true,
183
- scroll: false
184
- });
185
- };
186
- /**
187
- * Use this component to add a boundary between pages so we can
188
- * change the current page being viewed on infinite pagination.
189
- *
190
- * For more info: https://developers.google.com/search/blog/2014/02/infinite-scroll-search-friendly
191
- *
192
- * Also, this component's name is kind of curious. Wikipedia calls is Page Break(https://en.wikipedia.org/wiki/Page_break)
193
- * however all codes I've seen online use Sentinel
194
- */
195
-
196
-
197
- function Sentinel({
198
- page,
199
- pageSize,
200
- products,
201
- title
202
- }) {
203
- const viewedRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(false);
204
- const {
205
- ref,
206
- inView
207
- } = (0,react_intersection_observer__WEBPACK_IMPORTED_MODULE_1__.useInView)();
208
- const {
209
- pages
210
- } = (0,_faststore_sdk__WEBPACK_IMPORTED_MODULE_5__/* .useSearch */ .R)();
211
- const router = (0,next_router__WEBPACK_IMPORTED_MODULE_2__.useRouter)();
212
- const {
213
- sendViewItemListEvent
214
- } = (0,_analytics_hooks_useViewItemListEvent__WEBPACK_IMPORTED_MODULE_3__/* .useViewItemListEvent */ .m)({
215
- products,
216
- title,
217
- page,
218
- pageSize
219
- });
220
- (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {
221
- // Only replace pagination state when infinite scroll
222
- // state has more than one page being rendered to the screen
223
- if (inView && pages.length > 1) {
224
- replacePagination(page.toString(), router);
225
- }
226
-
227
- if (inView && !viewedRef.current && products.length) {
228
- sendViewItemListEvent();
229
- viewedRef.current = true;
230
- }
231
- }, [pages.length, inView, page, router, sendViewItemListEvent, products.length]);
232
- return /*#__PURE__*/react_jsx_runtime__WEBPACK_IMPORTED_MODULE_4__.jsx("div", {
233
- ref: ref
234
- });
235
- }
236
-
237
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Sentinel);
238
-
239
- /***/ })
240
-
241
- };
242
- ;