@luxfi/ui 5.3.11 → 5.3.13

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 (181) hide show
  1. package/.env +36 -0
  2. package/commerce/ui/conf.ts +13 -13
  3. package/commerce/ui/context.tsx +123 -123
  4. package/commerce/ui/store.ts +289 -289
  5. package/components/access-code-input.tsx +71 -71
  6. package/components/auth/auth-listener.tsx +29 -29
  7. package/components/auth/auth-token/clear-auth-token.tsx +12 -12
  8. package/components/auth/auth-token/set-auth-token.tsx +16 -16
  9. package/components/auth/common-auth-domains.ts +16 -16
  10. package/components/auth/login-panel.tsx +111 -116
  11. package/components/auth/signup-panel.tsx +113 -119
  12. package/components/back-button.tsx +49 -49
  13. package/components/chat-widget.tsx +85 -85
  14. package/components/commerce/_to_deprecate_checkout-widget/const.ts +13 -13
  15. package/components/commerce/_to_deprecate_checkout-widget/index.tsx_ +188 -188
  16. package/components/commerce/_to_deprecate_checkout-widget/obs-string-set.ts +48 -48
  17. package/components/commerce/_to_deprecate_checkout-widget/use-anim-clx-set.ts +58 -58
  18. package/components/commerce/bag-button.tsx +98 -98
  19. package/components/commerce/buy-button.tsx +34 -34
  20. package/components/commerce/checkout-button.tsx +129 -129
  21. package/components/commerce/checkout-panel/cart-accordian.tsx +66 -66
  22. package/components/commerce/checkout-panel/checkout-panel-props.ts +9 -9
  23. package/components/commerce/checkout-panel/desktop-bag-carousel.tsx +36 -36
  24. package/components/commerce/checkout-panel/desktop-cp.tsx +82 -82
  25. package/components/commerce/checkout-panel/index.tsx +126 -126
  26. package/components/commerce/checkout-panel/mobile-cp.tsx +66 -66
  27. package/components/commerce/checkout-panel/policy-links.tsx +29 -29
  28. package/components/commerce/checkout-panel/steps-indicator.tsx +39 -39
  29. package/components/commerce/checkout-panel/thank-you.tsx +18 -18
  30. package/components/commerce/desktop-bag-popup.tsx +78 -78
  31. package/components/commerce/desktop-nav-menu.tsx +194 -194
  32. package/components/commerce/drawer/index.tsx +88 -88
  33. package/components/commerce/drawer/micro.tsx +145 -145
  34. package/components/commerce/drawer/shell.tsx +85 -85
  35. package/components/commerce/mobile-bag-drawer.tsx +51 -51
  36. package/components/commerce/mobile-login-button.tsx +107 -107
  37. package/components/commerce/mobile-menu-toggle-button.tsx +35 -35
  38. package/components/commerce/mobile-nav-menu-ai.tsx +50 -50
  39. package/components/commerce/mobile-nav-menu-item.tsx +49 -49
  40. package/components/commerce/mobile-nav-menu.tsx +101 -101
  41. package/components/contact-dialog/contact-form.tsx +113 -113
  42. package/components/contact-dialog/disclaimer.tsx +13 -13
  43. package/components/contact-dialog/index.tsx +64 -64
  44. package/components/copyright.tsx +21 -21
  45. package/components/drawer-margin.tsx +28 -28
  46. package/components/footer.tsx +77 -77
  47. package/components/header/desktop.tsx +51 -51
  48. package/components/header/index.tsx +50 -50
  49. package/components/header/mobile.tsx +163 -163
  50. package/components/header/theme-toggle.tsx +26 -26
  51. package/components/icons/24k-gold-card.tsx +43 -43
  52. package/components/icons/ai-chat-act.tsx +47 -47
  53. package/components/icons/ai-chat.tsx +29 -29
  54. package/components/icons/anodized-titanium.tsx +45 -45
  55. package/components/icons/avatar.tsx +11 -11
  56. package/components/icons/bag-icon.tsx +10 -10
  57. package/components/icons/blog-act.tsx +14 -14
  58. package/components/icons/blog.tsx +20 -20
  59. package/components/icons/bridge-act.tsx +18 -18
  60. package/components/icons/bridge.tsx +68 -68
  61. package/components/icons/changelog-act.tsx +15 -15
  62. package/components/icons/changelog.tsx +21 -21
  63. package/components/icons/chrome.tsx +45 -45
  64. package/components/icons/coins-act.tsx +29 -29
  65. package/components/icons/coins.tsx +20 -20
  66. package/components/icons/compare-cards-act.tsx +30 -30
  67. package/components/icons/compare-cards.tsx +21 -21
  68. package/components/icons/credit-act.tsx +29 -29
  69. package/components/icons/credit.tsx +20 -20
  70. package/components/icons/customer-support-act.tsx +27 -27
  71. package/components/icons/customer-support.tsx +21 -21
  72. package/components/icons/customers-act.tsx +65 -65
  73. package/components/icons/customers.tsx +33 -33
  74. package/components/icons/developer-docs-act.tsx +26 -26
  75. package/components/icons/developer-docs.tsx +20 -20
  76. package/components/icons/exchange-act.tsx +27 -27
  77. package/components/icons/exchange.tsx +21 -21
  78. package/components/icons/explorer-act.tsx +27 -27
  79. package/components/icons/explorer.tsx +22 -22
  80. package/components/icons/faqs-act.tsx +27 -27
  81. package/components/icons/faqs.tsx +21 -21
  82. package/components/icons/github.tsx +14 -14
  83. package/components/icons/guides-act.tsx +26 -26
  84. package/components/icons/guides.tsx +21 -21
  85. package/components/icons/gun-metal.tsx +44 -44
  86. package/components/icons/index.tsx +43 -43
  87. package/components/icons/integrations-act.tsx +41 -41
  88. package/components/icons/integrations.tsx +25 -25
  89. package/components/icons/irradescent.tsx +41 -41
  90. package/components/icons/launch-subnet.tsx +21 -21
  91. package/components/icons/launchsubnet-act.tsx +29 -29
  92. package/components/icons/left-arrow.tsx +11 -11
  93. package/components/icons/lux-finance-act.tsx +34 -34
  94. package/components/icons/lux-finance.tsx +23 -23
  95. package/components/icons/lux-logo.tsx +10 -10
  96. package/components/icons/lux-pass-act.tsx +41 -41
  97. package/components/icons/lux-pass.tsx +25 -25
  98. package/components/icons/lux-quests-act.tsx +15 -15
  99. package/components/icons/lux-quests.tsx +21 -21
  100. package/components/icons/market-act.tsx +39 -39
  101. package/components/icons/market.tsx +24 -24
  102. package/components/icons/mirrored-titanium.tsx +46 -46
  103. package/components/icons/more-benefits-act.tsx +29 -29
  104. package/components/icons/more-benefits.tsx +21 -21
  105. package/components/icons/open-source-act.tsx +41 -41
  106. package/components/icons/open-source.tsx +26 -26
  107. package/components/icons/right-arrow.tsx +10 -10
  108. package/components/icons/safe-act.tsx +77 -77
  109. package/components/icons/safe.tsx +37 -37
  110. package/components/icons/search.tsx +12 -12
  111. package/components/icons/secure-delivery.tsx +13 -13
  112. package/components/icons/shop-act.tsx +29 -29
  113. package/components/icons/shop.tsx +20 -20
  114. package/components/icons/social-icon.tsx +35 -35
  115. package/components/icons/social-svg.css +3 -3
  116. package/components/icons/sterling-silver-card.tsx +44 -44
  117. package/components/icons/templates-act.tsx +29 -29
  118. package/components/icons/templates.tsx +21 -21
  119. package/components/icons/validators-act.tsx +42 -42
  120. package/components/icons/validators.tsx +41 -41
  121. package/components/icons/view-all-card-act.tsx +28 -28
  122. package/components/icons/view-all-card.tsx +20 -20
  123. package/components/icons/wallet-act.tsx +29 -29
  124. package/components/icons/wallet.tsx +20 -20
  125. package/components/icons/warpcast.tsx +58 -58
  126. package/components/icons/youtube-logo.tsx +59 -59
  127. package/components/index.ts +26 -26
  128. package/components/logo.tsx +89 -89
  129. package/components/main.tsx +27 -27
  130. package/components/mini-chart/index.tsx +7 -7
  131. package/components/mini-chart/mini-chart-props.ts +43 -43
  132. package/components/mini-chart/mini-chart.tsx +85 -85
  133. package/components/mini-chart/wrapper.tsx +23 -23
  134. package/components/not-found/index.tsx +28 -28
  135. package/components/not-found/not-found-content.mdx +5 -5
  136. package/components/scripts.tsx +24 -24
  137. package/components/tooltip.tsx +31 -31
  138. package/environment.d.ts +5 -5
  139. package/next/analytics/fpixel.ts +15 -15
  140. package/next/analytics/google-analytics.ts +13 -13
  141. package/next/analytics/index.ts +3 -3
  142. package/next/analytics/pixel-analytics.tsx +54 -54
  143. package/next/font/get-app-router-font-classes.ts +12 -12
  144. package/next/font/load-and-return-lux-next-fonts-on-import.ts +68 -68
  145. package/next/font/next-font-desc.ts +27 -27
  146. package/next/font/pages-router-font-vars.tsx +18 -18
  147. package/next/head-metadata/from-next/metadata-types.ts +158 -158
  148. package/next/head-metadata/from-next/opengraph-types.ts +267 -267
  149. package/next/head-metadata/from-next/twitter-types.ts +92 -92
  150. package/next/head-metadata/index.tsx +208 -208
  151. package/next/middleware/determine-device-mw.ts +29 -29
  152. package/package.json +80 -80
  153. package/root-layout/WHY_THIS_IS_SEPARATE.txt +1 -1
  154. package/root-layout/index.tsx +112 -112
  155. package/server-actions/firebase-app.ts +14 -14
  156. package/server-actions/index.ts +5 -5
  157. package/server-actions/store-contact.ts +51 -51
  158. package/site-def/footer/community.tsx +67 -67
  159. package/site-def/footer/company.ts +37 -37
  160. package/site-def/footer/ecosystem.ts +37 -37
  161. package/site-def/footer/index.tsx +26 -26
  162. package/site-def/footer/legal.ts +28 -28
  163. package/site-def/footer/network.ts +45 -45
  164. package/site-def/footer/svg/warpcast-logo.svg +11 -11
  165. package/site-def/index.ts +2 -2
  166. package/site-def/main-nav.tsx +458 -458
  167. package/style/cart-animation.css +29 -29
  168. package/style/checkout-animation.css +23 -23
  169. package/style/drawer-handle-overrides.css +160 -160
  170. package/style/lux-colors.css +85 -85
  171. package/style/lux-global.css +50 -50
  172. package/tailwind/fontFamily.tailwind.lux.ts +18 -18
  173. package/tailwind/index.ts +2 -2
  174. package/tailwind/lux-tw-fonts.ts +39 -39
  175. package/tailwind/tailwind.config.lux-preset.ts +10 -10
  176. package/tsconfig.json +15 -15
  177. package/types/chatbot-config.ts +6 -6
  178. package/types/chatbot-suggested-question.ts +7 -7
  179. package/types/contact-info.ts +10 -10
  180. package/types/index.ts +4 -4
  181. package/types/site-def.ts +43 -43
package/.env ADDED
@@ -0,0 +1,36 @@
1
+ #const firebaseConfig = {
2
+ # apiKey: "AIzaSyDl_yRww3LOmZ2x2M7Se44AZBRgJSf-9gc",
3
+ # authDomain: "luxdefi.firebaseapp.com",
4
+ # projectId: "luxdefi",
5
+ # storageBucket: "luxdefi.appspot.com",
6
+ # messagingSenderId: "945478779578",
7
+ # appId: "1:945478779578:web:4f58d05b0613633288b883",
8
+ # measurementId: "G-G5PCQS4GKF"
9
+ #}
10
+
11
+
12
+ NEXT_PUBLIC_FIREBASE_API_KEY="AIzaSyDl_yRww3LOmZ2x2M7Se44AZBRgJSf-9gc "
13
+ NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN="luxdefi.firebaseapp.com"
14
+ #NEXT_PUBLIC_FIREBASE_DATABASE_URL=
15
+ NEXT_PUBLIC_FIREBASE_PROJECT_ID="luxdefi"
16
+ NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET="luxdefi.appspot.com"
17
+ NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID="945478779578"
18
+ NEXT_PUBLIC_FIREBASE_APP_ID="1:945478779578:web:4f58d05b0613633288b883"
19
+ NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID="G-G5PCQS4GKF"
20
+ NEXT_PUBLIC_HANZO_AUTH_ADMIN_EMAILS=artemisprimedev@gmail.com|zachkelling@gmail.com
21
+
22
+ FIREBASE_PROJECT_ID="luxdefi"
23
+ FIREBASE_PRIVATE_KEY="-----BEGIN PRIVATE KEY-----\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQDYmSAtfyjMHf02\nPzevhRdBJHWsQjj+GezABssSbH0M2lImFBGfx8GpV3xiHypywzySzF1SQY/Yv00I\nEiAvc08ahTXn6B+ayexxByZdarqE6YdR5woPqLNMH8rw9CMt3ZqxREIhI/X32f9k\nTFsxMGwuoguauorl71mEm0MbAImoMKmg6FcGjncWx2zu5pLgIZN8mdFvl5WZl9H4\nXxeNyEQNvU449C+sC1wuajjRS7O/VBJ0Z1iwWP7O5ysQZJNbHxOR64YUhh1rD/dO\nKl0RNf09PEGIM5ApIdS3ey9pS4yLj8dG7OrOYSiQQUg1YHvLCLrp8ED64aVYpl2a\nB1Hcc7bhAgMBAAECggEAXq69VrYd9vBrFpIW/RagXj0aZXVDZayehijSD5k2Ju6u\n929RbvfK7ARO3rPCAg3fhkpoxwLa50Rk35DQ2f09iJnPwTMC0c7QGW6nMjHsHBrb\nqQ1mpAa6bh39wEvwruWO8Eum3sbSCIkWr9kDCiMhP1dd3EMMYcw55RJcCMs44bip\nu4JmOpnRZCPwoVpbQL0nC+yzD9puFua/dKvKrAKpqueKQOPPdmt8cmdAaIOhBrYK\nZhlI8doNNRwrCEoP/PeprlXxBTmRnbGHPp6f+eD9j76igQFu3d6vOu3X8vh1xKg4\nr6TX7Au11mEz54oC4P5Syk2+qB2UCNBtFREv7Ft9awKBgQD6+uwSZQri3ZZOFeBM\nlFr/7ncuxZZ0gRNxnIsVoykn6KGS0kmDpMOfCswxlsga0LINqz/oquWONyCzkPGc\nuAbduFj490NP9rPAdaffzqui7K78VjVTIkyuNFCeOM30LQedfUkpVPmMEFOzSRIR\n0SJbNbgTpHXp9kTflYRDujhtiwKBgQDc7ijTJkYvXB+xbffXmOb5s2QtBKC726kf\nQKNzhA1lKf1srk9FwnBEzgzDdx3xOYYmr/LfLZq6/LrKb85SUIxCboBgfKjmq1ZG\n4mTcifOy1ykQvqrBhDmhFJ/GodffVkwsan+5w3f96wUaWgkPCjzEnIeyr0ppw8ly\n7HxBTN2SwwKBgQCiwQNDrniPw8hLnM4WewJEA10QXJuDs4xrWWusPWFb+vSEJI/9\nqWQeB7+AzNm44esFCC9qbyBrx/4R1AWKbqAtOfWghaAGA+JvBR02+mu9PKUBB9qO\nrahyM4SwBgAwvt64V12RSwSEurW8hr8MBMW1xjE3s6evb78cCnZ6ARHEnwKBgEoq\nxZfE5JDnm1gkM6y0Du5Ks9mNESyfnFH6kCSqcxjAFOyUQ9aGZMwkZBKGfY3Koud/\n78fOdoBJcaeeCySFF+EBWaWKk+UEJe2b+QI0aZRjOMz/RTG74uDZnJ3BHUhDn0TV\n59UD8tdSO59SFHJxHF9gsQliYVfKO2mSTFBbrpKjAoGBAKOMaWf+L7qLk6IPSWt4\nY9K06pw8fXWekzb0Ahd8FqqvTsRrIFRdJZlHyWZu4wXP3IFpz/e14va8ud+nU+2H\n22EEqs2Ozza9I83atuqi3rHIf2WQQmI91mKVVd8rOmh5PeNp8i5ArPyPYYMxoIrT\nrKr2db+8eHvvM5M9Ak9RDLaA\n-----END PRIVATE KEY-----\n"
24
+ FIREBASE_CLIENT_EMAIL="firebase-adminsdk-j81xe@luxdefi.iam.gserviceaccount.com"
25
+
26
+ NEXT_PUBLIC_ETH_PAYMENT_ADDRESS=0xAdf62DADB9E527fb06509842a4266919Fd85d214
27
+ NEXT_PUBLIC_ETH_EXCHANGE_RATE_API=https://api.coinbase.com/v2/prices/ETH-USD/buy
28
+
29
+ NEXT_PUBLIC_SQUARE_APPLICATION_ID=sandbox-sq0idb-DoFjBoegsUjlm4PETGHhbQ
30
+ NEXT_PUBLIC_SQUARE_LOCATION_ID=LK8AFR2MXE4PE
31
+ SQUARE_ACCESS_TOKEN=EAAAl1T-5kT7Rcuq5ENJPVxVmt10gzFWVOkEjfJ_PdE31YVek5iEiM4SzR-dNQ6t
32
+ SQUARE_ENVIRONMENT=sandbox
33
+
34
+ NEXT_PUBLIC_FACEBOOK_PIXEL_ID=123
35
+ NEXT_PUBLIC_GA_MEASUREMENT_ID=123
36
+ NEXT_PUBLIC_LOGIN_SITE_URL=''
@@ -1,13 +1,13 @@
1
- import type { SnapPointsConfig } from './store'
2
-
3
- export default {
4
- mb: {
5
- micro: '62px',
6
- full: '550px'
7
- },
8
-
9
- dt: {
10
- micro: '74px',
11
- full: '575px'
12
- }
13
- } satisfies SnapPointsConfig
1
+ import type { SnapPointsConfig } from './store'
2
+
3
+ export default {
4
+ mb: {
5
+ micro: '62px',
6
+ full: '550px'
7
+ },
8
+
9
+ dt: {
10
+ micro: '74px',
11
+ full: '575px'
12
+ }
13
+ } satisfies SnapPointsConfig
@@ -1,123 +1,123 @@
1
- 'use client'
2
- import React, {
3
- createContext,
4
- useContext,
5
- useRef,
6
- type PropsWithChildren,
7
- useEffect,
8
- useLayoutEffect
9
- } from 'react'
10
- import { enableStaticRendering } from 'mobx-react-lite'
11
- import { usePathname } from 'next/navigation'
12
- import { useDebounceCallback } from 'usehooks-ts'
13
-
14
-
15
- import { preset as twConfig } from '@hanzo/ui/tailwind'
16
- import { useCommerce } from '@hanzo/commerce'
17
-
18
- import type { CommerceDrawer, SelectAndBuy } from './store'
19
- import { CommerceUIStore } from './store'
20
- import conf from './conf'
21
-
22
- const LOG = false ////////////////////
23
- const log = (s: string) => {
24
- if (LOG) {
25
- console.log('CMMC UI CONTEXT ' + s)
26
- }
27
- }
28
-
29
- // https://dev.to/ivandotv/mobx-server-side-rendering-with-next-js-4m18
30
- enableStaticRendering(typeof window === "undefined")
31
-
32
- const CommerceUIContext = createContext<CommerceUIStore | undefined>(undefined)
33
-
34
- const useCommerceDrawer = (): CommerceDrawer => {
35
- return useContext(CommerceUIContext) as CommerceDrawer
36
- }
37
-
38
- const useSelectAndBuy = (): SelectAndBuy => {
39
- return useContext(CommerceUIContext) as SelectAndBuy
40
- }
41
-
42
- const CommerceUIProvider: React.FC<PropsWithChildren> = ({
43
- children,
44
- }) => {
45
-
46
- const cmmc = useCommerce()
47
- const pathname = usePathname()
48
- const storeRef = useRef<CommerceUIStore>(new CommerceUIStore(cmmc, conf))
49
- const prevPathRef = useRef<string>('initial')
50
-
51
- const onResize = () => {
52
- const width = window.innerWidth
53
- let desktopMin = 0
54
- if (twConfig.theme?.screens) {
55
- // expected form: { md: '768px' }
56
- if ('md' in twConfig.theme?.screens && typeof twConfig.theme?.screens.md === 'string') {
57
- desktopMin = parseInt(twConfig.theme?.screens.md)
58
- }
59
- if (width < desktopMin) {
60
- if (!storeRef.current.isMobile) {
61
- storeRef.current.setMobile(true)
62
- }
63
- }
64
- else if (storeRef.current.isMobile) {
65
- storeRef.current.setMobile(false)
66
- }
67
- }
68
- storeRef.current.setViewportHeight(window.innerHeight)
69
- }
70
-
71
- const onResize_debounced = useDebounceCallback(onResize, 500)
72
-
73
- useLayoutEffect(() => {
74
- storeRef.current.initialize()
75
- onResize()
76
- window.addEventListener('resize', onResize_debounced);
77
-
78
- return () => {
79
- window.removeEventListener('resize', onResize_debounced)
80
- storeRef.current.dispose()
81
- }
82
- }, [])
83
-
84
- useEffect(() => {
85
- const checkingOut = (pathname === '/checkout')
86
-
87
- /////////////////////////////////////
88
- log("useEffect: pathname: " + pathname)
89
- log("useEffect: prev pathname: " + prevPathRef.current)
90
-
91
- if (storeRef.current.checkingOut === undefined || storeRef.current._checkingOut!== checkingOut) {
92
- log("useEffect: setting checkingOut to: " + checkingOut) /////////////////////////////////////
93
- storeRef.current.setCheckingOut(checkingOut)
94
- }
95
- if ( prevPathRef.current === 'initial') {
96
- prevPathRef.current = pathname
97
- storeRef.current.newRoute()
98
- }
99
- else if (
100
- !checkingOut
101
- &&
102
- prevPathRef.current !== pathname
103
- ) {
104
- storeRef.current.newRoute()
105
- prevPathRef.current = pathname
106
- log("ROUTE CHANGE: " + pathname + ": " + storeRef.current._routeChangedTime)
107
- }
108
- }, [pathname])
109
-
110
-
111
- return (
112
- <CommerceUIContext.Provider value={storeRef.current}>
113
- {children}
114
- </CommerceUIContext.Provider>
115
- )
116
- }
117
-
118
- export {
119
- useCommerceDrawer,
120
- useSelectAndBuy,
121
- CommerceUIProvider
122
- }
123
-
1
+ 'use client'
2
+ import React, {
3
+ createContext,
4
+ useContext,
5
+ useRef,
6
+ type PropsWithChildren,
7
+ useEffect,
8
+ useLayoutEffect
9
+ } from 'react'
10
+ import { enableStaticRendering } from 'mobx-react-lite'
11
+ import { usePathname } from 'next/navigation'
12
+ import { useDebounceCallback } from 'usehooks-ts'
13
+
14
+
15
+ import { preset as twConfig } from '@hanzo/ui/tailwind'
16
+ import { useCommerce } from '@hanzo/commerce'
17
+
18
+ import type { CommerceDrawer, SelectAndBuy } from './store'
19
+ import { CommerceUIStore } from './store'
20
+ import conf from './conf'
21
+
22
+ const LOG = false ////////////////////
23
+ const log = (s: string) => {
24
+ if (LOG) {
25
+ console.log('CMMC UI CONTEXT ' + s)
26
+ }
27
+ }
28
+
29
+ // https://dev.to/ivandotv/mobx-server-side-rendering-with-next-js-4m18
30
+ enableStaticRendering(typeof window === "undefined")
31
+
32
+ const CommerceUIContext = createContext<CommerceUIStore | undefined>(undefined)
33
+
34
+ const useCommerceDrawer = (): CommerceDrawer => {
35
+ return useContext(CommerceUIContext) as CommerceDrawer
36
+ }
37
+
38
+ const useSelectAndBuy = (): SelectAndBuy => {
39
+ return useContext(CommerceUIContext) as SelectAndBuy
40
+ }
41
+
42
+ const CommerceUIProvider: React.FC<PropsWithChildren> = ({
43
+ children,
44
+ }) => {
45
+
46
+ const cmmc = useCommerce()
47
+ const pathname = usePathname()
48
+ const storeRef = useRef<CommerceUIStore>(new CommerceUIStore(cmmc, conf))
49
+ const prevPathRef = useRef<string>('initial')
50
+
51
+ const onResize = () => {
52
+ const width = window.innerWidth
53
+ let desktopMin = 0
54
+ if (twConfig.theme?.screens) {
55
+ // expected form: { md: '768px' }
56
+ if ('md' in twConfig.theme?.screens && typeof twConfig.theme?.screens.md === 'string') {
57
+ desktopMin = parseInt(twConfig.theme?.screens.md)
58
+ }
59
+ if (width < desktopMin) {
60
+ if (!storeRef.current.isMobile) {
61
+ storeRef.current.setMobile(true)
62
+ }
63
+ }
64
+ else if (storeRef.current.isMobile) {
65
+ storeRef.current.setMobile(false)
66
+ }
67
+ }
68
+ storeRef.current.setViewportHeight(window.innerHeight)
69
+ }
70
+
71
+ const onResize_debounced = useDebounceCallback(onResize, 500)
72
+
73
+ useLayoutEffect(() => {
74
+ storeRef.current.initialize()
75
+ onResize()
76
+ window.addEventListener('resize', onResize_debounced);
77
+
78
+ return () => {
79
+ window.removeEventListener('resize', onResize_debounced)
80
+ storeRef.current.dispose()
81
+ }
82
+ }, [])
83
+
84
+ useEffect(() => {
85
+ const checkingOut = (pathname === '/checkout')
86
+
87
+ /////////////////////////////////////
88
+ log("useEffect: pathname: " + pathname)
89
+ log("useEffect: prev pathname: " + prevPathRef.current)
90
+
91
+ if (storeRef.current.checkingOut === undefined || storeRef.current._checkingOut!== checkingOut) {
92
+ log("useEffect: setting checkingOut to: " + checkingOut) /////////////////////////////////////
93
+ storeRef.current.setCheckingOut(checkingOut)
94
+ }
95
+ if ( prevPathRef.current === 'initial') {
96
+ prevPathRef.current = pathname
97
+ storeRef.current.newRoute()
98
+ }
99
+ else if (
100
+ !checkingOut
101
+ &&
102
+ prevPathRef.current !== pathname
103
+ ) {
104
+ storeRef.current.newRoute()
105
+ prevPathRef.current = pathname
106
+ log("ROUTE CHANGE: " + pathname + ": " + storeRef.current._routeChangedTime)
107
+ }
108
+ }, [pathname])
109
+
110
+
111
+ return (
112
+ <CommerceUIContext.Provider value={storeRef.current}>
113
+ {children}
114
+ </CommerceUIContext.Provider>
115
+ )
116
+ }
117
+
118
+ export {
119
+ useCommerceDrawer,
120
+ useSelectAndBuy,
121
+ CommerceUIProvider
122
+ }
123
+