Commit 8ea67428e9a73e9555b5ba4894572f3ac64a11d3
1 parent
6d7bd862
飞书bug
Showing
13 changed files
with
516 additions
and
159 deletions
src/api/axios.js
| @@ -71,7 +71,6 @@ service.interceptors.response.use( | @@ -71,7 +71,6 @@ service.interceptors.response.use( | ||
| 71 | 71 | ||
| 72 | if (status === 403 || status === 401) { | 72 | if (status === 403 || status === 401) { |
| 73 | if (data.status === 999) { | 73 | if (data.status === 999) { |
| 74 | - debugger | ||
| 75 | console.log(data.data) | 74 | console.log(data.data) |
| 76 | if (data.data) { | 75 | if (data.data) { |
| 77 | window.location.href = data.data; | 76 | window.location.href = data.data; |
src/components/setAnswer.vue
| @@ -356,10 +356,10 @@ export default { | @@ -356,10 +356,10 @@ export default { | ||
| 356 | } | 356 | } |
| 357 | }, | 357 | }, |
| 358 | async saveAnswer() { | 358 | async saveAnswer() { |
| 359 | - let questionList = []; | ||
| 360 | - for (let i = 0; i < this.FormQuestionList.length; i++) { | ||
| 361 | - if (this.FormQuestionList[i].qusType) { | ||
| 362 | - this.FormQuestionList.splice(i, 1); | 359 | + let questionList = [...this.FormQuestionList]; |
| 360 | + for (let i = 0; i < questionList.length; i++) { | ||
| 361 | + if (questionList[i].qusType) { | ||
| 362 | + questionList.splice(i, 1); | ||
| 363 | i--; | 363 | i--; |
| 364 | } | 364 | } |
| 365 | } | 365 | } |
src/components/upload.vue
| @@ -30,14 +30,8 @@ | @@ -30,14 +30,8 @@ | ||
| 30 | export default { | 30 | export default { |
| 31 | name: "downUpData", | 31 | name: "downUpData", |
| 32 | props: { | 32 | props: { |
| 33 | - id: { | ||
| 34 | - type: String, | ||
| 35 | - default: "", | ||
| 36 | - }, | ||
| 37 | - examId: { | ||
| 38 | - type: String, | ||
| 39 | - default: "", | ||
| 40 | - }, | 33 | + id: "", |
| 34 | + examId: "", | ||
| 41 | url: { | 35 | url: { |
| 42 | type: String, | 36 | type: String, |
| 43 | default: "", | 37 | default: "", |
src/views/analysis/index.vue
| @@ -185,6 +185,7 @@ export default { | @@ -185,6 +185,7 @@ export default { | ||
| 185 | //中国式星期天是一周的最后一天 | 185 | //中国式星期天是一周的最后一天 |
| 186 | day = 7; | 186 | day = 7; |
| 187 | } | 187 | } |
| 188 | + day-- | ||
| 188 | let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day; | 189 | let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day; |
| 189 | that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd"); | 190 | that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd"); |
| 190 | that.query.endDay = formatDate(new Date(), "yyyy-MM-dd"); | 191 | that.query.endDay = formatDate(new Date(), "yyyy-MM-dd"); |
src/views/ask/analysis.vue
| @@ -77,12 +77,12 @@ | @@ -77,12 +77,12 @@ | ||
| 77 | align="center" | 77 | align="center" |
| 78 | ></el-table-column> | 78 | ></el-table-column> |
| 79 | <el-table-column | 79 | <el-table-column |
| 80 | - prop="canyu" | 80 | + prop="participationRate" |
| 81 | label="班级参与度" | 81 | label="班级参与度" |
| 82 | sortable | 82 | sortable |
| 83 | align="center" | 83 | align="center" |
| 84 | ><template slot-scope="scoped" | 84 | ><template slot-scope="scoped" |
| 85 | - >{{ scoped.row.canyu }}%</template | 85 | + >{{ scoped.row.participationRate }}%</template |
| 86 | ></el-table-column | 86 | ></el-table-column |
| 87 | > | 87 | > |
| 88 | <el-table-column | 88 | <el-table-column |
| @@ -107,21 +107,22 @@ | @@ -107,21 +107,22 @@ | ||
| 107 | prop="correctAnswer" | 107 | prop="correctAnswer" |
| 108 | label="正确答案" | 108 | label="正确答案" |
| 109 | align="center" | 109 | align="center" |
| 110 | - ></el-table-column> | 110 | + > <template slot-scope="scoped">{{scoped.row.correctAnswer==1?"✓":scoped.row.correctAnswer==2?"✗":scoped.row.correctAnswer}}</template></el-table-column> |
| 111 | <el-table-column | 111 | <el-table-column |
| 112 | prop="fallible" | 112 | prop="fallible" |
| 113 | label="干扰答案" | 113 | label="干扰答案" |
| 114 | align="center" | 114 | align="center" |
| 115 | - ></el-table-column> | ||
| 116 | - <el-table-column prop="screenshot" label="题干" align="center"> | 115 | + ><template slot-scope="scoped">{{scoped.row.fallible==1?"✓":scoped.row.fallible==2?"✗":scoped.row.correctAnswer}}</template></el-table-column> |
| 116 | + <!-- <el-table-column prop="screenshot" label="题干" align="center"> | ||
| 117 | <template slot-scope="scoped"> | 117 | <template slot-scope="scoped"> |
| 118 | <el-image | 118 | <el-image |
| 119 | + v-if="scoped.row.screenshot" | ||
| 119 | style="width: 60px; height: 40px" | 120 | style="width: 60px; height: 40px" |
| 120 | :src="scoped.row.screenshot" | 121 | :src="scoped.row.screenshot" |
| 121 | :preview-src-list="[scoped.row.screenshot]" | 122 | :preview-src-list="[scoped.row.screenshot]" |
| 122 | > | 123 | > |
| 123 | - </el-image></template | ||
| 124 | - ></el-table-column> | 124 | + </el-image><span v-else>暂无</span></template |
| 125 | + ></el-table-column> --> | ||
| 125 | </el-table> | 126 | </el-table> |
| 126 | <el-table v-if="type == 2" :data="tableData" border style="width: 100%"> | 127 | <el-table v-if="type == 2" :data="tableData" border style="width: 100%"> |
| 127 | <el-table-column | 128 | <el-table-column |
| @@ -265,7 +266,7 @@ | @@ -265,7 +266,7 @@ | ||
| 265 | icon="fa fa-cloud-download" | 266 | icon="fa fa-cloud-download" |
| 266 | >导出报表</el-button | 267 | >导出报表</el-button |
| 267 | > | 268 | > |
| 268 | - <el-button @click="edit" type="primary" round>设置答案</el-button> | 269 | + <el-button @click="edit" type="primary" round>修改答案</el-button> |
| 269 | </p> | 270 | </p> |
| 270 | </div> | 271 | </div> |
| 271 | </div> | 272 | </div> |
| @@ -336,6 +337,7 @@ export default { | @@ -336,6 +337,7 @@ export default { | ||
| 336 | }, | 337 | }, |
| 337 | handleSuccess() { | 338 | handleSuccess() { |
| 338 | this.dialogVisible = false; | 339 | this.dialogVisible = false; |
| 340 | + this._QueryData(); | ||
| 339 | }, | 341 | }, |
| 340 | async edit() { | 342 | async edit() { |
| 341 | if (this.editLoading) return; | 343 | if (this.editLoading) return; |
src/views/ask/index.vue
| @@ -94,7 +94,9 @@ | @@ -94,7 +94,9 @@ | ||
| 94 | @change="tabChange" | 94 | @change="tabChange" |
| 95 | style="margin-bottom: 20px" | 95 | style="margin-bottom: 20px" |
| 96 | > | 96 | > |
| 97 | - <el-radio-button :label="1">单课时报表</el-radio-button> | 97 | + <el-radio-button :label="1" v-if="query.startDay != query.endDay" |
| 98 | + >单课时报表</el-radio-button | ||
| 99 | + > | ||
| 98 | <!-- <el-radio-button :label="2" v-if="this.role != 'ROLE_BANZHUREN'" | 100 | <!-- <el-radio-button :label="2" v-if="this.role != 'ROLE_BANZHUREN'" |
| 99 | >阶段问答报表</el-radio-button | 101 | >阶段问答报表</el-radio-button |
| 100 | > --> | 102 | > --> |
| @@ -109,7 +111,7 @@ | @@ -109,7 +111,7 @@ | ||
| 109 | <span>总课时数:10</span> | 111 | <span>总课时数:10</span> |
| 110 | <span>互动总数:22</span> | 112 | <span>互动总数:22</span> |
| 111 | </p> --> | 113 | </p> --> |
| 112 | - <div v-if="tabIndex == 1"> | 114 | + <div v-show="tabIndex == 1"> |
| 113 | <el-table | 115 | <el-table |
| 114 | :data="tableData" | 116 | :data="tableData" |
| 115 | border | 117 | border |
| @@ -153,40 +155,46 @@ | @@ -153,40 +155,46 @@ | ||
| 153 | > | 155 | > |
| 154 | </el-table-column> | 156 | </el-table-column> |
| 155 | <el-table-column | 157 | <el-table-column |
| 156 | - prop="correctRate" | 158 | + prop="classCorrectRate" |
| 157 | label="班级总正确率" | 159 | label="班级总正确率" |
| 158 | sortable="custom" | 160 | sortable="custom" |
| 159 | align="center" | 161 | align="center" |
| 160 | ><template slot-scope="scoped" | 162 | ><template slot-scope="scoped" |
| 161 | - >{{ scoped.row.correctRate }}%</template | 163 | + >{{ scoped.row.classCorrectRate }}%</template |
| 162 | ></el-table-column | 164 | ></el-table-column |
| 163 | > | 165 | > |
| 164 | <el-table-column label="操作" align="center"> | 166 | <el-table-column label="操作" align="center"> |
| 165 | <template slot-scope="scoped"> | 167 | <template slot-scope="scoped"> |
| 166 | - <el-tooltip effect="dark" content="详情" placement="top"> | 168 | + <el-tooltip |
| 169 | + effect="dark" | ||
| 170 | + v-if="scoped.row.answerNum == 0" | ||
| 171 | + content="设置答案" | ||
| 172 | + placement="top" | ||
| 173 | + > | ||
| 167 | <el-button | 174 | <el-button |
| 168 | type="primary" | 175 | type="primary" |
| 169 | circle | 176 | circle |
| 170 | size="mini" | 177 | size="mini" |
| 171 | - icon="fa fa-arrow-right" | ||
| 172 | - @click="linkTo(scoped.row)" | 178 | + icon="fa fa-file-text" |
| 179 | + @click="edit(scoped.row)" | ||
| 173 | ></el-button> | 180 | ></el-button> |
| 174 | </el-tooltip> | 181 | </el-tooltip> |
| 175 | - <el-tooltip effect="dark" content="修改答案" placement="top"> | 182 | + <el-tooltip v-else effect="dark" content="详情" placement="top"> |
| 176 | <el-button | 183 | <el-button |
| 177 | type="primary" | 184 | type="primary" |
| 178 | circle | 185 | circle |
| 179 | size="mini" | 186 | size="mini" |
| 180 | - icon="fa fa-file-text" | ||
| 181 | - @click="edit(scoped.row)" | 187 | + icon="fa fa-arrow-right" |
| 188 | + @click="linkTo(scoped.row)" | ||
| 182 | ></el-button> | 189 | ></el-button> |
| 183 | </el-tooltip> | 190 | </el-tooltip> |
| 184 | </template> | 191 | </template> |
| 185 | </el-table-column> | 192 | </el-table-column> |
| 186 | </el-table> | 193 | </el-table> |
| 187 | </div> | 194 | </div> |
| 188 | - <div v-if="tabIndex == 2"> | 195 | + <div v-show="tabIndex == 2"> |
| 189 | <el-table | 196 | <el-table |
| 197 | + v-if="role == 'ROLE_JIAOSHI'" | ||
| 190 | :data="tableData" | 198 | :data="tableData" |
| 191 | border | 199 | border |
| 192 | style="width: 100%" | 200 | style="width: 100%" |
| @@ -252,9 +260,34 @@ | @@ -252,9 +260,34 @@ | ||
| 252 | align="center" | 260 | align="center" |
| 253 | ></el-table-column> | 261 | ></el-table-column> |
| 254 | </el-table> | 262 | </el-table> |
| 263 | + <el-table v-else :data="tableData" border style="width: 100%"> | ||
| 264 | + <el-table-column | ||
| 265 | + prop="studentCode" | ||
| 266 | + label="学号" | ||
| 267 | + align="center" | ||
| 268 | + ></el-table-column> | ||
| 269 | + <el-table-column | ||
| 270 | + prop="studentName" | ||
| 271 | + label="姓名" | ||
| 272 | + align="center" | ||
| 273 | + width="100" | ||
| 274 | + ></el-table-column> | ||
| 275 | + <el-table-column | ||
| 276 | + v-for="(item, index) in phaseOption" | ||
| 277 | + :key="index" | ||
| 278 | + :label="item" | ||
| 279 | + align="center" | ||
| 280 | + > | ||
| 281 | + <el-table-column align="center" :label="index==0?'总课时数':'课时数'" :prop="'periodCount'+item"> </el-table-column> | ||
| 282 | + <el-table-column align="center" :label="index==0?'总出题数':'出题数'" :prop="'questionNum'+item"> </el-table-column> | ||
| 283 | + <el-table-column align="center" :label="index==0?'总参与度':'参与度'" :prop="'participationRate'+item"> </el-table-column> | ||
| 284 | + <el-table-column align="center" :label="index==0?'总正确率':'正确率'" :prop="'correctRate'+item"> </el-table-column> | ||
| 285 | + </el-table-column> | ||
| 286 | + </el-table> | ||
| 255 | </div> | 287 | </div> |
| 256 | - <div v-if="tabIndex == 3"> | 288 | + <div v-show="tabIndex == 3"> |
| 257 | <el-table | 289 | <el-table |
| 290 | + v-if="role == 'ROLE_JIAOSHI'" | ||
| 258 | :data="tableData" | 291 | :data="tableData" |
| 259 | border | 292 | border |
| 260 | style="width: 100%" | 293 | style="width: 100%" |
| @@ -296,18 +329,40 @@ | @@ -296,18 +329,40 @@ | ||
| 296 | align="center" | 329 | align="center" |
| 297 | ></el-table-column> | 330 | ></el-table-column> |
| 298 | <el-table-column | 331 | <el-table-column |
| 299 | - prop="canyu" | 332 | + prop="interactionsNum" |
| 300 | label="参与得分" | 333 | label="参与得分" |
| 301 | sortable | 334 | sortable |
| 302 | align="center" | 335 | align="center" |
| 303 | ></el-table-column> | 336 | ></el-table-column> |
| 304 | <el-table-column | 337 | <el-table-column |
| 305 | - prop="duicuo" | 338 | + prop="interactionsCorrectNum" |
| 306 | label="对错得分" | 339 | label="对错得分" |
| 307 | sortable | 340 | sortable |
| 308 | align="center" | 341 | align="center" |
| 309 | ></el-table-column> | 342 | ></el-table-column> |
| 310 | </el-table> | 343 | </el-table> |
| 344 | + <el-table v-else :data="tableData" border style="width: 100%"> | ||
| 345 | + <el-table-column | ||
| 346 | + prop="studentCode" | ||
| 347 | + label="学号" | ||
| 348 | + align="center" | ||
| 349 | + ></el-table-column> | ||
| 350 | + <el-table-column | ||
| 351 | + prop="studentName" | ||
| 352 | + label="姓名" | ||
| 353 | + align="center" | ||
| 354 | + width="100" | ||
| 355 | + ></el-table-column> | ||
| 356 | + <el-table-column | ||
| 357 | + v-for="(item, index) in phaseInter" | ||
| 358 | + :key="index" | ||
| 359 | + :label="item" | ||
| 360 | + align="center" | ||
| 361 | + > | ||
| 362 | + <el-table-column align="center" :label="index==0?'参与分':'互动数'" :prop="'interactionsNum'+item"> </el-table-column> | ||
| 363 | + <el-table-column align="center" :label="index==0?'对错分':'参与数'" :prop="'interactionsCorrectNum'+item"> </el-table-column> | ||
| 364 | + </el-table-column> | ||
| 365 | + </el-table> | ||
| 311 | </div> | 366 | </div> |
| 312 | <div class="pagination-box" v-show="tabIndex == 1"> | 367 | <div class="pagination-box" v-show="tabIndex == 1"> |
| 313 | <el-pagination | 368 | <el-pagination |
| @@ -369,6 +424,8 @@ export default { | @@ -369,6 +424,8 @@ export default { | ||
| 369 | subjectList: [], //科目 | 424 | subjectList: [], //科目 |
| 370 | tabIndex: 1, //选项卡 | 425 | tabIndex: 1, //选项卡 |
| 371 | tableData: [], | 426 | tableData: [], |
| 427 | + phaseOption: [],//问答补充数据 | ||
| 428 | + phaseInter:[],//互动补充数据 | ||
| 372 | page: 1, | 429 | page: 1, |
| 373 | size: 20, | 430 | size: 20, |
| 374 | total: 0, | 431 | total: 0, |
| @@ -418,6 +475,7 @@ export default { | @@ -418,6 +475,7 @@ export default { | ||
| 418 | //中国式星期天是一周的最后一天 | 475 | //中国式星期天是一周的最后一天 |
| 419 | day = 7; | 476 | day = 7; |
| 420 | } | 477 | } |
| 478 | + day--; | ||
| 421 | let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day; | 479 | let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day; |
| 422 | that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd"); | 480 | that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd"); |
| 423 | that.query.endDay = formatDate(new Date(), "yyyy-MM-dd"); | 481 | that.query.endDay = formatDate(new Date(), "yyyy-MM-dd"); |
| @@ -486,6 +544,7 @@ export default { | @@ -486,6 +544,7 @@ export default { | ||
| 486 | }, | 544 | }, |
| 487 | handleSuccess() { | 545 | handleSuccess() { |
| 488 | this.dialogVisible = false; | 546 | this.dialogVisible = false; |
| 547 | + this._QueryData(); | ||
| 489 | }, | 548 | }, |
| 490 | tabChange() { | 549 | tabChange() { |
| 491 | this.page = 1; | 550 | this.page = 1; |
| @@ -509,7 +568,7 @@ export default { | @@ -509,7 +568,7 @@ export default { | ||
| 509 | async changClazz() { | 568 | async changClazz() { |
| 510 | await this._QuerySubjectList(); | 569 | await this._QuerySubjectList(); |
| 511 | // await this.setDate(1); | 570 | // await this.setDate(1); |
| 512 | - this._QueryData() | 571 | + this._QueryData(); |
| 513 | }, | 572 | }, |
| 514 | async _QueryClassList() { | 573 | async _QueryClassList() { |
| 515 | const fetchClassList = | 574 | const fetchClassList = |
| @@ -640,7 +699,29 @@ export default { | @@ -640,7 +699,29 @@ export default { | ||
| 640 | }); | 699 | }); |
| 641 | this.loading = false; | 700 | this.loading = false; |
| 642 | if (status === 0) { | 701 | if (status === 0) { |
| 643 | - this.tableData = (data?.list && [...data?.list]) || []; | 702 | + if (this.role == "ROLE_BANZHUREN") { |
| 703 | + let subjectName = []; | ||
| 704 | + this.tableData = data?.list.map((item) => { | ||
| 705 | + let params = {}; | ||
| 706 | + item.dataList.map((items, index) => { | ||
| 707 | + if (!subjectName.includes(items.subjectName)) { | ||
| 708 | + subjectName.push(items.subjectName); | ||
| 709 | + } | ||
| 710 | + params["answerCorrectRate" + items.subjectName] = items.answerCorrectRate; | ||
| 711 | + params["correctRate" + items.subjectName] = items.correctRate; | ||
| 712 | + params["participationRate" + items.subjectName] = items.participationRate; | ||
| 713 | + params["periodCount" + items.subjectName] = items.periodCount; | ||
| 714 | + params["questionNum" + items.subjectName] = items.questionNum; | ||
| 715 | + }); | ||
| 716 | + return { | ||
| 717 | + ...item, | ||
| 718 | + ...params, | ||
| 719 | + }; | ||
| 720 | + }); | ||
| 721 | + this.phaseOption = [...subjectName]; | ||
| 722 | + } else { | ||
| 723 | + this.tableData = (data?.list && [...data?.list]) || []; | ||
| 724 | + } | ||
| 644 | this.total = data.count; | 725 | this.total = data.count; |
| 645 | } else { | 726 | } else { |
| 646 | this.$message.error(info); | 727 | this.$message.error(info); |
| @@ -680,7 +761,26 @@ export default { | @@ -680,7 +761,26 @@ export default { | ||
| 680 | }); | 761 | }); |
| 681 | this.loading = false; | 762 | this.loading = false; |
| 682 | if (status === 0) { | 763 | if (status === 0) { |
| 683 | - this.tableData = (data?.list && [...data?.list]) || []; | 764 | + if (this.role == "ROLE_BANZHUREN") { |
| 765 | + let subjectName = []; | ||
| 766 | + this.tableData = data?.list.map((item) => { | ||
| 767 | + let params = {}; | ||
| 768 | + item.dataList.map((items, index) => { | ||
| 769 | + if (!subjectName.includes(items.subjectName)) { | ||
| 770 | + subjectName.push(items.subjectName); | ||
| 771 | + } | ||
| 772 | + params["interactionsNum" + items.subjectName] = items.interactionsNum; | ||
| 773 | + params["interactionsCorrectNum" + items.subjectName] = items.interactionsCorrectNum; | ||
| 774 | + }); | ||
| 775 | + return { | ||
| 776 | + ...item, | ||
| 777 | + ...params, | ||
| 778 | + }; | ||
| 779 | + }); | ||
| 780 | + this.phaseInter = [...subjectName]; | ||
| 781 | + } else { | ||
| 782 | + this.tableData = (data?.list && [...data?.list]) || []; | ||
| 783 | + } | ||
| 684 | this.total = data.count; | 784 | this.total = data.count; |
| 685 | } else { | 785 | } else { |
| 686 | this.$message.error(info); | 786 | this.$message.error(info); |
src/views/device/index.vue
| @@ -39,7 +39,7 @@ | @@ -39,7 +39,7 @@ | ||
| 39 | </el-radio-group> | 39 | </el-radio-group> |
| 40 | </div> | 40 | </div> |
| 41 | <div class="content"> | 41 | <div class="content"> |
| 42 | - <div v-if="type == 1"> | 42 | + <div v-show="type == 1"> |
| 43 | <div class="chart-box" v-if="count"> | 43 | <div class="chart-box" v-if="count"> |
| 44 | <div class="device-num"> | 44 | <div class="device-num"> |
| 45 | <p class="p1">{{ count }}</p> | 45 | <p class="p1">{{ count }}</p> |
| @@ -175,7 +175,7 @@ | @@ -175,7 +175,7 @@ | ||
| 175 | </el-table> | 175 | </el-table> |
| 176 | </div> | 176 | </div> |
| 177 | </div> | 177 | </div> |
| 178 | - <div v-else-if="type == 2"> | 178 | + <div v-show="type == 2"> |
| 179 | <div class="chart-box" v-if="count"> | 179 | <div class="chart-box" v-if="count"> |
| 180 | <div class="device-num"> | 180 | <div class="device-num"> |
| 181 | <p class="p1">{{ count }}</p> | 181 | <p class="p1">{{ count }}</p> |
| @@ -291,7 +291,7 @@ | @@ -291,7 +291,7 @@ | ||
| 291 | </el-table> | 291 | </el-table> |
| 292 | </div> | 292 | </div> |
| 293 | </div> | 293 | </div> |
| 294 | - <div v-else-if="type == 3"> | 294 | + <div v-show="type == 3"> |
| 295 | <div class="table-box"> | 295 | <div class="table-box"> |
| 296 | <div class="answer-header"> | 296 | <div class="answer-header"> |
| 297 | <div class="sel-box"> | 297 | <div class="sel-box"> |
src/views/device/log.vue
| @@ -193,6 +193,7 @@ export default { | @@ -193,6 +193,7 @@ export default { | ||
| 193 | //中国式星期天是一周的最后一天 | 193 | //中国式星期天是一周的最后一天 |
| 194 | day = 7; | 194 | day = 7; |
| 195 | } | 195 | } |
| 196 | + day-- | ||
| 196 | let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day; | 197 | let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day; |
| 197 | that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd"); | 198 | that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd"); |
| 198 | that.query.endDay = formatDate(new Date(), "yyyy-MM-dd"); | 199 | that.query.endDay = formatDate(new Date(), "yyyy-MM-dd"); |
src/views/examinationPaper/index.vue
| @@ -201,7 +201,7 @@ export default { | @@ -201,7 +201,7 @@ export default { | ||
| 201 | tableData: null, | 201 | tableData: null, |
| 202 | shareForm: { | 202 | shareForm: { |
| 203 | id: "", | 203 | id: "", |
| 204 | - sharingType: 1, //0-任课班级/1-全年级 | 204 | + sharingType: 0, //0-任课班级/1-全年级 |
| 205 | }, | 205 | }, |
| 206 | shareRulesForm: { | 206 | shareRulesForm: { |
| 207 | sharingType: [ | 207 | sharingType: [ |
| @@ -243,7 +243,7 @@ export default { | @@ -243,7 +243,7 @@ export default { | ||
| 243 | case 1: | 243 | case 1: |
| 244 | //修改分享范围 | 244 | //修改分享范围 |
| 245 | that.shareForm.id = item.id; | 245 | that.shareForm.id = item.id; |
| 246 | - that.shareForm.sharingType = item.sharingType || 1; | 246 | + that.shareForm.sharingType = item.sharingType; |
| 247 | that.dialogVisible = true; | 247 | that.dialogVisible = true; |
| 248 | break; | 248 | break; |
| 249 | case 2: | 249 | case 2: |
src/views/login/index.vue
| @@ -95,12 +95,12 @@ export default { | @@ -95,12 +95,12 @@ export default { | ||
| 95 | loginForm: { | 95 | loginForm: { |
| 96 | // username: "15911715665", | 96 | // username: "15911715665", |
| 97 | // password: "Csiy88888", | 97 | // password: "Csiy88888", |
| 98 | - username: "13610050254", | ||
| 99 | - password: "Pw050254#", | 98 | + // username: "13610050254", |
| 99 | + // password: "Pw050254#", | ||
| 100 | // username: "18332123505", | 100 | // username: "18332123505", |
| 101 | // password: "Pw123505#", | 101 | // password: "Pw123505#", |
| 102 | - // username: "18687826606", | ||
| 103 | - // password: "Pw826606#", | 102 | + username: "18687826606", |
| 103 | + password: "Pw826606#", | ||
| 104 | // username: "18946034886", | 104 | // username: "18946034886", |
| 105 | // password: "Pw034886#", | 105 | // password: "Pw034886#", |
| 106 | // username: "18893712576", | 106 | // username: "18893712576", |
| @@ -129,7 +129,7 @@ export default { | @@ -129,7 +129,7 @@ export default { | ||
| 129 | this.dockkey = getURLParams("dockkey") || ""; | 129 | this.dockkey = getURLParams("dockkey") || ""; |
| 130 | if (this.code || this.dockkey) { | 130 | if (this.code || this.dockkey) { |
| 131 | this.loading = true | 131 | this.loading = true |
| 132 | - // this._LoginCheck(); | 132 | + this._LoginCheck(); |
| 133 | } | 133 | } |
| 134 | }, | 134 | }, |
| 135 | methods: { | 135 | methods: { |
src/views/test/analysis.vue
| @@ -16,7 +16,14 @@ | @@ -16,7 +16,14 @@ | ||
| 16 | <el-button type="danger" round @click="_ReScore" size="mini" | 16 | <el-button type="danger" round @click="_ReScore" size="mini" |
| 17 | >重新计分</el-button | 17 | >重新计分</el-button |
| 18 | > | 18 | > |
| 19 | - <el-button type="danger" round plain size="mini" @click="paperModifyLog.modifiedTime = ''">暂时不计</el-button> | 19 | + <el-button |
| 20 | + type="danger" | ||
| 21 | + round | ||
| 22 | + plain | ||
| 23 | + size="mini" | ||
| 24 | + @click="paperModifyLog.modifiedTime = ''" | ||
| 25 | + >暂时不计</el-button | ||
| 26 | + > | ||
| 20 | </div> | 27 | </div> |
| 21 | </div> | 28 | </div> |
| 22 | <div class="page-content"> | 29 | <div class="page-content"> |
| @@ -46,65 +53,123 @@ | @@ -46,65 +53,123 @@ | ||
| 46 | >作答明细表</span | 53 | >作答明细表</span |
| 47 | > | 54 | > |
| 48 | </div> | 55 | </div> |
| 49 | - <el-table v-if="type == 1" :data="tableData" border style="width: 100%"> | 56 | + <el-table v-show="type == 1" :data="tableData" border style="width: 100%"> |
| 50 | <el-table-column | 57 | <el-table-column |
| 51 | prop="questionIndex" | 58 | prop="questionIndex" |
| 52 | label="题号" | 59 | label="题号" |
| 53 | align="center" | 60 | align="center" |
| 61 | + width="60" | ||
| 54 | ></el-table-column> | 62 | ></el-table-column> |
| 55 | - <el-table-column prop="questionType" label="题型" align="center" | 63 | + <el-table-column |
| 64 | + prop="questionType" | ||
| 65 | + label="题型" | ||
| 66 | + align="center" | ||
| 67 | + width="100" | ||
| 56 | ><template slot-scope="scope">{{ | 68 | ><template slot-scope="scope">{{ |
| 57 | setSubPro(scope.row.questionType) | 69 | setSubPro(scope.row.questionType) |
| 58 | }}</template></el-table-column | 70 | }}</template></el-table-column |
| 59 | > | 71 | > |
| 60 | <el-table-column | 72 | <el-table-column |
| 61 | prop="score" | 73 | prop="score" |
| 74 | + width="100" | ||
| 62 | label="满分值" | 75 | label="满分值" |
| 63 | sortable | 76 | sortable |
| 64 | align="center" | 77 | align="center" |
| 65 | ></el-table-column> | 78 | ></el-table-column> |
| 66 | <el-table-column | 79 | <el-table-column |
| 80 | + width="110" | ||
| 67 | prop="highestScore" | 81 | prop="highestScore" |
| 68 | label="班最高分" | 82 | label="班最高分" |
| 69 | sortable | 83 | sortable |
| 70 | align="center" | 84 | align="center" |
| 71 | ></el-table-column> | 85 | ></el-table-column> |
| 72 | <el-table-column | 86 | <el-table-column |
| 87 | + width="110" | ||
| 73 | prop="lowestScore" | 88 | prop="lowestScore" |
| 74 | label="班最低分" | 89 | label="班最低分" |
| 75 | sortable | 90 | sortable |
| 76 | align="center" | 91 | align="center" |
| 77 | ></el-table-column> | 92 | ></el-table-column> |
| 78 | <el-table-column | 93 | <el-table-column |
| 94 | + width="110" | ||
| 79 | prop="avgScore" | 95 | prop="avgScore" |
| 80 | label="班平均分" | 96 | label="班平均分" |
| 81 | sortable | 97 | sortable |
| 82 | align="center" | 98 | align="center" |
| 83 | ></el-table-column> | 99 | ></el-table-column> |
| 84 | <el-table-column | 100 | <el-table-column |
| 85 | - prop="scoringRate" | 101 | + prop="classScoringRate" |
| 102 | + width="120" | ||
| 86 | sortable | 103 | sortable |
| 87 | label="班级得分率" | 104 | label="班级得分率" |
| 88 | align="center" | 105 | align="center" |
| 89 | ><template slot-scope="scoped" | 106 | ><template slot-scope="scoped" |
| 90 | - >{{ scoped.row.scoringRate }}%</template | 107 | + >{{ scoped.row.classScoringRate }}%</template |
| 91 | ></el-table-column | 108 | ></el-table-column |
| 92 | > | 109 | > |
| 93 | - <el-table-column | ||
| 94 | - prop="correctAnswer" | ||
| 95 | - label="答案" | ||
| 96 | - align="center" | ||
| 97 | - ></el-table-column> | 110 | + <el-table-column prop="correctAnswer" label="答案" align="center" |
| 111 | + ><template slot-scope="scoped">{{ | ||
| 112 | + scoped.row.correctAnswer == 1 | ||
| 113 | + ? "✓" | ||
| 114 | + : scoped.row.correctAnswer == 2 | ||
| 115 | + ? "✗" | ||
| 116 | + : scoped.row.correctAnswer | ||
| 117 | + }}</template> | ||
| 118 | + </el-table-column> | ||
| 98 | <el-table-column | 119 | <el-table-column |
| 99 | v-for="(item, index) in optionsList" | 120 | v-for="(item, index) in optionsList" |
| 100 | :key="index" | 121 | :key="index" |
| 101 | - :label="item.option" | ||
| 102 | - :prop="item.option" | 122 | + :label="'选项' + (index + 1)" |
| 123 | + :prop="'option' + index" | ||
| 124 | + align="center" | ||
| 103 | > | 125 | > |
| 104 | </el-table-column> | 126 | </el-table-column> |
| 105 | </el-table> | 127 | </el-table> |
| 128 | + <div class="hui-box" v-show="type == 1"> | ||
| 129 | + <span class="s-txt">汇总</span> | ||
| 130 | + <ul class="hui-ul"> | ||
| 131 | + <li class="hui-li"> | ||
| 132 | + <span class="hui-s s1">主观题</span> | ||
| 133 | + <span class="hui-s s1">{{ paperModifyLog.subjectiveScore }}</span> | ||
| 134 | + <span class="hui-s s2">{{ | ||
| 135 | + paperModifyLog.subjectiveHighestScore | ||
| 136 | + }}</span> | ||
| 137 | + <span class="hui-s s2">{{ | ||
| 138 | + paperModifyLog.subjectiveLowestScore | ||
| 139 | + }}</span> | ||
| 140 | + <span class="hui-s s2">{{ | ||
| 141 | + paperModifyLog.subjectiveAvgScore | ||
| 142 | + }}</span> | ||
| 143 | + <span class="hui-s s3" | ||
| 144 | + >{{ paperModifyLog.subjectiveClassScoringRate }}%</span | ||
| 145 | + > | ||
| 146 | + </li> | ||
| 147 | + <li class="hui-li"> | ||
| 148 | + <span class="hui-s s1">客观题</span> | ||
| 149 | + <span class="hui-s s1">{{ paperModifyLog.objectiveScore }}</span> | ||
| 150 | + <span class="hui-s s2">{{ | ||
| 151 | + paperModifyLog.objectiveHighestScore | ||
| 152 | + }}</span> | ||
| 153 | + <span class="hui-s s2">{{ | ||
| 154 | + paperModifyLog.objectiveLowestScore | ||
| 155 | + }}</span> | ||
| 156 | + <span class="hui-s s2">{{ paperModifyLog.objectiveAvgScore }}</span> | ||
| 157 | + <span class="hui-s s3" | ||
| 158 | + >{{ paperModifyLog.objectiveClassScoringRate }}%</span | ||
| 159 | + > | ||
| 160 | + </li> | ||
| 161 | + <li class="hui-li"> | ||
| 162 | + <span class="hui-s s1">整卷</span> | ||
| 163 | + <span class="hui-s s1">{{ paperModifyLog.examPaperScore }}</span> | ||
| 164 | + <span class="hui-s s2">{{ paperModifyLog.highestScore }}</span> | ||
| 165 | + <span class="hui-s s2">{{ paperModifyLog.lowestScore }}</span> | ||
| 166 | + <span class="hui-s s2">{{ paperModifyLog.avgScore }}</span> | ||
| 167 | + <span class="hui-s s3">{{ paperModifyLog.classScoringRate }}%</span> | ||
| 168 | + </li> | ||
| 169 | + </ul> | ||
| 170 | + </div> | ||
| 106 | <el-table | 171 | <el-table |
| 107 | - v-if="type == 2" | 172 | + v-show="type == 2" |
| 108 | :data="tableData2" | 173 | :data="tableData2" |
| 109 | border | 174 | border |
| 110 | style="width: 100%" | 175 | style="width: 100%" |
| @@ -123,7 +188,7 @@ | @@ -123,7 +188,7 @@ | ||
| 123 | align="center" | 188 | align="center" |
| 124 | ></el-table-column> | 189 | ></el-table-column> |
| 125 | <el-table-column | 190 | <el-table-column |
| 126 | - prop="examPaperScore" | 191 | + prop="examScore" |
| 127 | label="总分" | 192 | label="总分" |
| 128 | sortable | 193 | sortable |
| 129 | align="center" | 194 | align="center" |
| @@ -175,7 +240,7 @@ | @@ -175,7 +240,7 @@ | ||
| 175 | </el-table-column> | 240 | </el-table-column> |
| 176 | </el-table> | 241 | </el-table> |
| 177 | <el-table | 242 | <el-table |
| 178 | - v-if="type == 3" | 243 | + v-show="type == 3" |
| 179 | :data="tableData2" | 244 | :data="tableData2" |
| 180 | border | 245 | border |
| 181 | style="width: 100%" | 246 | style="width: 100%" |
| @@ -192,19 +257,19 @@ | @@ -192,19 +257,19 @@ | ||
| 192 | align="center" | 257 | align="center" |
| 193 | ></el-table-column> | 258 | ></el-table-column> |
| 194 | <el-table-column | 259 | <el-table-column |
| 195 | - prop="examPaperScore" | 260 | + prop="examScore" |
| 196 | label="总分" | 261 | label="总分" |
| 197 | sortable | 262 | sortable |
| 198 | align="center" | 263 | align="center" |
| 199 | ></el-table-column> | 264 | ></el-table-column> |
| 200 | <el-table-column label="分数组成" align="center"> | 265 | <el-table-column label="分数组成" align="center"> |
| 201 | <el-table-column | 266 | <el-table-column |
| 202 | - prop="objectiveScore" | 267 | + prop="objectiveExamScore" |
| 203 | label="客观题分" | 268 | label="客观题分" |
| 204 | align="center" | 269 | align="center" |
| 205 | ></el-table-column> | 270 | ></el-table-column> |
| 206 | <el-table-column | 271 | <el-table-column |
| 207 | - prop="subjectiveScore" | 272 | + prop="subjectiveExamScore" |
| 208 | label="主观题分" | 273 | label="主观题分" |
| 209 | align="center" | 274 | align="center" |
| 210 | ></el-table-column> | 275 | ></el-table-column> |
| @@ -219,7 +284,7 @@ | @@ -219,7 +284,7 @@ | ||
| 219 | </el-table-column> | 284 | </el-table-column> |
| 220 | </el-table> | 285 | </el-table> |
| 221 | <el-table | 286 | <el-table |
| 222 | - v-if="type == 4" | 287 | + v-show="type == 4" |
| 223 | :data="tableData2" | 288 | :data="tableData2" |
| 224 | border | 289 | border |
| 225 | style="width: 100%" | 290 | style="width: 100%" |
| @@ -291,6 +356,7 @@ | @@ -291,6 +356,7 @@ | ||
| 291 | > | 356 | > |
| 292 | <div> | 357 | <div> |
| 293 | <el-button | 358 | <el-button |
| 359 | + v-if="paperModifyLog.subjectiveScore != 0" | ||
| 294 | @click="diaUp = true" | 360 | @click="diaUp = true" |
| 295 | type="primary" | 361 | type="primary" |
| 296 | round | 362 | round |
| @@ -302,7 +368,6 @@ | @@ -302,7 +368,6 @@ | ||
| 302 | </div> | 368 | </div> |
| 303 | <div class="edit-dia" v-show="dialogVisible" height="100%"> | 369 | <div class="edit-dia" v-show="dialogVisible" height="100%"> |
| 304 | <editAnswer | 370 | <editAnswer |
| 305 | - :id="id" | ||
| 306 | :title="title" | 371 | :title="title" |
| 307 | :score="score" | 372 | :score="score" |
| 308 | @cancel="cancel" | 373 | @cancel="cancel" |
| @@ -346,6 +411,21 @@ export default { | @@ -346,6 +411,21 @@ export default { | ||
| 346 | paperModifyLog: { | 411 | paperModifyLog: { |
| 347 | realName: "", | 412 | realName: "", |
| 348 | modifiedTime: "", | 413 | modifiedTime: "", |
| 414 | + subjectiveScore: 0, | ||
| 415 | + subjectiveHighestScore: "", | ||
| 416 | + subjectiveLowestScore: "", | ||
| 417 | + subjectiveAvgScore: "", | ||
| 418 | + subjectiveClassScoringRate: "", | ||
| 419 | + objectiveScore: "", | ||
| 420 | + objectiveHighestScore: "", | ||
| 421 | + objectiveLowestScore: "", | ||
| 422 | + objectiveAvgScore: "", | ||
| 423 | + objectiveClassScoringRate: "", | ||
| 424 | + examPaperScore: "", | ||
| 425 | + highestScore: "", | ||
| 426 | + lowestScore: "", | ||
| 427 | + avgScore: "", | ||
| 428 | + classScoringRate: "", | ||
| 349 | }, | 429 | }, |
| 350 | tableData: [], | 430 | tableData: [], |
| 351 | optionsList: [], | 431 | optionsList: [], |
| @@ -382,6 +462,7 @@ export default { | @@ -382,6 +462,7 @@ export default { | ||
| 382 | return tit; | 462 | return tit; |
| 383 | }, | 463 | }, |
| 384 | edit() { | 464 | edit() { |
| 465 | + this.$refs.editAnswer.edit(this.id); | ||
| 385 | this.dialogVisible = true; | 466 | this.dialogVisible = true; |
| 386 | }, | 467 | }, |
| 387 | cancel() { | 468 | cancel() { |
| @@ -421,8 +502,8 @@ export default { | @@ -421,8 +502,8 @@ export default { | ||
| 421 | }); | 502 | }); |
| 422 | this.loading = false; | 503 | this.loading = false; |
| 423 | if (status === 0) { | 504 | if (status === 0) { |
| 424 | - if (data.paperModifyLog) { | ||
| 425 | - this.paperModifyLog = { ...data.paperModifyLog }; | 505 | + if (data.examReport) { |
| 506 | + this.paperModifyLog = { ...data.examReport }; | ||
| 426 | } | 507 | } |
| 427 | } else { | 508 | } else { |
| 428 | this.$message.error(info); | 509 | this.$message.error(info); |
| @@ -437,9 +518,9 @@ export default { | @@ -437,9 +518,9 @@ export default { | ||
| 437 | this.loading = false; | 518 | this.loading = false; |
| 438 | if (status === 0) { | 519 | if (status === 0) { |
| 439 | this.$message.success(info); | 520 | this.$message.success(info); |
| 440 | - this._QueryData() | ||
| 441 | - this.paperModifyLog.modifiedTime="" | ||
| 442 | - this.paperModifyLog.realName="" | 521 | + this._QueryData(); |
| 522 | + this.paperModifyLog.modifiedTime = ""; | ||
| 523 | + this.paperModifyLog.realName = ""; | ||
| 443 | } else { | 524 | } else { |
| 444 | this.$message.error(info); | 525 | this.$message.error(info); |
| 445 | } | 526 | } |
| @@ -463,8 +544,9 @@ export default { | @@ -463,8 +544,9 @@ export default { | ||
| 463 | console.log(detail); | 544 | console.log(detail); |
| 464 | detail.map((items, index) => { | 545 | detail.map((items, index) => { |
| 465 | params["que" + items.id] = items.id; | 546 | params["que" + items.id] = items.id; |
| 466 | - params["score" + items.id] = items.score; | ||
| 467 | - params["answer" + items.id] = items.answer; | 547 | + params["score" + items.id] = Number(items.score).toFixed(2); |
| 548 | + params["answer" + items.id] = | ||
| 549 | + items.answer == 1 ? "✓" : items.answer == 2 ? "✗" : items.answer; | ||
| 468 | params["isRight" + items.id] = items.isRight; | 550 | params["isRight" + items.id] = items.isRight; |
| 469 | params["questionType" + items.id] = items.questionType; | 551 | params["questionType" + items.id] = items.questionType; |
| 470 | }); | 552 | }); |
| @@ -498,7 +580,8 @@ export default { | @@ -498,7 +580,8 @@ export default { | ||
| 498 | } | 580 | } |
| 499 | console.log(detail); | 581 | console.log(detail); |
| 500 | detail.map((items, index) => { | 582 | detail.map((items, index) => { |
| 501 | - params[items.option] = items.count; | 583 | + params["option" + index] = |
| 584 | + items.option == 1 ? "✓" : items.option == 2 ? "✗" : items.option; | ||
| 502 | }); | 585 | }); |
| 503 | return { | 586 | return { |
| 504 | ...item, | 587 | ...item, |
| @@ -603,4 +686,38 @@ export default { | @@ -603,4 +686,38 @@ export default { | ||
| 603 | display: flex; | 686 | display: flex; |
| 604 | justify-content: space-between; | 687 | justify-content: space-between; |
| 605 | } | 688 | } |
| 689 | +.hui-box { | ||
| 690 | + display: flex; | ||
| 691 | + text-align: center; | ||
| 692 | + .s-txt { | ||
| 693 | + width: 61px; | ||
| 694 | + line-height: 144px; | ||
| 695 | + background: #e2e2e2; | ||
| 696 | + font-size: 16px; | ||
| 697 | + color: #fff; | ||
| 698 | + font-weight: 700; | ||
| 699 | + } | ||
| 700 | + .hui-ul { | ||
| 701 | + border-top: 1px solid #e2e2e2; | ||
| 702 | + } | ||
| 703 | + .hui-li { | ||
| 704 | + display: flex; | ||
| 705 | + .hui-s { | ||
| 706 | + height: 48px; | ||
| 707 | + line-height: 48px; | ||
| 708 | + border-right: 1px solid #e2e2e2; | ||
| 709 | + border-bottom: 1px solid #e2e2e2; | ||
| 710 | + box-sizing: border-box; | ||
| 711 | + } | ||
| 712 | + .s1 { | ||
| 713 | + width: 100px; | ||
| 714 | + } | ||
| 715 | + .s2 { | ||
| 716 | + width: 110px; | ||
| 717 | + } | ||
| 718 | + .s3 { | ||
| 719 | + width: 120px; | ||
| 720 | + } | ||
| 721 | + } | ||
| 722 | +} | ||
| 606 | </style> | 723 | </style> |
| 607 | \ No newline at end of file | 724 | \ No newline at end of file |
src/views/test/editAnswer.vue
| @@ -299,14 +299,14 @@ export default { | @@ -299,14 +299,14 @@ export default { | ||
| 299 | score: "", | 299 | score: "", |
| 300 | }, | 300 | }, |
| 301 | watch: { | 301 | watch: { |
| 302 | - id: { | ||
| 303 | - handler: function (val) { | ||
| 304 | - if (val) { | ||
| 305 | - this.edit(); | ||
| 306 | - } | ||
| 307 | - }, | ||
| 308 | - immediate: true, | ||
| 309 | - }, | 302 | + // id: { |
| 303 | + // handler: function (val) { | ||
| 304 | + // if (val) { | ||
| 305 | + // this.edit(); | ||
| 306 | + // } | ||
| 307 | + // }, | ||
| 308 | + // immediate: true, | ||
| 309 | + // }, | ||
| 310 | }, | 310 | }, |
| 311 | data() { | 311 | data() { |
| 312 | return { | 312 | return { |
| @@ -486,10 +486,10 @@ export default { | @@ -486,10 +486,10 @@ export default { | ||
| 486 | } | 486 | } |
| 487 | this.diaSetAns = false; | 487 | this.diaSetAns = false; |
| 488 | }, | 488 | }, |
| 489 | - async edit() { | 489 | + async edit(id) { |
| 490 | //修改答案 | 490 | //修改答案 |
| 491 | const { data, status, info } = await this.$request.examQuestionList({ | 491 | const { data, status, info } = await this.$request.examQuestionList({ |
| 492 | - examId: this.id, | 492 | + examId: id, |
| 493 | }); | 493 | }); |
| 494 | if (status == 0) { | 494 | if (status == 0) { |
| 495 | this.questionList = deepClone(data?.list || []); | 495 | this.questionList = deepClone(data?.list || []); |
src/views/test/index.vue
| @@ -11,7 +11,6 @@ | @@ -11,7 +11,6 @@ | ||
| 11 | class="sel" | 11 | class="sel" |
| 12 | v-model="query.classId" | 12 | v-model="query.classId" |
| 13 | placeholder="选择班级" | 13 | placeholder="选择班级" |
| 14 | - @change="changClazz" | ||
| 15 | > | 14 | > |
| 16 | <el-option | 15 | <el-option |
| 17 | v-for="item in classList" | 16 | v-for="item in classList" |
| @@ -27,7 +26,6 @@ | @@ -27,7 +26,6 @@ | ||
| 27 | multiple | 26 | multiple |
| 28 | v-model="query.subjectNames" | 27 | v-model="query.subjectNames" |
| 29 | placeholder="选择科目" | 28 | placeholder="选择科目" |
| 30 | - @change="_QueryData" | ||
| 31 | > | 29 | > |
| 32 | <el-option | 30 | <el-option |
| 33 | v-for="item in subjectList" | 31 | v-for="item in subjectList" |
| @@ -42,7 +40,6 @@ | @@ -42,7 +40,6 @@ | ||
| 42 | class="sel" | 40 | class="sel" |
| 43 | v-model="query.subjectNames" | 41 | v-model="query.subjectNames" |
| 44 | placeholder="选择科目" | 42 | placeholder="选择科目" |
| 45 | - @change="_QueryData" | ||
| 46 | > | 43 | > |
| 47 | <el-option | 44 | <el-option |
| 48 | v-for="item in subjectList" | 45 | v-for="item in subjectList" |
| @@ -97,7 +94,7 @@ | @@ -97,7 +94,7 @@ | ||
| 97 | <el-radio-button :label="1">单卷测练报表</el-radio-button> | 94 | <el-radio-button :label="1">单卷测练报表</el-radio-button> |
| 98 | <el-radio-button :label="2">阶段测练报表</el-radio-button> | 95 | <el-radio-button :label="2">阶段测练报表</el-radio-button> |
| 99 | </el-radio-group> | 96 | </el-radio-group> |
| 100 | - <div v-if="tabIndex == 1" v-loading="loading"> | 97 | + <div v-show="tabIndex == 1" v-loading="loading"> |
| 101 | <el-table :data="tableData" border style="width: 100%"> | 98 | <el-table :data="tableData" border style="width: 100%"> |
| 102 | <el-table-column | 99 | <el-table-column |
| 103 | prop="title" | 100 | prop="title" |
| @@ -110,39 +107,51 @@ | @@ -110,39 +107,51 @@ | ||
| 110 | align="center" | 107 | align="center" |
| 111 | width="100" | 108 | width="100" |
| 112 | ></el-table-column> | 109 | ></el-table-column> |
| 113 | - <el-table-column | ||
| 114 | - prop="answeredNum" | ||
| 115 | - label="测验人数" | ||
| 116 | - align="center" | ||
| 117 | - ></el-table-column> | 110 | + <el-table-column prop="answeredNum" label="测验人数" align="center" |
| 111 | + ><template slot-scope="scoped">{{ | ||
| 112 | + `${scoped.row.answeredNum}/${scoped.row.classPersonNum}` | ||
| 113 | + }}</template></el-table-column | ||
| 114 | + > | ||
| 118 | <el-table-column | 115 | <el-table-column |
| 119 | prop="examStartTime" | 116 | prop="examStartTime" |
| 120 | label="测验时间" | 117 | label="测验时间" |
| 121 | align="center" | 118 | align="center" |
| 122 | ></el-table-column> | 119 | ></el-table-column> |
| 123 | - <el-table-column | ||
| 124 | - prop="avgScore" | ||
| 125 | - label="班平均分" | ||
| 126 | - align="center" | ||
| 127 | - ></el-table-column> | ||
| 128 | - <el-table-column | ||
| 129 | - prop="highestScore" | ||
| 130 | - label="班最高分" | ||
| 131 | - align="center" | ||
| 132 | - ></el-table-column> | ||
| 133 | - <el-table-column | ||
| 134 | - prop="lowestScore" | ||
| 135 | - label="班最低分" | ||
| 136 | - align="center" | ||
| 137 | - ></el-table-column> | 120 | + <el-table-column prop="avgScore" label="班平均分" align="center" |
| 121 | + ><template slot-scope="scoped">{{ | ||
| 122 | + scoped.row.subjectiveScore == scoped.row.examPaperScore || | ||
| 123 | + scoped.row.answerNum == 0 | ||
| 124 | + ? scoped.row.avgScore || "-" | ||
| 125 | + : scoped.row.avgScore | ||
| 126 | + }}</template></el-table-column | ||
| 127 | + > | ||
| 128 | + <el-table-column prop="highestScore" label="班最高分" align="center" | ||
| 129 | + ><template slot-scope="scoped">{{ | ||
| 130 | + scoped.row.subjectiveScore == scoped.row.examPaperScore || | ||
| 131 | + scoped.row.answerNum == 0 | ||
| 132 | + ? scoped.row.highestScore || "-" | ||
| 133 | + : scoped.row.highestScore | ||
| 134 | + }}</template></el-table-column | ||
| 135 | + > | ||
| 136 | + <el-table-column prop="lowestScore" label="班最低分" align="center" | ||
| 137 | + ><template slot-scope="scoped">{{ | ||
| 138 | + scoped.row.subjectiveScore == scoped.row.examPaperScore || | ||
| 139 | + scoped.row.answerNum == 0 | ||
| 140 | + ? scoped.row.lowestScore || "-" | ||
| 141 | + : scoped.row.lowestScore | ||
| 142 | + }}</template></el-table-column | ||
| 143 | + > | ||
| 138 | <el-table-column | 144 | <el-table-column |
| 139 | prop="excellenRate" | 145 | prop="excellenRate" |
| 140 | label="优秀数(率)" | 146 | label="优秀数(率)" |
| 141 | sortable | 147 | sortable |
| 142 | align="center" | 148 | align="center" |
| 143 | - ><template slot-scope="scoped" | ||
| 144 | - >{{ scoped.row.excellenRate }}%</template | ||
| 145 | - ></el-table-column | 149 | + ><template slot-scope="scoped">{{ |
| 150 | + scoped.row.subjectiveScore == scoped.row.examPaperScore || | ||
| 151 | + scoped.row.answerNum == 0 | ||
| 152 | + ? scoped.row.excellenNum || "-" | ||
| 153 | + : `${scoped.row.excellenNum}/${scoped.row.excellenRate}%` | ||
| 154 | + }}</template></el-table-column | ||
| 146 | > | 155 | > |
| 147 | <el-table-column | 156 | <el-table-column |
| 148 | prop="goodRate" | 157 | prop="goodRate" |
| @@ -150,8 +159,13 @@ | @@ -150,8 +159,13 @@ | ||
| 150 | sortable | 159 | sortable |
| 151 | align="center" | 160 | align="center" |
| 152 | ><template slot-scope="scoped" | 161 | ><template slot-scope="scoped" |
| 153 | - >{{ scoped.row.goodRate }}%</template | ||
| 154 | - ></el-table-column | 162 | + >{{ |
| 163 | + scoped.row.subjectiveScore == scoped.row.examPaperScore || | ||
| 164 | + scoped.row.answerNum == 0 | ||
| 165 | + ? scoped.row.goodNum || "-" | ||
| 166 | + : `${scoped.row.goodNum}/${scoped.row.goodRate}%` | ||
| 167 | + }} | ||
| 168 | + </template></el-table-column | ||
| 155 | > | 169 | > |
| 156 | <el-table-column | 170 | <el-table-column |
| 157 | prop="passRate" | 171 | prop="passRate" |
| @@ -159,21 +173,34 @@ | @@ -159,21 +173,34 @@ | ||
| 159 | sortable | 173 | sortable |
| 160 | align="center" | 174 | align="center" |
| 161 | ><template slot-scope="scoped" | 175 | ><template slot-scope="scoped" |
| 162 | - >{{ scoped.row.passRate }}%</template | ||
| 163 | - ></el-table-column | 176 | + >{{ |
| 177 | + scoped.row.subjectiveScore == scoped.row.examPaperScore || | ||
| 178 | + scoped.row.answerNum == 0 | ||
| 179 | + ? scoped.row.passNum || "-" | ||
| 180 | + : `${scoped.row.passNum}/${scoped.row.passRate}%` | ||
| 181 | + }} | ||
| 182 | + </template></el-table-column | ||
| 164 | > | 183 | > |
| 165 | <el-table-column | 184 | <el-table-column |
| 166 | prop="failedRate" | 185 | prop="failedRate" |
| 167 | label="不及格数(率)" | 186 | label="不及格数(率)" |
| 168 | sortable | 187 | sortable |
| 169 | align="center" | 188 | align="center" |
| 170 | - ><template slot-scope="scoped" | ||
| 171 | - >{{ scoped.row.failedRate }}%</template | ||
| 172 | - ></el-table-column | 189 | + ><template slot-scope="scoped">{{ |
| 190 | + scoped.row.subjectiveScore == scoped.row.examPaperScore || | ||
| 191 | + scoped.row.answerNum == 0 | ||
| 192 | + ? scoped.row.failedNum || "-" | ||
| 193 | + : `${scoped.row.failedNum}/${scoped.row.failedRate}%` | ||
| 194 | + }}</template></el-table-column | ||
| 173 | > | 195 | > |
| 174 | <el-table-column label="操作" align="center"> | 196 | <el-table-column label="操作" align="center"> |
| 175 | <template slot-scope="scoped"> | 197 | <template slot-scope="scoped"> |
| 176 | - <el-tooltip effect="dark" content="详情" placement="top"> | 198 | + <el-tooltip |
| 199 | + v-if="scoped.row.answerNum != 0" | ||
| 200 | + effect="dark" | ||
| 201 | + content="详情" | ||
| 202 | + placement="top" | ||
| 203 | + > | ||
| 177 | <el-button | 204 | <el-button |
| 178 | type="primary" | 205 | type="primary" |
| 179 | circle | 206 | circle |
| @@ -182,7 +209,12 @@ | @@ -182,7 +209,12 @@ | ||
| 182 | @click="linkTo(scoped.row)" | 209 | @click="linkTo(scoped.row)" |
| 183 | ></el-button> | 210 | ></el-button> |
| 184 | </el-tooltip> | 211 | </el-tooltip> |
| 185 | - <el-tooltip effect="dark" content="修改答案" placement="top"> | 212 | + <el-tooltip |
| 213 | + v-else | ||
| 214 | + effect="dark" | ||
| 215 | + content="修改答案" | ||
| 216 | + placement="top" | ||
| 217 | + > | ||
| 186 | <el-button | 218 | <el-button |
| 187 | type="primary" | 219 | type="primary" |
| 188 | circle | 220 | circle |
| @@ -191,6 +223,20 @@ | @@ -191,6 +223,20 @@ | ||
| 191 | @click="edit(scoped.row)" | 223 | @click="edit(scoped.row)" |
| 192 | ></el-button> | 224 | ></el-button> |
| 193 | </el-tooltip> | 225 | </el-tooltip> |
| 226 | + <el-tooltip | ||
| 227 | + v-if="scoped.row.subjectiveScore == scoped.row.examPaperScore" | ||
| 228 | + effect="dark" | ||
| 229 | + content="导入主观题" | ||
| 230 | + placement="top" | ||
| 231 | + > | ||
| 232 | + <el-button | ||
| 233 | + type="primary" | ||
| 234 | + circle | ||
| 235 | + size="mini" | ||
| 236 | + icon="fa fa-cloud" | ||
| 237 | + @click="uploadSJ(scoped.row)" | ||
| 238 | + ></el-button> | ||
| 239 | + </el-tooltip> | ||
| 194 | </template> | 240 | </template> |
| 195 | </el-table-column> | 241 | </el-table-column> |
| 196 | </el-table> | 242 | </el-table> |
| @@ -207,8 +253,13 @@ | @@ -207,8 +253,13 @@ | ||
| 207 | </el-pagination> | 253 | </el-pagination> |
| 208 | </div> | 254 | </div> |
| 209 | </div> | 255 | </div> |
| 210 | - <div v-if="tabIndex == 2" v-loading="loading"> | ||
| 211 | - <el-table :data="tableData" border style="width: 100%"> | 256 | + <div v-show="tabIndex == 2" v-loading="loading"> |
| 257 | + <el-table | ||
| 258 | + v-if="role == 'ROLE_JIAOSHI'" | ||
| 259 | + :data="tableData" | ||
| 260 | + border | ||
| 261 | + style="width: 100%" | ||
| 262 | + > | ||
| 212 | <el-table-column | 263 | <el-table-column |
| 213 | prop="studentCode" | 264 | prop="studentCode" |
| 214 | label="学号" | 265 | label="学号" |
| @@ -229,7 +280,7 @@ | @@ -229,7 +280,7 @@ | ||
| 229 | > | 280 | > |
| 230 | <el-table-column | 281 | <el-table-column |
| 231 | :prop="'score' + index" | 282 | :prop="'score' + index" |
| 232 | - label="总分/成绩" | 283 | + :label="index == 0 ? '总分' : '成绩'" |
| 233 | align="center" | 284 | align="center" |
| 234 | ></el-table-column> | 285 | ></el-table-column> |
| 235 | <el-table-column | 286 | <el-table-column |
| @@ -239,6 +290,47 @@ | @@ -239,6 +290,47 @@ | ||
| 239 | ></el-table-column> | 290 | ></el-table-column> |
| 240 | </el-table-column> | 291 | </el-table-column> |
| 241 | </el-table> | 292 | </el-table> |
| 293 | + <el-table v-else :data="tableData" border style="width: 100%"> | ||
| 294 | + <el-table-column | ||
| 295 | + prop="studentCode" | ||
| 296 | + label="学号" | ||
| 297 | + align="center" | ||
| 298 | + fixed | ||
| 299 | + ></el-table-column> | ||
| 300 | + <el-table-column | ||
| 301 | + prop="studentName" | ||
| 302 | + label="姓名" | ||
| 303 | + fixed | ||
| 304 | + align="center" | ||
| 305 | + ></el-table-column> | ||
| 306 | + <el-table-column | ||
| 307 | + align="center" | ||
| 308 | + v-for="(item, index) in answerList" | ||
| 309 | + :key="index" | ||
| 310 | + :label="item" | ||
| 311 | + > | ||
| 312 | + <el-table-column | ||
| 313 | + :prop="'examCount' + item" | ||
| 314 | + label="测练数" | ||
| 315 | + align="center" | ||
| 316 | + ></el-table-column> | ||
| 317 | + <el-table-column | ||
| 318 | + :prop="'participationCount' + item" | ||
| 319 | + label="参与数" | ||
| 320 | + align="center" | ||
| 321 | + ></el-table-column> | ||
| 322 | + <el-table-column | ||
| 323 | + :prop="'score' + item" | ||
| 324 | + label="总分" | ||
| 325 | + align="center" | ||
| 326 | + ></el-table-column> | ||
| 327 | + <el-table-column | ||
| 328 | + :prop="'classRank' + item" | ||
| 329 | + label="班名" | ||
| 330 | + align="center" | ||
| 331 | + ></el-table-column> | ||
| 332 | + </el-table-column> | ||
| 333 | + </el-table> | ||
| 242 | </div> | 334 | </div> |
| 243 | <p class="down" v-if="tabIndex == 2"> | 335 | <p class="down" v-if="tabIndex == 2"> |
| 244 | <el-button type="info" plain round icon="fa fa-cloud-download" | 336 | <el-button type="info" plain round icon="fa fa-cloud-download" |
| @@ -246,9 +338,23 @@ | @@ -246,9 +338,23 @@ | ||
| 246 | > | 338 | > |
| 247 | </p> | 339 | </p> |
| 248 | </div> | 340 | </div> |
| 341 | + <el-dialog title="导入主观题分数" :visible.sync="diaUp" width="600"> | ||
| 342 | + <up-load :url="url" :examId="examId" fileName="教师名单"> | ||
| 343 | + <template slot="down"> | ||
| 344 | + <p class="down-txt"> | ||
| 345 | + 第一步:下载模板并编辑完成学生分数 | ||
| 346 | + <el-link type="danger" @click="downExcel">模板下载</el-link> 。 | ||
| 347 | + </p> | ||
| 348 | + <p class="down-txt">第二步:上传完成编辑的模板文件并导入。</p> | ||
| 349 | + </template> | ||
| 350 | + </up-load> | ||
| 351 | + <div class="dialog-footer" slot="footer"> | ||
| 352 | + <el-button @click="diaUp = false">取 消</el-button> | ||
| 353 | + </div> | ||
| 354 | + </el-dialog> | ||
| 249 | <div class="edit-dia" v-show="dialogVisible" height="100%"> | 355 | <div class="edit-dia" v-show="dialogVisible" height="100%"> |
| 250 | <editAnswer | 356 | <editAnswer |
| 251 | - :id="form.id" | 357 | + ref="editAnswer" |
| 252 | :title="form.title" | 358 | :title="form.title" |
| 253 | :score="form.examPaperScore" | 359 | :score="form.examPaperScore" |
| 254 | @cancel="cancel" | 360 | @cancel="cancel" |
| @@ -259,7 +365,7 @@ | @@ -259,7 +365,7 @@ | ||
| 259 | </template> | 365 | </template> |
| 260 | 366 | ||
| 261 | <script> | 367 | <script> |
| 262 | -import { formatDate } from "utils"; | 368 | +import { formatDate, downloadFile } from "utils"; |
| 263 | import editAnswer from "./editAnswer.vue"; | 369 | import editAnswer from "./editAnswer.vue"; |
| 264 | export default { | 370 | export default { |
| 265 | components: { editAnswer }, | 371 | components: { editAnswer }, |
| @@ -267,6 +373,9 @@ export default { | @@ -267,6 +373,9 @@ export default { | ||
| 267 | return { | 373 | return { |
| 268 | role: "", | 374 | role: "", |
| 269 | loading: false, | 375 | loading: false, |
| 376 | + diaUp: false, | ||
| 377 | + url: "/api_html/teaching/importSubjectiveScore", | ||
| 378 | + examId: "", | ||
| 270 | dialogVisible: false, | 379 | dialogVisible: false, |
| 271 | form: { | 380 | form: { |
| 272 | id: "", | 381 | id: "", |
| @@ -317,6 +426,10 @@ export default { | @@ -317,6 +426,10 @@ export default { | ||
| 317 | }, | 426 | }, |
| 318 | }); | 427 | }); |
| 319 | }, | 428 | }, |
| 429 | + uploadSJ(obj) { | ||
| 430 | + this.examId = obj.id; | ||
| 431 | + this.diaUp = true; | ||
| 432 | + }, | ||
| 320 | cancel() { | 433 | cancel() { |
| 321 | this.dialogVisible = false; | 434 | this.dialogVisible = false; |
| 322 | }, | 435 | }, |
| @@ -344,6 +457,7 @@ export default { | @@ -344,6 +457,7 @@ export default { | ||
| 344 | //中国式星期天是一周的最后一天 | 457 | //中国式星期天是一周的最后一天 |
| 345 | day = 7; | 458 | day = 7; |
| 346 | } | 459 | } |
| 460 | + day--; | ||
| 347 | let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day; | 461 | let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day; |
| 348 | that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd"); | 462 | that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd"); |
| 349 | that.query.endDay = formatDate(new Date(), "yyyy-MM-dd"); | 463 | that.query.endDay = formatDate(new Date(), "yyyy-MM-dd"); |
| @@ -398,12 +512,26 @@ export default { | @@ -398,12 +512,26 @@ export default { | ||
| 398 | }, | 512 | }, |
| 399 | edit(item) { | 513 | edit(item) { |
| 400 | this.form = { ...item }; | 514 | this.form = { ...item }; |
| 515 | + this.$refs.editAnswer.edit(this.form.id); | ||
| 401 | this.dialogVisible = true; | 516 | this.dialogVisible = true; |
| 402 | }, | 517 | }, |
| 403 | changeTab() { | 518 | changeTab() { |
| 404 | this.page = 1; | 519 | this.page = 1; |
| 405 | this._QueryData(); | 520 | this._QueryData(); |
| 406 | }, | 521 | }, |
| 522 | + async downExcel() { | ||
| 523 | + let data = await this.$request.subjectiveScoreTemplate({ | ||
| 524 | + examId: this.id, | ||
| 525 | + }); | ||
| 526 | + if (data && !data.code) { | ||
| 527 | + let blob = new Blob([data], { | ||
| 528 | + type: "application/vnd.ms-excel;charset=utf-8", | ||
| 529 | + }); | ||
| 530 | + downloadFile(`主观题模版.xlsx`, blob); | ||
| 531 | + } else { | ||
| 532 | + this.$message.error(data.message); | ||
| 533 | + } | ||
| 534 | + }, | ||
| 407 | async changClazz() { | 535 | async changClazz() { |
| 408 | this.page = 1; | 536 | this.page = 1; |
| 409 | await this._QuerySubjectList(); | 537 | await this._QuerySubjectList(); |
| @@ -478,6 +606,7 @@ export default { | @@ -478,6 +606,7 @@ export default { | ||
| 478 | query.subjectNames = [query.subjectNames]; | 606 | query.subjectNames = [query.subjectNames]; |
| 479 | } else { | 607 | } else { |
| 480 | if ( | 608 | if ( |
| 609 | + query["subjectNames"] && | ||
| 481 | query["subjectNames"].length == 1 && | 610 | query["subjectNames"].length == 1 && |
| 482 | query["subjectNames"][0] == "全部" | 611 | query["subjectNames"][0] == "全部" |
| 483 | ) { | 612 | ) { |
| @@ -485,6 +614,9 @@ export default { | @@ -485,6 +614,9 @@ export default { | ||
| 485 | return item.value; | 614 | return item.value; |
| 486 | }); | 615 | }); |
| 487 | query["subjectNames"].shift(); | 616 | query["subjectNames"].shift(); |
| 617 | + }else{ | ||
| 618 | + this.loading = false; | ||
| 619 | + return | ||
| 488 | } | 620 | } |
| 489 | } | 621 | } |
| 490 | const { data, status, info } = await this.$request.examReportList({ | 622 | const { data, status, info } = await this.$request.examReportList({ |
| @@ -515,13 +647,14 @@ export default { | @@ -515,13 +647,14 @@ export default { | ||
| 515 | } | 647 | } |
| 516 | if (this.role == "ROLE_BANZHUREN") { | 648 | if (this.role == "ROLE_BANZHUREN") { |
| 517 | if ( | 649 | if ( |
| 518 | - query["subjectNames"].length == 1 && | 650 | + query["subjectNames"] && |
| 651 | + query["subjectNames"]?.length == 1 && | ||
| 519 | query["subjectNames"][0] == "全部" | 652 | query["subjectNames"][0] == "全部" |
| 520 | ) { | 653 | ) { |
| 521 | query["subjectNames"] = this.subjectList.map((item) => { | 654 | query["subjectNames"] = this.subjectList.map((item) => { |
| 522 | return item.value; | 655 | return item.value; |
| 523 | }); | 656 | }); |
| 524 | - query["subjectNames"].shift(); | 657 | + query["subjectNames"]?.shift(); |
| 525 | } | 658 | } |
| 526 | } | 659 | } |
| 527 | const phaseExamReport = | 660 | const phaseExamReport = |
| @@ -534,47 +667,57 @@ export default { | @@ -534,47 +667,57 @@ export default { | ||
| 534 | this.loading = false; | 667 | this.loading = false; |
| 535 | if (status === 0) { | 668 | if (status === 0) { |
| 536 | this.total = data.count; | 669 | this.total = data.count; |
| 537 | - let dataIdsList = [], | ||
| 538 | - dataList = []; | ||
| 539 | - data?.list.map((item) => { | ||
| 540 | - item.examList.map((items) => { | ||
| 541 | - if (this.role == "ROLE_JITUAN") { | ||
| 542 | - // if (!dataIdsList.includes(items.grade)) { | ||
| 543 | - // dataIdsList.push(items.grade); | ||
| 544 | - // dataList.push(items); | ||
| 545 | - // } | ||
| 546 | - } else { | 670 | + if (this.role == "ROLE_BANZHUREN") { |
| 671 | + let subjectName = []; | ||
| 672 | + this.tableData = data?.list.map((item) => { | ||
| 673 | + let params = {}; | ||
| 674 | + item.dataList.map((items, index) => { | ||
| 675 | + if (!subjectName.includes(items.subjectName)) { | ||
| 676 | + subjectName.push(items.subjectName); | ||
| 677 | + } | ||
| 678 | + params["examCount" + items.subjectName] = items.examCount; | ||
| 679 | + params["participationCount" + items.subjectName] = | ||
| 680 | + items.participationCount; | ||
| 681 | + params["score" + items.subjectName] = items.score; | ||
| 682 | + params["classRank" + items.subjectName] = items.classRank; | ||
| 683 | + }); | ||
| 684 | + return { | ||
| 685 | + ...item, | ||
| 686 | + ...params, | ||
| 687 | + }; | ||
| 688 | + }); | ||
| 689 | + this.answerList = [...subjectName]; | ||
| 690 | + } else { | ||
| 691 | + let dataIdsList = [], | ||
| 692 | + dataList = []; | ||
| 693 | + data?.list.map((item) => { | ||
| 694 | + item.examList.map((items) => { | ||
| 547 | if (!dataIdsList.includes(items.title)) { | 695 | if (!dataIdsList.includes(items.title)) { |
| 548 | dataIdsList.push(items.title); | 696 | dataIdsList.push(items.title); |
| 549 | dataList.push(items); | 697 | dataList.push(items); |
| 550 | } | 698 | } |
| 551 | - } | 699 | + }); |
| 552 | }); | 700 | }); |
| 553 | - }); | ||
| 554 | - console.log(dataList); | ||
| 555 | - this.tableData = data?.list.map((item) => { | ||
| 556 | - let params = {}; | ||
| 557 | - dataIdsList.map((ids, index) => { | ||
| 558 | - params["score" + index] = "--"; | ||
| 559 | - params["classRank" + index] = "--"; | ||
| 560 | - item.examList.map((items) => { | ||
| 561 | - if (this.role == "ROLE_JITUAN") { | ||
| 562 | - if (items.title == ids) { | ||
| 563 | - } | ||
| 564 | - } else { | 701 | + console.log(dataList); |
| 702 | + this.tableData = data?.list.map((item) => { | ||
| 703 | + let params = {}; | ||
| 704 | + dataIdsList.map((ids, index) => { | ||
| 705 | + params["score" + index] = "--"; | ||
| 706 | + params["classRank" + index] = "--"; | ||
| 707 | + item.examList.map((items) => { | ||
| 565 | if (items.title == ids) { | 708 | if (items.title == ids) { |
| 566 | params["score" + index] = items.score; | 709 | params["score" + index] = items.score; |
| 567 | params["classRank" + index] = items.classRank; | 710 | params["classRank" + index] = items.classRank; |
| 568 | } | 711 | } |
| 569 | - } | 712 | + }); |
| 570 | }); | 713 | }); |
| 714 | + return { | ||
| 715 | + ...item, | ||
| 716 | + ...params, | ||
| 717 | + }; | ||
| 571 | }); | 718 | }); |
| 572 | - return { | ||
| 573 | - ...item, | ||
| 574 | - ...params, | ||
| 575 | - }; | ||
| 576 | - }); | ||
| 577 | - this.answerList = dataList; | 719 | + this.answerList = dataList; |
| 720 | + } | ||
| 578 | } else { | 721 | } else { |
| 579 | this.$message.error(info); | 722 | this.$message.error(info); |
| 580 | } | 723 | } |