Files
cosmos-explorer/src/hooks/useSidePanel.ts
Steve Faulkner 481ff9e7fe Migrate SidePanel state to Zustand (#799)
Co-authored-by: hardiknai-techm <HN00734461@TechMahindra.com>
2021-05-27 16:07:07 -05:00

16 lines
565 B
TypeScript

import create, { UseStore } from "zustand";
export interface SidePanelState {
isOpen: boolean;
panelContent?: JSX.Element;
headerText?: string;
openSidePanel: (headerText: string, panelContent: JSX.Element, onClose?: () => void) => void;
closeSidePanel: () => void;
}
export const useSidePanel: UseStore<SidePanelState> = create((set) => ({
isOpen: false,
openSidePanel: (headerText, panelContent) => set((state) => ({ ...state, headerText, panelContent, isOpen: true })),
closeSidePanel: () => set((state) => ({ ...state, isOpen: false })),
}));