Files
supabase/apps/studio/components/interfaces/Connect/ConnectTabs.tsx
2026-04-01 10:22:37 +02:00

63 lines
1.7 KiB
TypeScript

import { FileJson2 } from 'lucide-react'
import { isValidElement, ReactNode } from 'react'
import { Tabs_Shadcn_, TabsContent_Shadcn_, TabsList_Shadcn_, TabsTrigger_Shadcn_ } from 'ui'
interface ConnectTabTriggerProps {
value: string
}
interface ConnectTabTriggersProps {
children: ReactNode[]
}
interface ConnectFileTabProps {
children: ReactNode[]
value?: string
onValueChange?: (value: string) => void
}
interface ConnectTabContentProps {
children: ReactNode
value: string
}
export const ConnectTabs = ({ children, value, onValueChange }: ConnectFileTabProps) => {
const firstChild = children[0]
const defaultValue = isValidElement(firstChild)
? (firstChild.props as any)?.children[0]?.props?.value || ''
: null
return (
<Tabs_Shadcn_ defaultValue={defaultValue} value={value} onValueChange={onValueChange}>
{children}
</Tabs_Shadcn_>
)
}
export const ConnectTabTrigger = ({ value }: ConnectTabTriggerProps) => {
return (
<TabsTrigger_Shadcn_
value={value}
className="flex items-center gap-1 text-xs px-0 data-[state=active]:bg-transparent py-2.5"
>
<FileJson2 size={15} className="text-foreground-muted" />
{value}
</TabsTrigger_Shadcn_>
)
}
export const ConnectTabTriggers = ({ children }: ConnectTabTriggersProps) => {
return (
<TabsList_Shadcn_ className="bg-surface-100 px-5 rounded-lg rounded-b-none gap-5">
{children}
</TabsList_Shadcn_>
)
}
export const ConnectTabContent = ({ value, children }: ConnectTabContentProps) => {
return (
<TabsContent_Shadcn_ value={value} className="p-3 mt-1 max-h-72 overflow-scroll">
{children}
</TabsContent_Shadcn_>
)
}