<template>
<div class="w">
<el-tabs v-model="tabs_name" class="content-tabs" @tab-change="change_tab_event">
<el-tab-pane label="选项卡" name="tabs">
<model-tabs-styles :value="form" :content="new_content" :tabs-style="tabsStyle" :is-common-style="false"></model-tabs-styles>
</el-tab-pane>
<el-tab-pane label="轮播" name="carousel">
<model-carousel-styles :value="form" :content="new_content" :is-common-style="false"></model-carousel-styles>
</el-tab-pane>
<el-tab-pane label="公共" name="common">
<card-container>
<div class="mb-12">基础样式</div>
<el-form :model="form" label-width="74">
<el-form-item label="数据间距">
<slider v-model="form.data_spacing" :max="100"></slider>
</el-form-item>
</el-form>
</card-container>
<div class="divider-line"></div>
<common-styles :value="form.common_style" :is-floating-up="false" @update:value="common_styles_update" />
</el-tab-pane>
</el-tabs>
</div>
</template>
<script setup lang="ts">
const props = defineProps({
value: {
type: Object,
default: () => {},
},
content: {
type: Object,
default: () => {},
},
tabsStyle: {
type: String,
default: () => {},
},
tabsActive: {
type: String,
default: 'tabs',
},
});
const state = reactive({
form: props.value,
new_content: props.content,
});
const tabs_name = ref(props.tabsActive);
const emit = defineEmits(['update:tabs']);
const change_tab_event = (val: any) => {
emit('update:tabs', val);
};
// 如果需要解构,确保使用toRefs
const { form, new_content } = toRefs(state);
const common_styles_update = (val: Object) => {
form.value.common_style = val;
};
</script>
<style lang="scss" scoped>
:deep(.el-tabs.content-tabs) {
.el-tabs__header.is-top {
background: #fff;
margin: 0;
padding-top: 2rem;
}
.el-tabs__item.is-top {
padding: 0;
align-items: center;
width: 10rem;
font-size: 1.4rem;
}
.el-tabs__active-bar {
width: 100%;
}
}
</style>