@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,25 +1,25 @@
1
- export { default as AccessCodeInput } from './access-code-input'
2
- export { default as ChatWidget } from './chat-widget'
3
- export { default as ContactDialog } from './contact-dialog'
4
- export { default as Copyright} from './copyright'
5
- export { default as Footer } from './footer'
6
- export { default as Header } from './header'
7
- export * as Icons from './icons'
8
- export { default as Logo } from './logo'
9
- export { default as Main } from './main'
10
- export { default as MiniChart } from './mini-chart'
11
- export { default as NotFound } from './not-found'
12
-
13
- export { default as AuthListener } from './auth/auth-listener'
14
- export { default as AddWidget } from './commerce/add-widget'
15
- export { default as BuyDrawer } from './commerce/drawer'
16
- export { default as DrawerMargin } from './drawer-margin'
17
- export { default as BuyButton } from './commerce/buy-button'
18
- export { default as CheckoutButton } from './commerce/checkout-button'
19
- export { default as CheckoutPanel } from './commerce/checkout-panel'
20
- export { default as CheckoutWidget } from './commerce/checkout-widget'
21
- export { default as LoginPanel } from './auth/login-panel'
22
- export { default as Scripts } from './scripts'
23
-
24
- export { default as EmblaAutoplay } from 'embla-carousel-autoplay'
25
-
1
+ export { default as AccessCodeInput } from './access-code-input'
2
+ export { default as ChatWidget } from './chat-widget'
3
+ export { default as ContactDialog } from './contact-dialog'
4
+ export { default as Copyright} from './copyright'
5
+ export { default as Footer } from './footer'
6
+ export { default as Header } from './header'
7
+ export * as Icons from './icons'
8
+ export { default as Logo } from './logo'
9
+ export { default as Main } from './main'
10
+ export { default as MiniChart } from './mini-chart'
11
+ export { default as NotFound } from './not-found'
12
+
13
+ export { default as AuthListener } from './auth/auth-listener'
14
+ export { default as AddWidget } from './commerce/add-widget'
15
+ export { default as BuyDrawer } from './commerce/drawer'
16
+ export { default as DrawerMargin } from './drawer-margin'
17
+ export { default as BuyButton } from './commerce/buy-button'
18
+ export { default as CheckoutButton } from './commerce/checkout-button'
19
+ export { default as CheckoutPanel } from './commerce/checkout-panel'
20
+ export { default as CheckoutWidget } from './commerce/checkout-widget'
21
+ export { default as LoginPanel } from './auth/login-panel'
22
+ export { default as Scripts } from './scripts'
23
+
24
+ export { default as EmblaAutoplay } from 'embla-carousel-autoplay'
25
+
@@ -1,81 +1,81 @@
1
- import React from 'react'
2
- import Link from 'next/link'
3
-
4
- import { type TShirtSize } from '@hanzo/ui/types'
5
- import { cn } from '@hanzo/ui/util'
6
-
7
- import * as Icons from './icons'
8
-
9
- const Logo: React.FC<{
10
- size?: TShirtSize
11
- layout?: 'text-only' | 'logo-only' | 'full'
12
- href?: string
13
- className?: string
14
- spanClassName?: string
15
- }> = ({
16
- size,
17
- href, // no default please!
18
- className='',
19
- spanClassName,
20
- layout='full'
21
- }) => {
22
- let classes: any = {}
23
- const toAdd = (layout === 'logo-only') ? {
24
- span: ' hidden',
25
- icon: ''
26
- } :
27
- (layout === 'text-only') ? {
28
- span: '',
29
- icon: ' hidden'
30
- } :
31
- {
32
- span: '',
33
- icon: ''
34
- }
35
-
36
- if (size === 'lg' || size === 'xl' ) { // for safety
37
- classes.icon = 'h-10 w-10 mr-4 color-inherit' + toAdd.icon
38
- classes.span = 'text-3xl' + toAdd.span
39
- }
40
- // match lux.network
41
- else if (size === 'md') {
42
- classes.icon = 'h-[32px] w-[32px] mr-[12px] color-inherit' + toAdd.icon
43
- classes.span = 'text-[1.8rem]/[1.8rem] tracking-tighter' + toAdd.span
44
- }
45
- else if (size === 'sm' ) {
46
- classes.icon = 'h-6 w-6 mr-2 color-inherit' + toAdd.icon
47
- classes.span = 'text-lg' + toAdd.span
48
- }
49
- // xs
50
- else {
51
- classes.icon = 'h-4 w-4 mr-1 color-inherit' + toAdd.icon
52
- classes.span = 'text-base' + toAdd.span
53
- }
54
-
55
- const outerClasses = 'flex flex-row items-center ' + className
56
- const spanClasses = 'inline-block font-bold font-heading '
57
- + spanClassName
58
- + (href ? ' hover:text-accent ' : ' cursor-default ')
59
- + classes.span
60
-
61
- const Inner: React.FC = () => (<>
62
- <Icons.logo className={classes.icon} />
63
- <span className={cn(spanClasses, ' text-inherit')}>LUX</span>
64
- </>)
65
-
66
-
67
- return (
68
- href ? (
69
- <Link href={href} className={outerClasses} >
70
- <Inner />
71
- </Link>
72
-
73
- ) : (
74
- <span className={outerClasses} >
75
- <Inner />
76
- </span>
77
- )
78
- )
79
- }
80
-
81
- export default Logo
1
+ import React from 'react'
2
+ import Link from 'next/link'
3
+
4
+ import { type TShirtSize } from '@hanzo/ui/types'
5
+ import { cn } from '@hanzo/ui/util'
6
+
7
+ import * as Icons from './icons'
8
+
9
+ const Logo: React.FC<{
10
+ size?: TShirtSize
11
+ layout?: 'text-only' | 'logo-only' | 'full'
12
+ href?: string
13
+ className?: string
14
+ spanClassName?: string
15
+ }> = ({
16
+ size,
17
+ href, // no default please!
18
+ className='',
19
+ spanClassName,
20
+ layout='full'
21
+ }) => {
22
+ let classes: any = {}
23
+ const toAdd = (layout === 'logo-only') ? {
24
+ span: ' hidden',
25
+ icon: ''
26
+ } :
27
+ (layout === 'text-only') ? {
28
+ span: '',
29
+ icon: ' hidden'
30
+ } :
31
+ {
32
+ span: '',
33
+ icon: ''
34
+ }
35
+
36
+ if (size === 'lg' || size === 'xl' ) { // for safety
37
+ classes.icon = 'h-10 w-10 mr-4 color-inherit' + toAdd.icon
38
+ classes.span = 'text-3xl' + toAdd.span
39
+ }
40
+ // match lux.network
41
+ else if (size === 'md') {
42
+ classes.icon = 'h-[32px] w-[32px] mr-[12px] color-inherit' + toAdd.icon
43
+ classes.span = 'text-[1.8rem]/[1.8rem] tracking-tighter' + toAdd.span
44
+ }
45
+ else if (size === 'sm' ) {
46
+ classes.icon = 'h-6 w-6 mr-2 color-inherit' + toAdd.icon
47
+ classes.span = 'text-lg' + toAdd.span
48
+ }
49
+ // xs
50
+ else {
51
+ classes.icon = 'h-4 w-4 mr-1 color-inherit' + toAdd.icon
52
+ classes.span = 'text-base' + toAdd.span
53
+ }
54
+
55
+ const outerClasses = 'flex flex-row items-center ' + className
56
+ const spanClasses = 'inline-block font-bold font-heading '
57
+ + spanClassName
58
+ + (href ? ' hover:text-accent ' : ' cursor-default ')
59
+ + classes.span
60
+
61
+ const Inner: React.FC = () => (<>
62
+ <Icons.logo className={classes.icon} />
63
+ <span className={cn(spanClasses, ' text-inherit')}>LUX</span>
64
+ </>)
65
+
66
+
67
+ return (
68
+ href ? (
69
+ <Link href={href} className={outerClasses} >
70
+ <Inner />
71
+ </Link>
72
+
73
+ ) : (
74
+ <span className={outerClasses} >
75
+ <Inner />
76
+ </span>
77
+ )
78
+ )
79
+ }
80
+
81
+ export default Logo
@@ -1,27 +1,27 @@
1
- import React, { type PropsWithChildren } from 'react'
2
- import { cn } from '@hanzo/ui/util'
3
-
4
- const Main: React.FC<PropsWithChildren & {
5
- id?: string
6
- className?: string
7
- headerSpace?: boolean
8
- standardWidth?: boolean
9
- }> = ({
10
- children,
11
- className='',
12
- headerSpace=true,
13
- standardWidth=true,
14
- id
15
- }) => (
16
- <main id={id ?? 'LUX_UI_MAIN'} className={cn(
17
- 'flex flex-col justify-start items-center',
18
- 'px-4 md:px-6 lg:px-8',
19
- standardWidth ? 'max-w-screen-2xl w-full lg:mx-auto' : '',
20
- headerSpace ? 'pt-[44px] md:pt-[80px]' : 'py-4',
21
- className
22
- )}>
23
- {children}
24
- </main>
25
- )
26
-
27
- export default Main
1
+ import React, { type PropsWithChildren } from 'react'
2
+ import { cn } from '@hanzo/ui/util'
3
+
4
+ const Main: React.FC<PropsWithChildren & {
5
+ id?: string
6
+ className?: string
7
+ headerSpace?: boolean
8
+ standardWidth?: boolean
9
+ }> = ({
10
+ children,
11
+ className='',
12
+ headerSpace=true,
13
+ standardWidth=true,
14
+ id
15
+ }) => (
16
+ <main id={id ?? 'LUX_UI_MAIN'} className={cn(
17
+ 'flex flex-col justify-start items-center',
18
+ 'px-4 md:px-6 lg:px-8',
19
+ standardWidth ? 'max-w-screen-2xl w-full lg:mx-auto' : '',
20
+ headerSpace ? 'pt-[44px] md:pt-[80px]' : 'py-4',
21
+ className
22
+ )}>
23
+ {children}
24
+ </main>
25
+ )
26
+
27
+ export default Main
@@ -1,8 +1,8 @@
1
- import MiniChart from './wrapper'
2
- // import { type MiniChartProps, type MiniChartDateRanges } from './mini-chart-props'
3
-
4
- export {
5
- MiniChart as default,
6
- // type MiniChartProps,
7
- // type MiniChartDateRanges
1
+ import MiniChart from './wrapper'
2
+ // import { type MiniChartProps, type MiniChartDateRanges } from './mini-chart-props'
3
+
4
+ export {
5
+ MiniChart as default,
6
+ // type MiniChartProps,
7
+ // type MiniChartDateRanges
8
8
  }
@@ -1,44 +1,44 @@
1
- import type { CSSProperties } from 'react'
2
-
3
- // https://www.typescriptlang.org/docs/handbook/enums.html#enums-at-runtime
4
- const enum MiniChartDateRangesValues {
5
- '1D',
6
- '1M',
7
- '3M',
8
- '12M',
9
- '60M',
10
- 'ALL',
11
- }
12
-
13
- type MiniChartDateRanges = keyof typeof MiniChartDateRangesValues
14
-
15
- interface MiniChartBaseProps {
16
- symbol: string
17
- exchange?: string
18
- dateRange: MiniChartDateRanges
19
- noTimeScale?: boolean
20
- width?: number | string
21
- height?: number | string
22
- locale?: string
23
- colorTheme?: "light" | "dark"
24
- // @ts-ignore // TODO
25
- lineColor?: CSSProperties["color"]
26
- // @ts-ignore // TODO
27
- topGradientColor?: CSSProperties["color"]
28
- // @ts-ignore // TODO
29
- bottomGradientColor?: CSSProperties["color"]
30
- isTransparent?: boolean
31
- autosize?: boolean
32
- chartOnly?: boolean
33
- largeChartUrl?: string
34
- }
35
-
36
- type MiniChartProps = {
37
- widgetProps: MiniChartBaseProps
38
- containerStyles?: CSSProperties
39
- }
40
-
41
- export {
42
- type MiniChartProps,
43
- type MiniChartDateRanges
1
+ import type { CSSProperties } from 'react'
2
+
3
+ // https://www.typescriptlang.org/docs/handbook/enums.html#enums-at-runtime
4
+ const enum MiniChartDateRangesValues {
5
+ '1D',
6
+ '1M',
7
+ '3M',
8
+ '12M',
9
+ '60M',
10
+ 'ALL',
11
+ }
12
+
13
+ type MiniChartDateRanges = keyof typeof MiniChartDateRangesValues
14
+
15
+ interface MiniChartBaseProps {
16
+ symbol: string
17
+ exchange?: string
18
+ dateRange: MiniChartDateRanges
19
+ noTimeScale?: boolean
20
+ width?: number | string
21
+ height?: number | string
22
+ locale?: string
23
+ colorTheme?: "light" | "dark"
24
+ // @ts-ignore // TODO
25
+ lineColor?: CSSProperties["color"]
26
+ // @ts-ignore // TODO
27
+ topGradientColor?: CSSProperties["color"]
28
+ // @ts-ignore // TODO
29
+ bottomGradientColor?: CSSProperties["color"]
30
+ isTransparent?: boolean
31
+ autosize?: boolean
32
+ chartOnly?: boolean
33
+ largeChartUrl?: string
34
+ }
35
+
36
+ type MiniChartProps = {
37
+ widgetProps: MiniChartBaseProps
38
+ containerStyles?: CSSProperties
39
+ }
40
+
41
+ export {
42
+ type MiniChartProps,
43
+ type MiniChartDateRanges
44
44
  }
@@ -1,85 +1,85 @@
1
- 'use client'
2
-
3
- import React, { useEffect, useRef } from 'react'
4
- import { type MiniChartProps } from './mini-chart-props'
5
-
6
- const MiniChart: React.FC<MiniChartProps> = ({
7
- widgetProps,
8
- containerStyles = {}
9
- }) => {
10
-
11
- const {
12
- symbol,
13
- exchange,
14
- lineColor,
15
- topGradientColor,
16
- bottomGradientColor,
17
- width,
18
- height,
19
- autosize,
20
- locale,
21
- ...rest
22
- } = widgetProps
23
-
24
- const symbolString = (exchange) ? `${exchange}:${symbol}` : symbol
25
-
26
- const containerRef = useRef<HTMLDivElement | null>(null)
27
-
28
- useEffect(() => {
29
- if (!containerRef.current) {
30
- return
31
- }
32
- const script = document.createElement('script')
33
- script.type = 'text/javascript'
34
- script.src = 'https://s3.tradingview.com/external-embedding/embed-widget-mini-symbol-overview.js'
35
- script.async = true
36
- script.onload = async () => {
37
- const iframe = containerRef.current?.querySelector('iframe')
38
- if (iframe && iframe instanceof Element) {
39
- iframe.style.colorScheme = 'normal'
40
- setTimeout(() => {
41
- const value = document.querySelector('#mini-symbol-overview-ticker')
42
- console.log("TICKER: " + value)
43
- }, 1200) // from experimentation
44
-
45
-
46
- }
47
-
48
- const copyDiv = document.querySelector('.tradingview-widget-copyright')
49
- if (copyDiv) {
50
- console.log("COPY: " + copyDiv)
51
- setTimeout(() => {
52
- copyDiv.classList.remove('invisible')
53
- }, 1200) // from experimentation
54
- }
55
- }
56
- const config = JSON.stringify({
57
- symbol: symbolString,
58
- width: autosize ? '100%' : (width || 350),
59
- height: autosize ? '100%' : (height || 220),
60
- locale: locale ?? 'en',
61
- isTransparent: 'true',
62
- trendLineColor: lineColor || 'rgba(41, 98, 255, 1)',
63
- underLineColor: topGradientColor || 'rgba(41, 98, 255, 0.3)',
64
- underLineBottomColor: bottomGradientColor || 'rgba(41, 98, 255, 0)',
65
- ...rest,
66
- })
67
- script.innerHTML = config
68
- containerRef.current.appendChild(script)
69
- return () => {
70
- while (containerRef.current?.firstChild) {
71
- containerRef.current.removeChild(containerRef.current.firstChild)
72
- }
73
- }
74
- }, [ JSON.stringify(widgetProps) ])
75
-
76
- return (<>
77
- <div style={containerStyles} className='tradingview-widget-container h-[150px]' ref={containerRef} />
78
- <div className='tradingview-widget-copyright border-t w-full invisible'>
79
- <a href={`https://www.tradingview.com/symbols/${symbol}${exchange ? `/?exchange=${exchange}` : '' }`} rel="noopener" target="_blank">
80
- <span className="text-[--hz-ui-primary]">{symbol} quotes</span></a>&nbsp;by TradingView
81
- </div>
82
- </>)
83
- }
84
-
85
- export default MiniChart
1
+ 'use client'
2
+
3
+ import React, { useEffect, useRef } from 'react'
4
+ import { type MiniChartProps } from './mini-chart-props'
5
+
6
+ const MiniChart: React.FC<MiniChartProps> = ({
7
+ widgetProps,
8
+ containerStyles = {}
9
+ }) => {
10
+
11
+ const {
12
+ symbol,
13
+ exchange,
14
+ lineColor,
15
+ topGradientColor,
16
+ bottomGradientColor,
17
+ width,
18
+ height,
19
+ autosize,
20
+ locale,
21
+ ...rest
22
+ } = widgetProps
23
+
24
+ const symbolString = (exchange) ? `${exchange}:${symbol}` : symbol
25
+
26
+ const containerRef = useRef<HTMLDivElement | null>(null)
27
+
28
+ useEffect(() => {
29
+ if (!containerRef.current) {
30
+ return
31
+ }
32
+ const script = document.createElement('script')
33
+ script.type = 'text/javascript'
34
+ script.src = 'https://s3.tradingview.com/external-embedding/embed-widget-mini-symbol-overview.js'
35
+ script.async = true
36
+ script.onload = async () => {
37
+ const iframe = containerRef.current?.querySelector('iframe')
38
+ if (iframe && iframe instanceof Element) {
39
+ iframe.style.colorScheme = 'normal'
40
+ setTimeout(() => {
41
+ const value = document.querySelector('#mini-symbol-overview-ticker')
42
+ console.log("TICKER: " + value)
43
+ }, 1200) // from experimentation
44
+
45
+
46
+ }
47
+
48
+ const copyDiv = document.querySelector('.tradingview-widget-copyright')
49
+ if (copyDiv) {
50
+ console.log("COPY: " + copyDiv)
51
+ setTimeout(() => {
52
+ copyDiv.classList.remove('invisible')
53
+ }, 1200) // from experimentation
54
+ }
55
+ }
56
+ const config = JSON.stringify({
57
+ symbol: symbolString,
58
+ width: autosize ? '100%' : (width || 350),
59
+ height: autosize ? '100%' : (height || 220),
60
+ locale: locale ?? 'en',
61
+ isTransparent: 'true',
62
+ trendLineColor: lineColor || 'rgba(41, 98, 255, 1)',
63
+ underLineColor: topGradientColor || 'rgba(41, 98, 255, 0.3)',
64
+ underLineBottomColor: bottomGradientColor || 'rgba(41, 98, 255, 0)',
65
+ ...rest,
66
+ })
67
+ script.innerHTML = config
68
+ containerRef.current.appendChild(script)
69
+ return () => {
70
+ while (containerRef.current?.firstChild) {
71
+ containerRef.current.removeChild(containerRef.current.firstChild)
72
+ }
73
+ }
74
+ }, [ JSON.stringify(widgetProps) ])
75
+
76
+ return (<>
77
+ <div style={containerStyles} className='tradingview-widget-container h-[150px]' ref={containerRef} />
78
+ <div className='tradingview-widget-copyright border-t w-full invisible'>
79
+ <a href={`https://www.tradingview.com/symbols/${symbol}${exchange ? `/?exchange=${exchange}` : '' }`} rel="noopener" target="_blank">
80
+ <span className="text-[--hz-ui-primary]">{symbol} quotes</span></a>&nbsp;by TradingView
81
+ </div>
82
+ </>)
83
+ }
84
+
85
+ export default MiniChart
@@ -1,23 +1,23 @@
1
- import React from 'react'
2
-
3
- import BaseChart from './mini-chart'
4
-
5
- const Wrapper: React.FC<{
6
- symbol: string,
7
- exchange?: string
8
- }> = ({
9
- symbol,
10
- exchange
11
- }) => (
12
- <BaseChart widgetProps ={{
13
- symbol,
14
- exchange,
15
- autosize: true,
16
- colorTheme: 'dark',
17
- lineColor: "rgb(114, 27, 228)",
18
- bottomGradientColor: "rgba(255, 255, 255, 0.1)",
19
- dateRange: '60M',
20
- }}/>
21
- )
22
-
23
- export default Wrapper
1
+ import React from 'react'
2
+
3
+ import BaseChart from './mini-chart'
4
+
5
+ const Wrapper: React.FC<{
6
+ symbol: string,
7
+ exchange?: string
8
+ }> = ({
9
+ symbol,
10
+ exchange
11
+ }) => (
12
+ <BaseChart widgetProps ={{
13
+ symbol,
14
+ exchange,
15
+ autosize: true,
16
+ colorTheme: 'dark',
17
+ lineColor: "rgb(114, 27, 228)",
18
+ bottomGradientColor: "rgba(255, 255, 255, 0.1)",
19
+ dateRange: '60M',
20
+ }}/>
21
+ )
22
+
23
+ export default Wrapper
@@ -1,28 +1,28 @@
1
- import React from 'react'
2
-
3
- import { ApplyTypography } from '@hanzo/ui/primitives'
4
-
5
- import type { SiteDef } from '../../site-def'
6
- import Footer from '../footer'
7
- import Header from '../header'
8
- import Main from '../main'
9
-
10
- import NotFoundMDX from './not-found-content.mdx'
11
-
12
- const NotFound: React.FC<{
13
- header?: boolean
14
- siteDef: SiteDef
15
- }> = ({
16
- header=false,
17
- siteDef
18
- }) => (<>
19
- {header && <Header siteDef={siteDef}/>}
20
- <Main className='h-[100svh] sm:h-[700px] px-8 sm:px-10 ' headerSpace={header}>
21
- <ApplyTypography className='mt-[200px] flex flex-col md:gap-8 '>
22
- <NotFoundMDX />
23
- </ApplyTypography>
24
- </Main>
25
- <Footer siteDef={siteDef}/>
26
- </>)
27
-
28
- export default NotFound
1
+ import React from 'react'
2
+
3
+ import { ApplyTypography } from '@hanzo/ui/primitives'
4
+
5
+ import type { SiteDef } from '../../site-def'
6
+ import Footer from '../footer'
7
+ import Header from '../header'
8
+ import Main from '../main'
9
+
10
+ import NotFoundMDX from './not-found-content.mdx'
11
+
12
+ const NotFound: React.FC<{
13
+ header?: boolean
14
+ siteDef: SiteDef
15
+ }> = ({
16
+ header=false,
17
+ siteDef
18
+ }) => (<>
19
+ {header && <Header siteDef={siteDef}/>}
20
+ <Main className='h-[100svh] sm:h-[700px] px-8 sm:px-10 ' headerSpace={header}>
21
+ <ApplyTypography className='mt-[200px] flex flex-col md:gap-8 '>
22
+ <NotFoundMDX />
23
+ </ApplyTypography>
24
+ </Main>
25
+ <Footer siteDef={siteDef}/>
26
+ </>)
27
+
28
+ export default NotFound
@@ -1,5 +1,5 @@
1
- ### ...Huh?
2
- #### Sorry, we're fresh out of those.
3
- <br/>
4
- #### ...try something from the [Home Page](/)?
5
-
1
+ ### ...Huh?
2
+ #### Sorry, we're fresh out of those.
3
+ <br/>
4
+ #### ...try something from the [Home Page](/)?
5
+