Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 15 additions & 3 deletions amoro-web/src/components/Layout.vue
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@
/ -->

<script lang="ts">
import { defineComponent } from 'vue'
import { computed, defineComponent } from 'vue'
import { useRoute } from 'vue-router'
import SideBar from '@/components/Sidebar.vue'
import TopBar from '@/components/Topbar.vue'

Expand All @@ -37,6 +38,14 @@ export default defineComponent({
default: true,
},
},
setup() {
const route = useRoute()
const isTablesPage = computed(() => route.path.includes('/tables'))

return {
isTablesPage,
}
},
})
</script>

Expand All @@ -48,7 +57,7 @@ export default defineComponent({
<!-- topbar -->
<TopBar v-if="showTopBar" />
<!-- content -->
<div class="content">
<div class="content" :class="{ 'content--workspace': isTablesPage }">
<router-view />
</div>
</div>
Expand All @@ -66,11 +75,14 @@ export default defineComponent({
flex: 1;
flex-direction: column;
transition: width 0.3s;
overflow: auto;
overflow: hidden;
.content {
height: calc(100% - 48px);
overflow: auto;
}
.content--workspace {
overflow: hidden;
}
}
}
</style>
64 changes: 5 additions & 59 deletions amoro-web/src/components/Sidebar.vue
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,10 @@
/ -->

<script lang="ts">
import { computed, defineComponent, nextTick, reactive, ref, toRefs, watchEffect, onMounted, onBeforeUnmount } from 'vue'
import { computed, defineComponent, nextTick, reactive, toRefs, watchEffect } from 'vue'
import { useRoute, useRouter } from 'vue-router'
import { useI18n } from 'vue-i18n'
import useStore from '@/store/index'
import TableMenu from '@/components/tables-sub-menu/TablesMenu.vue'
import { getQueryString } from '@/utils'

interface MenuItem {
Expand All @@ -32,9 +31,6 @@ interface MenuItem {

export default defineComponent({
name: 'Sidebar',
components: {
TableMenu,
},
setup() {
const { t } = useI18n()
const router = useRouter()
Expand All @@ -48,7 +44,6 @@ export default defineComponent({
const hasToken = computed(() => {
return !!(getQueryString('token') || '')
})
const timer = ref(0)
const menuList = computed(() => {
const menu: MenuItem[] = [
{
Expand Down Expand Up @@ -111,74 +106,28 @@ export default defineComponent({
}

const navClick = (item: MenuItem) => {
if (item.key === 'tables') {
nextTick(() => {
setCurMenu()
})
return
}
const targetPath = item.key === 'tables' ? '/tables' : `/${item.key}`
router.replace({
path: `/${item.key}`,
path: targetPath,
})
nextTick(() => {
setCurMenu()
})
}

const mouseenter = (item: MenuItem) => {
toggleTablesMenu(item.key === 'tables')
}

const goCreatePage = () => {
toggleTablesMenu(false)
router.push({
path: '/tables/create',
})
}

function toggleTablesMenu(flag = false) {
if (hasToken.value) {
return
}
timer.value && clearTimeout(timer.value)
const time = flag ? 0 : 200
timer.value = setTimeout(() => {
store.updateTablesMenu(flag)
}, time)
}

const viewOverview = () => {
router.push({
path: '/overview',
})
}

const tableMenusRef = ref(null)
function handleClickOutside(event: Event) {
if (tableMenusRef?.value && !(tableMenusRef.value as any).contains(event.target)) {
toggleTablesMenu(false)
}
}

onBeforeUnmount(() => {
document.removeEventListener('click', handleClickOutside)
})

onMounted(() => {
document.addEventListener('click', handleClickOutside)
})

return {
...toRefs(state),
hasToken,
menuList,
toggleCollapsed,
navClick,
mouseenter,
store,
toggleTablesMenu,
tableMenusRef,
goCreatePage,
viewOverview,
}
},
Expand All @@ -187,7 +136,7 @@ export default defineComponent({

<template>
<div :class="{ 'side-bar-collapsed': collapsed }" class="side-bar">
<div :class="{ 'logo-collapsed': collapsed }" class="logo g-flex-ae" @mouseenter="toggleTablesMenu(false)" @click="viewOverview">
<div :class="{ 'logo-collapsed': collapsed }" class="logo g-flex-ae" @click="viewOverview">
<img src="../assets/images/logo1.svg" class="logo-img" alt="">
<img v-show="!collapsed" src="../assets/images/arctic-dashboard1.svg" class="arctic-name" alt="">
</div>
Expand All @@ -197,7 +146,7 @@ export default defineComponent({
theme="dark"
:inline-collapsed="collapsed"
>
<a-menu-item v-for="item in menuList" :key="item.key" :class="{ 'active-color': (store.isShowTablesMenu && item.key === 'tables'), 'table-item-tab': item.key === 'tables' }" @click="navClick(item)" @mouseenter="mouseenter(item)">
<a-menu-item v-for="item in menuList" :key="item.key" :class="{ 'active-color': (store.isShowTablesMenu && item.key === 'tables'), 'table-item-tab': item.key === 'tables' }" @click="navClick(item)">
<template #icon>
<svg-icon :icon-class="item.icon" class="svg-icon" />
</template>
Expand All @@ -208,9 +157,6 @@ export default defineComponent({
<MenuUnfoldOutlined v-if="collapsed" />
<MenuFoldOutlined v-else />
</a-button>
<div ref="tableMenusRef" v-if="store.isShowTablesMenu && !hasToken" :class="{ 'collapsed-sub-menu': collapsed }" class="tables-menu-wrap" @click.self="toggleTablesMenu(false)" @mouseenter="toggleTablesMenu(true)">
<TableMenu @go-create-page="goCreatePage" />
</div>
</div>
</template>

Expand Down
Loading