import { writable, derived, readable } from 'svelte/store'; import { ExtensionsDirectory } from 'dbgate-types'; interface TabDefinition { title: string; closedTime?: number; icon: string; props: any; selected: boolean; busy: boolean; tabid: string; tabComponent: string; } export function writableWithStorage(defaultValue: T, storageName) { const init = localStorage.getItem(storageName); const res = writable(init ? JSON.parse(init) : defaultValue); res.subscribe(value => { localStorage.setItem(storageName, JSON.stringify(value)); }); return res; } function subscribeCssVariable(store, transform, cssVariable) { store.subscribe(value => document.documentElement.style.setProperty(cssVariable, transform(value))); } export const selectedWidget = writable('database'); export const openedConnections = writable([]); export const currentDatabase = writable(null); export const openedTabs = writableWithStorage([], 'openedTabs'); export const extensions = writable(null); export const visibleCommandPalette = writable(false); export const commands = writable({}); export const currentTheme = writableWithStorage('theme-light', 'currentTheme'); export const activeTabId = derived([openedTabs], ([$openedTabs]) => $openedTabs.find(x => x.selected)?.tabid); export const visibleToolbar = writableWithStorage(1, 'visibleToolbar'); export const leftPanelWidth = writable(300); export const currentDropDownMenu = writable(null); export const openedModals = writable([]); export const nullStore = readable(null, () => {}); subscribeCssVariable(selectedWidget, x => (x ? 1 : 0), '--dim-visible-left-panel'); subscribeCssVariable(visibleToolbar, x => (x ? 1 : 0), '--dim-visible-toolbar'); subscribeCssVariable(leftPanelWidth, x => `${x}px`, '--dim-left-panel-width');