import { useMantineTheme } from '@mantine/core'; import create from 'zustand'; export const useGridstackStore = create((set, get) => ({ mainAreaWidth: null, currentShapeSize: null, setMainAreaWidth: (w: number) => set((v) => ({ ...v, mainAreaWidth: w, currentShapeSize: getCurrentShapeSize(w) })), })); interface GridstackStoreType { mainAreaWidth: null | number; currentShapeSize: null | 'sm' | 'md' | 'lg'; setMainAreaWidth: (width: number) => void; } export const useNamedWrapperColumnCount = (): 'small' | 'medium' | 'large' | null => { const mainAreaWidth = useGridstackStore((x) => x.mainAreaWidth); const { sm, xl } = useMantineTheme().breakpoints; if (!mainAreaWidth) return null; if (mainAreaWidth >= xl) return 'large'; if (mainAreaWidth >= sm) return 'medium'; return 'small'; }; export const useWrapperColumnCount = () => { switch (useNamedWrapperColumnCount()) { case 'large': return 12; case 'medium': return 6; case 'small': return 3; default: return null; } }; function getCurrentShapeSize(size: number) { return size >= 1400 ? 'lg' : size >= 768 ? 'md' : 'sm'; }