---
title: Tabs
description: A set of layered sections of content displayed one at a time.
links:
  doc: https://base-ui.com/react/components/tabs
  api: https://base-ui.com/react/components/tabs#api-reference
---

```tsx
'use client';

import {
  Tabs,
  TabsContent,
  TabsList,
  TabsTrigger,
} from '@/components/ui/tabs';

export function TabsDefault() {
  return (
    <Tabs defaultValue='account'>
      
      <TabsContent value='account' className='p-4'>
        <p className='text-sm text-muted-foreground'>
          Make changes to your account.
        </p>
      </TabsContent>
      <TabsContent value='password' className='p-4'>
        <p className='text-sm text-muted-foreground'>
          Change your password here.
        </p>
      </TabsContent>
      <TabsContent value='settings' className='p-4'>
        <p className='text-sm text-muted-foreground'>
          Adjust your settings here.
        </p>
      </TabsContent>
    </Tabs>
  );
}
```

## Installation

```bash
npx shadcn@latest add @fab-ui/tabs
```

**Install the following dependencies:**

```bash
npm install @base-ui/react
```

**Copy and paste the following code into your project.**

```tsx
'use client';

import { Tabs as TabsPrimitive } from '@base-ui/react/tabs';

import { cn } from '@/lib/utils';

type TabsVariant = 'default' | 'underline';

function Tabs({ className, ...props }: TabsPrimitive.Root.Props) {
  return (
    <TabsPrimitive.Root
      data-slot='tabs'
      className={cn(
        'flex flex-col gap-2 data-[orientation=vertical]:flex-row',
        className
      )}
      {...props}
    />
  );
}

function TabsList({
  variant = 'default',
  className,
  children,
  ...props
}: TabsPrimitive.List.Props & {
  variant?: TabsVariant;
}) {
  return (
    <TabsPrimitive.List
      data-slot='tabs-list'
      className={cn(
        'relative z-0 flex w-fit items-center justify-center gap-x-0.5',
        'data-[orientation=vertical]:flex-col',
        variant === 'default'
          ? 'rounded-lg bg-muted p-0.5 text-foreground'
          : 'text-foreground/50 hover:text-foreground data-[orientation=horizontal]:py-1 data-[orientation=vertical]:px-1 *:data-[slot=tabs-trigger]:data-active:text-foreground',
        className
      )}
      {...props}
    >
      {children}
      <TabsPrimitive.Indicator
        data-slot='tab-indicator'
        className={cn(
          'absolute bottom-0 left-0 h-(--active-tab-height) w-(--active-tab-width) translate-x-(--active-tab-left) -translate-y-(--active-tab-bottom) transition-[width,translate] duration-200 ease-in-out',
          variant === 'underline'
            ? 'z-10 bg-primary data-[orientation=horizontal]:h-0.5 data-[orientation=horizontal]:translate-y-px data-[orientation=vertical]:w-0.5 data-[orientation=vertical]:-translate-x-px'
            : '-z-1 rounded-md bg-background/70 shadow-sm dark:bg-background/50'
        )}
      />
    </TabsPrimitive.List>
  );
}

function TabsTrigger({ className, ...props }: TabsPrimitive.Tab.Props) {
  return (
    <TabsPrimitive.Tab
      data-slot='tabs-trigger'
      className={cn(
        "flex flex-1 shrink-0 cursor-pointer items-center justify-center rounded-md border border-transparent text-sm font-medium whitespace-nowrap shadow-none transition-[color,background-color,box-shadow] outline-none focus-visible:ring-2 focus-visible:ring-ring data-disabled:pointer-events-none data-disabled:opacity-64 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
        'gap-1.5 px-[calc(--spacing(2.5)-1px)] py-[calc(--spacing(1.5)-1px)]',
        'data-[orientation=vertical]:w-full data-[orientation=vertical]:justify-start',
        className
      )}
      {...props}
    />
  );
}

function TabsContent({ className, ...props }: TabsPrimitive.Panel.Props) {
  return (
    <TabsPrimitive.Panel
      data-slot='tabs-content'
      className={cn('flex-1 outline-none', className)}
      {...props}
    />
  );
}

export { Tabs, TabsList, TabsTrigger, TabsContent };
```

**Update the import paths to match your project setup.**

## Usage

```tsx
import { Tabs, TabsList, TabsTrigger, TabsPanel } from "@/components/ui/tabs"
```

```tsx
<Tabs defaultValue="account">
  
  Account content
  Password content
</Tabs>
```

## Examples

### Underline

Use `variant="underline"` on the `TabsList` for an underline style indicator.

```tsx
'use client';

import {
  Tabs,
  TabsContent,
  TabsList,
  TabsTrigger,
} from '@/components/ui/tabs';

export function TabsUnderline() {
  return (
    <Tabs defaultValue='overview'>
      
      <TabsContent value='overview' className='p-4'>
        <p className='text-sm text-muted-foreground'>
          View your dashboard overview.
        </p>
      </TabsContent>
      <TabsContent value='analytics' className='p-4'>
        <p className='text-sm text-muted-foreground'>
          Analyze your data and metrics.
        </p>
      </TabsContent>
      <TabsContent value='reports' className='p-4'>
        <p className='text-sm text-muted-foreground'>
          Generate and view reports.
        </p>
      </TabsContent>
    </Tabs>
  );
}
```
