Files
supabase/studio/components/layouts/ProjectLayout/NavigationBar/NavigationBar.tsx

112 lines
3.6 KiB
TypeScript

import Link from 'next/link'
import { FC } from 'react'
import { isUndefined } from 'lodash'
import { observer } from 'mobx-react-lite'
import { useRouter } from 'next/router'
import { Button, Dropdown, IconHome, IconSettings, IconUser } from '@supabase/ui'
import { useFlag, useStore } from 'hooks'
import { IS_PLATFORM } from 'lib/constants'
import { generateOtherRoutes, generateProductRoutes } from './NavigationBar.utils'
import NavigationIconButton from './NavigationIconButton'
interface Props {}
const NavigationBar: FC<Props> = ({}) => {
const router = useRouter()
const { ui } = useStore()
const projectRef = ui.selectedProjectRef as string
const projectBaseInfo = ui.selectedProjectBaseInfo
const ongoingIncident = useFlag('ongoingIncident')
const activeRoute = router.pathname.split('/')[3]
const productRoutes = generateProductRoutes(projectRef, projectBaseInfo)
const otherRoutes = generateOtherRoutes(projectRef, projectBaseInfo)
return (
<div
style={{ height: ongoingIncident ? 'calc(100vh - 44px)' : '100vh' }}
className={[
'flex w-14 flex-col justify-between overflow-y-hidden p-2',
'bg-sidebar-light dark:bg-sidebar-dark dark:border-dark border-r',
].join(' ')}
>
<ul className="flex flex-col space-y-2">
<Link href={'/'}>
<a className="block">
<img
src="/img/supabase-logo.svg"
alt="Supabase"
className="mx-auto h-[40px] w-6 cursor-pointer rounded"
/>
</a>
</Link>
<NavigationIconButton
isActive={isUndefined(activeRoute) && !isUndefined(router.query.ref)}
route={{
key: 'HOME',
label: 'Home',
icon: <IconHome size={18} strokeWidth={2} />,
link: `/project/${projectRef}`,
}}
/>
<div className="bg-scale-500 h-px w-full"></div>
{productRoutes.map((route) => (
<NavigationIconButton
key={route.key}
route={route}
isActive={activeRoute === route.key}
/>
))}
<div className="bg-scale-500 h-px w-full"></div>
{otherRoutes.map((route) => (
<NavigationIconButton
key={route.key}
route={route}
isActive={activeRoute === route.key}
/>
))}
</ul>
<ul className="flex flex-col space-y-2">
<Dropdown
side="right"
align="start"
overlay={
<>
{IS_PLATFORM && (
<>
<Link href="/account/me">
<Dropdown.Item key="header" icon={<IconSettings size={14} strokeWidth={1.5} />}>
Account Preferences
</Dropdown.Item>
</Link>
<Dropdown.Seperator />
</>
)}
<Dropdown.Label>Theme</Dropdown.Label>
<Dropdown.RadioGroup
key="theme"
value={ui.themeOption}
onChange={(e: any) => ui.onThemeOptionChange(e)}
>
<Dropdown.Radio value="system">System default</Dropdown.Radio>
<Dropdown.Radio value="dark">Dark</Dropdown.Radio>
<Dropdown.Radio value="light">Light</Dropdown.Radio>
</Dropdown.RadioGroup>
</>
}
>
<Button as="span" type="text" size="tiny">
<div className="py-1">
<IconUser size={18} strokeWidth={2} />
</div>
</Button>
</Dropdown>
</ul>
</div>
)
}
export default observer(NavigationBar)