@luxfi/core 5.2.12 → 5.2.13

Sign up to get free protection for your applications and to get access to all the features.
Files changed (178) hide show
  1. package/commerce/ui/conf.ts +13 -13
  2. package/commerce/ui/context.tsx +126 -126
  3. package/commerce/ui/store.ts +304 -304
  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 +42 -42
  11. package/components/chat-widget.tsx +85 -85
  12. package/components/commerce/add-widget.tsx +20 -20
  13. package/components/commerce/bag-button.tsx +98 -98
  14. package/components/commerce/buy-button.tsx +34 -34
  15. package/components/commerce/checkout-button.tsx +129 -129
  16. package/components/commerce/checkout-panel/dt-bag-carousel.tsx +36 -36
  17. package/components/commerce/checkout-panel/dt-checkout-panel.tsx +84 -84
  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 -130
  29. package/components/commerce/drawer/index.tsx +99 -99
  30. package/components/commerce/drawer/micro.tsx +144 -144
  31. package/components/commerce/drawer/shell.tsx +85 -85
  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 +48 -48
  36. package/components/commerce/mobile-nav-menu-item.tsx +49 -49
  37. package/components/commerce/mobile-nav-menu.tsx +101 -101
  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 +50 -50
  45. package/components/header/index.tsx +52 -52
  46. package/components/header/mobile.tsx +163 -163
  47. package/components/header/theme-toggle.tsx +26 -26
  48. package/components/icons/24k-gold-card.tsx +43 -43
  49. package/components/icons/ai-chat-act.tsx +47 -47
  50. package/components/icons/ai-chat.tsx +29 -29
  51. package/components/icons/anodized-titanium.tsx +45 -45
  52. package/components/icons/avatar.tsx +11 -11
  53. package/components/icons/bag-icon.tsx +10 -10
  54. package/components/icons/blog-act.tsx +14 -14
  55. package/components/icons/blog.tsx +20 -20
  56. package/components/icons/bridge-act.tsx +18 -18
  57. package/components/icons/bridge.tsx +68 -68
  58. package/components/icons/changelog-act.tsx +15 -15
  59. package/components/icons/changelog.tsx +21 -21
  60. package/components/icons/chrome.tsx +45 -45
  61. package/components/icons/coins-act.tsx +29 -29
  62. package/components/icons/coins.tsx +20 -20
  63. package/components/icons/compare-cards-act.tsx +30 -30
  64. package/components/icons/compare-cards.tsx +21 -21
  65. package/components/icons/credit-act.tsx +29 -29
  66. package/components/icons/credit.tsx +20 -20
  67. package/components/icons/customer-support-act.tsx +27 -27
  68. package/components/icons/customer-support.tsx +21 -21
  69. package/components/icons/customers-act.tsx +65 -65
  70. package/components/icons/customers.tsx +33 -33
  71. package/components/icons/developer-docs-act.tsx +26 -26
  72. package/components/icons/developer-docs.tsx +20 -20
  73. package/components/icons/exchange-act.tsx +27 -27
  74. package/components/icons/exchange.tsx +21 -21
  75. package/components/icons/explorer-act.tsx +27 -27
  76. package/components/icons/explorer.tsx +22 -22
  77. package/components/icons/faqs-act.tsx +27 -27
  78. package/components/icons/faqs.tsx +21 -21
  79. package/components/icons/github.tsx +14 -14
  80. package/components/icons/guides-act.tsx +26 -26
  81. package/components/icons/guides.tsx +21 -21
  82. package/components/icons/gun-metal.tsx +44 -44
  83. package/components/icons/index.tsx +43 -43
  84. package/components/icons/integrations-act.tsx +41 -41
  85. package/components/icons/integrations.tsx +25 -25
  86. package/components/icons/irradescent.tsx +41 -41
  87. package/components/icons/launch-subnet.tsx +21 -21
  88. package/components/icons/launchsubnet-act.tsx +29 -29
  89. package/components/icons/left-arrow.tsx +11 -11
  90. package/components/icons/lux-finance-act.tsx +34 -34
  91. package/components/icons/lux-finance.tsx +23 -23
  92. package/components/icons/lux-logo.tsx +10 -10
  93. package/components/icons/lux-pass-act.tsx +41 -41
  94. package/components/icons/lux-pass.tsx +25 -25
  95. package/components/icons/lux-quests-act.tsx +15 -15
  96. package/components/icons/lux-quests.tsx +21 -21
  97. package/components/icons/market-act.tsx +39 -39
  98. package/components/icons/market.tsx +24 -24
  99. package/components/icons/mirrored-titanium.tsx +46 -46
  100. package/components/icons/more-benefits-act.tsx +29 -29
  101. package/components/icons/more-benefits.tsx +21 -21
  102. package/components/icons/open-source-act.tsx +41 -41
  103. package/components/icons/open-source.tsx +26 -26
  104. package/components/icons/right-arrow.tsx +10 -10
  105. package/components/icons/safe-act.tsx +77 -77
  106. package/components/icons/safe.tsx +37 -37
  107. package/components/icons/search.tsx +12 -12
  108. package/components/icons/secure-delivery.tsx +13 -13
  109. package/components/icons/shop-act.tsx +29 -29
  110. package/components/icons/shop.tsx +20 -20
  111. package/components/icons/social-icon.tsx +35 -35
  112. package/components/icons/social-svg.css +3 -3
  113. package/components/icons/sterling-silver-card.tsx +44 -44
  114. package/components/icons/templates-act.tsx +29 -29
  115. package/components/icons/templates.tsx +21 -21
  116. package/components/icons/validators-act.tsx +42 -42
  117. package/components/icons/validators.tsx +41 -41
  118. package/components/icons/view-all-card-act.tsx +28 -28
  119. package/components/icons/view-all-card.tsx +20 -20
  120. package/components/icons/wallet-act.tsx +29 -29
  121. package/components/icons/wallet.tsx +20 -20
  122. package/components/icons/warpcast.tsx +58 -58
  123. package/components/icons/youtube-logo.tsx +59 -59
  124. package/components/index.ts +27 -27
  125. package/components/logo.tsx +89 -89
  126. package/components/main.tsx +27 -27
  127. package/components/mini-chart/index.tsx +7 -7
  128. package/components/mini-chart/mini-chart-props.ts +43 -43
  129. package/components/mini-chart/mini-chart.tsx +85 -85
  130. package/components/mini-chart/wrapper.tsx +23 -23
  131. package/components/not-found/index.tsx +28 -28
  132. package/components/not-found/not-found-content.mdx +5 -5
  133. package/components/scripts.tsx +24 -24
  134. package/components/tooltip.tsx +31 -31
  135. package/environment.d.ts +5 -5
  136. package/next/analytics/fpixel.ts +15 -15
  137. package/next/analytics/google-analytics.ts +13 -13
  138. package/next/analytics/index.ts +3 -3
  139. package/next/analytics/pixel-analytics.tsx +54 -54
  140. package/next/font/get-app-router-font-classes.ts +12 -12
  141. package/next/font/load-and-return-lux-next-fonts-on-import.ts +68 -68
  142. package/next/font/next-font-desc.ts +27 -27
  143. package/next/font/pages-router-font-vars.tsx +18 -18
  144. package/next/head-metadata/from-next/metadata-types.ts +158 -158
  145. package/next/head-metadata/from-next/opengraph-types.ts +267 -267
  146. package/next/head-metadata/from-next/twitter-types.ts +92 -92
  147. package/next/head-metadata/index.tsx +208 -208
  148. package/next/middleware/determine-device-mw.ts +16 -16
  149. package/package.json +79 -79
  150. package/root-layout/WHY_THIS_IS_SEPARATE.txt +1 -1
  151. package/root-layout/index.tsx +112 -112
  152. package/server-actions/firebase-app.ts +14 -14
  153. package/server-actions/index.ts +5 -5
  154. package/server-actions/store-contact.ts +51 -51
  155. package/site-def/footer/community.tsx +67 -67
  156. package/site-def/footer/company.ts +37 -37
  157. package/site-def/footer/ecosystem.ts +37 -37
  158. package/site-def/footer/index.tsx +26 -26
  159. package/site-def/footer/legal.ts +28 -28
  160. package/site-def/footer/network.ts +45 -45
  161. package/site-def/footer/svg/warpcast-logo.svg +11 -11
  162. package/site-def/index.ts +2 -2
  163. package/site-def/main-nav.tsx +458 -458
  164. package/style/cart-animation.css +29 -29
  165. package/style/checkout-animation.css +23 -23
  166. package/style/drawer-handle-overrides.css +160 -160
  167. package/style/lux-colors.css +85 -85
  168. package/style/lux-global.css +47 -47
  169. package/tailwind/fontFamily.tailwind.lux.ts +18 -18
  170. package/tailwind/index.ts +2 -2
  171. package/tailwind/lux-tw-fonts.ts +39 -39
  172. package/tailwind/tailwind.config.lux-preset.ts +10 -10
  173. package/tsconfig.json +15 -15
  174. package/types/chatbot-config.ts +6 -6
  175. package/types/chatbot-suggested-question.ts +7 -7
  176. package/types/contact-info.ts +10 -10
  177. package/types/index.ts +4 -4
  178. package/types/site-def.ts +43 -43
@@ -1,78 +1,78 @@
1
- 'use client'
2
- import React, { useState, useEffect } from 'react'
3
- import { useRouter } from 'next/navigation'
4
-
5
- import { X } from 'lucide-react'
6
-
7
- import {
8
- Popover,
9
- PopoverContent,
10
- PopoverTrigger,
11
- PopoverClose,
12
- } from "@hanzo/ui/primitives"
13
-
14
- import { cn } from '@hanzo/ui/util'
15
- import { CartPanel, useCommerce } from '@hanzo/commerce'
16
-
17
- import * as Icons from '../icons'
18
- import sendGAEvent from '../../next/analytics/google-analytics'
19
-
20
- const DesktopBagPopup: React.FC<{
21
- triggerClx?: string
22
- popupClx?: string
23
- trigger: React.ReactNode
24
- }> = ({
25
- triggerClx='',
26
- popupClx='',
27
- trigger
28
- }) => {
29
- const cmmc = useCommerce()
30
-
31
- const [bagOpen, setBagOpen] = useState<boolean>(false)
32
- const router = useRouter()
33
-
34
- useEffect(() => {
35
- if (bagOpen) {
36
- sendGAEvent('view_cart', {
37
- items: cmmc.cartItems.map((item) => ({
38
- item_id: item.sku,
39
- item_name: item.title,
40
- item_category: item.familyId,
41
- price: item.price,
42
- quantity: item.quantity
43
- })),
44
- value: cmmc.cartTotal,
45
- currency: 'USD',
46
- })
47
- }
48
- }, [bagOpen])
49
-
50
- return (
51
- <Popover open={bagOpen} onOpenChange={setBagOpen}>
52
- <PopoverTrigger className={triggerClx}>
53
- {trigger}
54
- </PopoverTrigger>
55
- <PopoverContent sideOffset={28} className={cn('relative flex flex-col p-0 px-4 pb-4 pt-2', popupClx)}>
56
- <PopoverClose className='absolute z-above-content right-2 top-2 self-end hover:bg-level-3 text-muted hover:text-accent p-1 rounded-full'><X className='w-5 h-5'/></PopoverClose>
57
- <CartPanel
58
- handleCheckout={() => {router.push('/checkout')}}
59
- className='mt-4 mb-4 border-none py-0 px-4'
60
- listClx='rounded-sm pr-3'
61
- scrollAfter={5}
62
- scrollHeightClx='h-[70vh]'
63
- itemClx='mt-3'
64
- totalClx='sticky px-1 pr-2 -bottom-[1px] bg-level-1'
65
- buttonClx='max-w-[220px] flex-none'
66
- >
67
- <div className='flex flex-row items-center flex-none justify-center '>
68
- <Icons.bag className='mr-2 relative w-6 h-7 fill-foreground ' />
69
- <p className='font-heading text-foreground text-default'>Your Bag</p>
70
- </div>
71
- <div className='h-[1px] w-pr-80 bg-muted-3 mx-auto mt-1.5 flex-none'/>
72
- </CartPanel>
73
- </PopoverContent>
74
- </Popover>
75
- )
76
- }
77
-
78
- export default DesktopBagPopup
1
+ 'use client'
2
+ import React, { useState, useEffect } from 'react'
3
+ import { useRouter } from 'next/navigation'
4
+
5
+ import { X } from 'lucide-react'
6
+
7
+ import {
8
+ Popover,
9
+ PopoverContent,
10
+ PopoverTrigger,
11
+ PopoverClose,
12
+ } from "@hanzo/ui/primitives"
13
+
14
+ import { cn } from '@hanzo/ui/util'
15
+ import { CartPanel, useCommerce } from '@hanzo/commerce'
16
+
17
+ import * as Icons from '../icons'
18
+ import sendGAEvent from '../../next/analytics/google-analytics'
19
+
20
+ const DesktopBagPopup: React.FC<{
21
+ triggerClx?: string
22
+ popupClx?: string
23
+ trigger: React.ReactNode
24
+ }> = ({
25
+ triggerClx='',
26
+ popupClx='',
27
+ trigger
28
+ }) => {
29
+ const cmmc = useCommerce()
30
+
31
+ const [bagOpen, setBagOpen] = useState<boolean>(false)
32
+ const router = useRouter()
33
+
34
+ useEffect(() => {
35
+ if (bagOpen) {
36
+ sendGAEvent('view_cart', {
37
+ items: cmmc.cartItems.map((item) => ({
38
+ item_id: item.sku,
39
+ item_name: item.title,
40
+ item_category: item.familyId,
41
+ price: item.price,
42
+ quantity: item.quantity
43
+ })),
44
+ value: cmmc.cartTotal,
45
+ currency: 'USD',
46
+ })
47
+ }
48
+ }, [bagOpen])
49
+
50
+ return (
51
+ <Popover open={bagOpen} onOpenChange={setBagOpen}>
52
+ <PopoverTrigger className={triggerClx}>
53
+ {trigger}
54
+ </PopoverTrigger>
55
+ <PopoverContent sideOffset={28} className={cn('relative flex flex-col p-0 px-4 pb-4 pt-2', popupClx)}>
56
+ <PopoverClose className='absolute z-above-content right-2 top-2 self-end hover:bg-level-3 text-muted hover:text-accent p-1 rounded-full'><X className='w-5 h-5'/></PopoverClose>
57
+ <CartPanel
58
+ handleCheckout={() => {router.push('/checkout')}}
59
+ className='mt-4 mb-4 border-none py-0 px-4'
60
+ listClx='rounded-sm pr-3'
61
+ scrollAfter={5}
62
+ scrollHeightClx='h-[70vh]'
63
+ itemClx='mt-3'
64
+ totalClx='sticky px-1 pr-2 -bottom-[1px] bg-level-1'
65
+ buttonClx='max-w-[220px] flex-none'
66
+ >
67
+ <div className='flex flex-row items-center flex-none justify-center '>
68
+ <Icons.bag className='mr-2 relative w-6 h-7 fill-foreground ' />
69
+ <p className='font-heading text-foreground text-default'>Your Bag</p>
70
+ </div>
71
+ <div className='h-[1px] w-pr-80 bg-muted-3 mx-auto mt-1.5 flex-none'/>
72
+ </CartPanel>
73
+ </PopoverContent>
74
+ </Popover>
75
+ )
76
+ }
77
+
78
+ export default DesktopBagPopup
@@ -1,131 +1,131 @@
1
- "use client"
2
-
3
- import * as React from "react"
4
- import Link from "next/link"
5
- import { cn } from '@hanzo/ui/util'
6
- import type { LinkDef } from '@hanzo/ui/types'
7
- import type { ChildMenu, LinkDefExtended } from "../../site-def/main-nav"
8
- import {
9
- NavigationMenu,
10
- NavigationMenuContent,
11
- NavigationMenuItem,
12
- NavigationMenuLink,
13
- NavigationMenuList,
14
- NavigationMenuTrigger,
15
- navigationMenuTriggerStyle
16
- } from '@hanzo/ui/primitives'
17
- import Warpcast from "../icons/warpcast"
18
-
19
- const DesktopNav: React.FC<{ links: LinkDefExtended[] }> = ({ links }) => (
20
- links.length > 0 ? (
21
- <NavigationMenu>
22
- <NavigationMenuList>
23
- {links.map((el, index) => {
24
- if (el.isAIMenu) {
25
- return (
26
- <NavigationMenuItem key={index}>
27
- <Link href={el.href} legacyBehavior passHref >
28
- <NavigationMenuLink className={cn('!rounded-2xl ', navigationMenuTriggerStyle())}>
29
- {el.title}
30
- </NavigationMenuLink>
31
- </Link>
32
- </NavigationMenuItem>
33
- )
34
- } else if (el.title === "Cards") {
35
- return (
36
- <NavigationMenuItem key={index}>
37
- <NavigationMenuTrigger className="!rounded-2xl">{el.title}</NavigationMenuTrigger>
38
- <NavigationMenuContent className="!left-0">
39
- <div className="grid grid-cols-3 w-[846px]">
40
- <GroupChildMenu childs={el.childMenu} />
41
- </div>
42
- </NavigationMenuContent>
43
- </NavigationMenuItem>
44
- )
45
- } else {
46
- return (
47
- <NavigationMenuItem key={index}>
48
- <NavigationMenuTrigger className="!rounded-2xl">{el.title}</NavigationMenuTrigger>
49
- <NavigationMenuContent className="!left-0">
50
- <div className="flex flex-row">
51
- <GroupChildMenu childs={el.childMenu} />
52
- </div>
53
- </NavigationMenuContent>
54
- </NavigationMenuItem>
55
- )
56
- }
57
- })}
58
- </NavigationMenuList>
59
- </NavigationMenu>
60
- ) : null
61
- )
62
- export default DesktopNav
63
-
64
- const ListItem = React.forwardRef<
65
- React.ElementRef<"a">,
66
- React.ComponentPropsWithoutRef<"a">
67
- >(({ className, title, children, ...props }, ref) => {
68
- return (
69
- <li>
70
- <NavigationMenuLink asChild>
71
- <a
72
- ref={ref}
73
- className={cn(
74
- "block select-none space-y-1 rounded-md p-3 leading-none no-underline outline-none transition-colors hover:bg-level-1 hover:text-accent-foreground focus:bg-level-1 focus:text-accent-foreground",
75
- className
76
- )}
77
- {...props}
78
- >
79
- <div className="text-sm font-medium leading-none">{title}</div>
80
- <p className="line-clamp-3 text-sm leading-snug text-muted-foreground">
81
- {children}
82
- </p>
83
- </a>
84
- </NavigationMenuLink>
85
- </li>
86
- )
87
- })
88
- ListItem.displayName = "ListItem"
89
-
90
- const GroupChildMenu: React.FC<{ childs: ChildMenu[] | undefined }> = ({ childs }) => {
91
- if (!childs) {
92
- return null
93
- }
94
-
95
- let groupedChildMenus = childs.reduce((grouped: Record<string, ChildMenu[]>, childLink) => {
96
- if (childLink.groupName) {
97
- if (!grouped[childLink.groupName]) {
98
- grouped[childLink.groupName] = []
99
- }
100
- grouped[childLink.groupName].push(childLink)
101
- }
102
- return grouped
103
- }, {} as Record<string, ChildMenu[]>)
104
-
105
- return Object.entries(groupedChildMenus).map(([groupName, childLinks]: [string, ChildMenu[]]) => (
106
- <div key={groupName} className={`py-4 px-4 ${groupName === "Elite Card" || groupName === "Sovereign Card" ? "-mt-34" : ""}`}>
107
- <h2 className="text-muted-1">{groupName}</h2>
108
- <ul className="w-[200px] gap-3 md:w-[250px] lg:w-[250px]">
109
- {childLinks.map((link) => (
110
- <div className="flex items-center element-container text-muted-1 hover:text-primary" key={link.title}>
111
- {
112
- link.icon_act ? (
113
- <>
114
- <div className="icon-container-nor">{link.icon}</div>
115
- <div className="icon-container-hov">{link.icon_act}</div>
116
- </>
117
- ):(
118
- <div>{link.icon}</div>
119
- )
120
- }
121
- <div className="text-container">
122
- <ListItem key={link.title} title={link.title} href={link.href} className="hover:bg-transparent">
123
- {link.contents}
124
- </ListItem>
125
- </div>
126
- </div>
127
- ))}
128
- </ul>
129
- </div>
130
- ))
1
+ "use client"
2
+
3
+ import * as React from "react"
4
+ import Link from "next/link"
5
+ import { cn } from '@hanzo/ui/util'
6
+ import type { LinkDef } from '@hanzo/ui/types'
7
+ import type { ChildMenu, LinkDefExtended } from "../../site-def/main-nav"
8
+ import {
9
+ NavigationMenu,
10
+ NavigationMenuContent,
11
+ NavigationMenuItem,
12
+ NavigationMenuLink,
13
+ NavigationMenuList,
14
+ NavigationMenuTrigger,
15
+ navigationMenuTriggerStyle
16
+ } from '@hanzo/ui/primitives'
17
+ import Warpcast from "../icons/warpcast"
18
+
19
+ const DesktopNav: React.FC<{ links: LinkDefExtended[] }> = ({ links }) => (
20
+ links.length > 0 ? (
21
+ <NavigationMenu>
22
+ <NavigationMenuList>
23
+ {links.map((el, index) => {
24
+ if (el.isAIMenu) {
25
+ return (
26
+ <NavigationMenuItem key={index}>
27
+ <Link href={el.href} legacyBehavior passHref >
28
+ <NavigationMenuLink className={cn('!rounded-2xl ', navigationMenuTriggerStyle())}>
29
+ {el.title}
30
+ </NavigationMenuLink>
31
+ </Link>
32
+ </NavigationMenuItem>
33
+ )
34
+ } else if (el.title === "Cards") {
35
+ return (
36
+ <NavigationMenuItem key={index}>
37
+ <NavigationMenuTrigger className="!rounded-2xl">{el.title}</NavigationMenuTrigger>
38
+ <NavigationMenuContent className="!left-0">
39
+ <div className="grid grid-cols-3 w-[846px]">
40
+ <GroupChildMenu childs={el.childMenu} />
41
+ </div>
42
+ </NavigationMenuContent>
43
+ </NavigationMenuItem>
44
+ )
45
+ } else {
46
+ return (
47
+ <NavigationMenuItem key={index}>
48
+ <NavigationMenuTrigger className="!rounded-2xl">{el.title}</NavigationMenuTrigger>
49
+ <NavigationMenuContent className="!left-0">
50
+ <div className="flex flex-row">
51
+ <GroupChildMenu childs={el.childMenu} />
52
+ </div>
53
+ </NavigationMenuContent>
54
+ </NavigationMenuItem>
55
+ )
56
+ }
57
+ })}
58
+ </NavigationMenuList>
59
+ </NavigationMenu>
60
+ ) : null
61
+ )
62
+ export default DesktopNav
63
+
64
+ const ListItem = React.forwardRef<
65
+ React.ElementRef<"a">,
66
+ React.ComponentPropsWithoutRef<"a">
67
+ >(({ className, title, children, ...props }, ref) => {
68
+ return (
69
+ <li>
70
+ <NavigationMenuLink asChild>
71
+ <a
72
+ ref={ref}
73
+ className={cn(
74
+ "block select-none space-y-1 rounded-md p-3 leading-none no-underline outline-none transition-colors hover:bg-level-1 hover:text-accent-foreground focus:bg-level-1 focus:text-accent-foreground",
75
+ className
76
+ )}
77
+ {...props}
78
+ >
79
+ <div className="text-sm font-medium leading-none">{title}</div>
80
+ <p className="line-clamp-3 text-sm leading-snug text-muted-foreground">
81
+ {children}
82
+ </p>
83
+ </a>
84
+ </NavigationMenuLink>
85
+ </li>
86
+ )
87
+ })
88
+ ListItem.displayName = "ListItem"
89
+
90
+ const GroupChildMenu: React.FC<{ childs: ChildMenu[] | undefined }> = ({ childs }) => {
91
+ if (!childs) {
92
+ return null
93
+ }
94
+
95
+ let groupedChildMenus = childs.reduce((grouped: Record<string, ChildMenu[]>, childLink) => {
96
+ if (childLink.groupName) {
97
+ if (!grouped[childLink.groupName]) {
98
+ grouped[childLink.groupName] = []
99
+ }
100
+ grouped[childLink.groupName].push(childLink)
101
+ }
102
+ return grouped
103
+ }, {} as Record<string, ChildMenu[]>)
104
+
105
+ return Object.entries(groupedChildMenus).map(([groupName, childLinks]: [string, ChildMenu[]]) => (
106
+ <div key={groupName} className={`py-4 px-4 ${groupName === "Elite Card" || groupName === "Sovereign Card" ? "-mt-34" : ""}`}>
107
+ <h2 className="text-muted-1">{groupName}</h2>
108
+ <ul className="w-[200px] gap-3 md:w-[250px] lg:w-[250px]">
109
+ {childLinks.map((link) => (
110
+ <div className="flex items-center element-container text-muted-1 hover:text-primary" key={link.title}>
111
+ {
112
+ link.icon_act ? (
113
+ <>
114
+ <div className="icon-container-nor">{link.icon}</div>
115
+ <div className="icon-container-hov">{link.icon_act}</div>
116
+ </>
117
+ ):(
118
+ <div>{link.icon}</div>
119
+ )
120
+ }
121
+ <div className="text-container">
122
+ <ListItem key={link.title} title={link.title} href={link.href} className="hover:bg-transparent">
123
+ {link.contents}
124
+ </ListItem>
125
+ </div>
126
+ </div>
127
+ ))}
128
+ </ul>
129
+ </div>
130
+ ))
131
131
  }
@@ -1,99 +1,99 @@
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
-
31
- const handleHandleClicked = (): void => {
32
-
33
- if (drawer.state === 'full') {
34
- buy.hideVariants()
35
- }
36
- else if (drawer.state === 'micro') {
37
- if (drawer.showAdded) {
38
- buy.showVariants(recent.item?.sku ?? '')
39
- }
40
- // checkout only
41
- else {
42
- drawer.setClosedByUser(true)
43
- }
44
- }
45
- }
46
-
47
- const handleItemClicked = () => {
48
- buy.showVariants(recent.item?.sku ?? '')
49
- }
50
-
51
- const handleCloseGesture = (): boolean => {
52
- if (drawer.state === 'full') {
53
- buy.hideVariants()
54
- return true // "handled!"
55
- }
56
- return false
57
- }
58
-
59
- return (
60
- <CommerceDrawer
61
- handleHandleClicked={handleHandleClicked}
62
- handleCloseGesture={handleCloseGesture}
63
- drawerClx='flex flex-col'
64
- >
65
- {drawer.state === 'full' && (
66
- /* The actual drawer is larger than the visible area (due to awkward
67
- vaul impl. So we have to ask the drawer for its currect snappoint
68
- and constrain layout to that.
69
- */
70
- <div style={{height: drawer.snapPointPx - 24 /* fudge factor for handle area */}}>
71
- <CarouselBuyCard
72
- skuPath={buy.currentSkuPath!}
73
- checkoutButton={
74
- <CheckoutButton
75
- handleCheckout={handleCheckout}
76
- className='w-full min-w-[160px] sm:max-w-[320px]'
77
- />
78
- }
79
- onQuantityChanged={recent.quantityChanged.bind(recent)}
80
- clx='justify-between h-full pb-3 gap-8'
81
- addBtnClx='w-full min-w-[160px] sm:max-w-[320px]'
82
- buttonsAreaClx='grow-0 shrink-0 mt-0'
83
- selectorClx='max-w-[475px] justify-between grow'
84
-
85
- />
86
- </div>
87
- )}
88
- {drawer.state === 'micro' && (
89
- <Micro
90
- handleCheckout={handleCheckout}
91
- handleItemClicked={handleItemClicked}
92
- clx='w-full px-2 sm:w-[460px] sm:mx-auto md:w-[550px]'
93
- />
94
- )}
95
- </CommerceDrawer>
96
- )
97
- })
98
-
99
- 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
+
31
+ const handleHandleClicked = (): void => {
32
+
33
+ if (drawer.state === 'full') {
34
+ buy.hideVariants()
35
+ }
36
+ else if (drawer.state === 'micro') {
37
+ if (drawer.showAdded) {
38
+ buy.showVariants(recent.item?.sku ?? '')
39
+ }
40
+ // checkout only
41
+ else {
42
+ drawer.setClosedByUser(true)
43
+ }
44
+ }
45
+ }
46
+
47
+ const handleItemClicked = () => {
48
+ buy.showVariants(recent.item?.sku ?? '')
49
+ }
50
+
51
+ const handleCloseGesture = (): boolean => {
52
+ if (drawer.state === 'full') {
53
+ buy.hideVariants()
54
+ return true // "handled!"
55
+ }
56
+ return false
57
+ }
58
+
59
+ return (
60
+ <CommerceDrawer
61
+ handleHandleClicked={handleHandleClicked}
62
+ handleCloseGesture={handleCloseGesture}
63
+ drawerClx='flex flex-col'
64
+ >
65
+ {drawer.state === 'full' && (
66
+ /* The actual drawer is larger than the visible area (due to awkward
67
+ vaul impl. So we have to ask the drawer for its currect snappoint
68
+ and constrain layout to that.
69
+ */
70
+ <div style={{height: drawer.snapPointPx - 24 /* fudge factor for handle area */}}>
71
+ <CarouselBuyCard
72
+ skuPath={buy.currentSkuPath!}
73
+ checkoutButton={
74
+ <CheckoutButton
75
+ handleCheckout={handleCheckout}
76
+ className='w-full min-w-[160px] sm:max-w-[320px]'
77
+ />
78
+ }
79
+ onQuantityChanged={recent.quantityChanged.bind(recent)}
80
+ clx='justify-between h-full pb-3 gap-8'
81
+ addBtnClx='w-full min-w-[160px] sm:max-w-[320px]'
82
+ buttonsAreaClx='grow-0 shrink-0 mt-0'
83
+ selectorClx='max-w-[475px] justify-between grow'
84
+
85
+ />
86
+ </div>
87
+ )}
88
+ {drawer.state === 'micro' && (
89
+ <Micro
90
+ handleCheckout={handleCheckout}
91
+ handleItemClicked={handleItemClicked}
92
+ clx='w-full px-2 sm:w-[460px] sm:mx-auto md:w-[550px]'
93
+ />
94
+ )}
95
+ </CommerceDrawer>
96
+ )
97
+ })
98
+
99
+ export default CommerceUIComponent