2021-05-27 16:07:07 -05:00
|
|
|
import create, { UseStore } from "zustand";
|
2021-02-10 13:44:00 -08:00
|
|
|
|
2021-05-27 16:07:07 -05:00
|
|
|
export interface SidePanelState {
|
|
|
|
isOpen: boolean;
|
2021-07-19 22:00:33 -07:00
|
|
|
panelWidth: string;
|
2021-05-27 16:07:07 -05:00
|
|
|
panelContent?: JSX.Element;
|
|
|
|
headerText?: string;
|
2021-07-19 22:00:33 -07:00
|
|
|
openSidePanel: (headerText: string, panelContent: JSX.Element, panelWidth?: string, onClose?: () => void) => void;
|
2021-02-10 13:44:00 -08:00
|
|
|
closeSidePanel: () => void;
|
|
|
|
}
|
|
|
|
|
2021-05-27 16:07:07 -05:00
|
|
|
export const useSidePanel: UseStore<SidePanelState> = create((set) => ({
|
|
|
|
isOpen: false,
|
2021-07-19 22:00:33 -07:00
|
|
|
panelWidth: "440px",
|
|
|
|
openSidePanel: (headerText, panelContent, panelWidth = "440px") =>
|
|
|
|
set((state) => ({ ...state, headerText, panelContent, panelWidth, isOpen: true })),
|
2021-05-27 16:07:07 -05:00
|
|
|
closeSidePanel: () => set((state) => ({ ...state, isOpen: false })),
|
|
|
|
}));
|