Ben Lin
2025-03-11 41d7be9f68c423012e2688fd45301300e9bb3dab
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<template>
  <Drawer
    v-if="getIsMobile"
    placement="left"
    :class="prefixCls"
    :width="getMenuWidth"
    :getContainer="false"
    :open="!getCollapsed"
    @close="handleClose"
  >
    <Sider />
  </Drawer>
  <MixSider v-else-if="getIsMixSidebar" />
  <Sider v-else />
</template>
 
<script lang="ts" setup>
  import Sider from './LayoutSider.vue';
  import MixSider from './MixSider.vue';
  import { Drawer } from 'ant-design-vue';
 
  import { useAppInject } from '@/hooks/web/useAppInject';
  import { useMenuSetting } from '@/hooks/setting/useMenuSetting';
  import { useDesign } from '@/hooks/web/useDesign';
 
  defineOptions({ name: 'SiderWrapper' });
 
  const { prefixCls } = useDesign('layout-sider-wrapper');
  const { getIsMobile } = useAppInject();
  const { setMenuSetting, getCollapsed, getMenuWidth, getIsMixSidebar } = useMenuSetting();
 
  function handleClose() {
    setMenuSetting({
      collapsed: true,
    });
  }
</script>
<style lang="less">
  @prefix-cls: ~'@{namespace}-layout-sider-wrapper';
 
  .@{prefix-cls} {
    .ant-drawer-body {
      height: 100vh;
      padding: 0;
    }
 
    .ant-drawer-header-no-title {
      display: none;
    }
  }
</style>