Files
school-developer/src/views/recruit/recruitstudentsignupturnovermoneychange/form.vue
吴红兵 b997b3ba48 fix
2026-03-07 12:35:45 +08:00

161 lines
4.5 KiB
Vue

<template>
<el-dialog v-model="visible" :title="dataForm.id ? '编辑' : '新增'" width="600px" :close-on-click-modal="false" destroy-on-close append-to-body>
<el-form ref="dataFormRef" :model="dataForm" :rules="dataRules" label-width="120px">
<el-form-item label="异动ID" prop="turnOverId">
<el-input v-model="dataForm.turnOverId" placeholder="请输入异动ID" clearable />
</el-form-item>
<el-form-item label="退补类型" prop="type">
<el-select v-model="dataForm.type" placeholder="请选择退补类型" clearable>
<el-option label="学费" value="1" />
<el-option label="代办费" value="2" />
<el-option label="捐资费" value="3" />
</el-select>
</el-form-item>
<el-form-item label="原费用" prop="oldFee">
<el-input-number v-model="dataForm.oldFee" :min="0" :precision="2" placeholder="请输入原费用" />
</el-form-item>
<el-form-item label="变更后费用" prop="newFee">
<el-input-number v-model="dataForm.newFee" :min="0" :precision="2" placeholder="请输入变更后费用" />
</el-form-item>
<el-form-item label="变更费用" prop="fee">
<el-input-number v-model="dataForm.fee" :precision="2" placeholder="请输入变更费用" />
</el-form-item>
<el-form-item label="补还是退" prop="incOrDec">
<el-select v-model="dataForm.incOrDec" placeholder="请选择补还是退" clearable>
<el-option label="补" value="1" />
<el-option label="退" value="2" />
</el-select>
</el-form-item>
<el-form-item label="是否推送" prop="pushed">
<el-select v-model="dataForm.pushed" placeholder="请选择是否推送" clearable>
<el-option label="是" value="1" />
<el-option label="否" value="0" />
</el-select>
</el-form-item>
<el-form-item label="推送失败原因" prop="pushFailReason">
<el-input v-model="dataForm.pushFailReason" type="textarea" :rows="3" placeholder="请输入推送失败原因" clearable />
</el-form-item>
</el-form>
<template #footer>
<div class="dialog-footer">
<el-button @click="visible = false">取消</el-button>
<el-button type="primary" @click="dataFormSubmit" :loading="submitLoading">确定</el-button>
</div>
</template>
</el-dialog>
</template>
<script setup lang="ts">
import { ref, reactive } from 'vue';
import { useMessage } from '/@/hooks/message';
import { addObj, putObj } from '/@/api/recruit/recruitstudentsignupturnovermoneychange';
// 消息提示 hooks
const message = useMessage();
// Emits
const emit = defineEmits<{
(e: 'refresh'): void;
}>();
// 表单引用
const dataFormRef = ref();
const submitLoading = ref(false);
// 弹窗显示状态
const visible = ref(false);
// 表单数据
const dataForm = reactive({
id: '',
turnOverId: '',
type: '',
oldFee: undefined as number | undefined,
newFee: undefined as number | undefined,
fee: undefined as number | undefined,
incOrDec: '',
pushed: '',
pushFailReason: '',
});
// 表单验证规则
const dataRules = {};
// 初始化
const init = (row?: any) => {
visible.value = true;
submitLoading.value = false;
// 重置表单
dataForm.id = '';
dataForm.turnOverId = '';
dataForm.type = '';
dataForm.oldFee = undefined;
dataForm.newFee = undefined;
dataForm.fee = undefined;
dataForm.incOrDec = '';
dataForm.pushed = '';
dataForm.pushFailReason = '';
// 如果是编辑,填充数据
if (row && row.id) {
dataForm.id = row.id || '';
dataForm.turnOverId = row.turnOverId || '';
dataForm.type = row.type || '';
dataForm.oldFee = row.oldFee;
dataForm.newFee = row.newFee;
dataForm.fee = row.fee;
dataForm.incOrDec = row.incOrDec || '';
dataForm.pushed = row.pushed || '';
dataForm.pushFailReason = row.pushFailReason || '';
}
// 清除验证
nextTick(() => {
dataFormRef.value?.clearValidate();
});
};
// 提交表单
const dataFormSubmit = async () => {
if (!dataFormRef.value) return;
await dataFormRef.value.validate(async (valid: boolean) => {
if (valid) {
submitLoading.value = true;
try {
if (dataForm.id) {
await putObj(dataForm);
message.success('修改成功');
} else {
await addObj(dataForm);
message.success('添加成功');
}
visible.value = false;
emit('refresh');
} catch (error: any) {
message.error(error.msg || '操作失败');
} finally {
submitLoading.value = false;
}
}
});
};
// 暴露方法给父组件
defineExpose({
init,
});
</script>
<style lang="scss" scoped>
.w-full {
width: 100%;
}
.dialog-footer {
text-align: right;
}
</style>