yudao-ui-admin-vue3/src/views/crm/customer/uploaddetail/UploadDetailForm.vue

168 lines
6.8 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<Dialog :title="dialogTitle" v-model="dialogVisible">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<el-form-item label="上传记录ID" prop="uploadId">
<el-input v-model="formData.uploadId" placeholder="请输入上传记录ID" />
</el-form-item>
<el-form-item label="客户姓名" prop="name">
<el-input v-model="formData.name" placeholder="请输入客户姓名" />
</el-form-item>
<el-form-item label="期望金额" prop="expectAmount">
<el-input v-model="formData.expectAmount" placeholder="请输入期望金额" />
</el-form-item>
<el-form-item label="年龄" prop="age">
<el-input v-model="formData.age" placeholder="请输入年龄" />
</el-form-item>
<el-form-item label="性别0:未知1:男生2:女生)" prop="sex">
<el-radio-group v-model="formData.sex">
<el-radio value="1">请选择字典生成</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="手机号码" prop="mobile">
<el-input v-model="formData.mobile" placeholder="请输入手机号码" />
</el-form-item>
<el-form-item label="居住地址" prop="address">
<el-input v-model="formData.address" placeholder="请输入居住地址" />
</el-form-item>
<el-form-item label=" 是否有车(0:没车1:有车)" prop="haveCar">
<el-input v-model="formData.haveCar" placeholder="请输入 是否有车(0:没车1:有车)" />
</el-form-item>
<el-form-item label="是否有房0:没房1:有房)" prop="haveHouse">
<el-input v-model="formData.haveHouse" placeholder="请输入是否有房0:没房1:有房)" />
</el-form-item>
<el-form-item label="是否有公积金0:没公积金1有公积金" prop="haveProvidentFund">
<el-input v-model="formData.haveProvidentFund" placeholder="请输入是否有公积金0:没公积金1有公积金" />
</el-form-item>
<el-form-item label="是否有社保0:没社保1:有社保)" prop="haveSocialSecurity">
<el-input v-model="formData.haveSocialSecurity" placeholder="请输入是否有社保0:没社保1:有社保)" />
</el-form-item>
<el-form-item label="是否有保单0:没保单1:有保单)" prop="haveGuaranteeSlip">
<el-input v-model="formData.haveGuaranteeSlip" placeholder="请输入是否有保单0:没保单1:有保单)" />
</el-form-item>
<el-form-item label="备注信息" prop="remark">
<el-input v-model="formData.remark" placeholder="请输入备注信息" />
</el-form-item>
<el-form-item label="是否重复0:否1:是)" prop="isRepeat">
<el-input v-model="formData.isRepeat" placeholder="请输入是否重复0:否1:是)" />
</el-form-item>
</el-form>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { UploadDetailApi, UploadDetailVO } from '@/api/crm/customer/uploaddetail'
/** 导入详情 表单 */
defineOptions({ name: 'UploadDetailForm' })
const { t } = useI18n() // 国际化
const message = useMessage() // 消息弹窗
const dialogVisible = ref(false) // 弹窗的是否展示
const dialogTitle = ref('') // 弹窗的标题
const formLoading = ref(false) // 表单的加载中1修改时的数据加载2提交的按钮禁用
const formType = ref('') // 表单的类型create - 新增update - 修改
const formData = ref({
id: undefined,
uploadId: undefined,
name: undefined,
expectAmount: undefined,
age: undefined,
sex: undefined,
mobile: undefined,
address: undefined,
haveCar: undefined,
haveHouse: undefined,
haveProvidentFund: undefined,
haveSocialSecurity: undefined,
haveGuaranteeSlip: undefined,
remark: undefined,
isRepeat: undefined
})
const formRules = reactive({
uploadId: [{ required: true, message: '上传记录ID不能为空', trigger: 'blur' }],
age: [{ required: true, message: '年龄不能为空', trigger: 'blur' }],
sex: [{ required: true, message: '性别0:未知1:男生2:女生)不能为空', trigger: 'blur' }],
mobile: [{ required: true, message: '手机号码不能为空', trigger: 'blur' }],
haveCar: [{ required: true, message: ' 是否有车(0:没车1:有车)不能为空', trigger: 'blur' }],
haveHouse: [{ required: true, message: '是否有房0:没房1:有房)不能为空', trigger: 'blur' }],
haveProvidentFund: [{ required: true, message: '是否有公积金0:没公积金1有公积金不能为空', trigger: 'blur' }],
haveSocialSecurity: [{ required: true, message: '是否有社保0:没社保1:有社保)不能为空', trigger: 'blur' }],
haveGuaranteeSlip: [{ required: true, message: '是否有保单0:没保单1:有保单)不能为空', trigger: 'blur' }],
isRepeat: [{ required: true, message: '是否重复0:否1:是)不能为空', trigger: 'blur' }]
})
const formRef = ref() // 表单 Ref
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
// 修改时,设置数据
if (id) {
formLoading.value = true
try {
formData.value = await UploadDetailApi.getUploadDetail(id)
} finally {
formLoading.value = false
}
}
}
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
/** 提交表单 */
const emit = defineEmits(['success']) // 定义 success 事件,用于操作成功后的回调
const submitForm = async () => {
// 校验表单
await formRef.value.validate()
// 提交请求
formLoading.value = true
try {
const data = formData.value as unknown as UploadDetailVO
if (formType.value === 'create') {
await UploadDetailApi.createUploadDetail(data)
message.success(t('common.createSuccess'))
} else {
await UploadDetailApi.updateUploadDetail(data)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
// 发送操作成功的事件
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
uploadId: undefined,
name: undefined,
expectAmount: undefined,
age: undefined,
sex: undefined,
mobile: undefined,
address: undefined,
haveCar: undefined,
haveHouse: undefined,
haveProvidentFund: undefined,
haveSocialSecurity: undefined,
haveGuaranteeSlip: undefined,
remark: undefined,
isRepeat: undefined
}
formRef.value?.resetFields()
}
</script>