PreviewCodeTab 1Tab 2Tab 3Content for Tab 1 How it works Install the following dependencies:pnpmnpmyarnbunpnpm add framer-motion Create a new file @/components/ui/tabs.tsx and paste the following code into your project.tabs.tsx"use client"; import * as React from "react"; import * as TabsPrimitive from "@radix-ui/react-tabs"; import { cn } from "@/lib/utils"; const Tabs = TabsPrimitive.Root; const TabsList = React.forwardRef< React.ComponentRef<typeof TabsPrimitive.List>, React.ComponentPropsWithoutRef<typeof TabsPrimitive.List> >(({ className, ...props }, ref) => ( <TabsPrimitive.List ref={ref} className={cn( "inline-flex h-9 items-center justify-center rounded-lg bg-muted p-1 text-muted-foreground", className, )} {...props} /> )); TabsList.displayName = TabsPrimitive.List.displayName; const TabsTrigger = React.forwardRef< React.ComponentRef<typeof TabsPrimitive.Trigger>, React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger> >(({ className, ...props }, ref) => ( <TabsPrimitive.Trigger ref={ref} className={cn( "data-[state=active] 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", className, )} {...props} /> )); TabsTrigger.displayName = TabsPrimitive.Trigger.displayName; const TabsContent = React.forwardRef< React.ComponentRef<typeof TabsPrimitive.Content>, React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content> >(({ className, ...props }, ref) => ( <TabsPrimitive.Content ref={ref} 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} /> )); TabsContent.displayName = TabsPrimitive.Content.displayName; export { Tabs, TabsList, TabsTrigger, TabsContent };CopyView CodeUse the component in your appimport { Tabs, TabsContent, TabsList, TabsTrigger } from "@/components/ui/tabs"; export default function TabDemo() { return ( <Tabs defaultValue="tab-1"> <TabsList className="bg-transparent"> <TabsTrigger value="tab-1" className="data-[state=active]:bg-muted data-[state=active]:shadow-none" > Tab 1 </TabsTrigger> <TabsTrigger value="tab-2" className="data-[state=active]:bg-muted data-[state=active]:shadow-none" > Tab 2 </TabsTrigger> <TabsTrigger value="tab-3" className="data-[state=active]:bg-muted data-[state=active]:shadow-none" > Tab 3 </TabsTrigger> </TabsList> <TabsContent value="tab-1"> <p className="p-4 text-center text-xs text-muted-foreground"> Content for Tab 1 </p> </TabsContent> <TabsContent value="tab-2"> <p className="p-4 text-center text-xs text-muted-foreground"> Content for Tab 2 </p> </TabsContent> <TabsContent value="tab-3"> <p className="p-4 text-center text-xs text-muted-foreground"> Content for Tab 3 </p> </TabsContent> </Tabs> ); }CopyView Code Examples Default PreviewCodeTab 1Tab 2Tab 3Content for Tab 1