mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-19 21:16:00 +00:00
156 lines
3.8 KiB
Svelte
156 lines
3.8 KiB
Svelte
<script lang="ts">
|
|
import { onMount } from 'svelte';
|
|
import FontIcon from '../icons/FontIcon.svelte';
|
|
import {
|
|
currentDropDownMenu,
|
|
selectedWidget,
|
|
visibleSelectedWidget,
|
|
visibleWidgetSideBar,
|
|
visibleHamburgerMenuWidget,
|
|
lockedDatabaseMode,
|
|
getCurrentConfig,
|
|
} from '../stores';
|
|
import mainMenuDefinition from '../../../../app/src/mainMenuDefinition';
|
|
import hasPermission from '../utility/hasPermission';
|
|
|
|
let domSettings;
|
|
let domMainMenu;
|
|
|
|
const widgets = [
|
|
getCurrentConfig().storageDatabase && {
|
|
icon: 'icon admin',
|
|
name: 'admin',
|
|
title: 'Administration',
|
|
},
|
|
{
|
|
icon: 'icon database',
|
|
name: 'database',
|
|
title: 'Database connections',
|
|
},
|
|
// {
|
|
// icon: 'fa-table',
|
|
// name: 'table',
|
|
// },
|
|
{
|
|
icon: 'icon file',
|
|
name: 'file',
|
|
title: 'Favorites & Saved files',
|
|
},
|
|
{
|
|
icon: 'icon history',
|
|
name: 'history',
|
|
title: 'Query history & Closed tabs',
|
|
},
|
|
{
|
|
icon: 'icon archive',
|
|
name: 'archive',
|
|
title: 'Archive (saved tabular data)',
|
|
},
|
|
{
|
|
icon: 'icon plugin',
|
|
name: 'plugins',
|
|
title: 'Extensions & Plugins',
|
|
},
|
|
{
|
|
icon: 'icon cell-data',
|
|
name: 'cell-data',
|
|
title: 'Selected cell data detail view',
|
|
},
|
|
{
|
|
icon: 'icon app',
|
|
name: 'app',
|
|
title: 'Application layers',
|
|
},
|
|
// {
|
|
// icon: 'icon settings',
|
|
// name: 'settings',
|
|
// },
|
|
// {
|
|
// icon: 'fa-check',
|
|
// name: 'settings',
|
|
// },
|
|
];
|
|
|
|
function handleChangeWidget(name) {
|
|
if ($visibleSelectedWidget == name) {
|
|
$visibleWidgetSideBar = false;
|
|
} else {
|
|
$selectedWidget = name;
|
|
$visibleWidgetSideBar = true;
|
|
}
|
|
}
|
|
//const handleChangeWidget= e => (selectedWidget.set(item.name))
|
|
|
|
function handleSettingsMenu() {
|
|
const rect = domSettings.getBoundingClientRect();
|
|
const left = rect.right;
|
|
const top = rect.bottom;
|
|
const items = [{ command: 'settings.show' }, { command: 'theme.changeTheme' }, { command: 'settings.commands' }];
|
|
currentDropDownMenu.set({ left, top, items });
|
|
}
|
|
|
|
function handleMainMenu() {
|
|
const rect = domMainMenu.getBoundingClientRect();
|
|
const left = rect.right;
|
|
const top = rect.top;
|
|
const items = mainMenuDefinition({ editMenu: false });
|
|
currentDropDownMenu.set({ left, top, items });
|
|
}
|
|
</script>
|
|
|
|
<div class="main">
|
|
{#if $visibleHamburgerMenuWidget}
|
|
<div class="wrapper mb-3" on:click={handleMainMenu} bind:this={domMainMenu}>
|
|
<FontIcon icon="icon menu" />
|
|
</div>
|
|
{/if}
|
|
{#each widgets.filter(x => x && hasPermission(`widgets/${x.name}`)) as item}
|
|
<div
|
|
class="wrapper"
|
|
class:selected={item.name == $visibleSelectedWidget}
|
|
on:click={() => handleChangeWidget(item.name)}
|
|
>
|
|
<FontIcon icon={item.icon} title={item.title} />
|
|
</div>
|
|
{/each}
|
|
|
|
<div class="flex1"> </div>
|
|
|
|
<div
|
|
class="wrapper"
|
|
title={`Toggle whether tabs from all databases are visible. Currently - ${$lockedDatabaseMode ? 'NO' : 'YES'}`}
|
|
on:click={() => {
|
|
$lockedDatabaseMode = !$lockedDatabaseMode;
|
|
}}
|
|
>
|
|
<FontIcon icon={$lockedDatabaseMode ? 'icon locked-database-mode' : 'icon unlocked-database-mode'} />
|
|
</div>
|
|
|
|
<div class="wrapper" on:click={handleSettingsMenu} bind:this={domSettings}>
|
|
<FontIcon icon="icon settings" />
|
|
</div>
|
|
</div>
|
|
|
|
<style>
|
|
.wrapper {
|
|
font-size: 23pt;
|
|
height: 60px;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
color: var(--theme-font-inv-2);
|
|
}
|
|
.wrapper:hover {
|
|
color: var(--theme-font-inv-1);
|
|
}
|
|
.wrapper.selected {
|
|
color: var(--theme-font-inv-1);
|
|
background: var(--theme-bg-inv-3);
|
|
}
|
|
.main {
|
|
display: flex;
|
|
flex: 1;
|
|
flex-direction: column;
|
|
}
|
|
</style>
|