Files
lingji-work-fe/src/layouts/Basic.vue

159 lines
4.2 KiB
Vue
Raw Normal View History

<script setup>
2025-06-16 14:42:26 +08:00
import { useAppStore } from '@/stores';
import { useResponsive } from '@/hooks';
import JoinModal from '@/components/join-modal.vue';
import { getQueryParam } from '@/utils/helper';
import { useUserStore } from '@/stores';
2025-06-22 22:52:03 -04:00
import { ref, onMounted, computed } from 'vue';
import { useRoute } from 'vue-router';
2025-06-16 14:42:26 +08:00
const joinEnterpriseVisible = ref(false);
const joinModalRef = ref(null);
2025-06-16 14:42:26 +08:00
const appStore = useAppStore();
const userStore = useUserStore();
2025-06-16 14:42:26 +08:00
const router = useRouter();
2025-06-22 22:52:03 -04:00
const route = useRoute();
2025-06-16 14:42:26 +08:00
useResponsive(true);
2025-08-15 14:32:40 +08:00
const navbarHeight = `52px`;
2025-06-16 14:42:26 +08:00
const renderMenu = computed(() => appStore.menu && !appStore.topMenu);
const hideMenu = computed(() => appStore.hideMenu);
const menuWidth = computed(() => {
return appStore.menuCollapse ? 48 : appStore.menuWidth;
});
const collapsed = computed(() => {
return appStore.menuCollapse;
});
2025-06-30 18:37:27 +08:00
const showSidebar = computed(() => {
return !(route.meta && route.meta.hideSidebar);
});
2025-06-16 14:42:26 +08:00
const paddingStyle = computed(() => {
2025-06-30 18:37:27 +08:00
const paddingLeft =
showSidebar.value && renderMenu.value && !hideMenu.value ? { paddingLeft: `${menuWidth.value}px` } : {};
return { ...paddingLeft };
2025-06-16 14:42:26 +08:00
});
2025-06-30 18:37:27 +08:00
onMounted(() => {
checkHasInviteCode();
});
const setCollapsed = (val) => {
2025-06-16 14:42:26 +08:00
appStore.updateSettings({ menuCollapse: val });
};
const checkHasInviteCode = () => {
const inviteCode = getQueryParam('invite_code');
if (userStore.isLogin && inviteCode) {
joinEnterpriseVisible.value = true;
joinModalRef.value?.getEnterprise?.();
}
};
2025-06-16 14:42:26 +08:00
const drawerVisible = ref(false);
const drawerCancel = () => {
drawerVisible.value = false;
};
provide('toggleDrawerMenu', () => {
drawerVisible.value = !drawerVisible.value;
});
</script>
<template>
<a-layout :class="['layout-wrap', { mobile: appStore.hideMenu }]" class="h-full flex flex-col w-full">
<JoinModal v-model:visible="joinEnterpriseVisible" ref="joinModalRef" />
<section class="layout-navbar-wrap">
2025-06-16 14:42:26 +08:00
<base-navbar />
</section>
<a-layout class="flex layout-content-wrap">
<a-layout-sider
v-if="renderMenu && showSidebar"
v-show="!hideMenu"
class="layout-sider"
breakpoint="xl"
:collapsed="collapsed"
:width="menuWidth"
collapsible
hide-trigger
@collapse="setCollapsed"
>
<section class="menu-wrapper">
2025-06-16 14:42:26 +08:00
<base-menu />
</section>
</a-layout-sider>
<a-drawer
v-if="hideMenu"
:visible="drawerVisible"
placement="left"
:footer="false"
mask-closable
:closable="false"
@cancel="drawerCancel"
>
<base-menu />
</a-drawer>
<a-layout class="flex-1 layout-content">
<a-layout-content class="px-24px py-16px">
<layout-page />
</a-layout-content>
2025-06-16 14:42:26 +08:00
</a-layout>
</a-layout>
</a-layout>
</template>
<style scoped lang="scss">
.layout-wrap {
min-width: 1200px;
.layout-navbar-wrap {
position: sticky;
2025-06-16 14:42:26 +08:00
top: 0;
2025-08-15 14:32:40 +08:00
left: 0;
z-index: 1000;
width: 100%;
height: $navbar-height;
2025-06-16 14:42:26 +08:00
}
.layout-content-wrap {
2025-08-15 14:32:40 +08:00
height: 100%;
min-height: calc(100vh - $navbar-height);
.layout-sider {
position: sticky;
top: $navbar-height;
left: 0;
// height: 100%;
height: calc(100vh - $navbar-height);
transition: all 0.2s cubic-bezier(0.34, 0.69, 0.1, 1);
background: none;
box-shadow: none;
> :deep(.arco-layout-sider-children) {
overflow-y: hidden;
2025-08-15 14:32:40 +08:00
}
.menu-wrapper {
height: 100%;
overflow: auto;
overflow-x: hidden;
:deep(.arco-menu) {
::-webkit-scrollbar {
width: 12px;
height: 4px;
}
::-webkit-scrollbar-thumb {
border: 4px solid transparent;
background-clip: padding-box;
border-radius: 7px;
background-color: var(--color-text-4);
}
::-webkit-scrollbar-thumb:hover {
background-color: var(--color-text-3);
}
}
2025-08-15 14:32:40 +08:00
}
2025-06-16 14:42:26 +08:00
}
.layout-content {
height: 100%;
overflow-y: scroll;
overflow-x: auto;
transition: padding 0.2s cubic-bezier(0.34, 0.69, 0.1, 1);
}
2025-08-15 14:32:40 +08:00
}
2025-06-16 14:42:26 +08:00
}
</style>