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

150 lines
3.7 KiB
Vue
Raw Normal View History

<script setup>
2025-08-16 17:55:49 +08:00
import { Layout } from 'ant-design-vue';
2025-08-18 17:22:11 +08:00
import Navbar from './components/navbar';
import SiderBar from './components/siderBar';
2025-08-16 17:55:49 +08:00
2025-06-16 14:42:26 +08:00
import { useAppStore } from '@/stores';
2025-08-18 17:22:11 +08:00
import { useSidebarStore } from '@/stores/modules/side-bar';
2025-06-16 14:42:26 +08:00
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();
2025-08-18 17:22:11 +08:00
const sidebarStore = useSidebarStore();
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-18 17:38:14 +08:00
2025-08-16 17:55:49 +08:00
const showSider = computed(() => {
2025-08-19 10:43:53 +08:00
return !route.meta?.hideSidebar;
2025-08-16 17:55:49 +08:00
});
2025-08-19 18:10:36 +08:00
const isHomeRoute = computed(() => {
return route.name === 'Home';
});
2025-08-21 16:26:57 +08:00
const showInOnePage = computed(() => {
return isHomeRoute.value;
});
2025-06-16 14:42:26 +08:00
const layoutPageClass = computed(() => {
2025-08-21 16:26:57 +08:00
let result = showInOnePage.value ? 'overflow-hidden' : '';
2025-08-19 18:10:36 +08:00
if (isHomeRoute.value) {
result += 'pb-8px pr-8px';
2025-08-21 16:26:57 +08:00
} else {
result += 'pb-24px pr-24px';
}
2025-08-21 16:26:57 +08:00
return result;
2025-08-19 10:43:53 +08:00
});
const siderWidth = computed(() => {
return showSider.value ? sidebarStore.sidebarWidth : 0;
});
2025-08-19 10:43:53 +08:00
2025-06-16 14:42:26 +08:00
const collapsed = computed(() => {
2025-08-18 17:22:11 +08:00
return sidebarStore.menuCollapse;
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
</script>
<template>
2025-08-16 17:55:49 +08:00
<Layout :class="['layout-wrap', { mobile: appStore.hideMenu }]" class="h-full flex flex-col w-full">
<JoinModal v-model:visible="joinEnterpriseVisible" ref="joinModalRef" />
2025-08-18 10:09:41 +08:00
<Layout.Header class="layout-header-wrap">
<Navbar />
</Layout.Header>
2025-08-16 17:55:49 +08:00
<Layout class="flex layout-content-wrap">
2025-08-18 10:09:41 +08:00
<Layout.Sider
2025-08-16 17:55:49 +08:00
v-if="showSider"
v-model="collapsed"
:width="siderWidth"
collapsible
2025-08-16 17:55:49 +08:00
trigger
@collapse="setCollapsed"
2025-08-19 10:43:53 +08:00
class="layout-sider"
>
2025-08-19 10:43:53 +08:00
<SiderBar />
2025-08-18 10:09:41 +08:00
</Layout.Sider>
<Layout
2025-08-19 10:43:53 +08:00
class="layout-content"
:style="{
paddingLeft: `${siderWidth}px`,
2025-08-19 10:43:53 +08:00
}"
>
2025-08-19 18:10:36 +08:00
<Layout.Content :class="layoutPageClass" class="!min-h-initial">
<layout-page />
</Layout.Content>
</Layout>
2025-08-16 17:55:49 +08:00
</Layout>
</Layout>
2025-06-16 14:42:26 +08:00
</template>
<style scoped lang="scss">
.layout-wrap {
2025-08-16 17:55:49 +08:00
font-family: inherit;
background: transparent;
min-width: 1200px;
2025-08-16 18:00:06 +08:00
.layout-header-wrap {
background: transparent;
2025-08-15 14:32:40 +08:00
height: $navbar-height;
2025-08-16 18:00:06 +08:00
line-height: $navbar-height;
padding-inline: inherit;
color: inherit;
2025-08-19 10:43:53 +08:00
position: fixed;
top: 0;
left: 0;
2025-08-21 10:54:18 +08:00
z-index: 1000;
2025-08-19 10:43:53 +08:00
width: 100%;
2025-06-16 14:42:26 +08:00
}
.layout-content-wrap {
2025-08-19 10:43:53 +08:00
width: 100%;
2025-08-15 14:32:40 +08:00
height: 100%;
2025-08-16 17:55:49 +08:00
background: transparent;
min-height: calc(100vh - $navbar-height);
2025-08-16 17:55:49 +08:00
:deep(.ant-layout-sider) {
background: none;
box-shadow: none;
2025-08-19 10:43:53 +08:00
padding-top: $navbar-height;
2025-08-16 17:55:49 +08:00
padding-bottom: 0;
2025-08-19 10:43:53 +08:00
position: fixed;
top: 0;
left: 0;
z-index: 999;
2025-08-19 10:43:53 +08:00
height: 100%;
transition: all 0.2s cubic-bezier(0.34, 0.69, 0.1, 1);
2025-08-16 17:55:49 +08:00
.ant-layout-sider-trigger {
display: none;
}
.ant-layout-sider-children {
overflow: hidden;
}
2025-06-16 14:42:26 +08:00
}
.layout-content {
2025-08-19 10:43:53 +08:00
padding-top: $navbar-height;
2025-08-16 17:55:49 +08:00
background: transparent;
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>