mirror of
https://github.com/dbgate/dbgate
synced 2024-11-07 20:26:23 +00:00
152 lines
5.1 KiB
TypeScript
152 lines
5.1 KiB
TypeScript
import { writable, derived, readable } from 'svelte/store';
|
|
import { ExtensionsDirectory } from 'dbgate-types';
|
|
import invalidateCommands from './commands/invalidateCommands';
|
|
import getElectron from './utility/getElectron';
|
|
import { GlobalCommand } from './commands/registerCommand';
|
|
import { useConfig, useSettings } from './utility/metadataLoaders';
|
|
import _ from 'lodash';
|
|
|
|
interface TabDefinition {
|
|
title: string;
|
|
closedTime?: number;
|
|
icon: string;
|
|
props: any;
|
|
selected: boolean;
|
|
busy: boolean;
|
|
tabid: string;
|
|
tabComponent: string;
|
|
}
|
|
|
|
export function writableWithStorage<T>(defaultValue: T, storageName) {
|
|
const init = localStorage.getItem(storageName);
|
|
const res = writable<T>(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<TabDefinition[]>([], 'openedTabs');
|
|
export const extensions = writable<ExtensionsDirectory>(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 activeTab = derived([openedTabs], ([$openedTabs]) => $openedTabs.find(x => x.selected));
|
|
export const recentDatabases = writableWithStorage([], 'recentDatabases');
|
|
export const commandsSettings = derived(useSettings(), (config: any) => (config || {}).commands || {});
|
|
export const allResultsInOneTabDefault = writableWithStorage(false, 'allResultsInOneTabDefault');
|
|
export const commandsCustomized = derived([commands, commandsSettings], ([$commands, $commandsSettings]) =>
|
|
_.mapValues($commands, (v, k) => ({
|
|
// @ts-ignore
|
|
...v,
|
|
...$commandsSettings[k],
|
|
}))
|
|
);
|
|
|
|
export const visibleToolbar = writableWithStorage(true, 'visibleToolbar');
|
|
export const leftPanelWidth = writable(300);
|
|
export const currentDropDownMenu = writable(null);
|
|
export const openedModals = writable([]);
|
|
export const nullStore = readable(null, () => {});
|
|
export const currentArchive = writable('default');
|
|
export const isFileDragActive = writable(false);
|
|
export const selectedCellsCallback = writable(null);
|
|
export const loadingPluginStore = writable({
|
|
loaded: false,
|
|
loadingPackageName: null,
|
|
});
|
|
|
|
export const currentThemeDefinition = derived([currentTheme, extensions], ([$currentTheme, $extensions]) =>
|
|
$extensions.themes.find(x => x.className == $currentTheme)
|
|
);
|
|
|
|
const electron = getElectron();
|
|
|
|
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');
|
|
|
|
let activeTabIdValue = null;
|
|
activeTabId.subscribe(value => {
|
|
activeTabIdValue = value;
|
|
invalidateCommands();
|
|
});
|
|
export const getActiveTabId = () => activeTabIdValue;
|
|
|
|
let visibleCommandPaletteValue = null;
|
|
visibleCommandPalette.subscribe(value => {
|
|
visibleCommandPaletteValue = value;
|
|
invalidateCommands();
|
|
});
|
|
export const getVisibleCommandPalette = () => visibleCommandPaletteValue;
|
|
|
|
let visibleToolbarValue = null;
|
|
visibleToolbar.subscribe(value => {
|
|
visibleToolbarValue = value;
|
|
invalidateCommands();
|
|
});
|
|
export const getVisibleToolbar = () => visibleToolbarValue;
|
|
|
|
let openedTabsValue = null;
|
|
openedTabs.subscribe(value => {
|
|
openedTabsValue = value;
|
|
invalidateCommands();
|
|
});
|
|
export const getOpenedTabs = () => openedTabsValue;
|
|
|
|
let commandsValue = null;
|
|
commands.subscribe(value => {
|
|
commandsValue = value;
|
|
|
|
if (electron) {
|
|
const { ipcRenderer } = electron;
|
|
ipcRenderer.send('update-commands', JSON.stringify(value));
|
|
}
|
|
});
|
|
export const getCommands = () => commandsValue;
|
|
|
|
let activeTabValue = null;
|
|
activeTab.subscribe(value => {
|
|
activeTabValue = value;
|
|
});
|
|
export const getActiveTab = () => activeTabValue;
|
|
|
|
const currentConfigStore = useConfig();
|
|
let currentConfigValue = null;
|
|
currentConfigStore.subscribe(value => {
|
|
currentConfigValue = value;
|
|
invalidateCommands();
|
|
if (value.singleDatabase) {
|
|
currentDatabase.set(value.singleDatabase);
|
|
}
|
|
});
|
|
export const getCurrentConfig = () => currentConfigValue;
|
|
|
|
let recentDatabasesValue = null;
|
|
recentDatabases.subscribe(value => {
|
|
recentDatabasesValue = value;
|
|
});
|
|
export const getRecentDatabases = () => _.compact(recentDatabasesValue);
|
|
|
|
let currentDatabaseValue = null;
|
|
currentDatabase.subscribe(value => {
|
|
currentDatabaseValue = value;
|
|
invalidateCommands();
|
|
});
|
|
export const getCurrentDatabase = () => currentDatabaseValue;
|
|
|
|
let currentSettingsValue = null;
|
|
useSettings().subscribe(value => {
|
|
currentSettingsValue = value;
|
|
invalidateCommands();
|
|
});
|
|
export const getCurrentSettings = () => currentSettingsValue || {};
|