Files
vue-vben-admin/packages/business/layouts/src/basic/tabs/tabs-toolbar.vue
2024-05-19 21:20:42 +08:00

36 lines
812 B
Vue

<script lang="ts" setup>
import { TabsMore, TabsScreen } from '@vben-core/tabs-ui';
import { preference, updatePreference } from '@vben/preference';
import { computed } from 'vue';
import { useRoute } from 'vue-router';
import { useTabs } from './use-tabs';
const route = useRoute();
const { createContextMenus } = useTabs();
const menus = computed(() => {
return createContextMenus(route);
});
function handleScreenChange(screen: boolean) {
updatePreference({
headerVisible: !screen,
sideVisible: !screen,
});
}
</script>
<template>
<div class="flex-center h-full">
<TabsMore :menus="menus" />
<TabsScreen
:screen="!preference.headerVisible && !preference.sideVisible"
@change="handleScreenChange"
@update:screen="handleScreenChange"
/>
</div>
</template>