mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-12-30 06:11:38 +00:00
33 lines
1.3 KiB
TypeScript
33 lines
1.3 KiB
TypeScript
import create, { UseStore } from "zustand";
|
|
|
|
export interface SidePanelState {
|
|
isOpen: boolean;
|
|
panelWidth: string;
|
|
hasConsole: boolean;
|
|
panelContent?: JSX.Element;
|
|
headerText?: string;
|
|
setHeaderText: (headerText: string) => void;
|
|
openSidePanel: (headerText: string, panelContent: JSX.Element, panelWidth?: string, onClose?: () => void) => void;
|
|
closeSidePanel: () => void;
|
|
setPanelHasConsole: (hasConsole: boolean) => void;
|
|
getRef?: React.RefObject<HTMLElement>; // Optional ref for focusing the last element.
|
|
}
|
|
export const useSidePanel: UseStore<SidePanelState> = create((set) => ({
|
|
isOpen: false,
|
|
panelWidth: "440px",
|
|
hasConsole: true,
|
|
setHeaderText: (headerText: string) => set((state) => ({ ...state, headerText })),
|
|
setPanelHasConsole: (hasConsole: boolean) => set((state) => ({ ...state, hasConsole })),
|
|
openSidePanel: (headerText, panelContent, panelWidth = "440px") =>
|
|
set((state) => ({ ...state, headerText, panelContent, panelWidth, isOpen: true })),
|
|
closeSidePanel: () => {
|
|
const lastFocusedElement = useSidePanel.getState().getRef;
|
|
set((state) => ({ ...state, isOpen: false }));
|
|
const timeoutId = setTimeout(() => {
|
|
lastFocusedElement?.current?.focus();
|
|
set({ getRef: undefined });
|
|
}, 300);
|
|
return () => clearTimeout(timeoutId);
|
|
},
|
|
}));
|