Files
supabase/studio/components/layouts/AuthLayout/AuthLayout.tsx
phamhieu 8a9b46250a refactor: auth policies page
- remove mobx local store
- filter table policies from meta.policies
- clean up
2022-05-23 18:08:24 +08:00

63 lines
1.5 KiB
TypeScript

import { FC, ReactNode, useState, useEffect } from 'react'
import { observer } from 'mobx-react-lite'
import { useRouter } from 'next/router'
import { useStore, withAuth } from 'hooks'
import BaseLayout from '../'
import Error from 'components/ui/Error'
import ProductMenu from 'components/ui/ProductMenu'
import { generateAuthMenu } from './AuthLayout.utils'
interface Props {
title?: string
children: ReactNode
}
const AuthLayout: FC<Props> = ({ title, children }) => {
const { ui, meta } = useStore()
const { isInitialized, isLoading, error } = meta.tables
const projectRef = ui.selectedProject?.ref ?? 'default'
const router = useRouter()
const page = router.pathname.split('/')[4]
const [loaded, setLoaded] = useState<boolean>(isInitialized)
useEffect(() => {
if (ui.selectedProject) {
meta.policies.load()
meta.tables.load()
meta.roles.load()
}
}, [ui.selectedProject])
useEffect(() => {
if (!isLoading && !loaded) {
setLoaded(true)
}
}, [isLoading])
if (error) {
return (
<BaseLayout>
<Error error={error} />
</BaseLayout>
)
}
return (
<BaseLayout
isLoading={!loaded}
title={title || 'Authentication'}
product="Authentication"
productMenu={<ProductMenu page={page} menu={generateAuthMenu(projectRef)} />}
>
<main style={{ maxHeight: '100vh' }} className="flex-1 overflow-y-auto">
{children}
</main>
</BaseLayout>
)
}
export default withAuth(observer(AuthLayout))