@luxfi/core 5.2.6 → 5.2.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (114) hide show
  1. package/commerce/ui/conf.ts +13 -13
  2. package/commerce/ui/context.tsx +102 -102
  3. package/commerce/ui/store.ts +276 -276
  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/chat-widget.tsx +85 -85
  11. package/components/commerce/add-widget.tsx +20 -20
  12. package/components/commerce/bag-button.tsx +98 -98
  13. package/components/commerce/buy-button.tsx +34 -34
  14. package/components/commerce/checkout-button.tsx +129 -129
  15. package/components/commerce/checkout-panel/close-button.tsx +26 -26
  16. package/components/commerce/checkout-panel/dt-bag-carousel.tsx +36 -36
  17. package/components/commerce/checkout-panel/dt-checkout-panel.tsx +66 -66
  18. package/components/commerce/checkout-panel/index.tsx +129 -129
  19. package/components/commerce/checkout-panel/links-row.tsx +21 -21
  20. package/components/commerce/checkout-panel/mb-checkout-panel.tsx +54 -54
  21. package/components/commerce/checkout-panel/steps-indicator.tsx +39 -39
  22. package/components/commerce/checkout-panel/thank-you.tsx +18 -18
  23. package/components/commerce/checkout-widget/const.ts +13 -13
  24. package/components/commerce/checkout-widget/index.tsx +192 -192
  25. package/components/commerce/checkout-widget/obs-string-set.ts +48 -48
  26. package/components/commerce/checkout-widget/use-anim-clx-set.ts +58 -58
  27. package/components/commerce/desktop-bag-popup.tsx +78 -78
  28. package/components/commerce/desktop-nav-menu.tsx +130 -235
  29. package/components/commerce/drawer/index.tsx +116 -116
  30. package/components/commerce/drawer/micro.tsx +144 -144
  31. package/components/commerce/drawer/shell.tsx +83 -83
  32. package/components/commerce/mobile-bag-drawer.tsx +51 -51
  33. package/components/commerce/mobile-login-button.tsx +101 -101
  34. package/components/commerce/mobile-menu-toggle-button.tsx +35 -35
  35. package/components/commerce/mobile-nav-menu-ai.tsx +44 -44
  36. package/components/commerce/mobile-nav-menu-item.tsx +49 -49
  37. package/components/commerce/mobile-nav-menu.tsx +68 -68
  38. package/components/contact-dialog/contact-form.tsx +113 -113
  39. package/components/contact-dialog/disclaimer.tsx +13 -13
  40. package/components/contact-dialog/index.tsx +64 -64
  41. package/components/copyright.tsx +21 -21
  42. package/components/drawer-margin.tsx +25 -25
  43. package/components/footer.tsx +77 -77
  44. package/components/header/desktop.tsx +49 -57
  45. package/components/header/index.tsx +52 -52
  46. package/components/header/mobile.tsx +166 -166
  47. package/components/header/theme-toggle.tsx +26 -26
  48. package/components/icons/avatar.tsx +11 -11
  49. package/components/icons/bag-icon.tsx +10 -10
  50. package/components/icons/github.tsx +14 -14
  51. package/components/icons/index.tsx +43 -43
  52. package/components/icons/left-arrow.tsx +11 -11
  53. package/components/icons/lux-logo.tsx +10 -10
  54. package/components/icons/right-arrow.tsx +10 -10
  55. package/components/icons/search.tsx +12 -12
  56. package/components/icons/secure-delivery.tsx +13 -13
  57. package/components/icons/social-icon.tsx +35 -35
  58. package/components/icons/social-svg.css +3 -3
  59. package/components/icons/warpcast.tsx +58 -58
  60. package/components/icons/youtube-logo.tsx +59 -59
  61. package/components/index.ts +25 -25
  62. package/components/logo.tsx +81 -81
  63. package/components/main.tsx +27 -27
  64. package/components/mini-chart/index.tsx +7 -7
  65. package/components/mini-chart/mini-chart-props.ts +43 -43
  66. package/components/mini-chart/mini-chart.tsx +85 -85
  67. package/components/mini-chart/wrapper.tsx +23 -23
  68. package/components/not-found/index.tsx +28 -28
  69. package/components/not-found/not-found-content.mdx +5 -5
  70. package/components/scripts.tsx +24 -24
  71. package/environment.d.ts +5 -5
  72. package/next/analytics/fpixel.ts +15 -15
  73. package/next/analytics/google-analytics.ts +13 -13
  74. package/next/analytics/index.ts +3 -3
  75. package/next/analytics/pixel-analytics.tsx +54 -54
  76. package/next/font/get-app-router-font-classes.ts +12 -12
  77. package/next/font/load-and-return-lux-next-fonts-on-import.ts +68 -68
  78. package/next/font/next-font-desc.ts +27 -27
  79. package/next/font/pages-router-font-vars.tsx +18 -18
  80. package/next/head-metadata/from-next/metadata-types.ts +158 -158
  81. package/next/head-metadata/from-next/opengraph-types.ts +267 -267
  82. package/next/head-metadata/from-next/twitter-types.ts +92 -92
  83. package/next/head-metadata/index.tsx +208 -208
  84. package/next/middleware/determine-device-mw.ts +16 -16
  85. package/package.json +78 -78
  86. package/root-layout/WHY_THIS_IS_SEPARATE.txt +1 -1
  87. package/root-layout/index.tsx +112 -112
  88. package/server-actions/firebase-app.ts +14 -14
  89. package/server-actions/index.ts +5 -5
  90. package/server-actions/store-contact.ts +51 -51
  91. package/site-def/footer/community.tsx +67 -67
  92. package/site-def/footer/company.ts +37 -37
  93. package/site-def/footer/ecosystem.ts +37 -37
  94. package/site-def/footer/index.tsx +26 -26
  95. package/site-def/footer/legal.ts +28 -28
  96. package/site-def/footer/network.ts +45 -45
  97. package/site-def/footer/svg/warpcast-logo.svg +11 -11
  98. package/site-def/index.ts +2 -2
  99. package/site-def/main-nav.tsx +338 -338
  100. package/style/cart-animation.css +29 -29
  101. package/style/checkout-animation.css +23 -23
  102. package/style/drawer-handle-overrides.css +160 -160
  103. package/style/lux-colors.css +85 -85
  104. package/style/lux-global.css +30 -30
  105. package/tailwind/fontFamily.tailwind.lux.ts +18 -18
  106. package/tailwind/index.ts +2 -2
  107. package/tailwind/lux-tw-fonts.ts +39 -39
  108. package/tailwind/tailwind.config.lux-preset.ts +10 -10
  109. package/tsconfig.json +15 -15
  110. package/types/chatbot-config.ts +6 -6
  111. package/types/chatbot-suggested-question.ts +7 -7
  112. package/types/contact-info.ts +10 -10
  113. package/types/index.ts +4 -4
  114. package/types/site-def.ts +43 -43
@@ -1,116 +1,116 @@
1
- 'use client'
2
- import React from 'react'
3
- import { useRouter } from 'next/navigation'
4
- import { observer } from 'mobx-react-lite'
5
-
6
- import { CarouselBuyCard } from '@hanzo/commerce'
7
-
8
- import {
9
- useSelectAndBuy,
10
- useCommerceDrawer,
11
- useRecentActivity
12
- } from '../../../commerce/ui/context'
13
-
14
- import CommerceDrawer from './shell'
15
- import CheckoutButton from '../checkout-button'
16
- import Micro from './micro'
17
-
18
- const CommerceUIComponent: React.FC = observer(() => {
19
-
20
- const buy = useSelectAndBuy()
21
- const drawer = useCommerceDrawer()
22
- const recent = useRecentActivity()
23
- const router = useRouter()
24
-
25
-
26
- const handleCheckout = (): void => {
27
- router.push('/checkout')
28
- }
29
-
30
- // see handleCloseGesture()
31
- const setOpen = (b: boolean): void => {
32
- if (!b) {
33
- if (!drawer.closedByUser) {
34
- drawer.setClosedByUser(true)
35
- }
36
- }
37
- }
38
-
39
- const handleHandleClicked = (): void => {
40
-
41
- if (drawer.state === 'full') {
42
- buy.hideVariants()
43
- }
44
- else if (drawer.state === 'micro') {
45
- if (drawer.showAdded) {
46
- buy.showVariants(recent.item?.sku ?? '')
47
- }
48
- // checkout only
49
- else {
50
- drawer.setClosedByUser(true)
51
- }
52
- }
53
- }
54
-
55
- const handleItemClicked = () => {
56
- buy.showVariants(recent.item?.sku ?? '')
57
- }
58
-
59
- const handleCloseGesture = (): boolean => {
60
- if (drawer.state === 'full') {
61
- buy.hideVariants()
62
- return true // "handled!"
63
- }
64
- return false
65
- }
66
-
67
-
68
- return (
69
- <CommerceDrawer
70
- open={drawer.open}
71
- setOpen={setOpen}
72
- snapPoints={drawer.points}
73
- modal={drawer.modal}
74
- activeSnapPoint={drawer.activePoint}
75
- setActiveSnapPoint={drawer.onActivePointChanged.bind(drawer)}
76
- handleHandleClicked={handleHandleClicked}
77
- handleCloseGesture={handleCloseGesture}
78
- micro={drawer.state === 'micro'}
79
- mobile={drawer.isMobile}
80
- drawerClx='flex flex-col'
81
- >
82
- {drawer.state === 'full' && (
83
- /* The actual drawer is larger than the visible area (due to awkward
84
- vaul impl. So we have to ask the drawer for its currect snappoint
85
- and constrain layout to that.
86
- */
87
- <div style={{height: drawer.snapPointPx - 24 /* fudge factor for handle area */}}>
88
- <CarouselBuyCard
89
- skuPath={buy.currentSkuPath!}
90
- checkoutButton={
91
- <CheckoutButton
92
- handleCheckout={handleCheckout}
93
- className='w-full min-w-[160px] sm:max-w-[320px]'
94
- />
95
- }
96
- onQuantityChanged={recent.quantityChanged.bind(recent)}
97
- clx='justify-between h-full pb-3 gap-8'
98
- addBtnClx='w-full min-w-[160px] sm:max-w-[320px]'
99
- buttonsAreaClx='grow-0 shrink-0 mt-0'
100
- selectorClx='max-w-[475px] justify-between grow'
101
-
102
- />
103
- </div>
104
- )}
105
- {drawer.state === 'micro' && (
106
- <Micro
107
- handleCheckout={handleCheckout}
108
- handleItemClicked={handleItemClicked}
109
- clx='w-full px-2 sm:w-[460px] sm:mx-auto md:w-[550px]'
110
- />
111
- )}
112
- </CommerceDrawer>
113
- )
114
- })
115
-
116
- export default CommerceUIComponent
1
+ 'use client'
2
+ import React from 'react'
3
+ import { useRouter } from 'next/navigation'
4
+ import { observer } from 'mobx-react-lite'
5
+
6
+ import { CarouselBuyCard } from '@hanzo/commerce'
7
+
8
+ import {
9
+ useSelectAndBuy,
10
+ useCommerceDrawer,
11
+ useRecentActivity
12
+ } from '../../../commerce/ui/context'
13
+
14
+ import CommerceDrawer from './shell'
15
+ import CheckoutButton from '../checkout-button'
16
+ import Micro from './micro'
17
+
18
+ const CommerceUIComponent: React.FC = observer(() => {
19
+
20
+ const buy = useSelectAndBuy()
21
+ const drawer = useCommerceDrawer()
22
+ const recent = useRecentActivity()
23
+ const router = useRouter()
24
+
25
+
26
+ const handleCheckout = (): void => {
27
+ router.push('/checkout')
28
+ }
29
+
30
+ // see handleCloseGesture()
31
+ const setOpen = (b: boolean): void => {
32
+ if (!b) {
33
+ if (!drawer.closedByUser) {
34
+ drawer.setClosedByUser(true)
35
+ }
36
+ }
37
+ }
38
+
39
+ const handleHandleClicked = (): void => {
40
+
41
+ if (drawer.state === 'full') {
42
+ buy.hideVariants()
43
+ }
44
+ else if (drawer.state === 'micro') {
45
+ if (drawer.showAdded) {
46
+ buy.showVariants(recent.item?.sku ?? '')
47
+ }
48
+ // checkout only
49
+ else {
50
+ drawer.setClosedByUser(true)
51
+ }
52
+ }
53
+ }
54
+
55
+ const handleItemClicked = () => {
56
+ buy.showVariants(recent.item?.sku ?? '')
57
+ }
58
+
59
+ const handleCloseGesture = (): boolean => {
60
+ if (drawer.state === 'full') {
61
+ buy.hideVariants()
62
+ return true // "handled!"
63
+ }
64
+ return false
65
+ }
66
+
67
+
68
+ return (
69
+ <CommerceDrawer
70
+ open={drawer.open}
71
+ setOpen={setOpen}
72
+ snapPoints={drawer.points}
73
+ modal={drawer.modal}
74
+ activeSnapPoint={drawer.activePoint}
75
+ setActiveSnapPoint={drawer.onActivePointChanged.bind(drawer)}
76
+ handleHandleClicked={handleHandleClicked}
77
+ handleCloseGesture={handleCloseGesture}
78
+ micro={drawer.state === 'micro'}
79
+ mobile={drawer.isMobile}
80
+ drawerClx='flex flex-col'
81
+ >
82
+ {drawer.state === 'full' && (
83
+ /* The actual drawer is larger than the visible area (due to awkward
84
+ vaul impl. So we have to ask the drawer for its currect snappoint
85
+ and constrain layout to that.
86
+ */
87
+ <div style={{height: drawer.snapPointPx - 24 /* fudge factor for handle area */}}>
88
+ <CarouselBuyCard
89
+ skuPath={buy.currentSkuPath!}
90
+ checkoutButton={
91
+ <CheckoutButton
92
+ handleCheckout={handleCheckout}
93
+ className='w-full min-w-[160px] sm:max-w-[320px]'
94
+ />
95
+ }
96
+ onQuantityChanged={recent.quantityChanged.bind(recent)}
97
+ clx='justify-between h-full pb-3 gap-8'
98
+ addBtnClx='w-full min-w-[160px] sm:max-w-[320px]'
99
+ buttonsAreaClx='grow-0 shrink-0 mt-0'
100
+ selectorClx='max-w-[475px] justify-between grow'
101
+
102
+ />
103
+ </div>
104
+ )}
105
+ {drawer.state === 'micro' && (
106
+ <Micro
107
+ handleCheckout={handleCheckout}
108
+ handleItemClicked={handleItemClicked}
109
+ clx='w-full px-2 sm:w-[460px] sm:mx-auto md:w-[550px]'
110
+ />
111
+ )}
112
+ </CommerceDrawer>
113
+ )
114
+ })
115
+
116
+ export default CommerceUIComponent
@@ -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, useRecentActivity } 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 recent = useRecentActivity()
71
- const mobile = drawer.isMobile
72
-
73
- return (
74
- <div className={cn(
75
- (drawer.showAdded ? 'grid grid-cols-2' : 'flex justify-center items-center '),
76
- (drawer.showAdded ? ((drawer.isMobile) ? '-mt-3' : '-mt-3') : ''),
77
- 'gap-2 md:gap-3 relative',
78
- clx
79
- )}>
80
- {drawer.showAdded && (
81
- <div className={'flex flex-col items-stretch ' + (drawer.isMobile ? 'justify-start' : 'group')}>
82
- <p className={'relative text-muted text-xxs md:text-xs leading-none pl-1 self-start ' + (drawer.isMobile ? 'top-[3px]' : 'top-[1px]')}>
83
- <span className='invisible'>scrictly for layout</span>
84
- {drawer.isMobile ? (
85
- <span className={PROMPT_COMMON_CLX}>tap for options:</span>
86
- ) : (<>
87
- <span className={PROMPT_COMMON_CLX + ' group-hover:opacity-0'}>recent item:</span>
88
- <span className={PROMPT_COMMON_CLX + ' opacity-0 group-hover:opacity-100'}>view options:</span>
89
- </>)}
90
- </p>
91
- <Button
92
- variant='ghost'
93
- rounded={drawer.isMobile ? 'md' : 'lg'}
94
- size={drawer.isMobile ? 'default' : 'lg'}
95
- onClick={handleItemClicked}
96
- className={cn(
97
- 'box-content',
98
- 'flex flex-row justify-between items-center gap-1',
99
- '-ml-1.5',
100
- 'overflow-hidden ',
101
- 'px-1 md:px-2 py-[2px]',
102
- 'border border-transparent group-hover:border-muted-3',
103
- 'group-hover:!bg-transparent '
104
- )}
105
- >
106
- {recent.item?.img && (<>
107
- <Image def={recent.item.img} constrainTo={CN.mobile} preload className='sm:hidden grow-0 shrink-0'/>
108
- <Image def={recent.item.img} constrainTo={CN.sm} preload className='hidden sm:block md:hidden grow-0 shrink-0'/>
109
- <Image def={recent.item.img} constrainTo={CN.desktop} preload className='hidden md:block grow-0 shrink-0'/>
110
- </>)}
111
- {recent.item && (
112
- <div className='grow w-full'>
113
- <Info item={recent.item} clx='w-full'/>
114
- </div>
115
- )}
116
- </Button>
117
- </div>
118
- )}
119
- {drawer.showCheckout && (
120
- <div className={cn(
121
- 'flex flex-col w-full',
122
- (drawer.showAdded ? 'items-stretch' : 'items-center' ),
123
- (drawer.isMobile ? 'justify-start' : 'justify-center')
124
- )}>
125
- {drawer.showAdded && <p className='invisible text-muted text-xxs md:text-xs leading-none pl-1 self-start'>for layout</p>}
126
- <CheckoutButton
127
- handleCheckout={handleCheckout}
128
- variant='primary'
129
- size={drawer.isMobile ? 'default' : 'lg'}
130
- rounded={drawer.isMobile ? 'md' : 'lg'}
131
- centerText={drawer.isMobile ? !drawer.showAdded : true}
132
- className={cn(drawer.isMobile ?
133
- (drawer.showAdded ? 'pl-3.5 pr-2.5' : 'min-w-[320px]')
134
- :
135
- (drawer.showAdded ? '' : 'w-[320px]')
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, useRecentActivity } 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 recent = useRecentActivity()
71
+ const mobile = drawer.isMobile
72
+
73
+ return (
74
+ <div className={cn(
75
+ (drawer.showAdded ? 'grid grid-cols-2' : 'flex justify-center items-center '),
76
+ (drawer.showAdded ? ((drawer.isMobile) ? '-mt-3' : '-mt-3') : ''),
77
+ 'gap-2 md:gap-3 relative',
78
+ clx
79
+ )}>
80
+ {drawer.showAdded && (
81
+ <div className={'flex flex-col items-stretch ' + (drawer.isMobile ? 'justify-start' : 'group')}>
82
+ <p className={'relative text-muted text-xxs md:text-xs leading-none pl-1 self-start ' + (drawer.isMobile ? 'top-[3px]' : 'top-[1px]')}>
83
+ <span className='invisible'>scrictly for layout</span>
84
+ {drawer.isMobile ? (
85
+ <span className={PROMPT_COMMON_CLX}>tap for options:</span>
86
+ ) : (<>
87
+ <span className={PROMPT_COMMON_CLX + ' group-hover:opacity-0'}>recent item:</span>
88
+ <span className={PROMPT_COMMON_CLX + ' opacity-0 group-hover:opacity-100'}>view options:</span>
89
+ </>)}
90
+ </p>
91
+ <Button
92
+ variant='ghost'
93
+ rounded={drawer.isMobile ? 'md' : 'lg'}
94
+ size={drawer.isMobile ? 'default' : 'lg'}
95
+ onClick={handleItemClicked}
96
+ className={cn(
97
+ 'box-content',
98
+ 'flex flex-row justify-between items-center gap-1',
99
+ '-ml-1.5',
100
+ 'overflow-hidden ',
101
+ 'px-1 md:px-2 py-[2px]',
102
+ 'border border-transparent group-hover:border-muted-3',
103
+ 'group-hover:!bg-transparent '
104
+ )}
105
+ >
106
+ {recent.item?.img && (<>
107
+ <Image def={recent.item.img} constrainTo={CN.mobile} preload className='sm:hidden grow-0 shrink-0'/>
108
+ <Image def={recent.item.img} constrainTo={CN.sm} preload className='hidden sm:block md:hidden grow-0 shrink-0'/>
109
+ <Image def={recent.item.img} constrainTo={CN.desktop} preload className='hidden md:block grow-0 shrink-0'/>
110
+ </>)}
111
+ {recent.item && (
112
+ <div className='grow w-full'>
113
+ <Info item={recent.item} clx='w-full'/>
114
+ </div>
115
+ )}
116
+ </Button>
117
+ </div>
118
+ )}
119
+ {drawer.showCheckout && (
120
+ <div className={cn(
121
+ 'flex flex-col w-full',
122
+ (drawer.showAdded ? 'items-stretch' : 'items-center' ),
123
+ (drawer.isMobile ? 'justify-start' : 'justify-center')
124
+ )}>
125
+ {drawer.showAdded && <p className='invisible text-muted text-xxs md:text-xs leading-none pl-1 self-start'>for layout</p>}
126
+ <CheckoutButton
127
+ handleCheckout={handleCheckout}
128
+ variant='primary'
129
+ size={drawer.isMobile ? 'default' : 'lg'}
130
+ rounded={drawer.isMobile ? 'md' : 'lg'}
131
+ centerText={drawer.isMobile ? !drawer.showAdded : true}
132
+ className={cn(drawer.isMobile ?
133
+ (drawer.showAdded ? 'pl-3.5 pr-2.5' : 'min-w-[320px]')
134
+ :
135
+ (drawer.showAdded ? '' : 'w-[320px]')
136
+ )}
137
+ />
138
+ </div>
139
+ )}
140
+ </div>
141
+ )
142
+ })
143
+
144
+ export default Micro