A set of panels with tabbed navigation.
"use client";
import { Tabs as TabsPrimitive } from "@ark-ui/react";
import { cva, VariantProps } from "class-variance-authority";
import * as React from "react";
const Tabs = TabsPrimitive.Root;
const tabListStyle = cva(
"border-b-base-300 relative flex h-10 items-center justify-start border-b",
{
variants: {
size: {
sm: "h-9",
md: "h-10",
lg: "h-11",
},
},
defaultVariants: {
size: "md",
},
},
);
const TabList = React.forwardRef<
React.ElementRef<typeof TabsPrimitive.List> &
VariantProps<typeof tabListStyle>,
React.ComponentPropsWithoutRef<typeof TabsPrimitive.List> &
VariantProps<typeof tabListStyle>
>(({ className, children, size, ...props }, ref) => (
<TabsPrimitive.List
ref={ref}
className={tabListStyle({ size, className })}
{...props}
>
{children}
</TabsPrimitive.List>
));
TabList.displayName = "TabList";
const Tab = React.forwardRef<
React.ElementRef<typeof TabsPrimitive.Trigger>,
React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger>
>(({ className, children, ...props }, ref) => {
return (
<TabsPrimitive.Trigger
ref={ref}
className={
"text-base-700 hover:bg-base-200 inline-flex h-full flex-shrink-0 items-center justify-center overflow-visible whitespace-nowrap px-3 text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 " +
className
}
{...props}
>
{children}
<TabsPrimitive.Indicator className="bg-primary-600 bottom-0 left-0 h-0.5 w-[--width]" />
</TabsPrimitive.Trigger>
);
});
Tab.displayName = "Tab";
const TabContent = React.forwardRef<
React.ElementRef<typeof TabsPrimitive.Content>,
React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content>
>(({ className, ...props }, ref) => (
<TabsPrimitive.Content
ref={ref}
className={
"ring-offset-background text-base-700 focus-visible:ring-ring mt-3 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 " +
className
}
{...props}
/>
));
TabContent.displayName = "TabContent";
export { Tab, TabContent, TabList, Tabs };
import { Tab, TabContent, TabList, Tabs } from "../core/tabs";
export const TabsExample = () => {
return (
<Tabs defaultValue="account">
<TabList size="sm">
<Tab value="account">Account</Tab>
<Tab value="settings">Settings</Tab>
</TabList>
<TabContent value="account">qrgjmoqnrmgorngqerignrez</TabContent>
<TabContent value="settings">qermguqhermgqrgn</TabContent>
</Tabs>
);
};