123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- <template>
- <div class="app">
- <div :class="classObj" class="app-wrapper">
- <dv-full-screen-container>
- <logo :collapse="isCollapse" class="fixed-header" />
- <app-main />
- <sidebar v-if="!sidebar.hide" class="fixed-bottom" />
- </dv-full-screen-container>
- </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 Logo from './components/Sidebar/Logo'
- import defaultSettings from '@/settings'
- 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 {
- position: relative;
- height: 100%;
- width: 100%;
- overflow: hidden;
- background: radial-gradient(at 50% 50%, rgb(29, 52, 94) 1%, rgb(3, 22, 46) 60%);
- }
- .app-wrapper {
- @include clearfix;
- position: relative;
- height: 100%;
- width: 100%;
- display: flex;
- flex-direction: column;
- overflow: hidden;
- background-image:
- repeating-linear-gradient(35deg, rgba(13, 28, 61, .5), rgba(13, 28, 61, .5) 1px, transparent 1px, transparent 70px),
- repeating-linear-gradient(-35deg, rgba(13, 28, 61, .5), rgba(13, 28, 61, .5) 1px, transparent 1px, transparent 70px),
- }
- .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;
- left: 0;
- z-index: 9;
- width: 100%;
- transition: width 0.28s;
- }
- .fixed-bottom {
- position: fixed;
- bottom: 0;
- right: 0;
- left: 0;
- z-index: 9;
- width: 100%;
- transition: width 0.28s;
- }
- </style>
|