mirror of
https://github.com/supabase/supabase.git
synced 2026-07-04 12:34:19 +08:00
* migrate some www components to tokens * consolidate InteractiveShimmerCard to Panel component * update tokens in blog * update tokens in careers page * update tokens in customers section * update tokens in open-source section * update tokens in Realtime page * update tokens in Storage and Vector * update tokens in SplitCodeBlockCarousel * update tokens in PGCharts * remove unused css files * update tokens in Card * update tokens in Pricing page * clean up priving page imports * remove hardcoded theme vars * migrate first half of defaultTheme.ts to tokens * migrate second half of defaultTheme.ts to tokens * improve inputs * add foreground to text-light and text-lighter * add foreground to text-light and text-lighter * migrate docs components with styling tokens * migrate docs components with styling tokens * fix broken Repos component * fix broken classes in blog * update tokens on Button and other components * update tokens on IconPanel * update studio main layout base styling tokens * update tokens across studio, docs and www * update tokens across studio, docs and www * update ui/Panel to styling tokens * update ExampleProject and TableEditorMenu tokens * www vector page tokens * update studio UI tokens * update other studio UI tokens * update more studio UI tokens * change tokens here, change tokens there * finish updating colors with tokens variables * add gui sandbox for theme experimentation * use common package for www, docs and studio and fix Command K tokens * provide light mode default tokens options * fix conflict leftover * update loading line * fix className typo * fix prettier * update themeSandbox preset default values * fix text-background0 * prettier * update warningBanner with warning color * switch all border-border with border-default * improve border-secondary and foreground-muted in light mode * force ring color on toggle * fix button bg color and border-muted light token * fix input bg color * fix dark button hover * fix homepage product card * fix code-hike table header colors * button dark border * remove tabIndex leftover from homepage main ctas --------- Co-authored-by: Kevin Grüneberg <k.grueneberg1994@gmail.com> Co-authored-by: Jonathan Summers-Muir <MildTomato@users.noreply.github.com>
148 lines
3.6 KiB
TypeScript
148 lines
3.6 KiB
TypeScript
import Link from 'next/link'
|
|
import { useRouter } from 'next/router'
|
|
import { IconChevronLeft } from 'ui'
|
|
import * as NavItems from './NavigationMenu.constants'
|
|
|
|
import clientLibsCommon from '~/../../spec/common-cli.yml' assert { type: 'yml' }
|
|
|
|
const NavigationMenuCliList = ({ currentLevel, setLevel, id }) => {
|
|
const router = useRouter()
|
|
|
|
const menu = NavItems[id]
|
|
|
|
const FunctionLink = ({
|
|
title,
|
|
id,
|
|
icon,
|
|
}: {
|
|
title: string
|
|
name: string
|
|
id: string
|
|
icon?: string
|
|
}) => {
|
|
return (
|
|
<li key={id} className="function-link-item text-foreground-lighter leading-3">
|
|
<Link
|
|
href={`#${id}`}
|
|
className="cursor-pointer transition text-foreground-lighter text-sm hover:text-brand flex gap-3"
|
|
>
|
|
{icon && <img className="w-3" src={`${router.basePath}${icon}`} />}
|
|
{title}
|
|
</Link>
|
|
</li>
|
|
)
|
|
}
|
|
|
|
const SideMenuTitle = ({ title }: { title: string }) => {
|
|
return (
|
|
<span
|
|
className="
|
|
font-mono text-xs uppercase
|
|
text-foreground font-medium
|
|
tracking-wider
|
|
mb-3
|
|
"
|
|
>
|
|
{title}
|
|
</span>
|
|
)
|
|
}
|
|
|
|
const Divider = () => {
|
|
return <div className="h-px w-full bg-border my-3"></div>
|
|
}
|
|
|
|
const MenuSections = [
|
|
{
|
|
key: 'general',
|
|
label: 'General',
|
|
},
|
|
{
|
|
key: 'secrets',
|
|
label: 'Secrets',
|
|
},
|
|
{
|
|
key: 'projects',
|
|
label: 'Projects',
|
|
},
|
|
{
|
|
key: 'organizations',
|
|
label: 'Organizations',
|
|
},
|
|
{
|
|
key: 'migration',
|
|
label: 'Migration',
|
|
},
|
|
{
|
|
key: 'database',
|
|
label: 'Database',
|
|
},
|
|
{
|
|
key: 'completion',
|
|
label: 'Completion',
|
|
},
|
|
]
|
|
|
|
return (
|
|
<div
|
|
className={[
|
|
'transition-all duration-150 ease-out',
|
|
// enabled
|
|
currentLevel === id && 'opacity-100 ml-0 delay-150 h-auto',
|
|
// move menu back to margin-left
|
|
currentLevel === 'home' && 'ml-12',
|
|
// disabled
|
|
currentLevel !== 'home' && currentLevel !== id ? '-ml-8' : '',
|
|
currentLevel !== id ? 'opacity-0 invisible absolute h-0 overflow-hidden' : '',
|
|
].join(' ')}
|
|
>
|
|
<div className={'w-full flex flex-col gap-0 sticky top-8'}>
|
|
<Link
|
|
href={`${menu.parent ?? '/'}`}
|
|
className={[
|
|
'flex items-center gap-1 text-xs group mb-3',
|
|
'text-base transition-all duration-200 text-brand hover:text-brand-600 hover:cursor-pointer ',
|
|
].join(' ')}
|
|
>
|
|
<div className="relative w-2">
|
|
<div className="transition-all ease-out ml-0 group-hover:-ml-1">
|
|
<IconChevronLeft size={10} strokeWidth={3} />
|
|
</div>
|
|
</div>
|
|
<span>Back to menu</span>
|
|
</Link>
|
|
<div className="flex items-center gap-3 my-3">
|
|
<img
|
|
src={`${router.basePath}` + menu.icon ?? `/img/icons/menu/${id}.svg`}
|
|
className="w-5 rounded"
|
|
/>
|
|
|
|
<h2 className={['text-foreground ', !menu.title && 'capitalize'].join(' ')}>
|
|
{menu.title ?? currentLevel}
|
|
</h2>
|
|
</div>
|
|
<ul className="function-link-list">
|
|
{MenuSections.map((section) => {
|
|
return (
|
|
<>
|
|
<Divider />
|
|
<SideMenuTitle title={section.label} />
|
|
|
|
{clientLibsCommon.commands
|
|
.filter((x) => x.product === section.key)
|
|
.map((x, index) => {
|
|
return <FunctionLink {...x} />
|
|
})}
|
|
</>
|
|
)
|
|
})}
|
|
|
|
<Divider />
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default NavigationMenuCliList
|