@luxfi/core 5.3.0 → 5.3.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 (179) hide show
  1. package/commerce/ui/conf.ts +13 -13
  2. package/commerce/ui/context.tsx +123 -123
  3. package/commerce/ui/store.ts +289 -289
  4. package/components/access-code-input.tsx +71 -71
  5. package/components/auth/auth-listener.tsx +29 -29
  6. package/components/auth/auth-token/clear-auth-token.tsx +12 -12
  7. package/components/auth/auth-token/set-auth-token.tsx +16 -16
  8. package/components/auth/common-auth-domains.ts +16 -16
  9. package/components/auth/login-panel.tsx +107 -107
  10. package/components/back-button.tsx +49 -49
  11. package/components/chat-widget.tsx +85 -85
  12. package/components/commerce/_to_deprecate_checkout-widget/const.ts +13 -13
  13. package/components/commerce/_to_deprecate_checkout-widget/index.tsx_ +188 -188
  14. package/components/commerce/_to_deprecate_checkout-widget/obs-string-set.ts +48 -48
  15. package/components/commerce/_to_deprecate_checkout-widget/use-anim-clx-set.ts +58 -58
  16. package/components/commerce/bag-button.tsx +98 -98
  17. package/components/commerce/buy-button.tsx +34 -34
  18. package/components/commerce/checkout-button.tsx +129 -129
  19. package/components/commerce/checkout-panel/cart-accordian.tsx +66 -66
  20. package/components/commerce/checkout-panel/checkout-panel-props.ts +9 -9
  21. package/components/commerce/checkout-panel/desktop-bag-carousel.tsx +36 -36
  22. package/components/commerce/checkout-panel/desktop-cp.tsx +82 -82
  23. package/components/commerce/checkout-panel/index.tsx +126 -126
  24. package/components/commerce/checkout-panel/mobile-cp.tsx +66 -66
  25. package/components/commerce/checkout-panel/policy-links.tsx +29 -29
  26. package/components/commerce/checkout-panel/steps-indicator.tsx +39 -39
  27. package/components/commerce/checkout-panel/thank-you.tsx +18 -18
  28. package/components/commerce/desktop-bag-popup.tsx +78 -78
  29. package/components/commerce/desktop-nav-menu.tsx +130 -130
  30. package/components/commerce/drawer/index.tsx +88 -88
  31. package/components/commerce/drawer/micro.tsx +144 -144
  32. package/components/commerce/drawer/shell.tsx +85 -85
  33. package/components/commerce/mobile-bag-drawer.tsx +51 -51
  34. package/components/commerce/mobile-login-button.tsx +107 -101
  35. package/components/commerce/mobile-menu-toggle-button.tsx +35 -35
  36. package/components/commerce/mobile-nav-menu-ai.tsx +50 -47
  37. package/components/commerce/mobile-nav-menu-item.tsx +49 -49
  38. package/components/commerce/mobile-nav-menu.tsx +101 -101
  39. package/components/contact-dialog/contact-form.tsx +113 -113
  40. package/components/contact-dialog/disclaimer.tsx +13 -13
  41. package/components/contact-dialog/index.tsx +64 -64
  42. package/components/copyright.tsx +21 -21
  43. package/components/drawer-margin.tsx +25 -25
  44. package/components/footer.tsx +77 -77
  45. package/components/header/desktop.tsx +51 -50
  46. package/components/header/index.tsx +50 -52
  47. package/components/header/mobile.tsx +163 -163
  48. package/components/header/theme-toggle.tsx +26 -26
  49. package/components/icons/24k-gold-card.tsx +43 -43
  50. package/components/icons/ai-chat-act.tsx +47 -47
  51. package/components/icons/ai-chat.tsx +29 -29
  52. package/components/icons/anodized-titanium.tsx +45 -45
  53. package/components/icons/avatar.tsx +11 -11
  54. package/components/icons/bag-icon.tsx +10 -10
  55. package/components/icons/blog-act.tsx +14 -14
  56. package/components/icons/blog.tsx +20 -20
  57. package/components/icons/bridge-act.tsx +18 -18
  58. package/components/icons/bridge.tsx +68 -68
  59. package/components/icons/changelog-act.tsx +15 -15
  60. package/components/icons/changelog.tsx +21 -21
  61. package/components/icons/chrome.tsx +45 -45
  62. package/components/icons/coins-act.tsx +29 -29
  63. package/components/icons/coins.tsx +20 -20
  64. package/components/icons/compare-cards-act.tsx +30 -30
  65. package/components/icons/compare-cards.tsx +21 -21
  66. package/components/icons/credit-act.tsx +29 -29
  67. package/components/icons/credit.tsx +20 -20
  68. package/components/icons/customer-support-act.tsx +27 -27
  69. package/components/icons/customer-support.tsx +21 -21
  70. package/components/icons/customers-act.tsx +65 -65
  71. package/components/icons/customers.tsx +33 -33
  72. package/components/icons/developer-docs-act.tsx +26 -26
  73. package/components/icons/developer-docs.tsx +20 -20
  74. package/components/icons/exchange-act.tsx +27 -27
  75. package/components/icons/exchange.tsx +21 -21
  76. package/components/icons/explorer-act.tsx +27 -27
  77. package/components/icons/explorer.tsx +22 -22
  78. package/components/icons/faqs-act.tsx +27 -27
  79. package/components/icons/faqs.tsx +21 -21
  80. package/components/icons/github.tsx +14 -14
  81. package/components/icons/guides-act.tsx +26 -26
  82. package/components/icons/guides.tsx +21 -21
  83. package/components/icons/gun-metal.tsx +44 -44
  84. package/components/icons/index.tsx +43 -43
  85. package/components/icons/integrations-act.tsx +41 -41
  86. package/components/icons/integrations.tsx +25 -25
  87. package/components/icons/irradescent.tsx +41 -41
  88. package/components/icons/launch-subnet.tsx +21 -21
  89. package/components/icons/launchsubnet-act.tsx +29 -29
  90. package/components/icons/left-arrow.tsx +11 -11
  91. package/components/icons/lux-finance-act.tsx +34 -34
  92. package/components/icons/lux-finance.tsx +23 -23
  93. package/components/icons/lux-logo.tsx +10 -10
  94. package/components/icons/lux-pass-act.tsx +41 -41
  95. package/components/icons/lux-pass.tsx +25 -25
  96. package/components/icons/lux-quests-act.tsx +15 -15
  97. package/components/icons/lux-quests.tsx +21 -21
  98. package/components/icons/market-act.tsx +39 -39
  99. package/components/icons/market.tsx +24 -24
  100. package/components/icons/mirrored-titanium.tsx +46 -46
  101. package/components/icons/more-benefits-act.tsx +29 -29
  102. package/components/icons/more-benefits.tsx +21 -21
  103. package/components/icons/open-source-act.tsx +41 -41
  104. package/components/icons/open-source.tsx +26 -26
  105. package/components/icons/right-arrow.tsx +10 -10
  106. package/components/icons/safe-act.tsx +77 -77
  107. package/components/icons/safe.tsx +37 -37
  108. package/components/icons/search.tsx +12 -12
  109. package/components/icons/secure-delivery.tsx +13 -13
  110. package/components/icons/shop-act.tsx +29 -29
  111. package/components/icons/shop.tsx +20 -20
  112. package/components/icons/social-icon.tsx +35 -35
  113. package/components/icons/social-svg.css +3 -3
  114. package/components/icons/sterling-silver-card.tsx +44 -44
  115. package/components/icons/templates-act.tsx +29 -29
  116. package/components/icons/templates.tsx +21 -21
  117. package/components/icons/validators-act.tsx +42 -42
  118. package/components/icons/validators.tsx +41 -41
  119. package/components/icons/view-all-card-act.tsx +28 -28
  120. package/components/icons/view-all-card.tsx +20 -20
  121. package/components/icons/wallet-act.tsx +29 -29
  122. package/components/icons/wallet.tsx +20 -20
  123. package/components/icons/warpcast.tsx +58 -58
  124. package/components/icons/youtube-logo.tsx +59 -59
  125. package/components/index.ts +25 -25
  126. package/components/logo.tsx +89 -89
  127. package/components/main.tsx +27 -27
  128. package/components/mini-chart/index.tsx +7 -7
  129. package/components/mini-chart/mini-chart-props.ts +43 -43
  130. package/components/mini-chart/mini-chart.tsx +85 -85
  131. package/components/mini-chart/wrapper.tsx +23 -23
  132. package/components/not-found/index.tsx +28 -28
  133. package/components/not-found/not-found-content.mdx +5 -5
  134. package/components/scripts.tsx +24 -24
  135. package/components/tooltip.tsx +31 -31
  136. package/environment.d.ts +5 -5
  137. package/next/analytics/fpixel.ts +15 -15
  138. package/next/analytics/google-analytics.ts +13 -13
  139. package/next/analytics/index.ts +3 -3
  140. package/next/analytics/pixel-analytics.tsx +54 -54
  141. package/next/font/get-app-router-font-classes.ts +12 -12
  142. package/next/font/load-and-return-lux-next-fonts-on-import.ts +68 -68
  143. package/next/font/next-font-desc.ts +27 -27
  144. package/next/font/pages-router-font-vars.tsx +18 -18
  145. package/next/head-metadata/from-next/metadata-types.ts +158 -158
  146. package/next/head-metadata/from-next/opengraph-types.ts +267 -267
  147. package/next/head-metadata/from-next/twitter-types.ts +92 -92
  148. package/next/head-metadata/index.tsx +208 -208
  149. package/next/middleware/determine-device-mw.ts +16 -16
  150. package/package.json +79 -79
  151. package/root-layout/WHY_THIS_IS_SEPARATE.txt +1 -1
  152. package/root-layout/index.tsx +112 -112
  153. package/server-actions/firebase-app.ts +14 -14
  154. package/server-actions/index.ts +5 -5
  155. package/server-actions/store-contact.ts +51 -51
  156. package/site-def/footer/community.tsx +67 -67
  157. package/site-def/footer/company.ts +37 -37
  158. package/site-def/footer/ecosystem.ts +37 -37
  159. package/site-def/footer/index.tsx +26 -26
  160. package/site-def/footer/legal.ts +28 -28
  161. package/site-def/footer/network.ts +45 -45
  162. package/site-def/footer/svg/warpcast-logo.svg +11 -11
  163. package/site-def/index.ts +2 -2
  164. package/site-def/main-nav.tsx +458 -458
  165. package/style/cart-animation.css +29 -29
  166. package/style/checkout-animation.css +23 -23
  167. package/style/drawer-handle-overrides.css +160 -160
  168. package/style/lux-colors.css +85 -85
  169. package/style/lux-global.css +50 -47
  170. package/tailwind/fontFamily.tailwind.lux.ts +18 -18
  171. package/tailwind/index.ts +2 -2
  172. package/tailwind/lux-tw-fonts.ts +39 -39
  173. package/tailwind/tailwind.config.lux-preset.ts +10 -10
  174. package/tsconfig.json +15 -15
  175. package/types/chatbot-config.ts +6 -6
  176. package/types/chatbot-suggested-question.ts +7 -7
  177. package/types/contact-info.ts +10 -10
  178. package/types/index.ts +4 -4
  179. package/types/site-def.ts +43 -43
@@ -1,144 +1,144 @@
1
- 'use client'
2
- import React from 'react'
3
- import { observer } from 'mobx-react-lite'
4
-
5
- import { Button, Image } from '@hanzo/ui/primitives'
6
- import { cn, } from '@hanzo/ui/util'
7
- import type { LineItem } from '@hanzo/commerce/types'
8
- import { useCommerce, formatCurrencyValue } from '@hanzo/commerce'
9
-
10
- import CheckoutButton from '../checkout-button'
11
- import { useCommerceDrawer } from '../../../commerce/ui/context'
12
-
13
- const CN = {
14
- // h: mind padding!
15
- mobile: { w: 36, h: 32 },
16
- sm: { w: 60, h: 34 },
17
- desktop: { w: 60, h: 32 },
18
- }
19
-
20
- const Info: React.FC<{
21
- item: LineItem
22
- clx?: string
23
- }> = ({
24
- item,
25
- clx=''
26
- }) => {
27
-
28
- const cmmc = useCommerce()
29
- const family = cmmc.getFamilyById(item.familyId)
30
-
31
- let topLine = family!.title
32
- if (item.sku.startsWith('LXM-AG') || item.sku.startsWith('LXM-AU')) {
33
- topLine = family!.parentTitle + ', ' + family!.title
34
- }
35
-
36
- const optionLabel = item.optionLabelShort ?? item.optionLabel
37
- const priceStr = formatCurrencyValue(item.price)
38
-
39
- return (<>
40
- <div className={cn('sm:hidden flex flex-col !text-muted items-stretch whitespace-nowrap text-ellipsis ', clx)}>
41
- <p className='text-left text-xs'>{topLine}</p>
42
- <div className='flex justify-between text-xxs'>
43
- <div>{optionLabel}</div>
44
- <div className='pl-2.5'>{priceStr}</div>
45
- </div>
46
- </div>
47
- <div className={cn('hidden sm:flex !text-muted flex-col items-stretch whitespace-nowrap text-ellipsis text-xs', clx)}>
48
- <p className='text-left'>{topLine}</p>
49
- <div className='flex justify-between'>
50
- <div>{optionLabel}</div>
51
- <div className='pl-2.5'>{priceStr}</div>
52
- </div>
53
- </div>
54
- </>)
55
- }
56
-
57
- const PROMPT_COMMON_CLX = 'block absolute top-0 left-0 bg-transparent duration-400 transition-opacity'
58
-
59
- const Micro: React.FC<{
60
- clx?: string
61
- handleCheckout: () => void
62
- handleItemClicked: () => void
63
- }> = observer(({
64
- clx='',
65
- handleCheckout,
66
- handleItemClicked
67
- }) => {
68
-
69
- const drawer = useCommerceDrawer()
70
- const cmmc = useCommerce()
71
-
72
- return (
73
- <div className={cn(
74
- (drawer.showRecent ? 'grid grid-cols-2' : 'flex justify-center items-center '),
75
- (drawer.showRecent ? ((drawer.isMobile) ? '-mt-3' : '-mt-3') : ''),
76
- 'gap-2 md:gap-3 relative',
77
- clx
78
- )}>
79
- {drawer.showRecent && (
80
- <div className={'flex flex-col items-stretch ' + (drawer.isMobile ? 'justify-start' : 'group')}>
81
- <p className={'relative text-muted text-xxs md:text-xs leading-none pl-1 self-start ' + (drawer.isMobile ? 'top-[3px]' : 'top-[1px]')}>
82
- <span className='invisible'>scrictly for layout</span>
83
- {drawer.isMobile ? (
84
- <span className={PROMPT_COMMON_CLX}>tap for options:</span>
85
- ) : (<>
86
- <span className={PROMPT_COMMON_CLX + ' group-hover:opacity-0'}>recent item:</span>
87
- <span className={PROMPT_COMMON_CLX + ' opacity-0 group-hover:opacity-100'}>view options:</span>
88
- </>)}
89
- </p>
90
- <Button
91
- variant='ghost'
92
- rounded={drawer.isMobile ? 'md' : 'lg'}
93
- size={drawer.isMobile ? 'sm' : 'lg'}
94
- onClick={handleItemClicked}
95
- className={cn(
96
- 'box-content',
97
- 'flex flex-row justify-between items-center gap-1',
98
- '-ml-1.5',
99
- 'overflow-hidden ',
100
- 'px-1 md:px-2 py-[2px]',
101
- 'border border-transparent group-hover:border-muted-3',
102
- 'group-hover:!bg-transparent '
103
- )}
104
- >
105
- {cmmc.recentItem?.item.img && (<>
106
- <Image def={cmmc.recentItem.item.img} constrainTo={CN.mobile} preload className='sm:hidden grow-0 shrink-0'/>
107
- <Image def={cmmc.recentItem.item.img} constrainTo={CN.sm} preload className='hidden sm:block md:hidden grow-0 shrink-0'/>
108
- <Image def={cmmc.recentItem.item.img} constrainTo={CN.desktop} preload className='hidden md:block grow-0 shrink-0'/>
109
- </>)}
110
- {cmmc.recentItem && (
111
- <div className='grow w-full'>
112
- <Info item={cmmc.recentItem.item} clx='w-full'/>
113
- </div>
114
- )}
115
- </Button>
116
- </div>
117
- )}
118
- {drawer.showCheckout && (
119
- <div className={cn(
120
- 'flex flex-col w-full',
121
- (drawer.showRecent ? 'items-stretch' : 'items-center' ),
122
- (drawer.isMobile ? 'justify-start' : 'justify-center')
123
- )}>
124
- {drawer.showRecent && <p className='invisible text-muted text-xxs md:text-xs leading-none pl-1 self-start'>for layout</p>}
125
- <CheckoutButton
126
- handleCheckout={handleCheckout}
127
- variant='primary'
128
- size={drawer.isMobile ? 'xs' : 'lg'}
129
- rounded={drawer.isMobile ? 'md' : 'lg'}
130
- centerText={drawer.isMobile ? !drawer.showRecent : true}
131
- className={cn(drawer.isMobile ?
132
- (drawer.showRecent ? 'pl-3.5 pr-2.5' : 'min-w-[320px]')
133
- :
134
- (drawer.showRecent ? '' : 'w-[320px]'),
135
- 'text-sm font-semibold'
136
- )}
137
- />
138
- </div>
139
- )}
140
- </div>
141
- )
142
- })
143
-
144
- export default Micro
1
+ 'use client'
2
+ import React from 'react'
3
+ import { observer } from 'mobx-react-lite'
4
+
5
+ import { Button, Image } from '@hanzo/ui/primitives'
6
+ import { cn, } from '@hanzo/ui/util'
7
+ import type { LineItem } from '@hanzo/commerce/types'
8
+ import { useCommerce, formatCurrencyValue } from '@hanzo/commerce'
9
+
10
+ import CheckoutButton from '../checkout-button'
11
+ import { useCommerceDrawer } from '../../../commerce/ui/context'
12
+
13
+ const CN = {
14
+ // h: mind padding!
15
+ mobile: { w: 36, h: 32 },
16
+ sm: { w: 60, h: 34 },
17
+ desktop: { w: 60, h: 32 },
18
+ }
19
+
20
+ const Info: React.FC<{
21
+ item: LineItem
22
+ clx?: string
23
+ }> = ({
24
+ item,
25
+ clx=''
26
+ }) => {
27
+
28
+ const cmmc = useCommerce()
29
+ const family = cmmc.getFamilyById(item.familyId)
30
+
31
+ let topLine = family!.title
32
+ if (item.sku.startsWith('LXM-AG') || item.sku.startsWith('LXM-AU')) {
33
+ topLine = family!.parentTitle + ', ' + family!.title
34
+ }
35
+
36
+ const optionLabel = item.optionLabelShort ?? item.optionLabel
37
+ const priceStr = formatCurrencyValue(item.price)
38
+
39
+ return (<>
40
+ <div className={cn('sm:hidden flex flex-col !text-muted items-stretch whitespace-nowrap text-ellipsis ', clx)}>
41
+ <p className='text-left text-xs'>{topLine}</p>
42
+ <div className='flex justify-between text-xxs'>
43
+ <div>{optionLabel}</div>
44
+ <div className='pl-2.5'>{priceStr}</div>
45
+ </div>
46
+ </div>
47
+ <div className={cn('hidden sm:flex !text-muted flex-col items-stretch whitespace-nowrap text-ellipsis text-xs', clx)}>
48
+ <p className='text-left'>{topLine}</p>
49
+ <div className='flex justify-between'>
50
+ <div>{optionLabel}</div>
51
+ <div className='pl-2.5'>{priceStr}</div>
52
+ </div>
53
+ </div>
54
+ </>)
55
+ }
56
+
57
+ const PROMPT_COMMON_CLX = 'block absolute top-0 left-0 bg-transparent duration-400 transition-opacity'
58
+
59
+ const Micro: React.FC<{
60
+ clx?: string
61
+ handleCheckout: () => void
62
+ handleItemClicked: () => void
63
+ }> = observer(({
64
+ clx='',
65
+ handleCheckout,
66
+ handleItemClicked
67
+ }) => {
68
+
69
+ const drawer = useCommerceDrawer()
70
+ const cmmc = useCommerce()
71
+
72
+ return (
73
+ <div className={cn(
74
+ (drawer.showRecent ? 'grid grid-cols-2' : 'flex justify-center items-center '),
75
+ (drawer.showRecent ? ((drawer.isMobile) ? '-mt-3' : '-mt-3') : ''),
76
+ 'gap-2 md:gap-3 relative',
77
+ clx
78
+ )}>
79
+ {drawer.showRecent && (
80
+ <div className={'flex flex-col items-stretch ' + (drawer.isMobile ? 'justify-start' : 'group')}>
81
+ <p className={'relative text-muted text-xxs md:text-xs leading-none pl-1 self-start ' + (drawer.isMobile ? 'top-[3px]' : 'top-[1px]')}>
82
+ <span className='invisible'>scrictly for layout</span>
83
+ {drawer.isMobile ? (
84
+ <span className={PROMPT_COMMON_CLX}>tap for options:</span>
85
+ ) : (<>
86
+ <span className={PROMPT_COMMON_CLX + ' group-hover:opacity-0'}>recent item:</span>
87
+ <span className={PROMPT_COMMON_CLX + ' opacity-0 group-hover:opacity-100'}>view options:</span>
88
+ </>)}
89
+ </p>
90
+ <Button
91
+ variant='ghost'
92
+ rounded={drawer.isMobile ? 'md' : 'lg'}
93
+ size={drawer.isMobile ? 'sm' : 'lg'}
94
+ onClick={handleItemClicked}
95
+ className={cn(
96
+ 'box-content',
97
+ 'flex flex-row justify-between items-center gap-1',
98
+ '-ml-1.5',
99
+ 'overflow-hidden ',
100
+ 'px-1 md:px-2 py-[2px]',
101
+ 'border border-transparent group-hover:border-muted-3',
102
+ 'group-hover:!bg-transparent '
103
+ )}
104
+ >
105
+ {cmmc.recentItem?.item.img && (<>
106
+ <Image def={cmmc.recentItem.item.img} constrainTo={CN.mobile} preload className='sm:hidden grow-0 shrink-0'/>
107
+ <Image def={cmmc.recentItem.item.img} constrainTo={CN.sm} preload className='hidden sm:block md:hidden grow-0 shrink-0'/>
108
+ <Image def={cmmc.recentItem.item.img} constrainTo={CN.desktop} preload className='hidden md:block grow-0 shrink-0'/>
109
+ </>)}
110
+ {cmmc.recentItem && (
111
+ <div className='grow w-full'>
112
+ <Info item={cmmc.recentItem.item} clx='w-full'/>
113
+ </div>
114
+ )}
115
+ </Button>
116
+ </div>
117
+ )}
118
+ {drawer.showCheckout && (
119
+ <div className={cn(
120
+ 'flex flex-col w-full',
121
+ (drawer.showRecent ? 'items-stretch' : 'items-center' ),
122
+ (drawer.isMobile ? 'justify-start' : 'justify-center')
123
+ )}>
124
+ {drawer.showRecent && <p className='invisible text-muted text-xxs md:text-xs leading-none pl-1 self-start'>for layout</p>}
125
+ <CheckoutButton
126
+ handleCheckout={handleCheckout}
127
+ variant='primary'
128
+ size={drawer.isMobile ? 'xs' : 'lg'}
129
+ rounded={drawer.isMobile ? 'md' : 'lg'}
130
+ centerText={drawer.isMobile ? !drawer.showRecent : true}
131
+ className={cn(drawer.isMobile ?
132
+ (drawer.showRecent ? 'pl-3.5 pr-2.5' : 'min-w-[320px]')
133
+ :
134
+ (drawer.showRecent ? '' : 'w-[320px]'),
135
+ 'text-sm font-semibold'
136
+ )}
137
+ />
138
+ </div>
139
+ )}
140
+ </div>
141
+ )
142
+ })
143
+
144
+ export default Micro
@@ -1,85 +1,85 @@
1
- 'use client'
2
- import React, {type PropsWithChildren } from 'react'
3
- import { observer } from 'mobx-react-lite'
4
-
5
- import {
6
- Drawer,
7
- DrawerContent,
8
- DrawerHandle,
9
- type DrawerProps,
10
- } from '@hanzo/ui/primitives'
11
- import { cn } from '@hanzo/ui/util'
12
-
13
- import '../../../style/drawer-handle-overrides.css'
14
- import { useCommerceDrawer } from '../../../commerce/ui/context'
15
-
16
- const CommerceDrawer: React.FC<PropsWithChildren &
17
- Omit<DrawerProps,
18
- 'onOpenChange' |
19
- 'open' |
20
- 'snapPoints' |
21
- 'modal' |
22
- 'setActiveSnapPoint' |
23
- 'activeSnapPoint'
24
- > &
25
- {
26
- handleHandleClicked: () => void
27
- drawerClx?: string
28
- }
29
- > = observer(({
30
- children,
31
- handleHandleClicked,
32
- drawerClx='',
33
- ...rest
34
- }) => {
35
-
36
- const drawer = useCommerceDrawer()
37
-
38
- return (
39
- <Drawer
40
- open={drawer.open}
41
- onOpenChange={() => {}}
42
- modal={drawer.modal}
43
- snapPoints={drawer.points}
44
- activeSnapPoint={drawer.activePoint}
45
- setActiveSnapPoint={drawer.onActivePointChanged.bind(drawer)}
46
- fastDragSkipsToEnd={false}
47
- dragHandleOnly={true}
48
- handleHandleClicked={handleHandleClicked}
49
- extendHandleDragRegion={false}
50
- // debugOutput
51
- {...rest}
52
- >
53
- <DrawerContent
54
- defaultHandle={false}
55
- className={cn(
56
- 'border-0',
57
- drawer.isMobile ? 'pt-5' : 'pt-6',
58
- 'w-full h-full',
59
- )}
60
- // https://github.com/radix-ui/primitives/discussions/935
61
- onOpenAutoFocus={(e) => {e.preventDefault()}}
62
- >
63
- <DrawerHandle
64
- className={cn(
65
- 'absolute top-0 left-0 right-0 mx-auto z-10',
66
- 'flex justify-center items-start',
67
- 'border-t rounded-t-lg border-muted-3',
68
- drawer.isMobile ? 'h-5 touch-pan-y' : 'h-6',
69
- )}
70
- >
71
- <div className={cn(
72
- // pseudo-handle
73
- 'rounded-[3px] bg-level-3',
74
- drawer.isMobile ? 'w-[155px] mt-[5px] h-1.5' : 'w-[180px] mt-[3px] h-2.5 hover:bg-level-4',
75
- !drawer.isMobile ? 'cursor-grab active:cursor-grabbing' : '',
76
- )} />
77
- </DrawerHandle>
78
- {children}
79
- </DrawerContent>
80
- </Drawer>
81
- )
82
- })
83
-
84
-
85
- export default CommerceDrawer
1
+ 'use client'
2
+ import React, {type PropsWithChildren } from 'react'
3
+ import { observer } from 'mobx-react-lite'
4
+
5
+ import {
6
+ Drawer,
7
+ DrawerContent,
8
+ DrawerHandle,
9
+ type DrawerProps,
10
+ } from '@hanzo/ui/primitives'
11
+ import { cn } from '@hanzo/ui/util'
12
+
13
+ import '../../../style/drawer-handle-overrides.css'
14
+ import { useCommerceDrawer } from '../../../commerce/ui/context'
15
+
16
+ const CommerceDrawer: React.FC<PropsWithChildren &
17
+ Omit<DrawerProps,
18
+ 'onOpenChange' |
19
+ 'open' |
20
+ 'snapPoints' |
21
+ 'modal' |
22
+ 'setActiveSnapPoint' |
23
+ 'activeSnapPoint'
24
+ > &
25
+ {
26
+ handleHandleClicked: () => void
27
+ drawerClx?: string
28
+ }
29
+ > = observer(({
30
+ children,
31
+ handleHandleClicked,
32
+ drawerClx='',
33
+ ...rest
34
+ }) => {
35
+
36
+ const drawer = useCommerceDrawer()
37
+
38
+ return (
39
+ <Drawer
40
+ open={drawer.open}
41
+ onOpenChange={() => {}}
42
+ modal={drawer.modal}
43
+ snapPoints={drawer.points}
44
+ activeSnapPoint={drawer.activePoint}
45
+ setActiveSnapPoint={drawer.onActivePointChanged.bind(drawer)}
46
+ fastDragSkipsToEnd={false}
47
+ dragHandleOnly={true}
48
+ handleHandleClicked={handleHandleClicked}
49
+ extendHandleDragRegion={false}
50
+ // debugOutput
51
+ {...rest}
52
+ >
53
+ <DrawerContent
54
+ defaultHandle={false}
55
+ className={cn(
56
+ 'border-0',
57
+ drawer.isMobile ? 'pt-5' : 'pt-6',
58
+ 'w-full h-full',
59
+ )}
60
+ // https://github.com/radix-ui/primitives/discussions/935
61
+ onOpenAutoFocus={(e) => {e.preventDefault()}}
62
+ >
63
+ <DrawerHandle
64
+ className={cn(
65
+ 'absolute top-0 left-0 right-0 mx-auto z-10',
66
+ 'flex justify-center items-start',
67
+ 'border-t rounded-t-lg border-muted-3',
68
+ drawer.isMobile ? 'h-5 touch-pan-y' : 'h-6',
69
+ )}
70
+ >
71
+ <div className={cn(
72
+ // pseudo-handle
73
+ 'rounded-[3px] bg-level-3',
74
+ drawer.isMobile ? 'w-[155px] mt-[5px] h-1.5' : 'w-[180px] mt-[3px] h-2.5 hover:bg-level-4',
75
+ !drawer.isMobile ? 'cursor-grab active:cursor-grabbing' : '',
76
+ )} />
77
+ </DrawerHandle>
78
+ {children}
79
+ </DrawerContent>
80
+ </Drawer>
81
+ )
82
+ })
83
+
84
+
85
+ export default CommerceDrawer
@@ -1,51 +1,51 @@
1
- 'use client'
2
- import React from 'react'
3
-
4
- import { Drawer, DrawerContent} from '@hanzo/ui/primitives'
5
- import { cn } from '@hanzo/ui/util'
6
- import { CartPanel } from '@hanzo/commerce'
7
-
8
- import BagButton from './bag-button'
9
-
10
- const MobileBagDrawer: React.FC<{
11
- open: boolean,
12
- setOpen: (b: boolean) => void
13
- handleCheckout: () => void
14
- className?: string
15
- }> = ({
16
- open,
17
- setOpen,
18
- handleCheckout,
19
- className='',
20
- }) => {
21
-
22
- return (
23
- <Drawer open={open} onOpenChange={setOpen}>
24
- <DrawerContent className={cn('rounded-t-xl mt-6 pb-12 h-auto', className)} >
25
- <CartPanel
26
- handleCheckout={handleCheckout}
27
- className='mt-4 mb-4 border-none py-0 px-4 w-full '
28
- listClx='rounded-sm pr-3'
29
- scrollAfter={5}
30
- itemClx='mt-2'
31
- totalClx='sticky px-1 pr-2 border rounded-sm -bottom-[1px] bg-background'
32
- buttonClx='max-w-[220px] flex-none'
33
- >
34
- <div className='flex flex-row items-center flex-none justify-center '>
35
- <BagButton
36
- animateOnHover={false}
37
- showIfEmpty
38
- className=
39
- 'mr-2 relative w-6 h-7'
40
- iconClx='fill-foreground '
41
- />
42
- <p className='font-heading text-foreground text-default'>Your Bag</p>
43
- </div>
44
- <div className='h-[1px] w-pr-80 bg-muted-3 mx-auto mt-1.5 flex-none'/>
45
- </CartPanel>
46
- </DrawerContent>
47
- </Drawer>
48
- )
49
- }
50
-
51
- export default MobileBagDrawer
1
+ 'use client'
2
+ import React from 'react'
3
+
4
+ import { Drawer, DrawerContent} from '@hanzo/ui/primitives'
5
+ import { cn } from '@hanzo/ui/util'
6
+ import { CartPanel } from '@hanzo/commerce'
7
+
8
+ import BagButton from './bag-button'
9
+
10
+ const MobileBagDrawer: React.FC<{
11
+ open: boolean,
12
+ setOpen: (b: boolean) => void
13
+ handleCheckout: () => void
14
+ className?: string
15
+ }> = ({
16
+ open,
17
+ setOpen,
18
+ handleCheckout,
19
+ className='',
20
+ }) => {
21
+
22
+ return (
23
+ <Drawer open={open} onOpenChange={setOpen}>
24
+ <DrawerContent className={cn('rounded-t-xl mt-6 pb-12 h-auto', className)} >
25
+ <CartPanel
26
+ handleCheckout={handleCheckout}
27
+ className='mt-4 mb-4 border-none py-0 px-4 w-full '
28
+ listClx='rounded-sm pr-3'
29
+ scrollAfter={5}
30
+ itemClx='mt-2'
31
+ totalClx='sticky px-1 pr-2 border rounded-sm -bottom-[1px] bg-background'
32
+ buttonClx='max-w-[220px] flex-none'
33
+ >
34
+ <div className='flex flex-row items-center flex-none justify-center '>
35
+ <BagButton
36
+ animateOnHover={false}
37
+ showIfEmpty
38
+ className=
39
+ 'mr-2 relative w-6 h-7'
40
+ iconClx='fill-foreground '
41
+ />
42
+ <p className='font-heading text-foreground text-default'>Your Bag</p>
43
+ </div>
44
+ <div className='h-[1px] w-pr-80 bg-muted-3 mx-auto mt-1.5 flex-none'/>
45
+ </CartPanel>
46
+ </DrawerContent>
47
+ </Drawer>
48
+ )
49
+ }
50
+
51
+ export default MobileBagDrawer