mirror of
https://github.com/supabase/supabase.git
synced 2026-05-08 09:50:33 -04:00
56de26fe22
This PR migrates the whole monorepo to use Tailwind v4: - Removed `@tailwindcss/container-queries` plugin since it's included by default in v4, - Bump all instances of Tailwind to v4. Made minimal changes to the shared config to remove non-supported features (`alpha` mentions), - Migrate all apps to be compatible with v4 configs, - Fix the `typography.css` import in 3 apps, - Add missing rules which were included by default in v3, - Run `pnpm dlx @tailwindcss/upgrade` on all apps, which renames a lot of classes - Rename all misnamed classes according to https://tailwindcss.com/docs/upgrade-guide#renamed-utilities in all apps. --------- Co-authored-by: Jordi Enric <jordi.err@gmail.com>
70 lines
2.6 KiB
TypeScript
70 lines
2.6 KiB
TypeScript
import React from 'react'
|
|
import { cn, IconDocumentation } from 'ui'
|
|
import Link from 'next/link'
|
|
import { PRODUCT_MODULES_NAMES } from 'shared-data/products'
|
|
|
|
import SectionContainer from '~/components/Layouts/SectionContainer'
|
|
import ProductModules from '~/data/ProductModules'
|
|
|
|
interface Props {
|
|
activePage: PRODUCT_MODULES_NAMES
|
|
docsUrl?: string
|
|
}
|
|
|
|
function ModulesNav({ activePage, docsUrl }: Props) {
|
|
return (
|
|
<nav className="sticky top-0 mb-4 z-30 flex flex-nowrap items-center bg-alternative/90 backdrop-blur-md w-full border-b border-muted">
|
|
<SectionContainer className="py-0! flex gap-3 items-center justify-between">
|
|
<div className="w-max flex gap-3 items-center">
|
|
{Object.entries(ProductModules).map((obj) => {
|
|
const currentModule = obj[1]
|
|
|
|
return (
|
|
<Link
|
|
key={currentModule.name}
|
|
className={cn(
|
|
'flex items-center gap-1.5 px-2 first:-ml-2 py-3 border-b border-transparent text-sm text-foreground-lighter hover:text-foreground',
|
|
'focus-visible:ring-2 focus-visible:ring-foreground-lighter focus-visible:text-foreground focus-visible:outline-brand-600',
|
|
currentModule.name === activePage && 'border-foreground-light text-foreground'
|
|
)}
|
|
href={currentModule.url ?? ''}
|
|
>
|
|
<svg
|
|
className="h-4 w-4 group-hover/menu-item:text-foreground group-focus-visible/menu-item:text-foreground"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
fill="none"
|
|
viewBox="0 0 24 24"
|
|
>
|
|
<path
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
strokeWidth="1"
|
|
d={currentModule.icon}
|
|
stroke="currentColor"
|
|
/>
|
|
</svg>
|
|
<p>{currentModule.name}</p>
|
|
</Link>
|
|
)
|
|
})}
|
|
</div>
|
|
<div className="flex gap-3 items-center">
|
|
{docsUrl && (
|
|
<Link
|
|
className={cn(
|
|
'flex items-center gap-1.5 py-3 border-b border-transparent text-sm text-foreground-lighter hover:text-foreground',
|
|
'focus-visible:ring-2 focus-visible:ring-foreground-lighter focus-visible:text-foreground focus-visible:outline-brand-600'
|
|
)}
|
|
href={docsUrl}
|
|
>
|
|
<IconDocumentation size={14} strokeWidth={1.2} /> Docs
|
|
</Link>
|
|
)}
|
|
</div>
|
|
</SectionContainer>
|
|
</nav>
|
|
)
|
|
}
|
|
|
|
export default ModulesNav
|