From f7a2f13a266861c36c6c514ae67191b029f345b1 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期二, 16 七月 2024 13:59:20 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
src/views/exam/personalRandomTemplate/edit.vue | 652 +++++++++++++++++++++++++++++++++++++---------------------
1 files changed, 416 insertions(+), 236 deletions(-)
diff --git a/src/views/exam/personalRandomTemplate/edit.vue b/src/views/exam/personalRandomTemplate/edit.vue
index 3009191..5a0eb7a 100644
--- a/src/views/exam/personalRandomTemplate/edit.vue
+++ b/src/views/exam/personalRandomTemplate/edit.vue
@@ -1,86 +1,100 @@
<template>
<div class="app-container">
<el-form :model="form" ref="form" label-width="200px" v-loading="formLoading" :rules="rules">
- <el-form-item label="鑰冪敓锛�" prop="menuIds" required>
-<!-- <el-cascader v-model="form.menuIds" :options="options" @change="cascaderChangeFun" :props="props" clearable collapse-tags>-->
-<!-- </el-cascader>-->
- <all-cascader :options="options"
- :optionsData = "optionsData"
- @change="cascaderChangeFun"
- :width="200"></all-cascader>
- </el-form-item>
- <el-form-item label="璇剧洰锛�" prop="subjectId" required >
- <el-select ref="subjectIdRef" v-model="form.subjectId" placeholder="璇剧洰" multiple
- collapse-tags @visible-change="subjectIdEvent">
- <el-option v-for="item in subjectFilter" :key="item.id" :value="item.id"
- :label="item.name+' '"></el-option>
+ <el-form-item label="鑰冪敓锛�" prop="userIds" required>
+ <el-select v-model="form.userIds" :collapse-tags="true" multiple placeholder="璇烽�夋嫨" @focus="selectStudent"
+ popper-class="examinee-popper">
+ <el-option v-for="item in form.examineeList" :value="item.id" :label="item.realName"
+ :key="item.id"></el-option>
</el-select>
</el-form-item>
- <el-form-item label="璇曞嵎绫诲瀷锛�" prop="paperType" required >
- <el-select v-model="form.paperType" placeholder="璇曞嵎绫诲瀷" @visible-change="subjectIdEvent" disabled>
- <el-option v-for="item in paperTypeEnum" :key="item.key" :value="item.key" :label="item.value" ></el-option>
+ <el-form-item label="閮ㄩ棬锛�" prop="deptId" required>
+ <!-- <el-select v-model="form.deptId" collapse-tags @change="getSubject" placeholder="閮ㄩ棬">
+ <el-option v-for="item in depts" :key="item.id" :value="item.id" :label="item.name"></el-option>
+ </el-select> -->
+ <el-cascader
+ clearable
+ @change="getSubject"
+ v-model="form.deptId"
+ :options="depts"
+ :props="{ emitPath: false, value: 'id', label: 'name', checkStrictly: true }"
+ ></el-cascader>
+ </el-form-item>
+ <el-form-item label="璇剧洰锛�" prop="subjectId" required>
+ <el-select ref="subjectIdRef" v-model="form.subjectId" :disabled="! form.deptId" placeholder="璇剧洰" multiple collapse-tags
+ @visible-change="subjectIdEvent">
+ <el-option v-for="item in subjectFilter" :key="item.id" :value="item.id" :label="item.name + ' '"></el-option>
+ </el-select>
+ </el-form-item>
+ <el-form-item label="璇曞嵎绫诲瀷锛�" prop="paperType" required>
+ <el-select v-model="form.paperType" placeholder="璇曞嵎绫诲瀷" @visible-change="subjectIdEvent" disabled>
+ <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="鏃堕棿闄愬埗锛�">
+ <el-form-item label="鏃堕棿闄愬埗锛�" prop="limitDateTime">
<el-date-picker v-model="form.limitDateTime" value-format="yyyy-MM-dd HH:mm:ss" type="datetimerange"
- range-separator="鑷�" start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡">
+ range-separator="鑷�" start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡">
</el-date-picker>
</el-form-item>
- <el-form-item label="璇曞嵎鍚嶇О锛�" prop="name" required >
+ <el-form-item label="璇曞嵎鍚嶇О锛�" prop="name" required>
<el-row :gutter="20">
<el-col :span="9">
- <el-input v-model="form.name"/>
+ <el-input v-model="form.name" />
</el-col>
- <el-col :span="2" v-if="form.paperType==7">
+ <el-col :span="2" v-if="form.paperType == 7">
<span>鎬绘暟鍒嗭細</span>
</el-col>
- <el-col :span="9" v-if="form.paperType==7">
- <el-input disabled v-model="form.aggregateSource"/>
+ <el-col :span="9" v-if="form.paperType == 7">
+ <el-input disabled v-model="form.aggregateSource" />
</el-col>
</el-row>
</el-form-item>
- <el-form-item :key="item.subjectId" :label="item.label" required v-for="(item,key) in form.questionTypeVMS" v-if="form.paperType ==7">
- <el-row >
- <el-col :span="3" >
+ <!-- <el-form-item :key="item.subjectId" :label="item.label" required v-for="(item, key) in form.questionTypeVMS"
+ v-if="form.paperType == 7">
+ <el-row>
+ <el-col :span="3">
<span>澶氶�夐锛� </span>
</el-col>
<el-col :span="3">
- <el-input v-model="form.questionTypeVMS[key].multipleChoice" style="width: 80%"/>
+ <el-input v-model="form.questionTypeVMS[key].multipleChoice" style="width: 80%" />
</el-col>
- <el-col :span="3" >
+ <el-col :span="3">
<span>鍗曢�夐锛�</span>
</el-col>
<el-col :span="3">
- <el-input v-model="form.questionTypeVMS[key].singleChoice" style="width: 80%"/>
+ <el-input v-model="form.questionTypeVMS[key].singleChoice" style="width: 80%" />
</el-col>
- <el-col :span="3" >
+ <el-col :span="3">
<span>鍒ゆ柇棰橈細</span>
</el-col>
<el-col :span="3">
- <el-input v-model="form.questionTypeVMS[key].trueFalse" style="width: 80%"/>
+ <el-input v-model="form.questionTypeVMS[key].trueFalse" style="width: 80%" />
</el-col>
</el-row>
- </el-form-item>
+ </el-form-item> -->
<!-- <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 v-if="form.paperType!=7" type="text" class="link-left" style="margin-left: 20px" size="mini" @click="addQuestion(titleItem)">
+ <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 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&&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-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 && 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>
<el-col :span="23">
- <QuestionShow :qType="questionItem.questionType" :question="questionItem"/>
+ <QuestionShow :qType="questionItem.questionType" :question="questionItem" />
</el-col>
<el-col :span="1">
- <el-button type="text" size="mini" @click="titleItem.questionItems.splice(questionIndex,1)">鍒犻櫎
+ <el-button type="text" size="mini" @click="titleItem.questionItems.splice(questionIndex, 1)">鍒犻櫎
</el-button>
</el-col>
</el-row>
@@ -88,7 +102,7 @@
</el-card>
</el-form-item>
<el-form-item label="寤鸿鏃堕暱锛�" prop="suggestTime" required>
- <el-input v-model="form.suggestTime" placeholder="鍒嗛挓"/>
+ <el-input v-model="form.suggestTime" placeholder="鍒嗛挓" />
</el-form-item>
<el-form-item>
@@ -97,14 +111,15 @@
<el-button type="success" @click="addTitle">娣诲姞鏍囬</el-button>
</el-form-item>
</el-form>
- <el-dialog :visible.sync="questionPage.showDialog" width="70%">
+ <el-dialog :visible.sync="questionPage.showDialog" width="70%">
<el-form :model="questionPage.queryParam" ref="queryForm" :inline="true">
<el-form-item label="ID锛�">
- <el-input v-model="questionPage.queryParam.id" clearable></el-input>
+ <el-input v-model="questionPage.queryParam.id" clearable></el-input>
</el-form-item>
<el-form-item label="棰樺瀷锛�">
<el-select v-model="questionPage.queryParam.questionType" clearable>
- <el-option v-for="item in questionTypeEnum" :key="item.key" :value="item.key" :label="item.value"></el-option>
+ <el-option v-for="item in questionTypeEnum" :key="item.key" :value="item.key"
+ :label="item.value"></el-option>
</el-select>
</el-form-item>
<el-form-item>
@@ -112,36 +127,95 @@
</el-form-item>
</el-form>
<el-table v-loading="questionPage.listLoading" :data="questionPage.tableData"
- @selection-change="handleSelectionChange" border fit highlight-current-row style="width: 100%">
+ @selection-change="handleSelectionChange" border fit highlight-current-row style="width: 100%">
<el-table-column type="selection" width="35"></el-table-column>
- <el-table-column prop="questionType" label="棰樺瀷" :formatter="questionTypeFormatter" width="70px"/>
- <el-table-column prop="shortTitle" label="棰樺共" show-overflow-tooltip/>
+ <el-table-column prop="questionType" label="棰樺瀷" :formatter="questionTypeFormatter" width="70px" />
+ <el-table-column prop="shortTitle" label="棰樺共" show-overflow-tooltip />
</el-table>
- <pagination v-show="questionPage.total>0" :total="questionPage.total"
- :page.sync="questionPage.queryParam.pageIndex" :limit.sync="questionPage.queryParam.pageSize"
- @pagination="search"/>
+ <pagination v-show="questionPage.total > 0" :total="questionPage.total"
+ :page.sync="questionPage.queryParam.pageIndex" :limit.sync="questionPage.queryParam.pageSize"
+ @pagination="search" />
<span slot="footer" class="dialog-footer">
- <el-button @click="questionPage.showDialog = false">鍙� 娑�</el-button>
- <el-button type="primary" @click="confirmQuestionSelect">纭畾</el-button>
- </span>
+ <el-button @click="questionPage.showDialog = false">鍙� 娑�</el-button>
+ <el-button type="primary" @click="confirmQuestionSelect">纭畾</el-button>
+ </span>
+ </el-dialog>
+
+ <el-dialog :visible.sync="studentDialog" width="70%">
+ <el-form :model="student" ref="queryForm" :inline="true">
+ <el-form-item label="鏍囩锛�">
+ <el-select v-model="student.tagIds" clearable multiple>
+ <el-option v-for="item in tags" :key="item.id" :value="item.id" :label="item.name"></el-option>
+ </el-select>
+ </el-form-item>
+ <el-form-item label="鎺掗櫎鏍囩锛�">
+ <el-select v-model="student.excludeTagIds" clearable multiple>
+ <el-option v-for="item in tags" :key="item.id" :value="item.id" :label="item.name"></el-option>
+ </el-select>
+ </el-form-item>
+ <el-form-item label="閮ㄩ棬锛�">
+ <!-- <el-select v-model="student.deptIds" clearable multiple>
+ <el-option v-for="item in depts" :key="item.id" :value="item.id" :label="item.name"></el-option>
+ </el-select> -->
+ <el-cascader
+ clearable
+ collapse-tags
+ v-model="student.deptIds"
+ :options="depts"
+ :props="{ multiple: true, emitPath: false, value: 'id', label: 'name', checkStrictly: true }"
+ ></el-cascader>
+ </el-form-item>
+ <el-form-item>
+ <el-button type="primary" @click="selectStudent">鏌ヨ</el-button>
+ </el-form-item>
+ </el-form>
+ <el-button type="danger" @click="selectAllBoolean ? selectAll() : unselectAll()" size="small" style="margin-bottom: 3px">{{ selectAllBoolean ? '鍏ㄩ��' : '鍙栨秷鍏ㄩ��' }}</el-button>
+ <el-table ref="multipleTable" v-loading="student.listLoading" :data="tableData" border fit highlight-current-row
+ style="width: 100%" @selection-change="handleSelection" row-key="id">
+ <el-table-column type="selection" :reserve-selection="true"></el-table-column>
+ <el-table-column prop="realName" label="瀛﹀憳" />
+ </el-table>
+ <pagination v-show="total > 0" :total="total" :page.sync="student.pageIndex" :limit.sync="student.pageSize"
+ @pagination="selectStudent" />
+ <span slot="footer" class="dialog-footer">
+ <el-button @click="studentDialog = false">鍙� 娑�</el-button>
+ <el-button type="primary" @click="confirmStudentSelect">纭畾</el-button>
+ </span>
</el-dialog>
</div>
</template>
<script>
-import { mapGetters, mapState, mapActions } from 'vuex'
-import Pagination from '@/components/Pagination'
-import QuestionShow from '../question/components/Show'
-import examPaperApi from '@/api/examPaper'
-import questionApi from '@/api/question'
-import departmentApi from '@/api/department'
-import allCascader from '@/components/Cascader'
+import { mapGetters, mapState, mapActions } from 'vuex';
+import Pagination from '@/components/Pagination';
+import QuestionShow from '../question/components/Show';
+import examPaperApi from '@/api/examPaper';
+import subjectApi from '@/api/subject';
+import userApi from '@/api/user';
+import questionApi from '@/api/question';
+import departmentApi from '@/api/department';
+import allCascader from '@/components/Cascader';
export default {
- components: { Pagination, QuestionShow ,allCascader},
+ components: { Pagination, QuestionShow, allCascader },
- data () {
+ data() {
return {
+ selectAllBoolean: true,
+ tags: [],
+ studentDialog: false,
+ student: {
+ deptIds: [],
+ pageIndex: 1,
+ pageSize: 5,
+ listLoading: true,
+ multipleSelection: [],
+ excludeTagIds: []
+ },
+ isFirstShow: true,
+
+ tableData: [],
+ total: 0,
props: {
multiple: true
// lazy: true,
@@ -157,38 +231,52 @@
// })
// }
},
+ depts: [],
options: [],
- optionsData:[],
- departCascaderProps:{
+ optionsData: [],
+ departCascaderProps: {
multiple: true
},
- subjectIdList:[],
+ subjectIdList: [],
form: {
- aggregateSource:'100',
+ aggregateSource: '100',
id: null,
departmentIds: [],
- menuIds:[],
+ menuIds: [],
subjectId: [],
paperType: 7,
limitDateTime: [],
name: '',
suggestTime: null,
- titleItems: [],
- subjectSource:{},
- questionTypeVMS:[]
+ titleItems: [{
+ name: '',
+ questionItems: []
+ }],
+ subjectSource: {},
+ questionTypeVMS: [],
+ examineeList: [],
+ userIds: []
},
subjectFilter: null,
formLoading: false,
rules: {
-
+ userIds: [
+ { required: true, message: '璇烽�夋嫨鑰冪敓', trigger: 'change' }
+ ],
subjectId: [
{ required: true, message: '璇烽�夋嫨璇剧洰', trigger: 'change' }
+ ],
+ deptId: [
+ { required: true, message: '璇烽�夋嫨閮ㄩ棬', trigger: 'change' }
],
paperType: [
{ required: true, message: '璇烽�夋嫨璇曞嵎绫诲瀷', trigger: 'change' }
],
name: [
{ required: true, message: '璇疯緭鍏ヨ瘯鍗峰悕绉�', trigger: 'blur' }
+ ],
+ limitDateTime: [
+ { required: true, message: '璇烽�夋嫨鏃堕棿闄愬埗', trigger: 'blur' }
],
suggestTime: [
{ required: true, message: '璇疯緭鍏ュ缓璁椂闀�', trigger: 'blur' }
@@ -202,101 +290,191 @@
questionType: null,
subjectId: 1,
pageIndex: 1,
- pageSize: 5
+ pageSize: 500000000
},
listLoading: true,
tableData: [],
total: 0
},
currentTitleItem: null
- }
+ };
},
- created () {
+ created() {
examPaperApi.selflist().then(res => {
- console.log(res)
- this.subjectFilter = res.response
- })
+ console.log(res);
+ this.subjectFilter = res.response;
+ });
+ departmentApi.list().then(res => {
+ this.depts = res.response;
+ });
},
- async mounted () {
+ async mounted() {
+ departmentApi.getCurrentDeptId().then(res => {
+ if (res.response && res.response[0]) {
+ this.form.deptId = res.response[0];
+ }
+ });
- let id = this.$route.query.id
- let _this = this
+ let id = this.$route.query.id;
+ let _this = this;
- this.initSubject(function () {
- _this.subjectFilter = _this.subjects
- })
- if (id && parseInt(id) !== 0) {
- _this.formLoading = true
- await examPaperApi.selfselect(id).then(re => {
- _this.form = re.response
- _this.form.menuIds = JSON.parse(re.response.menuIds)
- _this.optionsData = _this.form.menuIds
- console.log(_this.form)
-
- _this.formLoading = false
- })
- }
- departmentApi.selectDepartmentUser().then(res => {
- console.log("res", res);
-
- _this.options = res.response.map(x => {
- return {
- value: x.department.id, label: x.department.name, children: x.userList.map(xx => {
- return { value: xx.id, label: xx.realName }
- })
- }
- })
- })
-
- // this.subjectIdEvent(false)
- },
- methods: {
- cascaderChangeFun(event){
- console.log(event)
- this.form.menuIds = event
- },
- titlejs(val){
- console.log(val)
- let str = ''
- this.subjectFilter.forEach(item=>{
- if (item.id == val){
- str = item.name
+ this.initSubject(function () {
+ _this.subjectFilter = _this.subjects;
+ });
+ if (id && parseInt(id) !== 0) {
+ this.selectAllBoolean = false;
+ _this.formLoading = true;
+ await examPaperApi.selfselect(id).then(re => {
+ const { userIds, userNames } = re.response;
+ _this.form = re.response;
+ if (userIds && userIds.length) {
+ _this.form.examineeList = userIds.map((item, index) => {
+ return {
+ id: item,
+ realName: userNames && userNames[index] ? userNames[index] : ''
+ };
+ });
+ } else {
+ _this.form.examineeList = [];
}
- })
- return str
- },
- subjectIdEvent(e){
- console.log(e,this.$refs.subjectIdRef.selected)
- let arr=[]
- if (e){
- }else {
- this.$refs.subjectIdRef.selected.forEach(item=>{
- arr.push({
- label:item.label,
- subjectId:item.value,
- singleChoice:'',
- multipleChoice:'',
- trueFalse:''
+ _this.formLoading = false;
+ });
+ }
+ departmentApi.selectDepartmentUser().then(res => {
+ console.log("res", res);
+
+ _this.options = res.response.map(x => {
+ return {
+ value: x.department.id, label: x.department.name, children: x.userList.map(xx => {
+ return { value: xx.id, label: xx.realName };
})
+ };
+ });
+ });
+ },
+ methods: {
+ getSubject(deptId) {
+ // 鑾峰彇瀵瑰簲閮ㄩ棬鐨勮鐩�
+ subjectApi.selectByDeptId(deptId).then(res => {
+ this.form.subjectId = null
+ this.subjectFilter = res.response
+ })
+ },
+ handleSelection(val) {
+ this.student.multipleSelection = val;
+ },
+ selectAll () {
+ this.preSelectAll();
+ let param = { ...this.student };
+ param.pageSize = 999999;
+ examPaperApi.selectStudent(param).then(res => {
+ this.handleSelection(res.response.list);
+ res.response.list.forEach(item => {
+ this.$refs.multipleTable.toggleRowSelection(item, true);
+ this.selectAllBoolean = false;
})
- console.log(arr)
- this.form.questionTypeVMS = arr
+ this.getStudent();
+ });
+ },
+ unselectAll () {
+ this.$refs.multipleTable.clearSelection();
+ this.selectAllBoolean = true;
+ },
+ confirmStudentSelect() {
+ this.form.userIds = this.student.multipleSelection.map((item) => item.id);
+ this.form.examineeList = this.student.multipleSelection.map((item) => {
+ return {
+ id: item.id,
+ realName: item.realName
+ };
+ });
+ this.student.multipleSelection = [];
+ this.studentDialog = false;
+ },
+ preSelectAll() {
+ this.selectAllBoolean = true;
+ this.$refs.multipleTable.clearSelection();
+ this.form.userIds = this.student.multipleSelection.map((item) => item.id);
+ this.form.examineeList = this.student.multipleSelection.map((item) => {
+ return {
+ id: item.id,
+ realName: item.realName
+ };
+ });
+ this.student.multipleSelection = [];
+ },
+ getTags() {
+ userApi.tagList(null).then(data => {
+ this.tags = data.response;
+ });
+ },
+ selectStudent() {
+ this.getTags();
+ this.studentDialog = true;
+ this.student.listLoading = true;
+ this.getStudent();
+ },
+ getStudent() {
+ this.student.listLoading = true;
+ examPaperApi.selectStudent(this.student).then(res => {
+ this.tableData = res.response.list;
+ this.total = res.response.total;
+ this.student.listLoading = false;
+ if (this.studentDialog && this.isFirstShow) {
+ this.isFirstShow = false;
+ this.form.examineeList.forEach(item => {
+ this.$refs.multipleTable.toggleRowSelection(item, true);
+ });
+ }
+ });
+ },
+ cascaderChangeFun(event) {
+ console.log(event);
+ this.form.menuIds = event;
+ },
+ titlejs(val) {
+ console.log(val);
+ let str = '';
+ this.subjectFilter.forEach(item => {
+ if (item.id == val) {
+ str = item.name;
+ }
+ });
+ return str;
+ },
+ subjectIdEvent(e) {
+ console.log(e, this.$refs.subjectIdRef.selected);
+ let arr = [];
+ if (e) {
+
+ } else {
+ this.$refs.subjectIdRef.selected.forEach(item => {
+ arr.push({
+ label: item.label,
+ subjectId: item.value,
+ singleChoice: '',
+ multipleChoice: '',
+ trueFalse: ''
+ });
+ });
+ console.log(arr);
+ this.form.questionTypeVMS = arr;
}
- if (this.form.paperType ==7){
+ if (this.form.paperType == 7) {
//瑾槑鏄毃姗�
- this.subjectIdList = arr
- let obj1={}
- let arr1 = []
- arr.forEach((item,index)=>{
+ this.subjectIdList = arr;
+ let obj1 = {};
+ let arr1 = [];
+ arr.forEach((item, index) => {
// obj1[item.id]=''
arr1.push({
- subjectId:item.id,
- singleChoice:'',
- multipleChoice:'',
- trueFalse:''
- })
+ subjectId: item.id,
+ singleChoice: '',
+ multipleChoice: '',
+ trueFalse: ''
+ });
// let obj={
// item
// }
@@ -308,96 +486,94 @@
// console.log('閿悕锛�', i);
// console.log('閿�硷細', obj[i]);
// }
- })
- this.form.subjectSource = obj1
+ });
+ this.form.subjectSource = obj1;
- console.log(this.form.subjectSource)
- console.log(this.form.questionTypeVMS)
+ console.log(this.form.subjectSource);
+ console.log(this.form.questionTypeVMS);
// this.form.paperType = 7
- this.form.titleItems = []
- }else {
- this.form.subjectSource={}
- this.subjectIdList = []
+ this.form.titleItems = [{
+ name: '',
+ questionItems: []
+ }];
+ } else {
+ this.form.subjectSource = {};
+ this.subjectIdList = [];
// this.form.paperType = 1
}
},
- submitForm () {
- let _this = this
- console.log(this.subjectIdList)
- console.log(this.form.subjectSource)
+ submitForm() {
+ let _this = this;
this.$refs.form.validate((valid) => {
if (valid) {
+ const tempForm = JSON.parse(JSON.stringify(this.form));
this.formLoading = true;
- if (this.subjectIdList.length == 1){
- this.form.subjectId= this.form.subjectId
+ if (this.subjectIdList.length == 1) {
+ tempForm.subjectId = tempForm.subjectId;
};
- let lastHasAll = this.form.menuIds.find(arr => {
- return arr[0] === 'all';
- });
- if (lastHasAll){
- this.form.menuIds = this.form.menuIds.slice(1)
+ // let lastHasAll = tempForm.menuIds.find(arr => {
+ // return arr[0] === 'all';
+ // });
+ // if (lastHasAll) {
+ // tempForm.menuIds = tempForm.menuIds.slice(1);
+ // }
+
+ tempForm.menuIds = tempForm.userIds.join(',');
+
+ if (tempForm.questionTypeVMS == null) {
+ tempForm.questionTypeVMS = [];
}
- let op = [];
- for(var ele of this.form.menuIds){
- op.push(ele[1])
- };
- this.form.menuIds = JSON.stringify(this.form.menuIds);
- this.form.userIds = op;
- console.log("laks",this.form)
- if(this.form.questionTypeVMS == null){
- this.form.questionTypeVMS = [];
- }
- this.form.status = 0
- examPaperApi.selfedit(this.form).then(re => {
+ tempForm.status = 0;
+ examPaperApi.selfedit(tempForm).then(re => {
if (re.code === 1) {
- _this.$message.success(re.message)
+ _this.$message.success(re.message);
_this.delCurrentView(_this).then(() => {
- _this.$router.push('/exam/personalRandomTemplate/list')
- })
+ _this.$router.push('/exam/personalRandomTemplate/list');
+ });
} else {
- _this.$message.error(re.message)
- this.formLoading = false
+ _this.$message.error(re.message);
+ this.formLoading = false;
}
}).catch(e => {
- this.formLoading = false
- })
+ this.formLoading = false;
+ });
} else {
- return false
+ return false;
}
- })
+ });
},
- addTitle () {
+ addTitle() {
this.form.titleItems.push({
name: '',
questionItems: []
- })
+ });
},
- addQuestion (titleItem) {
- this.currentTitleItem = titleItem
- this.questionPage.showDialog = true
- this.search()
+ addQuestion(titleItem) {
+ this.currentTitleItem = titleItem;
+ this.questionPage.showDialog = true;
+ this.search();
},
- removeTitleItem (titleItem) {
- this.form.titleItems.remove(titleItem)
+ removeTitleItem(titleItem) {
+ this.form.titleItems.remove(titleItem);
},
- removeQuestion (titleItem, questionItem) {
- titleItem.questionItems.remove(questionItem)
+ removeQuestion(titleItem, questionItem) {
+ titleItem.questionItems.remove(questionItem);
},
- queryForm () {
- this.questionPage.queryParam.pageIndex = 1
- this.search()
+ queryForm() {
+ this.questionPage.queryParam.pageIndex = 1;
+ this.search();
},
- confirmQuestionSelect () {
- let _this = this
+ confirmQuestionSelect() {
+ let _this = this;
this.questionPage.multipleSelection.forEach(q => {
questionApi.select(q.id).then(re => {
- _this.currentTitleItem.questionItems.push(re.response)
- })
- })
- this.questionPage.showDialog = false
+ _this.currentTitleItem.questionItems.push(re.response);
+ });
+ });
+ this.questionPage.showDialog = false;
},
- levelChange () {
+ levelChange() {
// this.form.subjectId = null
// this.subjectFilter = this.subjects.filter(data =>{
// return this.form.departmentIds.forEach(item=>{data.level == item})
@@ -411,37 +587,37 @@
// }
// })
// })
- console.log(this.subjects,this.form.departmentIds)
+ console.log(this.subjects, this.form.departmentIds);
// this.subjectFilter = this.subjects
},
- search () {
- if (this.subjectIdList.length=1){
- this.questionPage.queryParam.subjectId = this.form.subjectId
+ search() {
+ if (this.subjectIdList.length = 1) {
+ this.questionPage.queryParam.subjectId = this.form.subjectId;
}
- this.questionPage.listLoading = true
+ this.questionPage.listLoading = true;
questionApi.pageList(this.questionPage.queryParam).then(data => {
- const re = data.response
- this.questionPage.tableData = re.list
- this.questionPage.total = re.total
- this.questionPage.queryParam.pageIndex = re.pageNum
- this.questionPage.listLoading = false
- })
+ const re = data.response;
+ this.questionPage.tableData = re.list;
+ this.questionPage.total = re.total;
+ this.questionPage.queryParam.pageIndex = re.pageNum;
+ this.questionPage.listLoading = false;
+ });
},
- handleSelectionChange (val) {
- this.questionPage.multipleSelection = val
+ handleSelectionChange(val) {
+ this.questionPage.multipleSelection = val;
},
- questionTypeFormatter (row, column, cellValue, index) {
- return this.enumFormat(this.questionTypeEnum, cellValue)
+ questionTypeFormatter(row, column, cellValue, index) {
+ return this.enumFormat(this.questionTypeEnum, cellValue);
},
- subjectFormatter (row, column, cellValue, index) {
- return this.subjectEnumFormat(cellValue)
+ subjectFormatter(row, column, cellValue, index) {
+ return this.subjectEnumFormat(cellValue);
},
- resetForm () {
- let lastId = this.form.id
- this.$refs['form'].resetFields()
- this.form= {
- aggregateSource:100,
+ resetForm() {
+ let lastId = this.form.id;
+ this.$refs['form'].resetFields();
+ this.form = {
+ aggregateSource: 100,
id: null,
departmentIds: [],
subjectId: [],
@@ -450,10 +626,10 @@
name: '',
suggestTime: null,
titleItems: [],
- subjectSource:null,
- questionTypeVMS:[]
- }
- this.form.id = lastId
+ subjectSource: null,
+ questionTypeVMS: []
+ };
+ this.form.id = lastId;
},
...mapActions('exam', { initSubject: 'initSubject' }),
...mapActions('tagsView', { delCurrentView: 'delCurrentView' }),
@@ -468,7 +644,7 @@
}),
...mapState('exam', { subjects: state => state.subjects })
}
-}
+};
</script>
<style lang="scss">
@@ -476,7 +652,11 @@
.q-title {
margin: 0px 5px 0px 5px;
}
- .q-item-content {
- }
+
+ .q-item-content {}
+}
+
+.examinee-popper {
+ display: none !important;
}
</style>
--
Gitblit v1.8.0