Files
Dwinzo_beta/app/src/store/useTemplateStore.ts

40 lines
859 B
TypeScript
Raw Normal View History

2025-03-19 18:06:33 +05:30
import { create } from "zustand";
2025-03-20 09:36:10 +05:30
// type Side = "top" | "bottom" | "left" | "right";
2025-03-19 18:06:33 +05:30
2025-03-20 09:36:10 +05:30
export interface Widget {
2025-03-19 18:06:33 +05:30
id: string;
type: string;
title: string;
2025-03-20 09:36:10 +05:30
panel: string;
2025-03-19 18:06:33 +05:30
data: any;
}
2025-03-20 09:36:10 +05:30
export interface Template {
2025-03-19 18:06:33 +05:30
id: string;
name: string;
2025-03-20 09:36:10 +05:30
panelOrder: string[];
2025-03-19 18:06:33 +05:30
widgets: Widget[];
2025-03-20 09:36:10 +05:30
snapshot?: string | null; // Add an optional image property (base64)
2025-03-19 18:06:33 +05:30
}
interface TemplateStore {
templates: Template[];
addTemplate: (template: Template) => void;
removeTemplate: (id: string) => void;
}
export const useTemplateStore = create<TemplateStore>((set) => ({
templates: [],
addTemplate: (template) =>
set((state) => ({
templates: [...state.templates, template],
})),
removeTemplate: (id) =>
set((state) => ({
templates: state.templates.filter((t) => t.id !== id),
})),
}));
export default useTemplateStore;