132 lines
5.5 KiB
Vue
132 lines
5.5 KiB
Vue
<template>
|
||
<div class="w h bg-f">
|
||
<el-form :model="form" label-width="70">
|
||
<custom-location v-model="diy_data.location" v-model:follow="form.data_follow" :is-follow="!followName.includes(diy_data.id)" :component-options="componentOptions" @operation_end="operation_end"></custom-location>
|
||
<div class="bg-f5 divider-line" />
|
||
<card-container class="">
|
||
<div class="mb-12">线条设置</div>
|
||
<el-form-item label="竖线横线">
|
||
<el-radio-group v-model="form.line_settings" @change="operation_end">
|
||
<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" @change="operation_end">
|
||
<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" @operation_end="container_size_change"></slider>
|
||
</el-form-item>
|
||
<el-form-item label="线条粗细">
|
||
<slider v-model="form.line_size" :min="1" :max="100" @operation_end="container_size_change"></slider>
|
||
</el-form-item>
|
||
<el-form-item label="线条颜色">
|
||
<color-picker v-model="form.line_color" @operation_end="operation_end"></color-picker>
|
||
</el-form-item>
|
||
<!-- <el-form-item label="是否置底">
|
||
<el-switch v-model="form.bottom_up" active-value="1" inactive-value="0" />
|
||
</el-form-item> -->
|
||
</card-container>
|
||
<div class="bg-f5 divider-line" />
|
||
<condition-config :value="form" :options="options" @operation_end="operation_end"></condition-config>
|
||
<div class="bg-f5 divider-line" />
|
||
<animation-config v-model:type="form.animation_style.type" v-model:number="form.animation_style.number" @operation_end="operation_end"></animation-config>
|
||
</el-form>
|
||
</div>
|
||
</template>
|
||
<script setup lang="ts">
|
||
import { get_container_location, get_history_name, location_compute } from '@/utils';
|
||
import { isEmpty } from 'lodash';
|
||
|
||
const props = defineProps({
|
||
value: {
|
||
type: Object,
|
||
default: () => ({}),
|
||
},
|
||
options: {
|
||
type: Array<any>,
|
||
default: () => [],
|
||
},
|
||
componentOptions: {
|
||
type: Array<any>,
|
||
default: () => [],
|
||
},
|
||
followName: {
|
||
type: Array<string>,
|
||
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 })
|
||
|
||
// 操作结束触发的事件
|
||
const emit = defineEmits(['operation_end']);
|
||
const operation_end = () => {
|
||
emit('operation_end', get_history_name(diy_data.value));
|
||
};
|
||
|
||
//#region 位置计算
|
||
// 监听数据变化
|
||
const size_location_change = (location: { x: number, y: number, record_x: number, record_y: number, staging_y: number }) => {
|
||
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, location.x, 390);
|
||
diy_data.value.location.y = location_compute(height, location.y, center_height.value);
|
||
|
||
diy_data.value.location.record_x = location_compute(width, location.record_x, 390);
|
||
diy_data.value.location.record_y = location_compute(height, location.record_y, center_height.value);
|
||
diy_data.value.location.staging_y = location_compute(height, location.staging_y, center_height.value);
|
||
|
||
form.value.com_width = width;
|
||
form.value.com_height = height;
|
||
form.value.staging_height = height;
|
||
}
|
||
// 组件大小变化触发事件
|
||
const container_size_change = () => {
|
||
const { spacing = 0, type = 'left', id = '' } = form.value.data_follow;
|
||
if (id != '') {
|
||
// 获取新的位置
|
||
const { x: new_x, y: new_y } = get_container_location(props.componentOptions, id, type, spacing, diy_data.value.location.x, diy_data.value.location.y);
|
||
// 重新更新位置信息
|
||
diy_data.value.location = { x: new_x, y: new_y, record_x: new_x, record_y: new_y, staging_y: new_y };
|
||
size_location_change(diy_data.value.location);
|
||
}
|
||
operation_end();
|
||
}
|
||
// 监听数据变化
|
||
watch(() => diy_data.value, (val) => {
|
||
size_location_change(val.location);
|
||
},{ immediate: true, deep: true });
|
||
// #endregion
|
||
</script>
|
||
<style lang="scss" scoped>
|
||
.border-style-item {
|
||
width: 3rem;
|
||
height: 2rem;
|
||
}
|
||
</style>
|