From 64d172717748c383a5c88348037354bffd60f966 Mon Sep 17 00:00:00 2001 From: gaoluyang <2820782392@qq.com> Date: 星期二, 27 五月 2025 17:52:03 +0800 Subject: [PATCH] 页面样式修改 --- src/layout/index.vue | 112 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 112 insertions(+), 0 deletions(-) diff --git a/src/layout/index.vue b/src/layout/index.vue new file mode 100644 index 0000000..a71347d --- /dev/null +++ b/src/layout/index.vue @@ -0,0 +1,112 @@ +<template> + <div :class="classObj" class="app-wrapper" :style="{ '--current-color': theme }"> + <div v-if="device === 'mobile' && sidebar.opened" class="drawer-bg" @click="handleClickOutside"/> + <navbar @setLayout="setLayout" /> + <sidebar v-if="!sidebar.hide" class="sidebar-container" /> + <div :class="{ hasTagsView: needTagsView, sidebarHide: sidebar.hide }" class="main-container"> + <div :class="{ 'fixed-header': fixedHeader }"> + <tags-view v-if="needTagsView" /> + </div> + <app-main /> + <settings ref="settingRef" /> + </div> + </div> +</template> + +<script setup> +import { useWindowSize } from '@vueuse/core' +import Sidebar from './components/Sidebar/index.vue' +import { AppMain, Navbar, Settings, TagsView } from './components' +import useAppStore from '@/store/modules/app' +import useSettingsStore from '@/store/modules/settings' + +const settingsStore = useSettingsStore() +const theme = computed(() => settingsStore.theme) +const sideTheme = computed(() => settingsStore.sideTheme) +const sidebar = computed(() => useAppStore().sidebar) +const device = computed(() => useAppStore().device) +const needTagsView = computed(() => settingsStore.tagsView) +const fixedHeader = computed(() => settingsStore.fixedHeader) + +const classObj = computed(() => ({ + hideSidebar: !sidebar.value.opened, + openSidebar: sidebar.value.opened, + withoutAnimation: sidebar.value.withoutAnimation, + mobile: device.value === 'mobile' +})) + +const { width, height } = useWindowSize() +const WIDTH = 992 // refer to Bootstrap's responsive design + +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 }) + } else { + useAppStore().toggleDevice('desktop') + } +}) + +function handleClickOutside() { + useAppStore().closeSideBar({ withoutAnimation: false }) +} + +const settingRef = ref(null) +function setLayout() { + settingRef.value.openSetting() +} +</script> + +<style lang="scss" scoped> + @import "@/assets/styles/mixin.scss"; + @import "@/assets/styles/variables.module.scss"; + +.app-wrapper { + @include clearfix; + position: relative; + height: 100%; + width: 100%; + + &.mobile.openSidebar { + position: fixed; + top: 0; + } +} + +.drawer-bg { + background: #000; + opacity: 0.3; + width: 100%; + top: 0; + height: 100%; + position: absolute; + z-index: 999; +} + +.fixed-header { + position: fixed; + top: 0; + right: 0; + z-index: 9; + width: calc(100% - #{$base-sidebar-width}); + transition: width 0.28s; +} + +.hideSidebar .fixed-header { + width: calc(100% - 54px); +} + +.sidebarHide .fixed-header { + width: 100%; +} + +.mobile .fixed-header { + width: 100%; +} +</style> \ No newline at end of file -- Gitblit v1.9.3