@doswiftly/cli 0.1.18 → 0.1.19

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 (210) hide show
  1. package/README.md +23 -323
  2. package/dist/commands/check.js +1 -1
  3. package/dist/commands/check.js.map +1 -1
  4. package/dist/commands/deploy.d.ts.map +1 -1
  5. package/dist/commands/deploy.js +39 -20
  6. package/dist/commands/deploy.js.map +1 -1
  7. package/dist/commands/doctor.js +3 -3
  8. package/dist/commands/doctor.js.map +1 -1
  9. package/dist/commands/init.js +4 -4
  10. package/dist/commands/sdk.js +5 -5
  11. package/dist/commands/sdk.js.map +1 -1
  12. package/dist/commands/template.js +4 -4
  13. package/dist/commands/template.js.map +1 -1
  14. package/dist/commands/types.js +5 -5
  15. package/dist/commands/types.js.map +1 -1
  16. package/dist/commands/verify.js +2 -2
  17. package/dist/commands/verify.js.map +1 -1
  18. package/dist/lib/package-manager.d.ts +1 -1
  19. package/dist/lib/package-manager.js +1 -1
  20. package/package.json +1 -1
  21. package/templates/storefront-nextjs/README.md +16 -12
  22. package/templates/storefront-nextjs/app/account/orders/page.tsx +2 -2
  23. package/templates/storefront-nextjs/app/account/page.tsx +2 -2
  24. package/templates/storefront-nextjs/app/auth/login/page.tsx +1 -1
  25. package/templates/storefront-nextjs/app/auth/register/page.tsx +1 -1
  26. package/templates/storefront-nextjs/app/cart/page.tsx +1 -1
  27. package/templates/storefront-nextjs/app/categories/[slug]/page.tsx +2 -2
  28. package/templates/storefront-nextjs/app/categories/page.tsx +1 -1
  29. package/templates/storefront-nextjs/app/collections/[slug]/page.tsx +1 -1
  30. package/templates/storefront-nextjs/app/collections/page.tsx +1 -1
  31. package/templates/storefront-nextjs/app/page.tsx +1 -1
  32. package/templates/storefront-nextjs/app/products/[slug]/page.tsx +1 -1
  33. package/templates/storefront-nextjs/app/products/page.tsx +2 -2
  34. package/templates/storefront-nextjs/app/search/page.tsx +1 -1
  35. package/templates/storefront-nextjs/components/auth/auth-guard.tsx +1 -1
  36. package/templates/storefront-nextjs/components/commerce/add-to-cart-button.tsx +1 -1
  37. package/templates/storefront-nextjs/components/commerce/cart-icon.tsx +1 -1
  38. package/templates/storefront-nextjs/components/commerce/currency-selector.tsx +2 -2
  39. package/templates/storefront-nextjs/components/commerce/product-filters.tsx +1 -1
  40. package/templates/storefront-nextjs/components/commerce/product-price.tsx +1 -1
  41. package/templates/storefront-nextjs/components/commerce/search-input.tsx +1 -1
  42. package/templates/storefront-nextjs/components/commerce/sort-select.tsx +1 -1
  43. package/templates/storefront-nextjs/components/providers.tsx +1 -1
  44. package/templates/storefront-nextjs/lib/currency.tsx +3 -3
  45. package/templates/storefront-nextjs/lib/format.ts +1 -1
  46. package/templates/storefront-nextjs/lib/graphql-queries.ts +3 -3
  47. package/templates/storefront-nextjs/package.dev.json +1 -1
  48. package/templates/storefront-nextjs/package.json +1 -1
  49. package/templates/storefront-nextjs/package.json.template +1 -1
  50. package/templates/storefront-nextjs-shadcn/.github/workflows/deploy.yml +47 -0
  51. package/templates/storefront-nextjs-shadcn/.github/workflows/preview.yml +47 -0
  52. package/templates/storefront-nextjs-shadcn/CLAUDE.md +148 -35
  53. package/templates/storefront-nextjs-shadcn/README.md +29 -162
  54. package/templates/storefront-nextjs-shadcn/app/account/addresses/page.tsx +98 -91
  55. package/templates/storefront-nextjs-shadcn/app/account/error.tsx +43 -0
  56. package/templates/storefront-nextjs-shadcn/app/account/loading.tsx +19 -0
  57. package/templates/storefront-nextjs-shadcn/app/account/loyalty/page.tsx +53 -162
  58. package/templates/storefront-nextjs-shadcn/app/account/orders/[id]/loading.tsx +60 -0
  59. package/templates/storefront-nextjs-shadcn/app/account/orders/[id]/page.tsx +36 -47
  60. package/templates/storefront-nextjs-shadcn/app/account/orders/page.tsx +46 -29
  61. package/templates/storefront-nextjs-shadcn/app/account/page.tsx +8 -5
  62. package/templates/storefront-nextjs-shadcn/app/account/settings/page.tsx +108 -71
  63. package/templates/storefront-nextjs-shadcn/app/api/auth/clear-token/route.ts +2 -86
  64. package/templates/storefront-nextjs-shadcn/app/api/auth/set-token/route.ts +2 -124
  65. package/templates/storefront-nextjs-shadcn/app/auth/forgot-password/page.tsx +10 -5
  66. package/templates/storefront-nextjs-shadcn/app/blog/[slug]/loading.tsx +17 -0
  67. package/templates/storefront-nextjs-shadcn/app/blog/[slug]/page.tsx +43 -2
  68. package/templates/storefront-nextjs-shadcn/app/blog/loading.tsx +19 -0
  69. package/templates/storefront-nextjs-shadcn/app/brands/page.tsx +2 -1
  70. package/templates/storefront-nextjs-shadcn/app/cart/loading.tsx +26 -0
  71. package/templates/storefront-nextjs-shadcn/app/cart/page.tsx +6 -3
  72. package/templates/storefront-nextjs-shadcn/app/categories/[slug]/category-products-client.tsx +56 -0
  73. package/templates/storefront-nextjs-shadcn/app/categories/[slug]/loading.tsx +32 -0
  74. package/templates/storefront-nextjs-shadcn/app/categories/[slug]/page.tsx +76 -59
  75. package/templates/storefront-nextjs-shadcn/app/categories/page.tsx +8 -4
  76. package/templates/storefront-nextjs-shadcn/app/checkout/error.tsx +43 -0
  77. package/templates/storefront-nextjs-shadcn/app/checkout/loading.tsx +31 -0
  78. package/templates/storefront-nextjs-shadcn/app/checkout/page.tsx +116 -79
  79. package/templates/storefront-nextjs-shadcn/app/collections/[handle]/loading.tsx +19 -0
  80. package/templates/storefront-nextjs-shadcn/app/collections/[handle]/page.tsx +1 -1
  81. package/templates/storefront-nextjs-shadcn/app/collections/loading.tsx +18 -0
  82. package/templates/storefront-nextjs-shadcn/app/collections/page.tsx +7 -4
  83. package/templates/storefront-nextjs-shadcn/app/global-error.tsx +117 -0
  84. package/templates/storefront-nextjs-shadcn/app/globals.css +8 -0
  85. package/templates/storefront-nextjs-shadcn/app/layout.tsx +46 -11
  86. package/templates/storefront-nextjs-shadcn/app/products/[slug]/error.tsx +43 -0
  87. package/templates/storefront-nextjs-shadcn/app/products/[slug]/loading.tsx +29 -0
  88. package/templates/storefront-nextjs-shadcn/app/products/[slug]/page.tsx +6 -6
  89. package/templates/storefront-nextjs-shadcn/app/products/[slug]/product-client.tsx +15 -61
  90. package/templates/storefront-nextjs-shadcn/app/products/loading.tsx +32 -0
  91. package/templates/storefront-nextjs-shadcn/app/products/products-client.tsx +405 -151
  92. package/templates/storefront-nextjs-shadcn/app/search/loading.tsx +18 -0
  93. package/templates/storefront-nextjs-shadcn/app/wishlist/page.tsx +8 -5
  94. package/templates/storefront-nextjs-shadcn/codegen.ts +48 -31
  95. package/templates/storefront-nextjs-shadcn/components/account/customer-info.fragment.graphql +36 -0
  96. package/templates/storefront-nextjs-shadcn/components/account/order-details.tsx +3 -1
  97. package/templates/storefront-nextjs-shadcn/components/account/order-history.tsx +26 -24
  98. package/templates/storefront-nextjs-shadcn/components/account/order-summary.fragment.graphql +36 -0
  99. package/templates/storefront-nextjs-shadcn/components/auth/account-menu.tsx +9 -9
  100. package/templates/storefront-nextjs-shadcn/components/auth/login-form.tsx +11 -37
  101. package/templates/storefront-nextjs-shadcn/components/auth/register-form.tsx +37 -23
  102. package/templates/storefront-nextjs-shadcn/components/cart/cart-drawer.tsx +4 -3
  103. package/templates/storefront-nextjs-shadcn/components/cart/cart-icon.tsx +8 -5
  104. package/templates/storefront-nextjs-shadcn/components/cart/cart-item.tsx +1 -1
  105. package/templates/storefront-nextjs-shadcn/components/cart/cart-line.fragment.graphql +53 -0
  106. package/templates/storefront-nextjs-shadcn/components/cart/cart-summary.tsx +1 -1
  107. package/templates/storefront-nextjs-shadcn/components/cart/shipping-estimator.tsx +22 -7
  108. package/templates/storefront-nextjs-shadcn/components/commerce/currency-selector.tsx +2 -2
  109. package/templates/storefront-nextjs-shadcn/components/commerce/product-actions.tsx +1 -1
  110. package/templates/storefront-nextjs-shadcn/components/commerce/search-input.tsx +2 -2
  111. package/templates/storefront-nextjs-shadcn/components/common/price-display.tsx +35 -11
  112. package/templates/storefront-nextjs-shadcn/components/discount/discount-breakdown.tsx +1 -1
  113. package/templates/storefront-nextjs-shadcn/components/discount/discount-code-input.tsx +3 -3
  114. package/templates/storefront-nextjs-shadcn/components/filters/range-slider-filter.tsx +5 -5
  115. package/templates/storefront-nextjs-shadcn/components/gift-card/gift-card-input.tsx +2 -2
  116. package/templates/storefront-nextjs-shadcn/components/home/category-grid.tsx +2 -1
  117. package/templates/storefront-nextjs-shadcn/components/home/collection-card.fragment.graphql +21 -0
  118. package/templates/storefront-nextjs-shadcn/components/home/featured-collections.tsx +2 -12
  119. package/templates/storefront-nextjs-shadcn/components/home/index.ts +0 -1
  120. package/templates/storefront-nextjs-shadcn/components/hydrated.tsx +24 -0
  121. package/templates/storefront-nextjs-shadcn/components/layout/breadcrumbs.tsx +4 -4
  122. package/templates/storefront-nextjs-shadcn/components/layout/category-node.fragment.graphql +22 -0
  123. package/templates/storefront-nextjs-shadcn/components/layout/currency-selector.tsx +2 -2
  124. package/templates/storefront-nextjs-shadcn/components/layout/header.tsx +33 -23
  125. package/templates/storefront-nextjs-shadcn/components/loyalty/points-balance.tsx +2 -11
  126. package/templates/storefront-nextjs-shadcn/components/loyalty/points-history.tsx +8 -25
  127. package/templates/storefront-nextjs-shadcn/components/loyalty/referral-section.tsx +10 -19
  128. package/templates/storefront-nextjs-shadcn/components/loyalty/rewards-catalog.tsx +17 -41
  129. package/templates/storefront-nextjs-shadcn/components/loyalty/tier-progress.tsx +2 -29
  130. package/templates/storefront-nextjs-shadcn/components/order/index.ts +6 -1
  131. package/templates/storefront-nextjs-shadcn/components/product/b2b-price-display.tsx +3 -1
  132. package/templates/storefront-nextjs-shadcn/components/product/filter-active-pills.tsx +69 -0
  133. package/templates/storefront-nextjs-shadcn/components/product/filter-mobile-sheet.tsx +84 -0
  134. package/templates/storefront-nextjs-shadcn/components/product/filter-price-range.tsx +138 -0
  135. package/templates/storefront-nextjs-shadcn/components/product/index.ts +9 -2
  136. package/templates/storefront-nextjs-shadcn/components/product/product-card.fragment.graphql +49 -0
  137. package/templates/storefront-nextjs-shadcn/components/product/product-card.tsx +3 -31
  138. package/templates/storefront-nextjs-shadcn/components/product/product-detail.fragment.graphql +52 -0
  139. package/templates/storefront-nextjs-shadcn/components/product/product-filters.tsx +176 -123
  140. package/templates/storefront-nextjs-shadcn/components/product/product-grid.tsx +3 -5
  141. package/templates/storefront-nextjs-shadcn/components/product/product-image.tsx +2 -2
  142. package/templates/storefront-nextjs-shadcn/components/product/product-price.tsx +2 -2
  143. package/templates/storefront-nextjs-shadcn/components/product/product-reviews.tsx +5 -4
  144. package/templates/storefront-nextjs-shadcn/components/product/product-sort.tsx +19 -7
  145. package/templates/storefront-nextjs-shadcn/components/product/product-variant-selector.tsx +8 -23
  146. package/templates/storefront-nextjs-shadcn/components/product/product-variant.fragment.graphql +51 -0
  147. package/templates/storefront-nextjs-shadcn/components/product/review-card.tsx +1 -1
  148. package/templates/storefront-nextjs-shadcn/components/product/review-form.tsx +1 -7
  149. package/templates/storefront-nextjs-shadcn/components/product/savings-display.tsx +17 -2
  150. package/templates/storefront-nextjs-shadcn/components/product/similar-products.tsx +3 -2
  151. package/templates/storefront-nextjs-shadcn/components/providers/index.ts +1 -1
  152. package/templates/storefront-nextjs-shadcn/components/providers/stores-provider.tsx +30 -0
  153. package/templates/storefront-nextjs-shadcn/components/providers/theme-provider.tsx +1 -1
  154. package/templates/storefront-nextjs-shadcn/components/returns/index.ts +2 -2
  155. package/templates/storefront-nextjs-shadcn/components/returns/return-request-form.tsx +3 -2
  156. package/templates/storefront-nextjs-shadcn/components/search/search-results.tsx +3 -2
  157. package/templates/storefront-nextjs-shadcn/components/ui/form.tsx +174 -0
  158. package/templates/storefront-nextjs-shadcn/components/ui/index.ts +30 -2
  159. package/templates/storefront-nextjs-shadcn/components/ui/progress.tsx +40 -0
  160. package/templates/storefront-nextjs-shadcn/components/ui/sheet.tsx +107 -0
  161. package/templates/storefront-nextjs-shadcn/components/ui/slider.tsx +33 -0
  162. package/templates/storefront-nextjs-shadcn/components/ui/textarea.tsx +24 -0
  163. package/templates/storefront-nextjs-shadcn/components/wishlist/wishlist-icon.tsx +3 -1
  164. package/templates/storefront-nextjs-shadcn/generated/graphql.ts +12779 -0
  165. package/templates/storefront-nextjs-shadcn/graphql/custom.example.graphql +159 -0
  166. package/templates/storefront-nextjs-shadcn/hooks/index.ts +2 -0
  167. package/templates/storefront-nextjs-shadcn/hooks/use-auth-sync.ts +42 -0
  168. package/templates/storefront-nextjs-shadcn/hooks/use-auth.ts +17 -295
  169. package/templates/storefront-nextjs-shadcn/hooks/use-cart-actions.ts +51 -19
  170. package/templates/storefront-nextjs-shadcn/hooks/use-cart-sync.ts +13 -9
  171. package/templates/storefront-nextjs-shadcn/lib/auth/routes.ts +4 -17
  172. package/templates/storefront-nextjs-shadcn/lib/graphql/client.ts +22 -99
  173. package/templates/storefront-nextjs-shadcn/lib/graphql/config.ts +32 -0
  174. package/templates/storefront-nextjs-shadcn/lib/graphql/fragments.ts +34 -0
  175. package/templates/storefront-nextjs-shadcn/lib/graphql/hooks.ts +687 -632
  176. package/templates/storefront-nextjs-shadcn/lib/graphql/query-keys.ts +86 -0
  177. package/templates/storefront-nextjs-shadcn/lib/graphql/server.ts +131 -182
  178. package/templates/storefront-nextjs-shadcn/lib/graphql/types.ts +62 -0
  179. package/templates/storefront-nextjs-shadcn/lib/theme/theme-config.ts +0 -17
  180. package/templates/storefront-nextjs-shadcn/next-env.d.ts +6 -0
  181. package/templates/storefront-nextjs-shadcn/package.dev.json +1 -3
  182. package/templates/storefront-nextjs-shadcn/package.json +12 -13
  183. package/templates/storefront-nextjs-shadcn/package.json.template +6 -7
  184. package/templates/storefront-nextjs-shadcn/proxy.ts +3 -4
  185. package/templates/storefront-nextjs-shadcn/stores/cart-store.ts +41 -39
  186. package/templates/storefront-nextjs-shadcn/stores/checkout-store.ts +64 -75
  187. package/templates/storefront-nextjs-shadcn/stores/wishlist-store.ts +178 -177
  188. package/templates/storefront-nextjs-shadcn/tsconfig.json +23 -5
  189. package/templates/storefront-nextjs-shadcn/CART_INTEGRATION.md +0 -282
  190. package/templates/storefront-nextjs-shadcn/GRAPHQL_DOCUMENT_NAMES.md +0 -190
  191. package/templates/storefront-nextjs-shadcn/GRAPHQL_ERROR_HANDLING.md +0 -263
  192. package/templates/storefront-nextjs-shadcn/GRAPHQL_FIXES_SUMMARY.md +0 -135
  193. package/templates/storefront-nextjs-shadcn/GRAPHQL_INTEGRATION_COMPLETE.md +0 -142
  194. package/templates/storefront-nextjs-shadcn/INTEGRATION_CHECKLIST.md +0 -448
  195. package/templates/storefront-nextjs-shadcn/PRODUCT_DETAIL_PAGE_IMPLEMENTATION.md +0 -307
  196. package/templates/storefront-nextjs-shadcn/THEME_CUSTOMIZATION.md +0 -245
  197. package/templates/storefront-nextjs-shadcn/components/providers/currency-provider.tsx +0 -103
  198. package/templates/storefront-nextjs-shadcn/graphql/collections.example.ts +0 -168
  199. package/templates/storefront-nextjs-shadcn/graphql/products.example.ts +0 -160
  200. package/templates/storefront-nextjs-shadcn/lib/auth/cookies.ts +0 -220
  201. package/templates/storefront-nextjs-shadcn/lib/config.ts +0 -46
  202. package/templates/storefront-nextjs-shadcn/lib/currency/IMPLEMENTATION_SUMMARY.md +0 -254
  203. package/templates/storefront-nextjs-shadcn/lib/currency/README.md +0 -464
  204. package/templates/storefront-nextjs-shadcn/lib/currency/cookie-manager.test.ts +0 -328
  205. package/templates/storefront-nextjs-shadcn/lib/currency/cookie-manager.ts +0 -295
  206. package/templates/storefront-nextjs-shadcn/lib/currency/index.ts +0 -27
  207. package/templates/storefront-nextjs-shadcn/lib/format.ts +0 -226
  208. package/templates/storefront-nextjs-shadcn/lib/hooks.ts +0 -30
  209. package/templates/storefront-nextjs-shadcn/stores/auth-store.ts +0 -66
  210. package/templates/storefront-nextjs-shadcn/stores/currency-store.ts +0 -103
@@ -1,15 +1,14 @@
1
1
  import { NextResponse } from "next/server";
2
2
  import type { NextRequest } from "next/server";
3
+ import { AUTH_COOKIE_NAME, matchesRoute } from "@doswiftly/storefront-sdk";
3
4
  import {
4
5
  protectedRoutes,
5
6
  guestOnlyRoutes,
6
- AUTH_COOKIE_NAME,
7
7
  redirects,
8
- matchesRoute,
9
8
  } from "@/lib/auth/routes";
10
9
 
11
10
  /**
12
- * Authentication Proxy Function (Next.js 15+)
11
+ * Authentication Proxy Function (Next.js 16+)
13
12
  *
14
13
  * Security Model (3 layers):
15
14
  * 1. Proxy function (this file) - Fast redirect based on cookie existence (UX layer)
@@ -75,6 +74,6 @@ export const config = {
75
74
  * - public folder files (images, etc.)
76
75
  * - API routes (handled separately)
77
76
  */
78
- "/((?!_next/static|_next/image|favicon.ico|.*\\.(?:svg|png|jpg|jpeg|gif|webp)$).*)",
77
+ "/((?!_next/static|_next/image|favicon.ico|.*\.(?:svg|png|jpg|jpeg|gif|webp)$).*)",
79
78
  ],
80
79
  };
@@ -1,11 +1,11 @@
1
- import { create } from 'zustand';
1
+ import { createStore } from 'zustand/vanilla';
2
2
  import { persist } from 'zustand/middleware';
3
+ import { createStoreContext } from '@doswiftly/storefront-sdk/react';
3
4
 
4
5
  export interface CartState {
5
6
  // State
6
7
  cartId: string | null;
7
8
  isOpen: boolean;
8
- isHydrated: boolean;
9
9
 
10
10
  // Actions
11
11
  setCartId: (cartId: string | null) => void;
@@ -15,42 +15,44 @@ export interface CartState {
15
15
  toggleCart: () => void;
16
16
  }
17
17
 
18
- export const useCartStore = create<CartState>()(
19
- persist(
20
- (set) => ({
21
- cartId: null,
22
- isOpen: false,
23
- isHydrated: false,
24
-
25
- setCartId: (cartId: string | null) => {
26
- set({ cartId });
27
- },
28
-
29
- clearCart: () => {
30
- set({ cartId: null, isOpen: false });
31
- },
32
-
33
- openCart: () => {
34
- set({ isOpen: true });
35
- },
36
-
37
- closeCart: () => {
38
- set({ isOpen: false });
18
+ export function createCartStore() {
19
+ return createStore<CartState>()(
20
+ persist(
21
+ (set) => ({
22
+ cartId: null,
23
+ isOpen: false,
24
+
25
+ setCartId: (cartId: string | null) => {
26
+ set({ cartId });
27
+ },
28
+
29
+ clearCart: () => {
30
+ set({ cartId: null, isOpen: false });
31
+ },
32
+
33
+ openCart: () => {
34
+ set({ isOpen: true });
35
+ },
36
+
37
+ closeCart: () => {
38
+ set({ isOpen: false });
39
+ },
40
+
41
+ toggleCart: () => {
42
+ set((state) => ({ isOpen: !state.isOpen }));
43
+ },
44
+ }),
45
+ {
46
+ name: 'cart-storage',
47
+ // Persist only cartId — server is the source of truth for items
48
+ partialize: (state) => ({ cartId: state.cartId }),
39
49
  },
50
+ ),
51
+ );
52
+ }
40
53
 
41
- toggleCart: () => {
42
- set((state) => ({ isOpen: !state.isOpen }));
43
- },
44
- }),
45
- {
46
- name: 'cart-storage',
47
- // Persist only cartId — server is the source of truth for items
48
- partialize: (state) => ({ cartId: state.cartId }),
49
- onRehydrateStorage: () => (state) => {
50
- if (state) {
51
- state.isHydrated = true;
52
- }
53
- },
54
- }
55
- )
56
- );
54
+ export const {
55
+ Provider: CartProvider,
56
+ useStore: useCartStore,
57
+ useApi: useCartStoreApi,
58
+ } = createStoreContext<CartState>('CartStore');
@@ -1,5 +1,6 @@
1
- import { create } from 'zustand';
1
+ import { createStore } from 'zustand/vanilla';
2
2
  import { persist } from 'zustand/middleware';
3
+ import { createStoreContext } from '@doswiftly/storefront-sdk/react';
3
4
 
4
5
  /**
5
6
  * Address form state
@@ -19,7 +20,6 @@ export interface AddressForm {
19
20
 
20
21
  /**
21
22
  * Checkout state interface
22
- * Requirements: 22.4
23
23
  */
24
24
  export interface CheckoutState {
25
25
  // Checkout ID from backend
@@ -48,9 +48,6 @@ export interface CheckoutState {
48
48
  acceptTerms: boolean;
49
49
  acceptMarketing: boolean;
50
50
 
51
- // Hydration state
52
- isHydrated: boolean;
53
-
54
51
  // Actions
55
52
  setCheckoutId: (id: string | null) => void;
56
53
  setEmail: (email: string) => void;
@@ -94,91 +91,83 @@ const initialState = {
94
91
  appliedDiscountCodes: [],
95
92
  acceptTerms: false,
96
93
  acceptMarketing: false,
97
- isHydrated: false,
98
94
  };
99
95
 
100
- /**
101
- * Checkout Store
102
- *
103
- * Manages checkout flow state with persistence.
104
- * Persists payment method selection in localStorage.
105
- *
106
- * Requirements: 22.4
107
- */
108
- export const useCheckoutStore = create<CheckoutState>()(
109
- persist(
110
- (set) => ({
111
- ...initialState,
96
+ export function createCheckoutStore() {
97
+ return createStore<CheckoutState>()(
98
+ persist(
99
+ (set) => ({
100
+ ...initialState,
112
101
 
113
- setCheckoutId: (id) => set({ checkoutId: id }),
102
+ setCheckoutId: (id) => set({ checkoutId: id }),
114
103
 
115
- setEmail: (email) => set({ email }),
104
+ setEmail: (email) => set({ email }),
116
105
 
117
- setPhone: (phone) => set({ phone }),
106
+ setPhone: (phone) => set({ phone }),
118
107
 
119
- setShippingAddress: (address) =>
120
- set((state) => ({
121
- shippingAddress: { ...state.shippingAddress, ...address },
122
- })),
108
+ setShippingAddress: (address) =>
109
+ set((state) => ({
110
+ shippingAddress: { ...state.shippingAddress, ...address },
111
+ })),
123
112
 
124
- setBillingAddress: (address) =>
125
- set((state) => ({
126
- billingAddress: { ...state.billingAddress, ...address },
127
- })),
113
+ setBillingAddress: (address) =>
114
+ set((state) => ({
115
+ billingAddress: { ...state.billingAddress, ...address },
116
+ })),
128
117
 
129
- setSameAsBilling: (same) => set({ sameAsBilling: same }),
118
+ setSameAsBilling: (same) => set({ sameAsBilling: same }),
130
119
 
131
- setSelectedShippingRateHandle: (handle) =>
132
- set({ selectedShippingRateHandle: handle }),
120
+ setSelectedShippingRateHandle: (handle) =>
121
+ set({ selectedShippingRateHandle: handle }),
133
122
 
134
- setSelectedPaymentMethodId: (id) =>
135
- set({ selectedPaymentMethodId: id }),
123
+ setSelectedPaymentMethodId: (id) =>
124
+ set({ selectedPaymentMethodId: id }),
136
125
 
137
- setDiscountCode: (code) => set({ discountCode: code }),
126
+ setDiscountCode: (code) => set({ discountCode: code }),
138
127
 
139
- addAppliedDiscountCode: (code) =>
140
- set((state) => ({
141
- appliedDiscountCodes: [...state.appliedDiscountCodes, code],
142
- discountCode: '',
143
- })),
128
+ addAppliedDiscountCode: (code) =>
129
+ set((state) => ({
130
+ appliedDiscountCodes: [...state.appliedDiscountCodes, code],
131
+ discountCode: '',
132
+ })),
144
133
 
145
- removeAppliedDiscountCode: (code) =>
146
- set((state) => ({
147
- appliedDiscountCodes: state.appliedDiscountCodes.filter(
148
- (c) => c !== code
149
- ),
150
- })),
134
+ removeAppliedDiscountCode: (code) =>
135
+ set((state) => ({
136
+ appliedDiscountCodes: state.appliedDiscountCodes.filter(
137
+ (c) => c !== code,
138
+ ),
139
+ })),
151
140
 
152
- setAcceptTerms: (accept) => set({ acceptTerms: accept }),
141
+ setAcceptTerms: (accept) => set({ acceptTerms: accept }),
153
142
 
154
- setAcceptMarketing: (accept) => set({ acceptMarketing: accept }),
143
+ setAcceptMarketing: (accept) => set({ acceptMarketing: accept }),
155
144
 
156
- resetCheckout: () =>
157
- set({
158
- ...initialState,
159
- isHydrated: true, // Keep hydrated flag
160
- }),
161
- }),
162
- {
163
- name: 'checkout-storage',
164
- // Persist only essential checkout state
165
- partialize: (state) => ({
166
- checkoutId: state.checkoutId,
167
- email: state.email,
168
- phone: state.phone,
169
- shippingAddress: state.shippingAddress,
170
- billingAddress: state.billingAddress,
171
- sameAsBilling: state.sameAsBilling,
172
- selectedShippingRateHandle: state.selectedShippingRateHandle,
173
- selectedPaymentMethodId: state.selectedPaymentMethodId,
174
- appliedDiscountCodes: state.appliedDiscountCodes,
175
- acceptMarketing: state.acceptMarketing,
145
+ resetCheckout: () =>
146
+ set({
147
+ ...initialState,
148
+ }),
176
149
  }),
177
- onRehydrateStorage: () => (state) => {
178
- if (state) {
179
- state.isHydrated = true;
180
- }
150
+ {
151
+ name: 'checkout-storage',
152
+ partialize: (state) => ({
153
+ checkoutId: state.checkoutId,
154
+ email: state.email,
155
+ phone: state.phone,
156
+ shippingAddress: state.shippingAddress,
157
+ billingAddress: state.billingAddress,
158
+ sameAsBilling: state.sameAsBilling,
159
+ selectedShippingRateHandle: state.selectedShippingRateHandle,
160
+ selectedPaymentMethodId: state.selectedPaymentMethodId,
161
+ appliedDiscountCodes: state.appliedDiscountCodes,
162
+ acceptMarketing: state.acceptMarketing,
163
+ }),
181
164
  },
182
- }
183
- )
184
- );
165
+ ),
166
+ );
167
+ }
168
+
169
+ export const {
170
+ Provider: CheckoutProvider,
171
+ useStore: useCheckoutStore,
172
+ useApi: useCheckoutStoreApi,
173
+ } = createStoreContext<CheckoutState>('CheckoutStore');