Commit 77da338a1cb46a0391105616642d1ab02a8e4f27
1 parent
f9916d4c
自测问题修改
Showing
14 changed files
with
426 additions
and
335 deletions
public/output/chtml/fonts/woff-v2/MathJax_Main-Regular.woff renamed to public/Temp/js/output/chtml/fonts/woff-v2/MathJax_Main-Regular.woff
No preview for this file type
public/output/chtml/fonts/woff-v2/MathJax_Math-Italic.woff renamed to public/Temp/js/output/chtml/fonts/woff-v2/MathJax_Math-Italic.woff
No preview for this file type
public/output/chtml/fonts/woff-v2/MathJax_Size2-Regular.woff renamed to public/Temp/js/output/chtml/fonts/woff-v2/MathJax_Size2-Regular.woff
No preview for this file type
public/output/chtml/fonts/woff-v2/MathJax_Size3-Regular.woff renamed to public/Temp/js/output/chtml/fonts/woff-v2/MathJax_Size3-Regular.woff
No preview for this file type
public/output/chtml/fonts/woff-v2/MathJax_Zero.woff renamed to public/Temp/js/output/chtml/fonts/woff-v2/MathJax_Zero.woff
No preview for this file type
public/index.html
@@ -19,8 +19,8 @@ | @@ -19,8 +19,8 @@ | ||
19 | var link = document.querySelector("link[rel*='icon']") || document.createElement('link'); | 19 | var link = document.querySelector("link[rel*='icon']") || document.createElement('link'); |
20 | link.type = 'image/x-icon'; | 20 | link.type = 'image/x-icon'; |
21 | link.rel = 'shortcut icon'; | 21 | link.rel = 'shortcut icon'; |
22 | - var isZS = window.location.host.includes('ezquiz.sunvotecloud') || window.location.host.includes('121.40.127.171') | ||
23 | - link.href = isZS ? "./favicon.ico" : "./331icon.ico"; | 22 | + var isZS = window.location.host.includes('121.199.53.164') |
23 | + link.href = isZS ? "./331icon.ico" : "./favicon.ico"; | ||
24 | document.getElementsByTagName('head')[0].appendChild(link); | 24 | document.getElementsByTagName('head')[0].appendChild(link); |
25 | } | 25 | } |
26 | </script> | 26 | </script> |
src/assets/css/index.scss
src/views/basic/test/list.vue
@@ -54,8 +54,8 @@ | @@ -54,8 +54,8 @@ | ||
54 | @current-change="changePage" :current-page="page" :page-size="size"> | 54 | @current-change="changePage" :current-page="page" :page-size="size"> |
55 | </el-pagination> | 55 | </el-pagination> |
56 | </div> | 56 | </div> |
57 | - <ScoreSet v-show="diaScoreSet" :role="role" :id="examId" :title="examTitlt" :examScore="examScore" | ||
58 | - @closeScoreSet="closeScoreSet" /> | 57 | + <ScoreSet v-show="diaScoreSet" :diaScoreSet="diaScoreSet" :role="role" :id="examId" :title="examTitlt" |
58 | + :examScore="examScore" @closeScoreSet="closeScoreSet" /> | ||
59 | </div> | 59 | </div> |
60 | <div v-else> | 60 | <div v-else> |
61 | <el-table :data="tableData" :max-height="tableMaxHeight" border style="width: 100%"> | 61 | <el-table :data="tableData" :max-height="tableMaxHeight" border style="width: 100%"> |
@@ -241,7 +241,7 @@ export default { | @@ -241,7 +241,7 @@ export default { | ||
241 | }, | 241 | }, |
242 | //打开答卷录分 | 242 | //打开答卷录分 |
243 | openScoreSet(obj) { | 243 | openScoreSet(obj) { |
244 | - this.examId = obj.id; | 244 | + this.examId = String(obj.id); |
245 | this.examTitlt = obj.title; | 245 | this.examTitlt = obj.title; |
246 | this.examScore = obj.examScore; | 246 | this.examScore = obj.examScore; |
247 | this.diaScoreSet = true; | 247 | this.diaScoreSet = true; |
src/views/examinationPaper/add.vue
@@ -317,6 +317,10 @@ | @@ -317,6 +317,10 @@ | ||
317 | <span class="title-txt">{{ question.questionTitle }}</span> | 317 | <span class="title-txt">{{ question.questionTitle }}</span> |
318 | <span class="m20">共:{{ setNums(question.subQuestions) }}题</span> | 318 | <span class="m20">共:{{ setNums(question.subQuestions) }}题</span> |
319 | <span>共:{{ setScore(question) }} 分</span> | 319 | <span>共:{{ setScore(question) }} 分</span> |
320 | + <el-popconfirm title="确定删除这道大题吗?" @confirm="form.questionList.splice(index, 1)"> | ||
321 | + <el-button slot="reference" class="delete" type="danger" size="mini" circle | ||
322 | + icon="el-icon-delete"></el-button> | ||
323 | + </el-popconfirm> | ||
320 | </p> | 324 | </p> |
321 | <ul class="questions-ul"> | 325 | <ul class="questions-ul"> |
322 | <li class="sub-questions"> | 326 | <li class="sub-questions"> |
@@ -700,9 +704,15 @@ export default { | @@ -700,9 +704,15 @@ export default { | ||
700 | answerScreenshot: "", //题目解析图片地址 | 704 | answerScreenshot: "", //题目解析图片地址 |
701 | knowledge: [], //知识点 | 705 | knowledge: [], //知识点 |
702 | }, | 706 | }, |
707 | + | ||
708 | + //返回列表页参数记录 | ||
709 | + listType: 1, | ||
710 | + listShare: 0, | ||
703 | }; | 711 | }; |
704 | }, | 712 | }, |
705 | async created() { | 713 | async created() { |
714 | + this.listType = this.$route.query.listType ? this.$route.query.listType : 1; | ||
715 | + this.listShare = this.$route.query.listShare ? this.$route.query.listShare : 0; | ||
706 | this.type = this.$route.query.type ? this.$route.query.type : 1; | 716 | this.type = this.$route.query.type ? this.$route.query.type : 1; |
707 | this.role = | 717 | this.role = |
708 | this.$store.getters.info.showRole || | 718 | this.$store.getters.info.showRole || |
@@ -1230,6 +1240,9 @@ export default { | @@ -1230,6 +1240,9 @@ export default { | ||
1230 | //删除小题 | 1240 | //删除小题 |
1231 | delTabData(subIndex, index) { | 1241 | delTabData(subIndex, index) { |
1232 | this.form.questionList[index].subQuestions.splice(subIndex, 1); | 1242 | this.form.questionList[index].subQuestions.splice(subIndex, 1); |
1243 | + if(this.form.questionList[index].subQuestions.length == 0){ | ||
1244 | + this.form.questionList.splice(index, 1) | ||
1245 | + } | ||
1233 | this.formateQuestion() | 1246 | this.formateQuestion() |
1234 | }, | 1247 | }, |
1235 | setScore(question) { | 1248 | setScore(question) { |
@@ -1431,6 +1444,8 @@ export default { | @@ -1431,6 +1444,8 @@ export default { | ||
1431 | if (status == 0) { | 1444 | if (status == 0) { |
1432 | this.$router.push({ | 1445 | this.$router.push({ |
1433 | path: "/examinationPaper", | 1446 | path: "/examinationPaper", |
1447 | + type: this.listType, | ||
1448 | + share: this.listShare, | ||
1434 | }); | 1449 | }); |
1435 | } else { | 1450 | } else { |
1436 | this.$message.error(info); | 1451 | this.$message.error(info); |
@@ -1531,11 +1546,14 @@ export default { | @@ -1531,11 +1546,14 @@ export default { | ||
1531 | }); | 1546 | }); |
1532 | if (status == 0) { | 1547 | if (status == 0) { |
1533 | this.form.title = data.title + "_副本"; | 1548 | this.form.title = data.title + "_副本"; |
1534 | - this.form.tagId = data.tagId === 0 ? "" : data.tagId; | 1549 | + |
1535 | this.form.examsDuration = data.examsDuration; | 1550 | this.form.examsDuration = data.examsDuration; |
1536 | if (this.role != "ROLE_PERSONAL") { | 1551 | if (this.role != "ROLE_PERSONAL") { |
1537 | this.form.sharingType = data.sharingType; | 1552 | this.form.sharingType = data.sharingType; |
1538 | } | 1553 | } |
1554 | + if (data.sharingType != 1) { | ||
1555 | + this.form.tagId = data.tagId === 0 ? "" : data.tagId; | ||
1556 | + } | ||
1539 | this.formatData(data) | 1557 | this.formatData(data) |
1540 | } else { | 1558 | } else { |
1541 | this.$message.error(info); | 1559 | this.$message.error(info); |
@@ -1770,7 +1788,7 @@ export default { | @@ -1770,7 +1788,7 @@ export default { | ||
1770 | } | 1788 | } |
1771 | 1789 | ||
1772 | .delete { | 1790 | .delete { |
1773 | - margin-right: 8px; | 1791 | + margin:0 8px; |
1774 | } | 1792 | } |
1775 | 1793 | ||
1776 | .title-txt { | 1794 | .title-txt { |
@@ -1932,7 +1950,8 @@ export default { | @@ -1932,7 +1950,8 @@ export default { | ||
1932 | .stem-pic { | 1950 | .stem-pic { |
1933 | display: block; | 1951 | display: block; |
1934 | margin: 0 auto 20px; | 1952 | margin: 0 auto 20px; |
1935 | - height: 200px; | 1953 | + max-width: 100%; |
1954 | + max-height: 200px; | ||
1936 | object-fit: cover; | 1955 | object-fit: cover; |
1937 | } | 1956 | } |
1938 | } | 1957 | } |
src/views/examinationPaper/addAsk.vue
@@ -109,6 +109,14 @@ | @@ -109,6 +109,14 @@ | ||
109 | <span class="answer-s" v-for="option in subQuestions.answerOptions.split(',')" :class="subQuestions.correctAnswer == option ? 'active' : '' | 109 | <span class="answer-s" v-for="option in subQuestions.answerOptions.split(',')" :class="subQuestions.correctAnswer == option ? 'active' : '' |
110 | " :key="option" @click="subQuestions.correctAnswer = option">{{ option }}</span> | 110 | " :key="option" @click="subQuestions.correctAnswer = option">{{ option }}</span> |
111 | </p> | 111 | </p> |
112 | + <p v-if="subQuestions.questionType == 3 || | ||
113 | + subQuestions.questionType == 2 | ||
114 | + " class="answer-box answer-box2"> | ||
115 | + <el-button size="mini" type="primary" icon="el-icon-plus" circle | ||
116 | + @click="addOptions(subQuestions)"></el-button> | ||
117 | + <el-button size="mini" type="primary" icon="el-icon-minus" round circle | ||
118 | + @click="removeOptions(subQuestions)"></el-button> | ||
119 | + </p> | ||
112 | </div> | 120 | </div> |
113 | 121 | ||
114 | <div class="qs-upload"> | 122 | <div class="qs-upload"> |
@@ -609,6 +617,28 @@ export default { | @@ -609,6 +617,28 @@ export default { | ||
609 | }; | 617 | }; |
610 | } | 618 | } |
611 | }, | 619 | }, |
620 | + //添加选项 | ||
621 | + addOptions(subQuestions) { | ||
622 | + let length = subQuestions.answerOptions.split(",").length; | ||
623 | + if (length > 9) return; | ||
624 | + subQuestions.selectNum = length + 1; | ||
625 | + subQuestions.answerOptions = this.rightOptions | ||
626 | + .slice(0, subQuestions.selectNum) | ||
627 | + .join(","); | ||
628 | + }, | ||
629 | + //删除选项 | ||
630 | + removeOptions(subQuestions) { | ||
631 | + let length = subQuestions.answerOptions.split(",").length; | ||
632 | + if (length < 3) return; | ||
633 | + subQuestions.selectNum = length - 1; | ||
634 | + subQuestions.answerOptions = this.rightOptions | ||
635 | + .slice(0, subQuestions.selectNum) | ||
636 | + .join(","); | ||
637 | + subQuestions.correctAnswer = subQuestions.correctAnswer.slice( | ||
638 | + 0, | ||
639 | + subQuestions.selectNum | ||
640 | + ); | ||
641 | + }, | ||
612 | //多选答案设置 | 642 | //多选答案设置 |
613 | setMultiple(obj, answer, type) { | 643 | setMultiple(obj, answer, type) { |
614 | let elements = | 644 | let elements = |
@@ -1322,7 +1352,8 @@ export default { | @@ -1322,7 +1352,8 @@ export default { | ||
1322 | .stem-pic { | 1352 | .stem-pic { |
1323 | display: block; | 1353 | display: block; |
1324 | margin: 0 auto 20px; | 1354 | margin: 0 auto 20px; |
1325 | - height: 200px; | 1355 | + max-width: 100%; |
1356 | + max-height: 200px; | ||
1326 | object-fit: cover; | 1357 | object-fit: cover; |
1327 | } | 1358 | } |
1328 | } | 1359 | } |
src/views/examinationPaper/edit.vue
@@ -23,8 +23,8 @@ | @@ -23,8 +23,8 @@ | ||
23 | <p class="totals">卷面总分:{{ allScore }}分</p> | 23 | <p class="totals">卷面总分:{{ allScore }}分</p> |
24 | </div> | 24 | </div> |
25 | <div class="question-box"> | 25 | <div class="question-box"> |
26 | - <div class="questions-ul" :class="form.examType == 1 ? 'questions-ul2' : ''" v-if="form.examType == 1"> | ||
27 | - <div class="sub-questions"> | 26 | + <ul class="questions-ul questions-ul2" v-if="!questionList[0]?.subQuestions"> |
27 | + <li class="sub-questions"> | ||
28 | <div class="qs-num">题号</div> | 28 | <div class="qs-num">题号</div> |
29 | <div class="qs-type">题型</div> | 29 | <div class="qs-type">题型</div> |
30 | <div class="qs-score">分数</div> | 30 | <div class="qs-score">分数</div> |
@@ -33,19 +33,96 @@ | @@ -33,19 +33,96 @@ | ||
33 | <div class="qs-set">题干</div> | 33 | <div class="qs-set">题干</div> |
34 | <div class="qs-set">题目解析</div> | 34 | <div class="qs-set">题目解析</div> |
35 | <div class="qs-set">知识点</div> | 35 | <div class="qs-set">知识点</div> |
36 | - </div> | ||
37 | - </div> | ||
38 | - <template v-for="(question, index) in questionList"> | ||
39 | - <template v-if="form.examType == 2"> | 36 | + </li> |
37 | + <li v-for="(subQuestions, indexs) in questionList" :key="indexs"> | ||
38 | + <p class="set-ans-btn" v-if="subQuestions.qusType && | ||
39 | + subQuestions.subNum && | ||
40 | + subQuestions.subNum > 4 | ||
41 | + "> | ||
42 | + <el-button type="primary" @click="setFormAns(indexs)">批量设置答案</el-button> | ||
43 | + </p> | ||
44 | + <div v-else class="sub-questions"> | ||
45 | + <div class="qs-num">{{ subQuestions.questionIndex }}</div> | ||
46 | + <div class="qs-type"> | ||
47 | + {{ setSubPro(subQuestions.questionType) }} | ||
48 | + </div> | ||
49 | + <div class="qs-score"> | ||
50 | + {{ subQuestions.score }} | ||
51 | + </div> | ||
52 | + <div class="qs-partScore"> | ||
53 | + <p v-if="subQuestions.questionType != 3">--</p> | ||
54 | + <el-input-number class="number-ipt" v-else size="medium" :min="0" :precision="2" :max="subQuestions.score" | ||
55 | + :step="0.5" v-model="subQuestions.partScore" label="漏选得分"></el-input-number> | ||
56 | + </div> | ||
57 | + <div class="qs-options qs-options2"> | ||
58 | + <p v-if="subQuestions.questionType == 5">--</p> | ||
59 | + <p v-if="subQuestions.questionType == 4" class="answer-box"> | ||
60 | + <span class="answer-s" :class="subQuestions.correctAnswer == 1 ? 'active' : ''" | ||
61 | + @click="subQuestions.correctAnswer = 1">✓</span> | ||
62 | + <span class="answer-s" :class="subQuestions.correctAnswer == 2 ? 'active' : ''" | ||
63 | + @click="subQuestions.correctAnswer = 2">✗</span> | ||
64 | + </p> | ||
65 | + <p v-if="subQuestions.questionType == 3" class="answer-box"> | ||
66 | + <template v-for="option in subQuestions.answerOptions.split(',')"> | ||
67 | + <span v-if="option" class="answer-s" :class="subQuestions.correctAnswer.includes(option) | ||
68 | + ? 'active' | ||
69 | + : '' | ||
70 | + " :key="option" @click="changAnswer(subQuestions, option)">{{ option }}</span> | ||
71 | + </template> | ||
72 | + </p> | ||
73 | + <p v-if="subQuestions.questionType == 2" class="answer-box"> | ||
74 | + <template v-for="option in subQuestions.answerOptions.split(',')"> | ||
75 | + <span class="answer-s" v-if="option" :class="subQuestions.correctAnswer == option ? 'active' : '' | ||
76 | + " :key="option" @click="subQuestions.correctAnswer = option">{{ option }}</span> | ||
77 | + </template> | ||
78 | + </p> | ||
79 | + </div> | ||
80 | + <div class="qs-set"> | ||
81 | + <el-popover placement="right" width="600" trigger="click"> | ||
82 | + <div class="screenshot-box"> | ||
83 | + <iframe class="screenshot" v-if="subQuestions.screenshot && subQuestions.screenshot.includes('html')" | ||
84 | + :src="subQuestions.screenshot"></iframe> | ||
85 | + <img class="screenshot screenshot-img" | ||
86 | + v-if="subQuestions.screenshot && !subQuestions.screenshot.includes('html')" | ||
87 | + :src="subQuestions.screenshot" alt=""> | ||
88 | + <p style="textAlign:center"><el-button type="primary" round size="mini" icon="el-icon-upload" | ||
89 | + @click="openStem(subQuestions, 1, indexs)">重新选择图片</el-button></p> | ||
90 | + </div> | ||
91 | + <el-button slot="reference" class="icon-tickets" type="primary" circle size="mini" | ||
92 | + icon="el-icon-tickets"></el-button> | ||
93 | + </el-popover> | ||
94 | + </div> | ||
95 | + <div class="qs-set"> | ||
96 | + <el-popover placement="right" width="600" trigger="click"> | ||
97 | + <div class="screenshot-box"> | ||
98 | + <iframe class="screenshot" | ||
99 | + v-if="subQuestions.answerScreenshot && subQuestions.answerScreenshot.includes('html')" | ||
100 | + :src="subQuestions.answerScreenshot"></iframe> | ||
101 | + <img class="screenshot screenshot-img" | ||
102 | + v-if="subQuestions.answerScreenshot && !subQuestions.answerScreenshot.includes('html')" | ||
103 | + :src="subQuestions.answerScreenshot" alt=""> | ||
104 | + <p style="textAlign:center"><el-button type="primary" round size="mini" icon="el-icon-upload" | ||
105 | + @click="openStem(subQuestions, 2, indexs)">重新选择图片</el-button></p> | ||
106 | + </div> | ||
107 | + <el-button slot="reference" class="icon-tickets" type="primary" circle size="mini" | ||
108 | + icon="el-icon-tickets"></el-button> | ||
109 | + </el-popover> | ||
110 | + </div> | ||
111 | + <div class="qs-set"> | ||
112 | + <el-button type="primary" circle size="mini" icon="el-icon-price-tag" | ||
113 | + @click="openKnowledge(subQuestions, indexs)"></el-button> | ||
114 | + </div> | ||
115 | + </div> | ||
116 | + </li> | ||
117 | + </ul> | ||
118 | + <template v-if="questionList[0]?.subQuestions"> | ||
119 | + <template v-for="(question, index) in questionList"> | ||
40 | <p class="question-title"> | 120 | <p class="question-title"> |
41 | <span>{{ setBigNum(index) }}、</span> | 121 | <span>{{ setBigNum(index) }}、</span> |
42 | <el-input class="ipt" v-model.trim="question.questionTitle" maxlength="30" placeholder="填写大题名称"></el-input> | 122 | <el-input class="ipt" v-model.trim="question.questionTitle" maxlength="30" placeholder="填写大题名称"></el-input> |
43 | <span>共 {{ setScore(question) }} 分</span> | 123 | <span>共 {{ setScore(question) }} 分</span> |
44 | </p> | 124 | </p> |
45 | - | ||
46 | - </template> | ||
47 | - <div class="questions-ul" :class="form.examType == 1 ? 'questions-ul2' : ''"> | ||
48 | - <template v-if="form.examType == 2"> | 125 | + <div class="questions-ul"> |
49 | <div class="sub-questions"> | 126 | <div class="sub-questions"> |
50 | <div class="qs-num">题号</div> | 127 | <div class="qs-num">题号</div> |
51 | <div class="qs-type">题型</div> | 128 | <div class="qs-type">题型</div> |
@@ -56,90 +133,91 @@ | @@ -56,90 +133,91 @@ | ||
56 | <div class="qs-set">题目解析</div> | 133 | <div class="qs-set">题目解析</div> |
57 | <div class="qs-set">知识点</div> | 134 | <div class="qs-set">知识点</div> |
58 | </div> | 135 | </div> |
59 | - </template> | ||
60 | - <div v-for="(subQuestions, indexs) in question.subQuestions" :key="indexs"> | ||
61 | - <p class="set-ans-btn" v-if="subQuestions.qusType && | ||
62 | - subQuestions.subNum && | ||
63 | - subQuestions.subNum > 4 | ||
64 | - "> | ||
65 | - <el-button type="primary" @click="setFormAns(indexs, index)">批量设置答案</el-button> | ||
66 | - </p> | ||
67 | - <div v-else class="sub-questions"> | ||
68 | - <div class="qs-num">{{ subQuestions.questionIndex }}</div> | ||
69 | - <div class="qs-type"> | ||
70 | - {{ setSubPro(subQuestions.questionType) }} | ||
71 | - </div> | ||
72 | - <div class="qs-score"> | ||
73 | - <el-input-number class="number-ipt" size="medium" :min="1" :max="200" :precision="2" :step="1" | ||
74 | - v-model="subQuestions.score" label="单题分值"></el-input-number> | ||
75 | - </div> | ||
76 | - <div class="qs-partScore"> | ||
77 | - <p v-if="subQuestions.questionType != 3">--</p> | ||
78 | - <el-input-number class="number-ipt" v-else size="medium" :min="0" :precision="2" | ||
79 | - :max="subQuestions.score" :step="0.5" v-model="subQuestions.partScore" label="漏选得分"></el-input-number> | ||
80 | - </div> | ||
81 | - <div class="qs-options qs-options2"> | ||
82 | - <p v-if="subQuestions.questionType == 5">--</p> | ||
83 | - <p v-if="subQuestions.questionType == 4" class="answer-box"> | ||
84 | - <span class="answer-s" :class="subQuestions.correctAnswer == 1 ? 'active' : ''" | ||
85 | - @click="subQuestions.correctAnswer = 1">✓</span> | ||
86 | - <span class="answer-s" :class="subQuestions.correctAnswer == 2 ? 'active' : ''" | ||
87 | - @click="subQuestions.correctAnswer = 2">✗</span> | ||
88 | - </p> | ||
89 | - <p v-if="subQuestions.questionType == 3" class="answer-box"> | ||
90 | - <template v-for="option in subQuestions.answerOptions.split(',')"> | ||
91 | - <span v-if="option" class="answer-s" :class="subQuestions.correctAnswer.includes(option) | ||
92 | - ? 'active' | ||
93 | - : '' | ||
94 | - " :key="option" @click="changAnswer(subQuestions, option)">{{ option }}</span> | ||
95 | - </template> | ||
96 | - </p> | ||
97 | - <p v-if="subQuestions.questionType == 2" class="answer-box"> | ||
98 | - <template v-for="option in subQuestions.answerOptions.split(',')"> | ||
99 | - <span class="answer-s" v-if="option" :class="subQuestions.correctAnswer == option ? 'active' : '' | ||
100 | - " :key="option" @click="subQuestions.correctAnswer = option">{{ option }}</span> | ||
101 | - </template> | ||
102 | - </p> | ||
103 | - </div> | ||
104 | - <div class="qs-set"> | ||
105 | - <el-popover placement="right" width="600" trigger="click"> | ||
106 | - <div class="screenshot-box"> | ||
107 | - <iframe class="screenshot" | ||
108 | - v-if="subQuestions.screenshot && subQuestions.screenshot.includes('html')" | ||
109 | - :src="subQuestions.screenshot"></iframe> | ||
110 | - <img class="screenshot screenshot-img" | ||
111 | - v-if="subQuestions.screenshot && !subQuestions.screenshot.includes('html')" | ||
112 | - :src="subQuestions.screenshot" alt=""> | ||
113 | - <p style="textAlign:center"><el-button type="primary" round size="mini" icon="el-icon-upload" | ||
114 | - @click="openStem(subQuestions, index, indexs, 1)">重新选择图片</el-button></p> | ||
115 | - </div> | ||
116 | - <el-button slot="reference" class="icon-tickets" type="primary" circle size="mini" | ||
117 | - icon="el-icon-tickets"></el-button> | ||
118 | - </el-popover> | ||
119 | - </div> | ||
120 | - <div class="qs-set"> | ||
121 | - <el-popover placement="right" width="600" trigger="click"> | ||
122 | - <div class="screenshot-box"> | ||
123 | - <iframe class="screenshot" | ||
124 | - v-if="subQuestions.answerScreenshot && subQuestions.answerScreenshot.includes('html')" | ||
125 | - :src="subQuestions.answerScreenshot"></iframe> | ||
126 | - <img class="screenshot screenshot-img" | ||
127 | - v-if="subQuestions.answerScreenshot && !subQuestions.answerScreenshot.includes('html')" | ||
128 | - :src="subQuestions.answerScreenshot" alt=""> | ||
129 | - <p style="textAlign:center"><el-button type="primary" round size="mini" icon="el-icon-upload" | ||
130 | - @click="openStem(subQuestions, index, indexs, 2)">重新选择图片</el-button></p> | ||
131 | - </div> | ||
132 | - <el-button slot="reference" class="icon-tickets" type="primary" circle size="mini" | ||
133 | - icon="el-icon-tickets"></el-button> | ||
134 | - </el-popover> | ||
135 | - </div> | ||
136 | - <div class="qs-set"> | ||
137 | - <el-button type="primary" circle size="mini" icon="el-icon-price-tag" | ||
138 | - @click="openKnowledge(subQuestions, index, indexs)"></el-button> | 136 | + <div v-for="(subQuestions, indexs) in question.subQuestions" :key="indexs"> |
137 | + <p class="set-ans-btn" v-if="subQuestions.qusType && | ||
138 | + subQuestions.subNum && | ||
139 | + subQuestions.subNum > 4 | ||
140 | + "> | ||
141 | + <el-button type="primary" @click="setFormAns(indexs, index)">批量设置答案</el-button> | ||
142 | + </p> | ||
143 | + <div v-else class="sub-questions"> | ||
144 | + <div class="qs-num">{{ subQuestions.questionIndex }}</div> | ||
145 | + <div class="qs-type"> | ||
146 | + {{ setSubPro(subQuestions.questionType) }} | ||
147 | + </div> | ||
148 | + <div class="qs-score"> | ||
149 | + <el-input-number class="number-ipt" size="medium" :min="1" :max="200" :precision="2" :step="1" | ||
150 | + v-model="subQuestions.score" label="单题分值"></el-input-number> | ||
151 | + </div> | ||
152 | + <div class="qs-partScore"> | ||
153 | + <p v-if="subQuestions.questionType != 3">--</p> | ||
154 | + <el-input-number class="number-ipt" v-else size="medium" :min="0" :precision="2" | ||
155 | + :max="subQuestions.score" :step="0.5" v-model="subQuestions.partScore" | ||
156 | + label="漏选得分"></el-input-number> | ||
157 | + </div> | ||
158 | + <div class="qs-options qs-options2"> | ||
159 | + <p v-if="subQuestions.questionType == 5">--</p> | ||
160 | + <p v-if="subQuestions.questionType == 4" class="answer-box"> | ||
161 | + <span class="answer-s" :class="subQuestions.correctAnswer == 1 ? 'active' : ''" | ||
162 | + @click="subQuestions.correctAnswer = 1">✓</span> | ||
163 | + <span class="answer-s" :class="subQuestions.correctAnswer == 2 ? 'active' : ''" | ||
164 | + @click="subQuestions.correctAnswer = 2">✗</span> | ||
165 | + </p> | ||
166 | + <p v-if="subQuestions.questionType == 3" class="answer-box"> | ||
167 | + <template v-for="option in subQuestions.answerOptions.split(',')"> | ||
168 | + <span v-if="option" class="answer-s" :class="subQuestions.correctAnswer.includes(option) | ||
169 | + ? 'active' | ||
170 | + : '' | ||
171 | + " :key="option" @click="changAnswer(subQuestions, option)">{{ option }}</span> | ||
172 | + </template> | ||
173 | + </p> | ||
174 | + <p v-if="subQuestions.questionType == 2" class="answer-box"> | ||
175 | + <template v-for="option in subQuestions.answerOptions.split(',')"> | ||
176 | + <span class="answer-s" v-if="option" :class="subQuestions.correctAnswer == option ? 'active' : '' | ||
177 | + " :key="option" @click="subQuestions.correctAnswer = option">{{ option }}</span> | ||
178 | + </template> | ||
179 | + </p> | ||
180 | + </div> | ||
181 | + <div class="qs-set"> | ||
182 | + <el-popover placement="right" width="600" trigger="click"> | ||
183 | + <div class="screenshot-box"> | ||
184 | + <iframe class="screenshot" | ||
185 | + v-if="subQuestions.screenshot && subQuestions.screenshot.includes('html')" | ||
186 | + :src="subQuestions.screenshot"></iframe> | ||
187 | + <img class="screenshot screenshot-img" | ||
188 | + v-if="subQuestions.screenshot && !subQuestions.screenshot.includes('html')" | ||
189 | + :src="subQuestions.screenshot" alt=""> | ||
190 | + <p style="textAlign:center"><el-button type="primary" round size="mini" icon="el-icon-upload" | ||
191 | + @click="openStem(subQuestions, 1, index, indexs)">重新选择图片</el-button></p> | ||
192 | + </div> | ||
193 | + <el-button slot="reference" class="icon-tickets" type="primary" circle size="mini" | ||
194 | + icon="el-icon-tickets"></el-button> | ||
195 | + </el-popover> | ||
196 | + </div> | ||
197 | + <div class="qs-set"> | ||
198 | + <el-popover placement="right" width="600" trigger="click"> | ||
199 | + <div class="screenshot-box"> | ||
200 | + <iframe class="screenshot" | ||
201 | + v-if="subQuestions.answerScreenshot && subQuestions.answerScreenshot.includes('html')" | ||
202 | + :src="subQuestions.answerScreenshot"></iframe> | ||
203 | + <img class="screenshot screenshot-img" | ||
204 | + v-if="subQuestions.answerScreenshot && !subQuestions.answerScreenshot.includes('html')" | ||
205 | + :src="subQuestions.answerScreenshot" alt=""> | ||
206 | + <p style="textAlign:center"><el-button type="primary" round size="mini" icon="el-icon-upload" | ||
207 | + @click="openStem(subQuestions, 2, index, indexs)">重新选择图片</el-button></p> | ||
208 | + </div> | ||
209 | + <el-button slot="reference" class="icon-tickets" type="primary" circle size="mini" | ||
210 | + icon="el-icon-tickets"></el-button> | ||
211 | + </el-popover> | ||
212 | + </div> | ||
213 | + <div class="qs-set"> | ||
214 | + <el-button type="primary" circle size="mini" icon="el-icon-price-tag" | ||
215 | + @click="openKnowledge(subQuestions, index, indexs)"></el-button> | ||
216 | + </div> | ||
139 | </div> | 217 | </div> |
140 | </div> | 218 | </div> |
141 | </div> | 219 | </div> |
142 | - </div> | 220 | + </template> |
143 | </template> | 221 | </template> |
144 | </div> | 222 | </div> |
145 | <div class="btn-box"> | 223 | <div class="btn-box"> |
@@ -328,7 +406,7 @@ export default { | @@ -328,7 +406,7 @@ export default { | ||
328 | methods: { | 406 | methods: { |
329 | // v1.5 | 407 | // v1.5 |
330 | //上传截图 | 408 | //上传截图 |
331 | - openStem(obj, index, indexs, type) { | 409 | + openStem(obj, type, index, indexs) { |
332 | this.stem.index = index; | 410 | this.stem.index = index; |
333 | this.stem.indexs = indexs; | 411 | this.stem.indexs = indexs; |
334 | if (type == 1) { | 412 | if (type == 1) { |
@@ -346,18 +424,18 @@ export default { | @@ -346,18 +424,18 @@ export default { | ||
346 | if (res && res.status == 0) { | 424 | if (res && res.status == 0) { |
347 | this.stem.screenshot = res.data.url; | 425 | this.stem.screenshot = res.data.url; |
348 | if (this.stem.type == 1) { | 426 | if (this.stem.type == 1) { |
349 | - // if (this.form.examType == 2) { | ||
350 | - this.questionList[this.stem.index].subQuestions[this.stem.indexs].screenshot = this.stem.screenshot; | ||
351 | - // } else { | ||
352 | - // this.questionList[this.stem.index].screenshot = this.stem.screenshot; | ||
353 | - // } | 427 | + if (this.questionList[0]?.subQuestions) { |
428 | + this.questionList[this.stem.index].subQuestions[this.stem.indexs].screenshot = this.stem.screenshot; | ||
429 | + } else { | ||
430 | + this.questionList[this.stem.index].screenshot = this.stem.screenshot; | ||
431 | + } | ||
354 | 432 | ||
355 | } else { | 433 | } else { |
356 | - // if (this.form.examType == 2) { | ||
357 | - this.questionList[this.stem.index].subQuestions[this.stem.indexs].answerScreenshot = this.stem.answerScreenshot; | ||
358 | - // } else { | ||
359 | - // this.questionList[this.stem.index].answerScreenshot = this.stem.answerScreenshot; | ||
360 | - // } | 434 | + if (this.questionList[0]?.subQuestions) { |
435 | + this.questionList[this.stem.index].subQuestions[this.stem.indexs].answerScreenshot = this.stem.answerScreenshot; | ||
436 | + } else { | ||
437 | + this.questionList[this.stem.index].answerScreenshot = this.stem.answerScreenshot; | ||
438 | + } | ||
361 | 439 | ||
362 | } | 440 | } |
363 | 441 | ||
@@ -373,19 +451,19 @@ export default { | @@ -373,19 +451,19 @@ export default { | ||
373 | // 打开知识点 | 451 | // 打开知识点 |
374 | openKnowledge(obj, index, indexs) { | 452 | openKnowledge(obj, index, indexs) { |
375 | this.stem.index = index; | 453 | this.stem.index = index; |
376 | - this.stem.indexs = indexs; | 454 | + this.stem.indexs = indexs || 0; |
377 | this.stem.knowledge = (obj.knowledge && obj.knowledge.split(",")) || []; | 455 | this.stem.knowledge = (obj.knowledge && obj.knowledge.split(",")) || []; |
378 | this.dialogKnowledge = true; | 456 | this.dialogKnowledge = true; |
379 | }, | 457 | }, |
380 | // 选择知识点 | 458 | // 选择知识点 |
381 | setKnowledge() { | 459 | setKnowledge() { |
382 | - // if (this.form.examType == 2) { | ||
383 | - this.questionList[this.stem.index].subQuestions[ | ||
384 | - this.stem.indexs | ||
385 | - ].knowledge = this.stem.knowledge.join(","); | ||
386 | - // } else { | ||
387 | - // this.questionList[this.stem.index].knowledge = this.stem.knowledge.join(","); | ||
388 | - // } | 460 | + if (this.questionList[0]?.subQuestions) { |
461 | + this.questionList[this.stem.index].subQuestions[ | ||
462 | + this.stem.indexs | ||
463 | + ].knowledge = this.stem.knowledge.join(","); | ||
464 | + } else { | ||
465 | + this.questionList[this.stem.index].knowledge = this.stem.knowledge.join(","); | ||
466 | + } | ||
389 | this.dialogKnowledge = false; | 467 | this.dialogKnowledge = false; |
390 | }, | 468 | }, |
391 | //end | 469 | //end |
@@ -539,32 +617,32 @@ export default { | @@ -539,32 +617,32 @@ export default { | ||
539 | //初始化要修改的答案 | 617 | //初始化要修改的答案 |
540 | setFormAns(indexs, index) { | 618 | setFormAns(indexs, index) { |
541 | let answerList = ""; | 619 | let answerList = ""; |
542 | - // if (this.form.examType == 2) { | ||
543 | - this.formAns = { ...this.questionList[index].subQuestions[indexs] }; | ||
544 | - this.formAns.listIndex = index; | ||
545 | - let startIndex = indexs - this.formAns.subNum; //批量设置大难开始位置 | ||
546 | - this.questionList[index].subQuestions.map((item, subIdx) => { | ||
547 | - if (subIdx >= startIndex && subIdx < indexs) { | ||
548 | - answerList += this.setAnswer(item.questionType, item.correctAnswer); | ||
549 | - if (item.qusType == 3) { | ||
550 | - answerList = answerList.slice(0, -1); | 620 | + if (this.questionList[0]?.subQuestions) { |
621 | + this.formAns = { ...this.questionList[index].subQuestions[indexs] }; | ||
622 | + this.formAns.listIndex = index; | ||
623 | + let startIndex = indexs - this.formAns.subNum; //批量设置大难开始位置 | ||
624 | + this.questionList[index].subQuestions.map((item, subIdx) => { | ||
625 | + if (subIdx >= startIndex && subIdx < indexs) { | ||
626 | + answerList += this.setAnswer(item.questionType, item.correctAnswer); | ||
627 | + if (item.qusType == 3) { | ||
628 | + answerList = answerList.slice(0, -1); | ||
629 | + } | ||
551 | } | 630 | } |
552 | - } | ||
553 | - }); | ||
554 | - // } else { | ||
555 | - // this.formAns = { ...this.questionList[indexs] }; | ||
556 | - // let startIndex = indexs - this.formAns.subNum; //批量设置开始位置 | ||
557 | - // this.formAns.answerList = []; | ||
558 | - // this.formAns.listIndex = indexs; | ||
559 | - // this.questionList.map((item, subIdx) => { | ||
560 | - // if (subIdx >= startIndex && subIdx < indexs) { | ||
561 | - // answerList += this.setAnswer(item.questionType, item.correctAnswer); | ||
562 | - // if (item.qusType == 3) { | ||
563 | - // answerList = answerList.slice(0, -1); | ||
564 | - // } | ||
565 | - // } | ||
566 | - // }); | ||
567 | - // } | 631 | + }); |
632 | + } else { | ||
633 | + this.formAns = { ...this.questionList[indexs] }; | ||
634 | + let startIndex = indexs - this.formAns.subNum; //批量设置开始位置 | ||
635 | + this.formAns.answerList = []; | ||
636 | + this.formAns.listIndex = indexs; | ||
637 | + this.questionList.map((item, subIdx) => { | ||
638 | + if (subIdx >= startIndex && subIdx < indexs) { | ||
639 | + answerList += this.setAnswer(item.questionType, item.correctAnswer); | ||
640 | + if (item.qusType == 3) { | ||
641 | + answerList = answerList.slice(0, -1); | ||
642 | + } | ||
643 | + } | ||
644 | + }); | ||
645 | + } | ||
568 | this.formAns.answerList = answerList; | 646 | this.formAns.answerList = answerList; |
569 | this.diaSetAns = true; | 647 | this.diaSetAns = true; |
570 | }, | 648 | }, |
@@ -572,23 +650,23 @@ export default { | @@ -572,23 +650,23 @@ export default { | ||
572 | //批量修改答案 | 650 | //批量修改答案 |
573 | let EndIndex; | 651 | let EndIndex; |
574 | let subNum = this.formAns.subNum - 1; | 652 | let subNum = this.formAns.subNum - 1; |
575 | - // if (this.form.examType == 2) { | ||
576 | - this.questionList[this.formAns.listIndex].subQuestions.some( | ||
577 | - (item, index) => { | 653 | + if (this.questionList[0]?.subQuestions) { |
654 | + this.questionList[this.formAns.listIndex].subQuestions.some( | ||
655 | + (item, index) => { | ||
656 | + if (this.formAns.endIndex == item.questionIndex) { | ||
657 | + EndIndex = index; | ||
658 | + } | ||
659 | + return this.formAns.endIndex == item.questionIndex | ||
660 | + } | ||
661 | + ); | ||
662 | + } else { | ||
663 | + this.questionList.some((item, index) => { | ||
578 | if (this.formAns.endIndex == item.questionIndex) { | 664 | if (this.formAns.endIndex == item.questionIndex) { |
579 | EndIndex = index; | 665 | EndIndex = index; |
580 | } | 666 | } |
581 | return this.formAns.endIndex == item.questionIndex | 667 | return this.formAns.endIndex == item.questionIndex |
582 | - } | ||
583 | - ); | ||
584 | - // } else { | ||
585 | - // this.questionList.some((item, index) => { | ||
586 | - // if (this.formAns.endIndex == item.questionIndex) { | ||
587 | - // EndIndex = index; | ||
588 | - // } | ||
589 | - // return this.formAns.endIndex == item.questionIndex | ||
590 | - // }); | ||
591 | - // } | 668 | + }); |
669 | + } | ||
592 | 670 | ||
593 | for (let i = 0; i <= subNum; i++) { | 671 | for (let i = 0; i <= subNum; i++) { |
594 | let correctAnswer = ""; | 672 | let correctAnswer = ""; |
@@ -604,30 +682,30 @@ export default { | @@ -604,30 +682,30 @@ export default { | ||
604 | ? 2 | 682 | ? 2 |
605 | : ""; | 683 | : ""; |
606 | } | 684 | } |
607 | - // if (this.form.examType == 2) { | ||
608 | - this.questionList[this.formAns.listIndex].subQuestions[ | ||
609 | - EndIndex - i | ||
610 | - ].correctAnswer = correctAnswer; | ||
611 | - // } else { | ||
612 | - // this.questionList[EndIndex - i].correctAnswer = correctAnswer; | ||
613 | - // } | 685 | + if (this.questionList[0]?.subQuestions) { |
686 | + this.questionList[this.formAns.listIndex].subQuestions[ | ||
687 | + EndIndex - i | ||
688 | + ].correctAnswer = correctAnswer; | ||
689 | + } else { | ||
690 | + this.questionList[EndIndex - i].correctAnswer = correctAnswer; | ||
691 | + } | ||
614 | } | 692 | } |
615 | this.diaSetAns = false; | 693 | this.diaSetAns = false; |
616 | }, | 694 | }, |
617 | async save() { | 695 | async save() { |
618 | for (let i = 0; i < this.questionList.length; i++) { | 696 | for (let i = 0; i < this.questionList.length; i++) { |
619 | - // if (this.form.examType == 2) { | ||
620 | - for (let j = 0; j < this.questionList[i].subQuestions.length; j++) { | ||
621 | - if (this.questionList[i].subQuestions[j].qusType) { | ||
622 | - this.questionList[i].subQuestions.splice(j, 1); | 697 | + if (this.questionList[0]?.subQuestions) { |
698 | + for (let j = 0; j < this.questionList[i].subQuestions.length; j++) { | ||
699 | + if (this.questionList[i].subQuestions[j].qusType) { | ||
700 | + this.questionList[i].subQuestions.splice(j, 1); | ||
701 | + } | ||
702 | + } | ||
703 | + } else { | ||
704 | + if (this.questionList[i].qusType) { | ||
705 | + this.questionList.splice(i, 1); | ||
706 | + i--; | ||
623 | } | 707 | } |
624 | } | 708 | } |
625 | - // } else { | ||
626 | - // if (this.questionList[i].qusType) { | ||
627 | - // this.questionList.splice(i, 1); | ||
628 | - // i--; | ||
629 | - // } | ||
630 | - // } | ||
631 | } | 709 | } |
632 | let questionList = this.questionList.map((item) => { | 710 | let questionList = this.questionList.map((item) => { |
633 | item.score = null; | 711 | item.score = null; |
@@ -722,11 +800,72 @@ export default { | @@ -722,11 +800,72 @@ export default { | ||
722 | } | 800 | } |
723 | }, | 801 | }, |
724 | formateQuestion() { | 802 | formateQuestion() { |
725 | - // if (this.form.examType == 2) { | ||
726 | - this.questionList?.map((item) => { | 803 | + if (this.questionList[0]?.subQuestions) { |
804 | + this.questionList?.map((item) => { | ||
805 | + let types = [{}]; | ||
806 | + let addndex = 0; | ||
807 | + item.subQuestions.map((sub, index) => { | ||
808 | + if (!!sub.questionType) { | ||
809 | + if ( | ||
810 | + sub.questionType == types[addndex].qusType && | ||
811 | + sub.questionType != 5 | ||
812 | + ) { | ||
813 | + //同类型批量答案+1 | ||
814 | + types[addndex].subNum += 1; | ||
815 | + if ( | ||
816 | + types[addndex].answerOptions.length < | ||
817 | + sub.answerOptions.length | ||
818 | + ) { | ||
819 | + types[addndex].answerOptions = sub.answerOptions; | ||
820 | + } | ||
821 | + types[addndex].answerList += this.setAnswer( | ||
822 | + sub.questionType, | ||
823 | + sub.correctAnswer | ||
824 | + ); | ||
825 | + if (index == item.subQuestions.length - 1) { | ||
826 | + //循环最后类型数量大于等于5,保存批量答案 | ||
827 | + if (types[addndex].subNum && types[addndex].subNum >= 5) { | ||
828 | + types[addndex].endIndex = sub.questionIndex; | ||
829 | + types[addndex].index = index; | ||
830 | + } | ||
831 | + } | ||
832 | + } else { | ||
833 | + if (types[addndex].subNum && types[addndex].subNum >= 5) { | ||
834 | + //不同类型时如果原有类型数量大于等于5,保存批量答案 | ||
835 | + types[addndex].endIndex = | ||
836 | + item.subQuestions[index - 1].questionIndex; | ||
837 | + types[addndex].index = index - 1; | ||
838 | + addndex += 1; | ||
839 | + types[addndex] = {}; | ||
840 | + } | ||
841 | + //不同类型初始化批量答案 | ||
842 | + types[addndex].qusType = sub.questionType; | ||
843 | + types[addndex].subNum = 1; | ||
844 | + types[addndex].answerOptions = sub.answerOptions; | ||
845 | + types[addndex].answerList = this.setAnswer( | ||
846 | + sub.questionType, | ||
847 | + sub.correctAnswer | ||
848 | + ); | ||
849 | + } | ||
850 | + } | ||
851 | + }); | ||
852 | + for (let i = 0; i < types.length; i++) { | ||
853 | + if (types[i].qusType == 3) { | ||
854 | + types[i].answerList = types[i].answerList.slice(0, -1); | ||
855 | + } | ||
856 | + if (types[i].subNum >= 5) { | ||
857 | + item.subQuestions.splice( | ||
858 | + types[i].index + i + 1, | ||
859 | + 0, | ||
860 | + deepClone(types[i]) | ||
861 | + ); | ||
862 | + } | ||
863 | + } | ||
864 | + }); | ||
865 | + } else { | ||
727 | let types = [{}]; | 866 | let types = [{}]; |
728 | let addndex = 0; | 867 | let addndex = 0; |
729 | - item.subQuestions.map((sub, index) => { | 868 | + this.questionList?.map((sub, index) => { |
730 | if (!!sub.questionType) { | 869 | if (!!sub.questionType) { |
731 | if ( | 870 | if ( |
732 | sub.questionType == types[addndex].qusType && | 871 | sub.questionType == types[addndex].qusType && |
@@ -735,8 +874,7 @@ export default { | @@ -735,8 +874,7 @@ export default { | ||
735 | //同类型批量答案+1 | 874 | //同类型批量答案+1 |
736 | types[addndex].subNum += 1; | 875 | types[addndex].subNum += 1; |
737 | if ( | 876 | if ( |
738 | - types[addndex].answerOptions.length < | ||
739 | - sub.answerOptions.length | 877 | + types[addndex].answerOptions.length < sub.answerOptions.length |
740 | ) { | 878 | ) { |
741 | types[addndex].answerOptions = sub.answerOptions; | 879 | types[addndex].answerOptions = sub.answerOptions; |
742 | } | 880 | } |
@@ -744,7 +882,7 @@ export default { | @@ -744,7 +882,7 @@ export default { | ||
744 | sub.questionType, | 882 | sub.questionType, |
745 | sub.correctAnswer | 883 | sub.correctAnswer |
746 | ); | 884 | ); |
747 | - if (index == item.subQuestions.length - 1) { | 885 | + if (index == this.questionList.length - 1) { |
748 | //循环最后类型数量大于等于5,保存批量答案 | 886 | //循环最后类型数量大于等于5,保存批量答案 |
749 | if (types[addndex].subNum && types[addndex].subNum >= 5) { | 887 | if (types[addndex].subNum && types[addndex].subNum >= 5) { |
750 | types[addndex].endIndex = sub.questionIndex; | 888 | types[addndex].endIndex = sub.questionIndex; |
@@ -755,7 +893,7 @@ export default { | @@ -755,7 +893,7 @@ export default { | ||
755 | if (types[addndex].subNum && types[addndex].subNum >= 5) { | 893 | if (types[addndex].subNum && types[addndex].subNum >= 5) { |
756 | //不同类型时如果原有类型数量大于等于5,保存批量答案 | 894 | //不同类型时如果原有类型数量大于等于5,保存批量答案 |
757 | types[addndex].endIndex = | 895 | types[addndex].endIndex = |
758 | - item.subQuestions[index - 1].questionIndex; | 896 | + this.questionList[index - 1].questionIndex; |
759 | types[addndex].index = index - 1; | 897 | types[addndex].index = index - 1; |
760 | addndex += 1; | 898 | addndex += 1; |
761 | types[addndex] = {}; | 899 | types[addndex] = {}; |
@@ -776,74 +914,14 @@ export default { | @@ -776,74 +914,14 @@ export default { | ||
776 | types[i].answerList = types[i].answerList.slice(0, -1); | 914 | types[i].answerList = types[i].answerList.slice(0, -1); |
777 | } | 915 | } |
778 | if (types[i].subNum >= 5) { | 916 | if (types[i].subNum >= 5) { |
779 | - item.subQuestions.splice( | 917 | + this.questionList.splice( |
780 | types[i].index + i + 1, | 918 | types[i].index + i + 1, |
781 | 0, | 919 | 0, |
782 | deepClone(types[i]) | 920 | deepClone(types[i]) |
783 | ); | 921 | ); |
784 | } | 922 | } |
785 | } | 923 | } |
786 | - }); | ||
787 | - // } else { | ||
788 | - // let types = [{}]; | ||
789 | - // let addndex = 0; | ||
790 | - // this.questionList?.map((sub, index) => { | ||
791 | - // if (!!sub.questionType) { | ||
792 | - // if ( | ||
793 | - // sub.questionType == types[addndex].qusType && | ||
794 | - // sub.questionType != 5 | ||
795 | - // ) { | ||
796 | - // //同类型批量答案+1 | ||
797 | - // types[addndex].subNum += 1; | ||
798 | - // if ( | ||
799 | - // types[addndex].answerOptions.length < sub.answerOptions.length | ||
800 | - // ) { | ||
801 | - // types[addndex].answerOptions = sub.answerOptions; | ||
802 | - // } | ||
803 | - // types[addndex].answerList += this.setAnswer( | ||
804 | - // sub.questionType, | ||
805 | - // sub.correctAnswer | ||
806 | - // ); | ||
807 | - // if (index == this.questionList.length - 1) { | ||
808 | - // //循环最后类型数量大于等于5,保存批量答案 | ||
809 | - // if (types[addndex].subNum && types[addndex].subNum >= 5) { | ||
810 | - // types[addndex].endIndex = sub.questionIndex; | ||
811 | - // types[addndex].index = index; | ||
812 | - // } | ||
813 | - // } | ||
814 | - // } else { | ||
815 | - // if (types[addndex].subNum && types[addndex].subNum >= 5) { | ||
816 | - // //不同类型时如果原有类型数量大于等于5,保存批量答案 | ||
817 | - // types[addndex].endIndex = | ||
818 | - // this.questionList[index - 1].questionIndex; | ||
819 | - // types[addndex].index = index - 1; | ||
820 | - // addndex += 1; | ||
821 | - // types[addndex] = {}; | ||
822 | - // } | ||
823 | - // //不同类型初始化批量答案 | ||
824 | - // types[addndex].qusType = sub.questionType; | ||
825 | - // types[addndex].subNum = 1; | ||
826 | - // types[addndex].answerOptions = sub.answerOptions; | ||
827 | - // types[addndex].answerList = this.setAnswer( | ||
828 | - // sub.questionType, | ||
829 | - // sub.correctAnswer | ||
830 | - // ); | ||
831 | - // } | ||
832 | - // } | ||
833 | - // }); | ||
834 | - // for (let i = 0; i < types.length; i++) { | ||
835 | - // if (types[i].qusType == 3) { | ||
836 | - // types[i].answerList = types[i].answerList.slice(0, -1); | ||
837 | - // } | ||
838 | - // if (types[i].subNum >= 5) { | ||
839 | - // this.questionList.splice( | ||
840 | - // types[i].index + i + 1, | ||
841 | - // 0, | ||
842 | - // deepClone(types[i]) | ||
843 | - // ); | ||
844 | - // } | ||
845 | - // } | ||
846 | - // } | 924 | + } |
847 | }, | 925 | }, |
848 | }, | 926 | }, |
849 | }; | 927 | }; |
@@ -1060,7 +1138,8 @@ export default { | @@ -1060,7 +1138,8 @@ export default { | ||
1060 | .stem-pic { | 1138 | .stem-pic { |
1061 | display: block; | 1139 | display: block; |
1062 | margin: 0 auto 20px; | 1140 | margin: 0 auto 20px; |
1063 | - height: 200px; | 1141 | + max-width: 100%; |
1142 | + max-height: 200px; | ||
1064 | object-fit: cover; | 1143 | object-fit: cover; |
1065 | } | 1144 | } |
1066 | } | 1145 | } |
src/views/examinationPaper/edit_Old.vue
@@ -1262,7 +1262,8 @@ export default { | @@ -1262,7 +1262,8 @@ export default { | ||
1262 | .stem-pic { | 1262 | .stem-pic { |
1263 | display: block; | 1263 | display: block; |
1264 | margin: 0 auto 20px; | 1264 | margin: 0 auto 20px; |
1265 | - height: 200px; | 1265 | + max-width: 100%; |
1266 | + max-height: 200px; | ||
1266 | object-fit: cover; | 1267 | object-fit: cover; |
1267 | } | 1268 | } |
1268 | } | 1269 | } |
src/views/examinationPaper/index.vue
@@ -70,8 +70,10 @@ | @@ -70,8 +70,10 @@ | ||
70 | <p class="num"> | 70 | <p class="num"> |
71 | 总题数:{{ item.questionNum }} | 71 | 总题数:{{ item.questionNum }} |
72 | <em class="s-line">|</em> | 72 | <em class="s-line">|</em> |
73 | - 预计时长:{{ item.examsDuration }} | ||
74 | - <em class="s-line">|</em> | 73 | + <template v-if="query.type == 2"> |
74 | + 预计时长:{{ item.examsDuration }} | ||
75 | + <em class="s-line">|</em> | ||
76 | + </template> | ||
75 | <template v-if="role != 'ROLE_PERSONAL'"> | 77 | <template v-if="role != 'ROLE_PERSONAL'"> |
76 | 授课端同步: | 78 | 授课端同步: |
77 | <span class="clazz" v-for="(clazzChild, indexs) in item.classList" :key="clazzChild.classId" | 79 | <span class="clazz" v-for="(clazzChild, indexs) in item.classList" :key="clazzChild.classId" |
@@ -100,7 +102,7 @@ | @@ -100,7 +102,7 @@ | ||
100 | <el-dropdown-item :command="1" | 102 | <el-dropdown-item :command="1" |
101 | v-if="userName == item.realName && role != 'ROLE_PERSONAL'">修改分享范围</el-dropdown-item> | 103 | v-if="userName == item.realName && role != 'ROLE_PERSONAL'">修改分享范围</el-dropdown-item> |
102 | <el-dropdown-item v-show="query.type == 2" :command="2">复制</el-dropdown-item> | 104 | <el-dropdown-item v-show="query.type == 2" :command="2">复制</el-dropdown-item> |
103 | - <el-dropdown-item :command="3">放入回收站</el-dropdown-item> | 105 | + <el-dropdown-item v-show="query.share == 0" :command="3">放入回收站</el-dropdown-item> |
104 | </el-dropdown-menu> | 106 | </el-dropdown-menu> |
105 | </el-dropdown> | 107 | </el-dropdown> |
106 | </div> | 108 | </div> |
@@ -196,6 +198,8 @@ export default { | @@ -196,6 +198,8 @@ export default { | ||
196 | this.$store.getters.info.showRole || | 198 | this.$store.getters.info.showRole || |
197 | this.$store.getters.info.permissions[0].role; | 199 | this.$store.getters.info.permissions[0].role; |
198 | this.userName = this.$store.getters.info.name || ""; | 200 | this.userName = this.$store.getters.info.name || ""; |
201 | + this.query.type = this.$route.query.type || 1; | ||
202 | + this.query.share = this.$route.query.share || 0; | ||
199 | this._QueryClassList2() | 203 | this._QueryClassList2() |
200 | await this._QueryClassList(); | 204 | await this._QueryClassList(); |
201 | if (!this.query.classId) { | 205 | if (!this.query.classId) { |
@@ -206,8 +210,9 @@ export default { | @@ -206,8 +210,9 @@ export default { | ||
206 | }, | 210 | }, |
207 | methods: { | 211 | methods: { |
208 | refreshStic() { | 212 | refreshStic() { |
209 | - setTimeout(function () { | ||
210 | - window.location.reload(); | 213 | + this.loading = true; |
214 | + setTimeout(() => { | ||
215 | + this._QueryData(); | ||
211 | }, 500); | 216 | }, 500); |
212 | }, | 217 | }, |
213 | toArchiving() { | 218 | toArchiving() { |
@@ -223,6 +228,8 @@ export default { | @@ -223,6 +228,8 @@ export default { | ||
223 | } | 228 | } |
224 | let routerItem = { | 229 | let routerItem = { |
225 | path: "/examinationPaperAdd", | 230 | path: "/examinationPaperAdd", |
231 | + listType: this.query.type, | ||
232 | + listShare: this.query.share, | ||
226 | }; | 233 | }; |
227 | query ? (routerItem["query"] = { ...query }) : ""; | 234 | query ? (routerItem["query"] = { ...query }) : ""; |
228 | this.$router.push(routerItem); | 235 | this.$router.push(routerItem); |
@@ -235,6 +242,8 @@ export default { | @@ -235,6 +242,8 @@ export default { | ||
235 | } | 242 | } |
236 | let routerItem = { | 243 | let routerItem = { |
237 | path: "/examinationPaperAddAsk", | 244 | path: "/examinationPaperAddAsk", |
245 | + listType: this.query.type, | ||
246 | + listShare: this.query.share, | ||
238 | }; | 247 | }; |
239 | query ? (routerItem["query"] = { ...query }) : ""; | 248 | query ? (routerItem["query"] = { ...query }) : ""; |
240 | this.$router.push(routerItem); | 249 | this.$router.push(routerItem); |
src/views/examinationPaper/recycle.vue
@@ -21,60 +21,26 @@ | @@ -21,60 +21,26 @@ | ||
21 | <span v-if="!node.isLeaf"> ({{ data.children.length }}) </span> | 21 | <span v-if="!node.isLeaf"> ({{ data.children.length }}) </span> |
22 | </template></el-cascader | 22 | </template></el-cascader |
23 | > --> | 23 | > --> |
24 | - <el-select | ||
25 | - class="sel" | ||
26 | - v-model="query.classId" | ||
27 | - placeholder="选择班级" | ||
28 | - @change="changClazz" | ||
29 | - > | ||
30 | - <el-option | ||
31 | - v-for="item in classList" | ||
32 | - :key="item.value" | ||
33 | - :label="item.label" | ||
34 | - :value="item.value" | ||
35 | - > | 24 | + <el-select class="sel" v-model="query.type" placeholder="选择类型" @change="_QueryData()"> |
25 | + <el-option label="备题" :value="1"></el-option> | ||
26 | + <el-option label="组卷" :value="2"></el-option> | ||
27 | + </el-select> | ||
28 | + <el-select class="sel" v-model="query.classId" placeholder="选择班级" @change="changClazz"> | ||
29 | + <el-option v-for="item in classList" :key="item.value" :label="item.label" :value="item.value"> | ||
36 | </el-option> | 30 | </el-option> |
37 | </el-select> | 31 | </el-select> |
38 | - <el-select | ||
39 | - class="sel" | ||
40 | - v-model="query.subjectName" | ||
41 | - placeholder="选择科目" | ||
42 | - @change="_QueryData()" | ||
43 | - > | ||
44 | - <el-option | ||
45 | - v-for="item in subjectList" | ||
46 | - :key="item.value" | ||
47 | - :label="item.label" | ||
48 | - :value="item.value" | ||
49 | - > | 32 | + <el-select class="sel" v-model="query.subjectName" placeholder="选择科目" @change="_QueryData()"> |
33 | + <el-option v-for="item in subjectList" :key="item.value" :label="item.label" :value="item.value"> | ||
50 | </el-option> | 34 | </el-option> |
51 | </el-select> | 35 | </el-select> |
52 | - <el-select | ||
53 | - class="sel" | ||
54 | - v-model="query.tagId" | ||
55 | - placeholder="选择类型" | ||
56 | - @change="_QueryData()" | ||
57 | - > | ||
58 | - <el-option | ||
59 | - v-for="item in typeList" | ||
60 | - :key="item.label" | ||
61 | - :label="item.label" | ||
62 | - :value="item.value" | ||
63 | - >{{ item.label }} | 36 | + <el-select class="sel" v-model="query.tagId" placeholder="选择类型" @change="_QueryData()"> |
37 | + <el-option v-for="item in typeList" :key="item.label" :label="item.label" :value="item.value">{{ item.label }} | ||
64 | </el-option> | 38 | </el-option> |
65 | </el-select> | 39 | </el-select> |
66 | 40 | ||
67 | - <el-input | ||
68 | - placeholder="输入试卷名称" | ||
69 | - v-model="query.title" | ||
70 | - class="input-with-select" | ||
71 | - @keyup.enter.native="_QueryData(true)" | ||
72 | - > | ||
73 | - <el-button | ||
74 | - slot="append" | ||
75 | - icon="el-icon-search" | ||
76 | - @click="_QueryData(true)" | ||
77 | - ></el-button> | 41 | + <el-input placeholder="输入试卷名称" v-model="query.title" class="input-with-select" |
42 | + @keyup.enter.native="_QueryData(true)"> | ||
43 | + <el-button slot="append" icon="el-icon-search" @click="_QueryData(true)"></el-button> | ||
78 | </el-input> | 44 | </el-input> |
79 | </div> | 45 | </div> |
80 | </div> | 46 | </div> |
@@ -97,51 +63,26 @@ | @@ -97,51 +63,26 @@ | ||
97 | 预计时长:{{ item.examsDuration }} | 63 | 预计时长:{{ item.examsDuration }} |
98 | </p> | 64 | </p> |
99 | <p class="person"> | 65 | <p class="person"> |
100 | - {{ item.realName }}<em class="s-line">|</em | ||
101 | - ><span class="date">{{ item.modifiedTime }}</span> | 66 | + {{ item.realName }}<em class="s-line">|</em><span class="date">{{ item.modifiedTime }}</span> |
102 | </p> | 67 | </p> |
103 | </div> | 68 | </div> |
104 | <div class="btn-box"> | 69 | <div class="btn-box"> |
105 | <el-tooltip effect="dark" content="恢复" placement="bottom"> | 70 | <el-tooltip effect="dark" content="恢复" placement="bottom"> |
106 | - <el-button | ||
107 | - class="edit" | ||
108 | - type="info" | ||
109 | - size="mini" | ||
110 | - circle | ||
111 | - icon="fa fa-mail-reply" | ||
112 | - @click="modify(item)" | ||
113 | - ></el-button> | 71 | + <el-button class="edit" type="info" size="mini" circle icon="fa fa-mail-reply" |
72 | + @click="modify(item)"></el-button> | ||
114 | </el-tooltip> | 73 | </el-tooltip> |
115 | <el-popconfirm title="确定删除这张答题卡吗?" @confirm="remove(item)"> | 74 | <el-popconfirm title="确定删除这张答题卡吗?" @confirm="remove(item)"> |
116 | - <el-button | ||
117 | - slot="reference" | ||
118 | - class="delete" | ||
119 | - type="info" | ||
120 | - size="mini" | ||
121 | - circle | ||
122 | - icon="el-icon-delete" | ||
123 | - ></el-button> | 75 | + <el-button slot="reference" class="delete" type="info" size="mini" circle icon="el-icon-delete"></el-button> |
124 | </el-popconfirm> | 76 | </el-popconfirm> |
125 | </div> | 77 | </div> |
126 | </li> | 78 | </li> |
127 | </ul> | 79 | </ul> |
128 | <div class="pagination-box"> | 80 | <div class="pagination-box"> |
129 | - <el-pagination | ||
130 | - small="" | ||
131 | - layout="total,prev, pager, next" | ||
132 | - :hide-on-single-page="true" | ||
133 | - :total="total" | ||
134 | - @current-change="changePage" | ||
135 | - :current-page="page" | ||
136 | - :page-size="size" | ||
137 | - > | 81 | + <el-pagination small="" layout="total,prev, pager, next" :hide-on-single-page="true" :total="total" |
82 | + @current-change="changePage" :current-page="page" :page-size="size"> | ||
138 | </el-pagination> | 83 | </el-pagination> |
139 | </div> | 84 | </div> |
140 | - <el-empty | ||
141 | - :image-size="100" | ||
142 | - v-if="!tableData.length && loading == false" | ||
143 | - description="没有更多数据" | ||
144 | - ></el-empty> | 85 | + <el-empty :image-size="100" v-if="!tableData.length && loading == false" description="没有更多数据"></el-empty> |
145 | </div> | 86 | </div> |
146 | </template> | 87 | </template> |
147 | 88 | ||
@@ -183,6 +124,7 @@ export default { | @@ -183,6 +124,7 @@ export default { | ||
183 | }, | 124 | }, |
184 | ], | 125 | ], |
185 | query: { | 126 | query: { |
127 | + type: 1, | ||
186 | classId: "", | 128 | classId: "", |
187 | subjectName: "", | 129 | subjectName: "", |
188 | tagId: "", | 130 | tagId: "", |
@@ -258,8 +200,6 @@ export default { | @@ -258,8 +200,6 @@ export default { | ||
258 | query = { ...this.query }; | 200 | query = { ...this.query }; |
259 | } else { | 201 | } else { |
260 | query = { title: this.query.title }; | 202 | query = { title: this.query.title }; |
261 | - this.query.type = ""; | ||
262 | - this.query.subjectId = ""; | ||
263 | } | 203 | } |
264 | query.classId = this.query.classId; | 204 | query.classId = this.query.classId; |
265 | for (let key in query) { | 205 | for (let key in query) { |
@@ -309,7 +249,7 @@ export default { | @@ -309,7 +249,7 @@ export default { | ||
309 | }, | 249 | }, |
310 | // 查找科目 | 250 | // 查找科目 |
311 | async _QuerySubjectList() { | 251 | async _QuerySubjectList() { |
312 | - let fetchSubjectList = | 252 | + let fetchSubjectList = |
313 | this.role == "ROLE_PERSONAL" | 253 | this.role == "ROLE_PERSONAL" |
314 | ? this.$request.pSubjectList | 254 | ? this.$request.pSubjectList |
315 | : this.$request.fetchSubjectList; | 255 | : this.$request.fetchSubjectList; |
@@ -332,7 +272,7 @@ export default { | @@ -332,7 +272,7 @@ export default { | ||
332 | }, | 272 | }, |
333 | // 查找答题卡类型 | 273 | // 查找答题卡类型 |
334 | async _QueryTypeList() { | 274 | async _QueryTypeList() { |
335 | - let fetchTypeNames = | 275 | + let fetchTypeNames = |
336 | this.role == "ROLE_PERSONAL" | 276 | this.role == "ROLE_PERSONAL" |
337 | ? this.$request.pPaperTagList | 277 | ? this.$request.pPaperTagList |
338 | : this.$request.fetchTypeNames; | 278 | : this.$request.fetchTypeNames; |
@@ -367,16 +307,19 @@ export default { | @@ -367,16 +307,19 @@ export default { | ||
367 | .sel { | 307 | .sel { |
368 | min-width: 160px; | 308 | min-width: 160px; |
369 | } | 309 | } |
310 | + | ||
370 | :deep(.el-cascader__tags) { | 311 | :deep(.el-cascader__tags) { |
371 | flex-wrap: nowrap; | 312 | flex-wrap: nowrap; |
372 | } | 313 | } |
373 | } | 314 | } |
374 | } | 315 | } |
316 | + | ||
375 | .content { | 317 | .content { |
376 | margin: 0 20px; | 318 | margin: 0 20px; |
377 | background: #f8f8f8; | 319 | background: #f8f8f8; |
378 | padding: 12px; | 320 | padding: 12px; |
379 | border-radius: 20px; | 321 | border-radius: 20px; |
322 | + | ||
380 | .item { | 323 | .item { |
381 | display: flex; | 324 | display: flex; |
382 | align-items: center; | 325 | align-items: center; |
@@ -387,9 +330,11 @@ export default { | @@ -387,9 +330,11 @@ export default { | ||
387 | border-radius: 20px; | 330 | border-radius: 20px; |
388 | background: #fff; | 331 | background: #fff; |
389 | margin-bottom: 12px; | 332 | margin-bottom: 12px; |
333 | + | ||
390 | &:last-of-type { | 334 | &:last-of-type { |
391 | margin-bottom: 0; | 335 | margin-bottom: 0; |
392 | } | 336 | } |
337 | + | ||
393 | .pic-box { | 338 | .pic-box { |
394 | width: 80px; | 339 | width: 80px; |
395 | height: 80px; | 340 | height: 80px; |
@@ -400,12 +345,14 @@ export default { | @@ -400,12 +345,14 @@ export default { | ||
400 | text-align: center; | 345 | text-align: center; |
401 | color: #fff; | 346 | color: #fff; |
402 | font-weight: 500; | 347 | font-weight: 500; |
348 | + | ||
403 | .i-box { | 349 | .i-box { |
404 | padding-top: 10px; | 350 | padding-top: 10px; |
405 | font-size: 32px; | 351 | font-size: 32px; |
406 | margin-bottom: 3px; | 352 | margin-bottom: 3px; |
407 | } | 353 | } |
408 | } | 354 | } |
355 | + | ||
409 | .info { | 356 | .info { |
410 | height: 80px; | 357 | height: 80px; |
411 | flex: 1; | 358 | flex: 1; |
@@ -413,14 +360,17 @@ export default { | @@ -413,14 +360,17 @@ export default { | ||
413 | display: flex; | 360 | display: flex; |
414 | flex-direction: column; | 361 | flex-direction: column; |
415 | justify-content: space-between; | 362 | justify-content: space-between; |
363 | + | ||
416 | .s-line { | 364 | .s-line { |
417 | padding: 0 5px; | 365 | padding: 0 5px; |
418 | color: #e2e2e2; | 366 | color: #e2e2e2; |
419 | } | 367 | } |
368 | + | ||
420 | .title { | 369 | .title { |
421 | font-size: 16px; | 370 | font-size: 16px; |
422 | color: #222; | 371 | color: #222; |
423 | font-weight: 500; | 372 | font-weight: 500; |
373 | + | ||
424 | .label { | 374 | .label { |
425 | display: inline-block; | 375 | display: inline-block; |
426 | font-size: 12px; | 376 | font-size: 12px; |
@@ -432,12 +382,15 @@ export default { | @@ -432,12 +382,15 @@ export default { | ||
432 | transform: translateY(-2px); | 382 | transform: translateY(-2px); |
433 | } | 383 | } |
434 | } | 384 | } |
385 | + | ||
435 | .person { | 386 | .person { |
436 | color: #666; | 387 | color: #666; |
437 | } | 388 | } |
438 | } | 389 | } |
390 | + | ||
439 | .btn-box { | 391 | .btn-box { |
440 | flex-shrink: 0; | 392 | flex-shrink: 0; |
393 | + | ||
441 | .edit { | 394 | .edit { |
442 | margin-right: 12px; | 395 | margin-right: 12px; |
443 | } | 396 | } |