From 4e43f5b3a19db9af5015e0200c9590c8aba3b9ed Mon Sep 17 00:00:00 2001 From: odc.xiaohui <xiaohui@Q1> Date: 星期四, 15 六月 2023 13:37:45 +0800 Subject: [PATCH] 修改试卷列表 --- src/views/exam/paper/edit.vue | 48 ++++++++++++++++++++++++++++++++++-------------- 1 files changed, 34 insertions(+), 14 deletions(-) diff --git a/src/views/exam/paper/edit.vue b/src/views/exam/paper/edit.vue index db92343..29e8a43 100644 --- a/src/views/exam/paper/edit.vue +++ b/src/views/exam/paper/edit.vue @@ -1,8 +1,9 @@ <template> <div class="app-container"> <el-form :model="form" ref="form" label-width="200px" v-loading="formLoading" :rules="rules"> - <el-form-item label="閮ㄩ棬锛�" prop="level" required> - <el-select v-model="form.level" placeholder="閮ㄩ棬" @change="levelChange"> + <el-form-item label="閮ㄩ棬锛�" prop="departmentIds" required> + <el-select v-model="form.departmentIds" placeholder="閮ㄩ棬" @change="levelChange" multiple + collapse-tags> <el-option v-for="item in levelEnum" :key="item.key" :value="item.key" :label="item.value"></el-option> </el-select> </el-form-item> @@ -14,8 +15,8 @@ </el-select> </el-form-item> <el-form-item label="璇曞嵎绫诲瀷锛�" prop="paperType" required> - <el-select v-model="form.paperType" placeholder="璇曞嵎绫诲瀷" :disabled="subjectIdList.length>1"> - <el-option v-for="item in paperTypeEnum" :key="item.key" :value="item.key" :label="item.value" :disabled="item.disabled"></el-option> + <el-select v-model="form.paperType" placeholder="璇曞嵎绫诲瀷" > + <el-option v-for="item in paperTypeEnum" :key="item.key" :value="item.key" :label="item.value" ></el-option> </el-select> </el-form-item> <el-form-item label="鏃堕棿闄愬埗锛�" required v-show="form.paperType===4"> @@ -26,7 +27,7 @@ <el-form-item label="璇曞嵎鍚嶇О锛�" prop="name" required> <el-input v-model="form.name"/> </el-form-item> - <el-form-item :key="index" :label="titleItem.label+':'" required v-for="(titleItem,index) in subjectIdList"> + <el-form-item :key="index" :label="titleItem.label+':'" required v-for="(titleItem,index) in subjectIdList" v-if="form.paperType ==7"> <el-row> <el-col :span="3"> <span>棰樼洰鏁伴噺锛�</span> @@ -43,16 +44,16 @@ </el-row> </el-form-item> - <el-form-item label="鎬绘暟鍒嗭細" v-if="subjectIdList.length>1" prop="name" required> + <el-form-item label="鎬绘暟鍒嗭細" v-if="form.paperType==7" prop="name" required> <el-input v-model="form.name"/> </el-form-item> <el-form-item :key="index" :label="'鏍囬'+(index+1)+'锛�'" required v-for="(titleItem,index) in form.titleItems"> <el-input v-model="titleItem.name" style="width: 80%"/> - <el-button type="text" class="link-left" style="margin-left: 20px" size="mini" @click="addQuestion(titleItem)"> + <el-button v-if="form.paperType!=7" type="text" class="link-left" style="margin-left: 20px" size="mini" @click="addQuestion(titleItem)"> 娣诲姞棰樼洰 </el-button> <el-button type="text" class="link-left" size="mini" @click="form.titleItems.splice(index,1)">鍒犻櫎</el-button> - <el-card class="exampaper-item-box" v-if="titleItem.questionItems.length!==0"> + <el-card class="exampaper-item-box" v-if="titleItem.questionItems.length!==0&&subjectIdList.length<2"> <el-form-item :key="questionIndex" :label="'棰樼洰'+(questionIndex+1)+'锛�'" v-for="(questionItem,questionIndex) in titleItem.questionItems" style="margin-bottom: 15px"> <el-row> @@ -123,7 +124,7 @@ subjectIdList:[], form: { id: null, - level: null, + departmentIds: [], subjectId: [], paperType: 1, limitDateTime: [], @@ -134,7 +135,7 @@ subjectFilter: null, formLoading: false, rules: { - level: [ + departmentIds: [ { required: true, message: '璇烽�夋嫨閮ㄩ棬', trigger: 'change' } ], subjectId: [ @@ -200,7 +201,8 @@ if (arr.length>1){ //瑾槑鏄毃姗� this.subjectIdList = arr - this.form.paperType = 7 + // this.form.paperType = 7 + this.form.titleItems = [] }else { this.subjectIdList = [] this.form.paperType = 1 @@ -211,6 +213,9 @@ this.$refs.form.validate((valid) => { if (valid) { this.formLoading = true + if (this.subjectIdList.length=1){ + this.form.subjectId= this.form.subjectId + } examPaperApi.edit(this.form).then(re => { if (re.code === 1) { _this.$message.success(re.message) @@ -261,10 +266,25 @@ }, levelChange () { this.form.subjectId = null - this.subjectFilter = this.subjects.filter(data => data.level === this.form.level) + // this.subjectFilter = this.subjects.filter(data =>{ + // return this.form.departmentIds.forEach(item=>{data.level == item}) + // }) + this.subjectFilter = [] + this.form.departmentIds.forEach(item=>{ + this.subjects.forEach(jectitem=>{ + if (item==jectitem.level){ + this.subjectFilter.push(jectitem) + } + }) + }) + console.log(this.subjects,this.form.departmentIds) + // this.subjectFilter = this.subjects }, search () { - this.questionPage.queryParam.subjectId = this.form.subjectId + if (this.subjectIdList.length=1){ + this.questionPage.queryParam.subjectId = this.form.subjectId + } + this.questionPage.listLoading = true questionApi.pageList(this.questionPage.queryParam).then(data => { const re = data.response @@ -288,7 +308,7 @@ this.$refs['form'].resetFields() this.form = { id: null, - level: null, + departmentIds: [], subjectId: null, paperType: 1, limitDateTime: [], -- Gitblit v1.8.0