Files
supabase/studio/components/interfaces/Functions/FunctionsLayout.tsx
Jonathan Summers-Muir dae4aeac09 fix: use isLoaded in stores
2022-03-30 21:31:16 +02:00

87 lines
2.3 KiB
TypeScript

import BaseLayout from 'components/layouts'
import { observer } from 'mobx-react-lite'
import { useStore, withAuth } from 'hooks'
import { IconCode, IconSlash, Loading, Tabs } from '@supabase/ui'
import { Tab } from '@headlessui/react'
import FunctionsNav from './FunctionsNav'
import React, { useEffect } from 'react'
import { useRouter } from 'next/router'
import WarningBanner from 'components/ui/WarningBanner'
import { WARNING_MESSAGE } from './Functions.constants'
const PageLayout = ({ children, centered }: { children?: React.ReactNode; centered?: boolean }) => {
const { functions, ui } = useStore()
const router = useRouter()
const { id } = router.query
useEffect(() => {
functions.load()
}, [ui.selectedProject])
if (!functions.isLoaded) {
return (
<BaseLayout>
<Loading active={true}>loading</Loading>
</BaseLayout>
)
}
return (
<BaseLayout>
<WarningBanner title={WARNING_MESSAGE.title} description={WARNING_MESSAGE.description} />
{centered ? (
<>
<div className="mx-auto max-w-5xl py-32 px-5">
<div className="flex items-center gap-3">
<div
className="w-6 h-6 bg-brand-300 border border-brand-600 rounded text-brand-900
flex items-center justify-center
"
>
<IconCode size={14} strokeWidth={3} />
</div>
<h1 className="text-2xl text-scale-1200">Functions</h1>
</div>
{children}
</div>
</>
) : (
<div
className="
py-10
w-full mx-auto
transition-all
px-5
lg:px-20
xl:px-24
1xl:px-28
2xl:px-32
flex flex-col
gap-8
"
>
<div className="flex items-center gap-3">
<div
className="w-6 h-6 bg-brand-300 border border-brand-600 rounded text-brand-900
flex items-center justify-center
"
>
<IconCode size={14} strokeWidth={3} />
</div>
<h1 className="text-2xl text-scale-1200">Functions</h1>
</div>
{children}
</div>
)}
</BaseLayout>
)
}
export default withAuth(observer(PageLayout))