* Refactor icons passed as props with the new way Co-authored-by: v1b3m <vibenjamin6@gmail.com> Co-authored-by: Matheus <matheus_benini@hotmail.com> * Update more files Co-authored-by: v1b3m <vibenjamin6@gmail.com> Co-authored-by: Matheus <matheus_benini@hotmail.com> * Fix according to review * Fix according to review * Fix according to review * Fix chromatic regressions --------- Co-authored-by: v1b3m <vibenjamin6@gmail.com> Co-authored-by: Matheus <matheus_benini@hotmail.com> Co-authored-by: Charles Bochet <charles@twenty.com>
55 lines
1.2 KiB
TypeScript
55 lines
1.2 KiB
TypeScript
import * as React from 'react';
|
|
|
|
import { IconComponent } from '@/ui/icon/types/IconComponent';
|
|
import { useRecoilScopedState } from '@/ui/utilities/recoil-scope/hooks/useRecoilScopedState';
|
|
|
|
import { activeTabIdScopedState } from '../states/activeTabIdScopedState';
|
|
|
|
import { Tab } from './Tab';
|
|
|
|
type SingleTabProps = {
|
|
title: string;
|
|
Icon?: IconComponent;
|
|
id: string;
|
|
hide?: boolean;
|
|
disabled?: boolean;
|
|
};
|
|
|
|
type TabListProps = {
|
|
tabs: SingleTabProps[];
|
|
context: React.Context<string | null>;
|
|
};
|
|
|
|
export function TabList({ tabs, context }: TabListProps) {
|
|
const initialActiveTabId = tabs[0].id;
|
|
|
|
const [activeTabId, setActiveTabId] = useRecoilScopedState(
|
|
activeTabIdScopedState,
|
|
context,
|
|
);
|
|
|
|
React.useEffect(() => {
|
|
setActiveTabId(initialActiveTabId);
|
|
}, [initialActiveTabId, setActiveTabId]);
|
|
|
|
return (
|
|
<>
|
|
{tabs
|
|
.filter((tab) => !tab.hide)
|
|
.map((tab) => (
|
|
<Tab
|
|
id={tab.id}
|
|
key={tab.id}
|
|
title={tab.title}
|
|
Icon={tab.Icon}
|
|
active={tab.id === activeTabId}
|
|
onClick={() => {
|
|
setActiveTabId(tab.id);
|
|
}}
|
|
disabled={tab.disabled}
|
|
/>
|
|
))}
|
|
</>
|
|
);
|
|
}
|