RuoYi
2025-04-24 7de94e2ea37803216e5afe9d40e7121c87a5344e
src/layout/index.vue
@@ -3,15 +3,13 @@
    <div v-if="device === 'mobile' && sidebar.opened" class="drawer-bg" @click="handleClickOutside"/>
    <sidebar v-if="!sidebar.hide" class="sidebar-container" />
    <div :class="{ hasTagsView: needTagsView, sidebarHide: sidebar.hide }" class="main-container">
      <el-scrollbar>
        <div :class="{ 'fixed-header': fixedHeader }">
          <navbar @setLayout="setLayout" />
          <tags-view v-if="needTagsView" />
        </div>
        <app-main />
        <settings ref="settingRef" />
      </el-scrollbar>
    </div>
      <div :class="{ 'fixed-header': fixedHeader }">
        <navbar @setLayout="setLayout" />
        <tags-view v-if="needTagsView" />
      </div>
      <app-main />
      <settings ref="settingRef" />
    </div>
  </div>
</template>
@@ -42,10 +40,13 @@
const { width, height } = useWindowSize();
const WIDTH = 992; // refer to Bootstrap's responsive design
watchEffect(() => {
watch(() => device.value, () => {
  if (device.value === 'mobile' && sidebar.value.opened) {
    useAppStore().closeSideBar({ withoutAnimation: false })
  }
})
watchEffect(() => {
  if (width.value - 1 < WIDTH) {
    useAppStore().toggleDevice('mobile')
    useAppStore().closeSideBar({ withoutAnimation: true })
@@ -73,18 +74,6 @@
  position: relative;
  height: 100%;
  width: 100%;
  .el-scrollbar {
    height: 100%;
  }
  :deep(.el-scrollbar__bar).is-vertical {
    z-index: 10;
  }
  :deep(.el-scrollbar__wrap) {
    overflow-x: hidden;
  }
  &.mobile.openSidebar {
    position: fixed;