This commit is contained in:
guochunsi
2026-01-14 11:41:04 +08:00
parent d0c8ea0223
commit 6055033289
49 changed files with 2043 additions and 1740 deletions

View File

@@ -2,11 +2,11 @@
<el-dialog
:title="!dataForm.id ? '新增' : '修改'"
:close-on-click-modal="false"
:visible.sync="visible">
<el-form :model="dataForm" :rules="dataRule" ref="dataForm" @keyup.enter.native="dataFormSubmit()" label-width="140px">
v-model="visible">
<el-form :model="dataForm" :rules="dataRule" ref="dataFormRef" @keyup.enter="dataFormSubmit" label-width="140px">
<el-form-item label="招生计划" prop="groupId">
<el-select v-model="dataForm.groupId" filterable :disabled="!dataForm.id ? false : true" placeholder="请选择招生计划" size="small" style="width: 100%">
<el-select v-model="dataForm.groupId" filterable :disabled="!!dataForm.id" placeholder="请选择招生计划" size="small" style="width: 100%">
<el-option
v-for="item in planList"
:key="item.id"
@@ -29,9 +29,9 @@
</el-select>
</el-form-item>
<el-form-item label="地区" prop="area">
<el-select v-model="dataForm.area" filterable placeholder="请选择地区" size="small" style="width: 100%;">
<el-select v-model="dataForm.area" filterable placeholder="请选择地区" size="small" style="width: 100%;">
<el-option
v-for="item in areaList"
v-for="item in areaListData"
:key="item.code"
:label="item.name"
:value="item.code">
@@ -40,111 +40,136 @@
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="visible = false">取消</el-button>
<el-button type="primary" @click="dataFormSubmit()" v-if="canSubmit">确定</el-button>
</span>
<template #footer>
<div class="dialog-footer">
<el-button @click="visible = false">取消</el-button>
<el-button type="primary" @click="dataFormSubmit" v-if="canSubmit">确定</el-button>
</div>
</template>
</el-dialog>
</template>
<script>
import {addObj, areaList, getObj, putObj} from '@/api/recruit/recruitstudentschool'
import {getDeptList} from "@/api/basic/basicclass";
import {list} from "@/api/recruit/recruitstudentplangroup";
<script setup lang="ts">
import { ref, reactive, nextTick } from 'vue'
import { ElNotification } from 'element-plus'
import { addObj, areaList, getObj, putObj } from '@/api/recruit/recruitstudentschool'
import { getDeptList } from "@/api/basic/basicclass"
import { list } from "@/api/recruit/recruitstudentplangroup"
export default {
data () {
return {
visible: false,
canSubmit: false,
dataForm: {
id:"",
groupId:"",
area:"",
xy:"",
schoolName:"",
},
disabled:false,
planList: [],
areaList:[],
deptList:[],
dataRule: {
groupId: [
{ required: true, message: '招生计划不能为空', trigger: 'blur' },
],
schoolName: [
{ required: true, message: '学校名称不能为空', trigger: 'blur' },
{ min: 1, max: 20, message: '学校名称长度不大于20个字符', trigger: 'blur' }
],
// Emits
const emit = defineEmits<{
(e: 'refreshDataList'): void
}>()
area: [
{ required: true, message: '地区不能为空', trigger: 'blur' },
],
}
}
},
created () {
},
methods: {
init (id) {
this.dataForm.id = id || null;
this.visible = true;
this.canSubmit = true;
this.initData();
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
if (this.dataForm.id) {
getObj(this.dataForm.id).then(response => {
this.dataForm = response.data.data
this.dataForm.area = this.dataForm.area+"";
})
}else{
this.disabled = true;
}
// 表单引用
const dataFormRef = ref()
// 响应式数据
const visible = ref(false)
const canSubmit = ref(false)
const planList = ref<any[]>([])
const areaListData = ref<any[]>([])
const deptList = ref<any[]>([])
const dataForm = reactive({
id: "",
groupId: "",
area: "",
xy: "",
schoolName: ""
})
const dataRule = {
groupId: [
{ required: true, message: '招生计划不能为空', trigger: 'blur' },
],
schoolName: [
{ required: true, message: '学校名称不能为空', trigger: 'blur' },
{ min: 1, max: 20, message: '学校名称长度不大于20个字符', trigger: 'blur' }
],
area: [
{ required: true, message: '地区不能为空', trigger: 'blur' },
],
}
// 初始化数据
const initData = () => {
// 查询二级学院信息
getDeptList().then((data: any) => {
deptList.value = data.data
deptList.value.push({ deptCode: "190", deptName: "招生就业处" })
})
list().then((data: any) => {
planList.value = data.data
if (!dataForm.id) {
dataForm.groupId = planList.value[0]?.id || ""
}
})
// 获取所有省
areaList({ type: "0", parentId: 112 }).then((res: any) => {
areaListData.value = res.data
})
}
// 表单提交
const dataFormSubmit = () => {
dataFormRef.value?.validate((valid: boolean) => {
if (valid) {
canSubmit.value = false
if (dataForm.id) {
putObj(dataForm).then(() => {
ElNotification.success({
title: '成功',
message: '修改成功'
})
visible.value = false
emit('refreshDataList')
}).catch(() => {
canSubmit.value = true
})
},
initData() {
//查询二级学院信息
getDeptList().then(data => {
this.deptList = data.data.data
this.deptList.push({deptCode:"190",deptName:"招生就业处"})
})
list().then(data =>{
this.planList = data.data.data
if(!this.dataForm.id){
this.dataForm.groupId=this.planList[0].id
}
});
//获取所有省
areaList({type:"0",parentId:112}).then(res=>{
this.areaList = res.data.data;
});
},
// 表单提交
dataFormSubmit () {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
this.canSubmit = false;
if (this.dataForm.id) {
putObj(this.dataForm).then(data => {
this.$notify.success('修改成功')
this.visible = false
this.$emit('refreshDataList')
}).catch(() => {
this.canSubmit = true;
});
} else {
addObj(this.dataForm).then(data => {
this.$notify.success('添加成功')
this.visible = false
this.$emit('refreshDataList')
}).catch(() => {
this.canSubmit = true;
});
}
}
} else {
addObj(dataForm).then(() => {
ElNotification.success({
title: '成功',
message: '添加成功'
})
visible.value = false
emit('refreshDataList')
}).catch(() => {
canSubmit.value = true
})
}
}
}
})
}
// 初始化方法
const init = (id: string | null) => {
dataForm.id = id || ""
visible.value = true
canSubmit.value = true
initData()
nextTick(() => {
dataFormRef.value?.resetFields()
if (dataForm.id) {
getObj(dataForm.id).then((response: any) => {
Object.assign(dataForm, response.data)
if (dataForm.area) {
dataForm.area = String(dataForm.area)
}
})
}
})
}
// 暴露方法给父组件
defineExpose({
init
})
</script>
<style scoped>
.dialog-footer {
text-align: right;
}
</style>