feat: implement base application layout with NavigationRail and DevExtreme data grid integration
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
import { create } from 'zustand';
|
import { create } from 'zustand';
|
||||||
|
import { persist, createJSONStorage } from 'zustand/middleware';
|
||||||
|
|
||||||
interface ConnectionConfig {
|
interface ConnectionConfig {
|
||||||
host: string;
|
host: string;
|
||||||
@@ -23,7 +24,9 @@ interface AppState {
|
|||||||
setActiveTable: (table: string | null) => void;
|
setActiveTable: (table: string | null) => void;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const useAppStore = create<AppState>((set) => ({
|
export const useAppStore = create<AppState>()(
|
||||||
|
persist(
|
||||||
|
(set) => ({
|
||||||
darkMode: true,
|
darkMode: true,
|
||||||
activeTab: 'explorer',
|
activeTab: 'explorer',
|
||||||
activeDatabase: null,
|
activeDatabase: null,
|
||||||
@@ -36,4 +39,16 @@ export const useAppStore = create<AppState>((set) => ({
|
|||||||
clearConnection: () => set({ connection: null, connected: false, activeDatabase: null, activeTable: null }),
|
clearConnection: () => set({ connection: null, connected: false, activeDatabase: null, activeTable: null }),
|
||||||
setActiveDatabase: (db) => set({ activeDatabase: db, activeTable: null }),
|
setActiveDatabase: (db) => set({ activeDatabase: db, activeTable: null }),
|
||||||
setActiveTable: (table) => set({ activeTable: table }),
|
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
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|||||||
Reference in New Issue
Block a user