mirror of
https://gitee.com/zongzhige/shopxo-diy.git
synced 2026-06-05 18:25:52 +08:00
91 lines
3.2 KiB
Vue
91 lines
3.2 KiB
Vue
<template>
|
||
<div class="w h bg-f">
|
||
<el-form :model="form" label-width="80">
|
||
<card-container class="">
|
||
<div class="mb-12">线条设置</div>
|
||
<el-form-item label="竖线横线">
|
||
<el-radio-group v-model="form.line_settings">
|
||
<el-radio value="horizontal">横线</el-radio>
|
||
<el-radio value="vertical">竖线</el-radio>
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item label="线条样式">
|
||
<el-radio-group v-model="form.line_style">
|
||
<el-radio value="dashed">
|
||
<icon name="line-point" class="re top-2" size="32"></icon>
|
||
</el-radio>
|
||
<el-radio value="solid">
|
||
<icon name="line" class="re top-2" size="32"></icon>
|
||
</el-radio>
|
||
<el-radio value="dotted">
|
||
<icon name="line-point" class="re top-2" size="32"></icon>
|
||
</el-radio>
|
||
</el-radio-group>
|
||
</el-form-item>
|
||
<el-form-item :label="form.line_settings === 'horizontal' ? '线条宽度' : '线条高度'">
|
||
<slider v-model="form.line_width" :max="1000"></slider>
|
||
</el-form-item>
|
||
<el-form-item label="线条粗细">
|
||
<slider v-model="form.line_size" :min="1" :max="100"></slider>
|
||
</el-form-item>
|
||
<el-form-item label="线条颜色">
|
||
<color-picker v-model="form.line_color" default-color="#FF3F3F"></color-picker>
|
||
</el-form-item>
|
||
<el-form-item label="是否置底">
|
||
<el-switch v-model="form.bottom_up" />
|
||
</el-form-item>
|
||
</card-container>
|
||
</el-form>
|
||
</div>
|
||
</template>
|
||
<script setup lang="ts">
|
||
import { location_compute } from '@/utils';
|
||
|
||
const props = defineProps({
|
||
value: {
|
||
type: Object,
|
||
default: () => ({}),
|
||
}
|
||
});
|
||
// 默认值
|
||
const state = reactive({
|
||
diy_data: props.value
|
||
});
|
||
// 如果需要解构,确保使用toRefs
|
||
const { diy_data } = toRefs(state);
|
||
const form = ref(diy_data.value.com_data);
|
||
const center_height = defineModel("height", { type: Number, default: 0 })
|
||
|
||
watch(diy_data, (val) => {
|
||
let width = 0;
|
||
let height = 0;
|
||
if (form.value.line_settings === 'horizontal') {
|
||
width = form.value.line_width;
|
||
height = form.value.line_size + 10;
|
||
} else {
|
||
width = form.value.line_size + 10;
|
||
height = form.value.line_width;
|
||
}
|
||
|
||
diy_data.value.location.x = location_compute(width, val.location.x, 390);
|
||
diy_data.value.location.y = location_compute(height, val.location.y, center_height.value);
|
||
diy_data.value.location.staging_y = diy_data.value.location.y;
|
||
|
||
form.value.com_width = width;
|
||
form.value.com_height = height;
|
||
form.value.staging_height = height;
|
||
|
||
}, {immediate: true, deep: true});
|
||
</script>
|
||
<style lang="scss" scoped>
|
||
.card.mb-8 {
|
||
.el-form-item:last-child {
|
||
margin-bottom: 0;
|
||
}
|
||
}
|
||
.border-style-item {
|
||
width: 3rem;
|
||
height: 2rem;
|
||
}
|
||
</style>
|