blob: 411025f4dba1f5f5b20f278a8ae7c914ab902a79 [file] [log] [blame]
giod0026612025-05-08 13:00:36 +00001import * as React from "react";
2import * as TabsPrimitive from "@radix-ui/react-tabs";
gio5f2f1002025-03-20 18:38:48 +04003
giod0026612025-05-08 13:00:36 +00004import { cn } from "@/lib/utils";
gio5f2f1002025-03-20 18:38:48 +04005
giod0026612025-05-08 13:00:36 +00006const Tabs = TabsPrimitive.Root;
gio5f2f1002025-03-20 18:38:48 +04007
8const TabsList = React.forwardRef<
giod0026612025-05-08 13:00:36 +00009 React.ElementRef<typeof TabsPrimitive.List>,
10 React.ComponentPropsWithoutRef<typeof TabsPrimitive.List>
gio5f2f1002025-03-20 18:38:48 +040011>(({ className, ...props }, ref) => (
giod0026612025-05-08 13:00:36 +000012 <TabsPrimitive.List
13 ref={ref}
14 className={cn(
15 "inline-flex h-9 items-center justify-center rounded-lg bg-muted p-1 text-muted-foreground",
16 className,
17 )}
18 {...props}
19 />
20));
21TabsList.displayName = TabsPrimitive.List.displayName;
gio5f2f1002025-03-20 18:38:48 +040022
23const TabsTrigger = React.forwardRef<
giod0026612025-05-08 13:00:36 +000024 React.ElementRef<typeof TabsPrimitive.Trigger>,
25 React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger>
gio5f2f1002025-03-20 18:38:48 +040026>(({ className, ...props }, ref) => (
giod0026612025-05-08 13:00:36 +000027 <TabsPrimitive.Trigger
28 ref={ref}
29 className={cn(
30 "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",
31 className,
32 )}
33 {...props}
34 />
35));
36TabsTrigger.displayName = TabsPrimitive.Trigger.displayName;
gio5f2f1002025-03-20 18:38:48 +040037
38const TabsContent = React.forwardRef<
giod0026612025-05-08 13:00:36 +000039 React.ElementRef<typeof TabsPrimitive.Content>,
40 React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content>
gio5f2f1002025-03-20 18:38:48 +040041>(({ className, ...props }, ref) => (
giod0026612025-05-08 13:00:36 +000042 <TabsPrimitive.Content
43 ref={ref}
44 className={cn(
45 "mt-2 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2",
46 className,
47 )}
48 {...props}
49 />
50));
51TabsContent.displayName = TabsPrimitive.Content.displayName;
gio5f2f1002025-03-20 18:38:48 +040052
giod0026612025-05-08 13:00:36 +000053export { Tabs, TabsList, TabsTrigger, TabsContent };