Files
ruoyi-plus-vben5/packages/effects/common-ui/src/ui/dashboard/analysis/analysis-charts-tabs.vue

41 lines
948 B
Vue
Raw Normal View History

2024-06-23 23:18:55 +08:00
<script setup lang="ts">
import type { TabOption } 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: TabOption[];
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;
2024-06-23 23:18:55 +08:00
});
</script>
<template>
2024-08-31 14:11:01 +08:00
<div class="card-box w-full px-4 pb-5 pt-3">
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>