123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- <template>
- <div
- class="vab-layout-vertical"
- :class="{
- fixed: fixedHeader,
- 'no-tabs-bar': !showTabs,
- }"
- >
- <vab-side-bar />
- <div v-if="device === 'mobile' && !collapse" class="v-modal" @click="foldSideBar" />
- <div
- class="vab-main"
- :class="{
- 'is-collapse-main': collapse,
- 'is-no-tabs': !showTabs,
- }"
- >
- <div
- class="vab-layout-header"
- :class="{
- 'fixed-header': fixedHeader,
- 'is-no-tabs': !showTabs,
- }"
- >
- <vab-nav />
- <vab-tabs v-show="showTabs" />
- </div>
- <vab-app-main />
- </div>
- </div>
- </template>
- <script lang="ts" setup>
- import { useSettingsStore } from '/@/store/modules/settings'
- defineOptions({
- name: 'VabLayoutVertical',
- })
- defineProps({
- collapse: {
- type: Boolean,
- default() {
- return false
- },
- },
- fixedHeader: {
- type: Boolean,
- default() {
- return true
- },
- },
- showTabs: {
- type: Boolean,
- default() {
- return true
- },
- },
- device: {
- type: String,
- default() {
- return 'desktop'
- },
- },
- })
- const settingsStore = useSettingsStore()
- const { foldSideBar } = settingsStore
- </script>
|