1
- import type { ThemeUtilsCSS } from '@fuel-ui/css' ;
2
- import { cssObj } from '@fuel-ui/css' ;
3
- import { Box , Flex } from '@fuel-ui/react' ;
4
1
import type { FC , ReactNode } from 'react' ;
5
2
import { Helmet } from 'react-helmet' ;
6
3
import { META_DESC , META_OGIMG } from '~/constants' ;
7
4
import { OverlayDialog } from '~/systems/Overlay' ;
8
5
9
6
import { coreStyles } from '../styles' ;
10
7
8
+ import { Box , Flex , cx } from '@fuels/ui' ;
9
+ import { tv } from 'tailwind-variants' ;
11
10
import { Header } from './Header' ;
12
11
13
12
type ContentProps = {
14
13
// eslint-disable-next-line @typescript-eslint/no-explicit-any
15
14
as ?: any ;
16
15
children : ReactNode ;
17
- css ?: ThemeUtilsCSS ;
16
+ className ?: string ;
18
17
} ;
19
18
20
- const Content = ( { as, children, css } : ContentProps ) => {
19
+ const Content = ( { as, children, className } : ContentProps ) => {
20
+ const classes = styles ( ) ;
21
+
21
22
return (
22
- < Box
23
- as = { as }
24
- css = { { ...styles . content , ...css } }
25
- className = "layout__content"
26
- >
23
+ < Box as = { as } className = { cx ( classes . content ( ) , className ) } >
27
24
{ children }
28
25
</ Box >
29
26
) ;
@@ -39,6 +36,7 @@ type LayoutProps = {
39
36
} ;
40
37
41
38
export const Layout : LayoutComponent = ( { title, children } : LayoutProps ) => {
39
+ const classes = styles ( ) ;
42
40
const titleText = title || '' ;
43
41
return (
44
42
< >
@@ -55,11 +53,13 @@ export const Layout: LayoutComponent = ({ title, children }: LayoutProps) => {
55
53
href = ""
56
54
/>
57
55
</ Helmet >
58
- < Flex as = "main" direction = "column" css = { styles . root } >
56
+ < Flex as = "main" direction = "column" className = { classes . root ( ) } >
59
57
< Header />
60
58
< OverlayDialog />
61
- < Box css = { styles . scrollView } >
62
- < Box css = { coreStyles . scrollableContent } > { children } </ Box >
59
+ < Box className = { classes . scrollView ( ) } >
60
+ < Box > { children } </ Box >
61
+ { /* TODO: add scrollable content class */ }
62
+ { /* <Box className={coreStyles.scrollableContent()}>{children}</Box> */ }
63
63
</ Box >
64
64
</ Flex >
65
65
</ >
@@ -68,20 +68,16 @@ export const Layout: LayoutComponent = ({ title, children }: LayoutProps) => {
68
68
69
69
Layout . Content = Content ;
70
70
71
- const styles = {
72
- root : cssObj ( {
73
- width : '100vw' ,
74
- height : '100vh' ,
75
- overflow : 'hidden' ,
76
- position : 'absolute' ,
77
- } ) ,
78
- scrollView : cssObj ( {
79
- flex : 1 ,
80
- ...coreStyles . scrollable ( ) ,
81
- } ) ,
82
- content : cssObj ( {
83
- padding : '$16 $4 $4 $4' ,
84
- maxWidth : 955 ,
85
- margin : '0 auto' ,
86
- } ) ,
87
- } ;
71
+ export const styles = tv ( {
72
+ slots : {
73
+ root : 'w-screen h-screen overflow-hidden absolute' ,
74
+ // TODO: add scrollable in scrollView
75
+ scrollView : 'flex-1' ,
76
+ content : 'p-4 pt-16 max-w-[955px] mx-auto' ,
77
+
78
+ // scrollView: cssObj({
79
+ // flex: 1,
80
+ // ...coreStyles.scrollable(),
81
+ // }),
82
+ } ,
83
+ } ) ;
0 commit comments