Skip to content

Commit

Permalink
fix tabs flashing that occurs first render
Browse files Browse the repository at this point in the history
  • Loading branch information
layerok committed Jul 1, 2024
1 parent 4869293 commit 5433645
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 4 deletions.
3 changes: 3 additions & 0 deletions src/examples/clip-one/components/AppLayout/AppLayout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,9 @@ export function AppLayout() {
onTabsChange={setTabs}
onStartPinnedTabsChange={setStartPinnedTabsChange}
startPinnedTabs={startPinnedTabs}
initialActiveTabId={activeTabId}
initialTabs={tabs}
initialStartPinnedTabs={startPinnedTabs}
hasControlledActiveTabId
activeTabId={activeTabId}
onActiveTabIdChange={setActiveTabId}
Expand Down
3 changes: 3 additions & 0 deletions src/examples/clip-one/routes/CategoriesRoute.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,9 @@ export function CategoriesRoute() {
onActiveTabIdChange={setActiveTabId}
tabs={tabs}
startPinnedTabs={startPinnedTabs}
initialActiveTabId={activeTabId}
initialTabs={tabs}
initialStartPinnedTabs={startPinnedTabs}
onTabsChange={setTabs}
hasControlledActiveTabId
onStartPinnedTabsChange={setStartPinnedTabsChange}
Expand Down
3 changes: 3 additions & 0 deletions src/examples/clip-one/routes/ProductsRoute.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,9 @@ export function ProductsRoute() {
onTabsChange={setTabs}
onStartPinnedTabsChange={onStartPinnedTabsChange}
startPinnedTabs={startPinnedTabs}
initialActiveTabId={activeTabId}
initialTabs={tabs}
initialStartPinnedTabs={startPinnedTabs}
hasControlledActiveTabId
activeTabId={activeTabId}
onActiveTabIdChange={setActiveTabId}
Expand Down
18 changes: 14 additions & 4 deletions src/lib/tabs/useTabs.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,11 @@ export type TabsApi = {
export type TabsProps = {
hasControlledActiveTabId?: boolean;
activeTabId?: string;
initialActiveTabId?: string;
startPinnedTabs?: string[];
tabs?: TabModel<any>[];
initialTabs?: TabModel<any>[];
initialStartPinnedTabs?: string[];
onActiveTabIdChange?: (id: string | undefined) => void;
onStartPinnedTabsChange?: (ids: string[]) => void;
onTabsChange?: (tabs: TabModel<any>[]) => void;
Expand Down Expand Up @@ -91,7 +94,14 @@ const useActive = (apiRef: MutableRefObject<TabsApi>, props: TabsProps) => {
};

const useTabsState = (apiRef: MutableRefObject<TabsApi>, props: TabsProps) => {
const { onTabsChange, onActiveTabIdChange, onStartPinnedTabsChange } = props;
const {
onTabsChange,
onActiveTabIdChange,
onStartPinnedTabsChange,
initialTabs = [],
initialActiveTabId,
initialStartPinnedTabs = [],
} = props;
const handlersMapRef = useRef<{
tabs?: (tabs: TabModel[]) => void;
activeTabId?: (id: string | undefined) => void;
Expand All @@ -103,9 +113,9 @@ const useTabsState = (apiRef: MutableRefObject<TabsApi>, props: TabsProps) => {
});

const stateRef = useRef<State>({
tabs: [],
activeTabId: undefined,
startPinnedTabs: [],
tabs: initialTabs,
activeTabId: initialActiveTabId,
startPinnedTabs: initialStartPinnedTabs,
});

apiRef.current["getState"] = () => {
Expand Down

0 comments on commit 5433645

Please sign in to comment.