105 lines
3.0 KiB
TypeScript
105 lines
3.0 KiB
TypeScript
"use client";
|
|
|
|
import * as TabsPrimitive from "@radix-ui/react-tabs";
|
|
import * as React from "react";
|
|
|
|
import { cn } from "@repo/shadcn-ui/lib/utils";
|
|
import { cva } from "class-variance-authority";
|
|
|
|
const DynamicTabsListVariants = cva("inline-flex items-center justify-center", {
|
|
variants: {
|
|
variant: {
|
|
default: "rounded-lg bg-muted p-1 text-muted-foreground",
|
|
underline: "border-b rounded-none bg-background gap-2 p-0 justify-start",
|
|
},
|
|
width: {
|
|
full: "w-full",
|
|
fit: "w-fit",
|
|
},
|
|
},
|
|
defaultVariants: {
|
|
variant: "default",
|
|
},
|
|
});
|
|
|
|
const DynamicTabsTriggerVariants = cva(
|
|
"inline-flex items-center justify-center whitespace-nowrap text-sm font-normal transition-all disabled:pointer-events-none data-[state=active]:text-foreground px-3",
|
|
{
|
|
variants: {
|
|
variant: {
|
|
default:
|
|
"inline-flex items-center justify-center whitespace-nowrap rounded-md px-3 py-1 text-sm font-medium ring-offset-background transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow",
|
|
underline:
|
|
"bg-background border-b-2 border-background focus:border-primary ring-0 outline-none shadow-none data-[state=active]:shadow-none data-[state=active]:border-b-2 data-[state=active]:border-primary disabled:opacity-100 data-[state=active]:shadow-none rounded-none m-0 pt-1.5 pb-2 hover:bg-background-muted",
|
|
},
|
|
width: {
|
|
full: "w-full",
|
|
fit: "w-fit",
|
|
},
|
|
},
|
|
defaultVariants: {
|
|
variant: "default",
|
|
},
|
|
}
|
|
);
|
|
|
|
function DynamicTabs({ className, ...props }: React.ComponentProps<typeof TabsPrimitive.Root>) {
|
|
return (
|
|
<TabsPrimitive.Root
|
|
data-slot='tabs'
|
|
className={cn("flex flex-col gap-2", className)}
|
|
{...props}
|
|
/>
|
|
);
|
|
}
|
|
|
|
function DynamicTabsList({
|
|
className,
|
|
variant,
|
|
width,
|
|
asChild = false,
|
|
...props
|
|
}: React.ComponentProps<typeof TabsPrimitive.List>) {
|
|
return (
|
|
<TabsPrimitive.List
|
|
data-slot='tabs-list'
|
|
className={cn(DynamicTabsListVariants({ variant, width, className }))}
|
|
{...props}
|
|
/>
|
|
);
|
|
}
|
|
|
|
function DynamicTabsTrigger({
|
|
className,
|
|
variant,
|
|
width,
|
|
asChild = false,
|
|
...props
|
|
}: React.ComponentProps<typeof TabsPrimitive.Trigger>) {
|
|
return (
|
|
<TabsPrimitive.Trigger
|
|
data-slot='tabs-trigger'
|
|
className={cn(DynamicTabsTriggerVariants({ variant, width, className }))}
|
|
{...props}
|
|
/>
|
|
);
|
|
}
|
|
|
|
function DynamicTabsContent({
|
|
className,
|
|
...props
|
|
}: React.ComponentProps<typeof TabsPrimitive.Content>) {
|
|
return (
|
|
<TabsPrimitive.Content
|
|
data-slot='tabs-content'
|
|
className={cn(
|
|
"mt-2 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2",
|
|
className
|
|
)}
|
|
{...props}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export { DynamicTabs, DynamicTabsContent, DynamicTabsList, DynamicTabsTrigger };
|