12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- <template>
- <div
- class="vab-layout-column"
- :class="{
- fixed: fixedHeader,
- 'no-tabs-bar': !showTabs,
- }"
- >
- <vab-column-bar />
- <div
- class="vab-main"
- :class="{
- ['vab-main-' + theme.columnStyle]: true,
- '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: 'VabLayoutColumn',
- })
- defineProps({
- collapse: {
- type: Boolean,
- default: false,
- },
- fixedHeader: {
- type: Boolean,
- default: true,
- },
- showTabs: {
- type: Boolean,
- default: true,
- },
- })
- const settingsStore = useSettingsStore()
- const { theme } = storeToRefs(settingsStore)
- </script>
- <style lang="scss" scoped>
- .vab-layout-column {
- .vab-main {
- &.is-collapse-main {
- &.vab-main-horizontal,
- &.vab-main-semicircle {
- margin-left: calc(var(--el-left-menu-width-min) * 1.4);
- :deep() {
- .fixed-header {
- width: calc(100% - var(--el-left-menu-width-min) * 1.4);
- }
- }
- }
- }
- }
- }
- </style>
|