Files
Homarr/src/components/Dashboard/Wrappers/gridstack/store.tsx

51 lines
1.5 KiB
TypeScript
Raw Normal View History

2023-01-06 22:46:07 +01:00
import { useMantineTheme } from '@mantine/core';
import create from 'zustand';
import { useConfigContext } from '../../../../config/provider';
2023-01-06 22:46:07 +01:00
export const useGridstackStore = create<GridstackStoreType>((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 => {
2023-01-06 22:46:07 +01:00
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';
2023-01-06 22:46:07 +01:00
return 'small';
};
2023-01-06 22:46:07 +01:00
export const useWrapperColumnCount = () => {
const { config } = useConfigContext();
const numberOfSidebars =
(config?.settings.customization.layout.enabledLeftSidebar ? 1 : 0) +
(config?.settings.customization.layout.enabledRightSidebar ? 1 : 0);
switch (useNamedWrapperColumnCount()) {
case 'large':
return 15 - numberOfSidebars * 2;
case 'medium':
return 9 - numberOfSidebars * 2;
case 'small':
return 3;
default:
return null;
}
2023-01-06 22:46:07 +01:00
};
function getCurrentShapeSize(size: number) {
return size >= 1400 ? 'lg' : size >= 768 ? 'md' : 'sm';
}