tabs.tsx raw
1 import * as React from 'react'
2 import * as TabsPrimitive from '@radix-ui/react-tabs'
3
4 import { cn } from '@/lib/utils'
5
6 const Tabs = TabsPrimitive.Root
7
8 const TabsList = React.forwardRef<
9 React.ElementRef<typeof TabsPrimitive.List>,
10 React.ComponentPropsWithoutRef<typeof TabsPrimitive.List>
11 >(({ className, ...props }, ref) => (
12 <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 ))
21 TabsList.displayName = TabsPrimitive.List.displayName
22
23 const TabsTrigger = React.forwardRef<
24 React.ElementRef<typeof TabsPrimitive.Trigger>,
25 React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger>
26 >(({ className, ...props }, ref) => (
27 <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 ))
36 TabsTrigger.displayName = TabsPrimitive.Trigger.displayName
37
38 const TabsContent = React.forwardRef<
39 React.ElementRef<typeof TabsPrimitive.Content>,
40 React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content>
41 >(({ className, ...props }, ref) => (
42 <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 ))
51 TabsContent.displayName = TabsPrimitive.Content.displayName
52
53 export { Tabs, TabsList, TabsTrigger, TabsContent }
54