From 3bfbac1400ab8c9735e175a2aaf7dc962dd9428f Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期四, 20 六月 2024 16:47:21 +0800
Subject: [PATCH] 阅卷

---
 src/views/exam/exam/MarkPaperDetail.vue |  312 +++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 287 insertions(+), 25 deletions(-)

diff --git a/src/views/exam/exam/MarkPaperDetail.vue b/src/views/exam/exam/MarkPaperDetail.vue
index da51e38..283198e 100644
--- a/src/views/exam/exam/MarkPaperDetail.vue
+++ b/src/views/exam/exam/MarkPaperDetail.vue
@@ -1,61 +1,323 @@
 <template>
   <div>
-    <el-row style="text-align: center;margin-top: 20px;margin-bottom: 20px; font-size: 28px">xxx鑰冭瘯</el-row>
+    <el-row style="text-align: center;margin-top: 20px;margin-bottom: 20px; font-size: 28px">璇枃鑰冭瘯</el-row>
     <el-row :gutter="20">
       <el-col :span="8" class="info">
         <span class="exam-info">瀛﹀憳濮撳悕锛�</span>
-        <span class="exam-info">{{userName}}</span>
+        <span class="exam-info">{{ userName }}</span>
       </el-col>
       <el-col :span="8" class="info">
         <span class="exam-info">浜ゅ嵎鏃堕棿锛�</span>
-        <span class="exam-info">{{examInfo.updateTime}}</span>
+        <span class="exam-info">{{ examInfo.updateTime }}</span>
       </el-col>
       <el-col :span="8" class="info">
         <span class="exam-info">瀹屾垚鑰楁椂锛�</span>
-        <span class="exam-info">{{examInfo.doTime}}</span>
+        <span class="exam-info">{{ examInfo.doTime }}</span>
       </el-col>
     </el-row>
-    <el-row class="paper-warp">
-      <div v-for="(paper,index) in examInfo.paperQuestionList" :key="index" class="paperTitleWarp">
-        <div class="paperTitle">{{ paper.title }}</div>
-        <div class="question-warp">
-          <div v-for="(doQuestion, index) in paper.questionList" :key="index">
-            <DoQuestion :question="doQuestion" :qType="paper.questionType" :qLoading="questionLoading"></DoQuestion>
-          </div>
-        </div>
-      </div>
-    </el-row>
+    <el-main>
+      <el-form :model="form" ref="form" v-loading="formLoading" label-width="100px">
+        <el-row :key="index" v-for="(titleItem, index) in form.titleItems">
+          <h3>{{ titleItem.name }}</h3>
+          <el-card class="exampaper-item-box" v-if="titleItem.questionItems.length !== 0">
+            <el-form-item :key="questionItem.itemOrder" :label="questionItem.itemOrder + '.'"
+                          v-for="questionItem in titleItem.questionItems" class="exam-question-item"
+                          label-width="50px" :id="'question-' + questionItem.itemOrder">
+              <QuestionAnswerShow :qType="questionItem.questionType" :question="questionItem"
+                                  :answer="answer.answerItems[questionItem.itemOrder - 1]"/>
+            </el-form-item>
+          </el-card>
+        </el-row>
+      </el-form>
+    </el-main>
   </div>
 </template>
 
 <script>
-import DoQuestion from '@/components/question/DoQuestion'
 import { getStudentExam } from '@/api/exam'
+import QuestionAnswerShow from '@/views/answer/components/QuestionAnswerShow'
+import examPaperAnswerApi from '@/api/examPaperAnswer'
 
 export default {
   name: 'MarkPaperDetail',
-  components: { DoQuestion },
+  components: { QuestionAnswerShow },
   mounted () {
     this.examInfo.examId = this.$route.query.examId
     this.examInfo.examName = this.$route.query.examName
     this.userId = this.$route.query.userId
-    if (this.examInfo.examId && this.userId) {
-      this.getStudentPaper()
-    }
+    examPaperAnswerApi.read(1).then(re => {
+      re = {
+        'code': 1, 'message': '鎴愬姛', 'data': {
+          'paper': {
+            'id': 30,
+            'level': 1,
+            'subjectId': 4,
+            'paperType': 7,
+            'name': '杩欐槸涓�涓祴璇曡瘯鍗�',
+            'suggestTime': 12,
+            'limitDateTime': null,
+            'titleItems': [{
+              'name': '鍗曢�夐',
+              'questionItems': [{
+                'id': 25,
+                'questionType': 1,
+                'subjectId': 4,
+                'title': '涓崕鍥涘ぇ鍚嶈憲閮芥湁鍝簺锛屼笅鍒楁纭殑鏄�',
+                'gradeLevel': 1,
+                'items': [{ 'prefix': 'A', 'content': '绾㈡ゼ姊�', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'B',
+                  'content': '鐧芥ゼ姊�',
+                  'score': null,
+                  'itemUuid': null
+                }, { 'prefix': 'C', 'content': '闈掓ゼ姊�', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'D',
+                  'content': '缁挎ゼ姊�',
+                  'score': null,
+                  'itemUuid': null
+                }],
+                'analyze': '棰樼洰姣旇緝绠�鍗曪紝鑷鍒嗘瀽',
+                'correctArray': null,
+                'correct': 'A',
+                'score': '2.5',
+                'difficult': 3,
+                'itemOrder': 1,
+                'knowledgeIdList': [8, 9]
+              }, {
+                'id': 30,
+                'questionType': 1,
+                'subjectId': 4,
+                'title': '涓崕鍥涘ぇ鍚嶈憲閮芥湁鍝簺锛屼笅鍒楁纭殑鏄�',
+                'gradeLevel': 1,
+                'items': [{ 'prefix': 'A', 'content': '绾㈡ゼ姊�', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'B',
+                  'content': '鐧芥ゼ姊�',
+                  'score': null,
+                  'itemUuid': null
+                }, { 'prefix': 'C', 'content': '闈掓ゼ姊�', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'D',
+                  'content': '缁挎ゼ姊�',
+                  'score': null,
+                  'itemUuid': null
+                }],
+                'analyze': '棰樼洰姣旇緝绠�鍗曪紝鑷鍒嗘瀽',
+                'correctArray': null,
+                'correct': 'A',
+                'score': '2.5',
+                'difficult': 3,
+                'itemOrder': 2,
+                'knowledgeIdList': [8, 9]
+              }]
+            }, {
+              'name': '澶氶�夐',
+              'questionItems': [{
+                'id': 26,
+                'questionType': 2,
+                'subjectId': 4,
+                'title': '涓崕鍥涘ぇ鍚嶈憲閮芥湁鍝簺锛屼笅鍒楁纭殑鏄�',
+                'gradeLevel': 1,
+                'items': [{ 'prefix': 'A', 'content': '绾㈡ゼ姊�', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'B',
+                  'content': '鐧芥ゼ姊�',
+                  'score': null,
+                  'itemUuid': null
+                }, { 'prefix': 'C', 'content': '闈掓ゼ姊�', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'D',
+                  'content': '缁挎ゼ姊�',
+                  'score': null,
+                  'itemUuid': null
+                }],
+                'analyze': '棰樼洰姣旇緝绠�鍗曪紝鑷鍒嗘瀽',
+                'correctArray': ['A', 'C'],
+                'correct': 'A,C',
+                'score': '2.5',
+                'difficult': 3,
+                'itemOrder': 3,
+                'knowledgeIdList': [8, 9]
+              }, {
+                'id': 31,
+                'questionType': 2,
+                'subjectId': 4,
+                'title': '涓崕鍥涘ぇ鍚嶈憲閮芥湁鍝簺锛屼笅鍒楁纭殑鏄�',
+                'gradeLevel': 1,
+                'items': [{ 'prefix': 'A', 'content': '绾㈡ゼ姊�', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'B',
+                  'content': '鐧芥ゼ姊�',
+                  'score': null,
+                  'itemUuid': null
+                }, { 'prefix': 'C', 'content': '闈掓ゼ姊�', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'D',
+                  'content': '缁挎ゼ姊�',
+                  'score': null,
+                  'itemUuid': null
+                }],
+                'analyze': '棰樼洰姣旇緝绠�鍗曪紝鑷鍒嗘瀽',
+                'correctArray': ['A', 'C'],
+                'correct': 'A,C',
+                'score': '2.5',
+                'difficult': 3,
+                'itemOrder': 4,
+                'knowledgeIdList': [8, 9]
+              }]
+            }, {
+              'name': '鍒ゆ柇棰�',
+              'questionItems': [{
+                'id': 27,
+                'questionType': 3,
+                'subjectId': 4,
+                'title': '涓崕鍥涘ぇ鍚嶈憲閮芥湁鍝簺锛屼笅鍒楄鏄庢纭悧',
+                'gradeLevel': 1,
+                'items': [{ 'prefix': 'A', 'content': '姝g‘', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'B',
+                  'content': '閿欒',
+                  'score': null,
+                  'itemUuid': null
+                }],
+                'analyze': '棰樼洰姣旇緝绠�鍗曪紝鑷鍒嗘瀽',
+                'correctArray': null,
+                'correct': 'A',
+                'score': '2.5',
+                'difficult': 3,
+                'itemOrder': 5,
+                'knowledgeIdList': [8, 9]
+              }, {
+                'id': 32,
+                'questionType': 3,
+                'subjectId': 4,
+                'title': '涓崕鍥涘ぇ鍚嶈憲閮芥湁鍝簺锛屼笅鍒楄鏄庢纭悧',
+                'gradeLevel': 1,
+                'items': [{ 'prefix': 'A', 'content': '姝g‘', 'score': null, 'itemUuid': null }, {
+                  'prefix': 'B',
+                  'content': '閿欒',
+                  'score': null,
+                  'itemUuid': null
+                }],
+                'analyze': '棰樼洰姣旇緝绠�鍗曪紝鑷鍒嗘瀽',
+                'correctArray': null,
+                'correct': 'A',
+                'score': '2.5',
+                'difficult': 3,
+                'itemOrder': 6,
+                'knowledgeIdList': [8, 9]
+              }]
+            }, {
+              'name': '绠�绛旈',
+              'questionItems': [{
+                'id': 1,
+                'questionType': 5,
+                'subjectId': 4,
+                'title': '涓崕鍥涘ぇ鍚嶈憲閮芥湁鍝簺',
+                'gradeLevel': 1,
+                'analyze': '棰樼洰姣旇緝绠�鍗曪紝鑷鍒嗘瀽',
+                'correct': '绾㈡ゼ姊︺�佽タ娓歌銆佹按娴掍紶銆佷笁鍥芥紨涔�',
+                'score': '10',
+                'difficult': 3,
+                'itemOrder': 7,
+                'knowledgeIdList': [8, 9]
+              }
+              ]
+            }],
+            'score': '15',
+            'classes': null
+          },
+          'answer': {
+            'id': 9,
+            'doTime': 26,
+            'score': '100',
+            'createUser': null,
+            'answerItems': [{
+              'id': 25,
+              'questionId': 25,
+              'doRight': true,
+              'content': 'A',
+              'itemOrder': 1,
+              'contentArray': null,
+              'score': '2.5',
+              'questionScore': '2.5'
+            }, {
+              'id': 26,
+              'questionId': 30,
+              'doRight': false,
+              'content': 'C',
+              'itemOrder': 2,
+              'contentArray': null,
+              'score': '0',
+              'questionScore': '2.5'
+            }, {
+              'id': 27,
+              'questionId': 26,
+              'doRight': false,
+              'content': '',
+              'itemOrder': 3,
+              'contentArray': [''],
+              'score': '0',
+              'questionScore': '2.5'
+            }, {
+              'id': 28,
+              'questionId': 31,
+              'doRight': false,
+              'content': 'C,D',
+              'itemOrder': 4,
+              'contentArray': ['C', 'D'],
+              'score': '0',
+              'questionScore': '2.5'
+            }, {
+              'id': 29,
+              'questionId': 27,
+              'doRight': true,
+              'content': 'A',
+              'itemOrder': 5,
+              'contentArray': null,
+              'score': '2.5',
+              'questionScore': '2.5'
+            }, {
+              'id': 30,
+              'questionId': 32,
+              'doRight': true,
+              'content': 'A',
+              'itemOrder': 6,
+              'contentArray': null,
+              'score': '2.5',
+              'questionScore': '2.5'
+            }, {
+              'id': 31,
+              'questionId': 1,
+              'doRight': null,
+              'content': '绾㈡ゼ姊�.......',
+              'itemOrder': 6,
+              'questionScore': '10'
+            }],
+            'doTimeStr': '26绉�'
+          }
+        }
+      }
+      this.form = re.data.paper
+      this.answer = re.data.answer
+      this.formLoading = false
+    })
+    // if (this.examInfo.examId && this.userId) {
+    //   this.getStudentPaper()
+    // }
   },
   data () {
     return {
-      paperQuestionList: [
-
-      ],
+      paperQuestionList: [],
+      form: {},
+      formLoading: false,
+      answer: {
+        id: null,
+        score: 0,
+        doTime: 0,
+        answerItems: [],
+        doRight: false
+      },
       userId: null,
-      userName: null,
+      userName: '寮犱笁',
       questionLoading: false,
       examInfo: {
         examId: null,
         examName: '',
-        doTime: 0,
-        updateTime: null,
+        doTime: '119鍒�40绉�',
+        updateTime: '2024-06-20 15:59:40',
         paperQuestionList: []
       }
     }

--
Gitblit v1.8.0