cal.pub0.org/packages/ui/components/navigation/tabs/VerticalTabs.tsx

52 lines
1.1 KiB
TypeScript

import { classNames } from "@calcom/lib";
import type { VerticalTabItemProps } from "./VerticalTabItem";
import VerticalTabItem from "./VerticalTabItem";
export { VerticalTabItem };
export interface NavTabProps {
tabs: VerticalTabItemProps[];
children?: React.ReactNode;
className?: string;
sticky?: boolean;
linkProps?: VerticalTabItemProps["linkProps"];
itemClassname?: string;
iconClassName?: string;
}
const NavTabs = function ({
tabs,
className = "",
sticky,
linkProps,
itemClassname,
iconClassName,
...props
}: NavTabProps) {
return (
<nav
className={classNames(
`no-scrollbar flex flex-col space-y-0.5 overflow-scroll ${className}`,
sticky && "sticky top-0 -mt-7"
)}
aria-label="Tabs"
{...props}>
{/* padding top for sticky */}
{sticky && <div className="pt-6" />}
{props.children}
{tabs.map((tab, idx) => (
<VerticalTabItem
{...tab}
key={idx}
linkProps={linkProps}
className={itemClassname}
iconClassName={iconClassName}
/>
))}
</nav>
);
};
export default NavTabs;