admin-vben5/packages/business/universal-ui/src/dashboard/analysis/analysis-charts-tabs.vue

41 lines
956 B
Vue
Raw Normal View History

2024-06-23 23:18:55 +08:00
<script setup lang="ts">
import type { TabsOption } from '@vben/types';
2024-06-23 23:18:55 +08:00
import { computed } from 'vue';
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@vben-core/shadcn-ui';
interface Props {
tabs: TabsOption[];
2024-06-23 23:18:55 +08:00
}
defineOptions({
name: 'AnalysisChartsTabs',
});
const props = withDefaults(defineProps<Props>(), {
tabs: () => [],
});
const defaultValue = computed(() => {
return props.tabs?.[0].value;
});
</script>
<template>
<div class="card-box w-full px-4 pb-5 pt-3 shadow">
2024-06-23 23:18:55 +08:00
<Tabs :default-value="defaultValue">
<TabsList>
<template v-for="tab in tabs" :key="tab.label">
<TabsTrigger :value="tab.value"> {{ tab.label }} </TabsTrigger>
</template>
</TabsList>
<template v-for="tab in tabs" :key="tab.label">
<TabsContent :value="tab.value" class="pt-4">
<slot :name="tab.value"></slot>
</TabsContent>
</template>
</Tabs>
</div>
</template>