feat: implement base application layout with NavigationRail and DevExtreme data grid integration

This commit is contained in:
Ümit Tunç
2026-04-24 07:39:06 +03:00
parent bf3d05ea97
commit 914fd0affd
+29 -14
View File
@@ -1,4 +1,5 @@
import { create } from 'zustand';
import { persist, createJSONStorage } from 'zustand/middleware';
interface ConnectionConfig {
host: string;
@@ -23,17 +24,31 @@ interface AppState {
setActiveTable: (table: string | null) => void;
}
export const useAppStore = create<AppState>((set) => ({
darkMode: true,
activeTab: 'explorer',
activeDatabase: null,
activeTable: null,
connection: null,
connected: false,
toggleDarkMode: () => set((state) => ({ darkMode: !state.darkMode })),
setActiveTab: (tab) => set({ activeTab: tab }),
setConnection: (config) => set({ connection: config, connected: true }),
clearConnection: () => set({ connection: null, connected: false, activeDatabase: null, activeTable: null }),
setActiveDatabase: (db) => set({ activeDatabase: db, activeTable: null }),
setActiveTable: (table) => set({ activeTable: table }),
}));
export const useAppStore = create<AppState>()(
persist(
(set) => ({
darkMode: true,
activeTab: 'explorer',
activeDatabase: null,
activeTable: null,
connection: null,
connected: false,
toggleDarkMode: () => set((state) => ({ darkMode: !state.darkMode })),
setActiveTab: (tab) => set({ activeTab: tab }),
setConnection: (config) => set({ connection: config, connected: true }),
clearConnection: () => set({ connection: null, connected: false, activeDatabase: null, activeTable: null }),
setActiveDatabase: (db) => set({ activeDatabase: db, activeTable: null }),
setActiveTable: (table) => set({ activeTable: table }),
}),
{
name: 'mariavel-storage',
storage: createJSONStorage(() => localStorage),
// Only persist connection and connected status
partialize: (state) => ({
connection: state.connection,
connected: state.connected,
darkMode: state.darkMode
}),
}
)
);