<template>
<el-form :model="form" label-width="40" label-position="left" @submit.prevent>
<!-- <div class="mb-10 fw">内容设置</div> -->
<el-form-item label-width="0">
<div class="flex-col gap-10 w h">
<div class="new_title flex-row align-c jc-sb"><div class="flex-row">FROM名称<span class="required">*</span></div><div class="new_desc">数字</div></div>
<form-name :value="all_form_value.form_name" :model-id="all_form_value.id" :is-subform="isSubform" :subform-list="subformList" @name_change="name_change"></form-name>
</div>
</el-form-item>
<el-form-item label-width="0">
<div class="flex-col gap-10 w h">
<div class="new_title flex-row align-c jc-sb"><div class="flex-row">标题<span class="required">*</span></div></div>
<el-input v-model="form.title" placeholder="请输入标题" @change="title_change"></el-input>
</div>
</el-form-item>
<el-form-item label-width="0">
<div class="flex-col gap-10 w h">
<div class="new_title">提示文字</div>
<el-input v-model="form.placeholder" placeholder="请输入提示文字" clearable @change="operation_end"></el-input>
</div>
</el-form-item>
<el-form-item label-width="0">
<div class="flex-col gap-10 w h">
<div class="new_title">格式</div>
<el-select v-model="form.format" value-key="id" filterable placeholder="请选择输入格式" @change="format_change">
<el-option v-for="item in format_option" :key="item.value" :label="item.name" :value="item.value" />
</el-select>
<div class="flex-col gap-10">
<div class="flex-row align-c gap-10">
<el-checkbox v-model="form.is_decimal" label="保留小数位数" true-value="1" false-value="0" />
<el-input-number v-if="form.is_decimal == '1'" v-model="form.decimal_num" :min="0" :max="6" type="number" value-on-clear="min" class="w number-show" controls-position="right" @change="decimal_num_change"></el-input-number>
</div>
<template v-if="form.format == 'num'">
<div class="flex-row align-c gap-10"><el-checkbox v-model="form.is_thousandths_symbol" label="显示千分符" true-value="1" false-value="0" /></div>
<div class="flex-row align-c gap-10"><el-checkbox v-model="form.is_display_uppercase" label="显示大写" true-value="1" false-value="0" /><tooltip content="仅展示页面有效"></tooltip></div>
<div class="flex-row align-c gap-10"><el-checkbox v-model="form.is_display_money" label="显示金额" true-value="1" false-value="0" /></div>
<template v-if="form.is_display_money == '1'">
<el-select v-model="form.money_sign" value-key="id" filterable clearable placeholder="请选择金额符号" @change="operation_end">
<el-option v-for="item in money_option" :key="item.value" :label="item.name" :value="item.value" />
</el-select>
</template>
</template>
<div v-if="form.is_decimal == '1' || (form.format == 'num' && form.is_thousandths_symbol == '1')" class="num-preview">
<template v-if="form.format == 'num' && form.is_thousandths_symbol == '1'">
{{ formatNumber(Number(formatNumber(99999, false)).toFixed(form.decimal_num).toString(), true) }}
</template>
<template v-else>
{{ Number(formatNumber(99999, false)).toFixed(form.decimal_num) }}
</template>
<template v-if="form.format == 'percentage'">%</template>
</div>
</div>
</div>
</el-form-item>
<el-form-item label-width="0">
<div class="flex-col gap-10 w h">
<div class="new_title">默认值</div>
<number-input v-model="form.form_value" :decimal-num="form.is_decimal == '1' ? form.decimal_num : 0" :money-sign="form.is_display_money == '1' ? form.money_sign : ''" :format="form.format" :is-thousandths-symbol="form.is_thousandths_symbol" :is-percentage="form.format == 'percentage'" class="rendering-area"></number-input>
</div>
</el-form-item>
<el-form-item label-width="0">
<div class="flex-col w h">
<div class="new_title mb-10">校验</div>
<div><el-checkbox v-model="form.is_required" label="必填" true-value="1" false-value="0" /></div>
<div><el-checkbox v-model="form.is_limit_num" label="限定数值范围" true-value="1" false-value="0" /></div>
<template v-if="form.is_limit_num == '1'">
<div class="flex-row gap-10 w mt-10">
<number-input v-model="form.min_num" :decimal-num="form.is_decimal == '1' ? form.decimal_num : 0" :money-sign="form.is_display_money == '1' ? form.money_sign : ''" :format="form.format" :is-thousandths-symbol="form.is_thousandths_symbol" :is-percentage="form.format == 'percentage'" placeholder="不限" class="rendering-area" @blur="handle_min_max_blur('min_num')"></number-input>
<div class="flex-1">~</div>
<number-input v-model="form.max_num" :decimal-num="form.is_decimal == '1' ? form.decimal_num : 0" :money-sign="form.is_display_money == '1' ? form.money_sign : ''" :format="form.format" :is-thousandths-symbol="form.is_thousandths_symbol" :is-percentage="form.format == 'percentage'" placeholder="不限" class="rendering-area" @blur="handle_min_max_blur('max_num')"></number-input>
</div>
</template>
<desensitization v-model:value="form.desensitization_value" v-model:show="form.is_desensitization"></desensitization>
</div>
</el-form-item>
<border-config class="mb-18" :value="form.common_config" />
<help-config class="mb-18" :value="form.common_config" />
<template v-if="isSubform">
<subform-width v-model="form.com_width"></subform-width>
</template>
</el-form>
</template>
<script setup lang="ts">
import { formatNumber, parse_and_format } from '@/utils/index'
import { isEmpty, cloneDeep } from 'lodash';
const props = defineProps({
value: {
type: Object,
default: () => ({}),
},
isSubform: {
type: Boolean,
default: false,
},
subformList: {
type: Array,
default: () => ([]),
},
allValue: {
type: Object,
default: () => {},
}
});
const all_form_value = ref(props.allValue);
const form = ref(props.value);// 判断配置项是否有误
//#region 标题更新时的修改
const old_title = ref(cloneDeep(form.value.title));
const title_change = () => {
if (isEmpty(form.value.title)) {
form.value.title = old_title.value;
}
};
//#endregion
// 校验类型选项
const format_option = [
{ name: '数值', value: 'num' },
{ name: '百分比', value: 'percentage' }
];
const money_option = [
{ name: '美元', value: '$' },
{ name: '人民币', value: '¥' }
];
// 小数点处理
const decimal_num_change = () => {
if (!isEmpty(form.value.form_value)) {
form.value.form_value = Number(formatNumber(form.value.form_value, false)).toFixed(form.value.decimal_num).toString();
}
}
/**
* 处理最小值和最大值输入框失焦事件
* 该函数旨在确保最小值和最大值符合规定的十进制数,并防止最小值大于最大值
* 当最小值大于最大值时,将两个值设置为相等
*
* @param {string} triggerField - 触发该函数的字段,只能是 'min_num' 或 'max_num'
*/
const handle_min_max_blur = (triggerField: 'min_num' | 'max_num') => {
// 从表单中提取当前的最小值、最大值和小数位数
const { min_num, max_num, decimal_num = 0 } = form.value;
// 校验 decimalNum 是否为有效整数
if (typeof decimal_num !== 'number' || decimal_num < 0 || !Number.isInteger(decimal_num)) {
return;
}
// 解析并格式化最小值和最大值
const min = parse_and_format(min_num, decimal_num);
const max = parse_and_format(max_num, decimal_num);
// 确保最小值不大于最大值,如果违反,则将两个值设置为相等
if (min !== null && max !== null && min > max) {
if (triggerField === 'min_num') {
form.value.max_num = form.value.min_num;
} else {
form.value.min_num = form.value.max_num;
}
}
};
// 格式切换时的处理显示逻辑
const format_change = () => {
form.value.money_sign = '';
}
const name_change = (val: string) => {
all_form_value.value.form_name = val;
}
const emit = defineEmits(['operation_end']);
const operation_end = () => {
emit('operation_end');
};
</script>
<style scoped lang="scss">
.num-preview {
background: #f5f6f8;
border-radius: 3px;
height: 50px;
position: relative;
text-align: center;
color: #141E31;
font-size: 18px;
font-weight: 500;
line-height: 50px;
}
.number-show {
width: 7rem !important;
}
</style>