UploadStructure.vue 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. <template>
  2. <div class="upload-structure">
  3. <div class="part-box part-box-filter part-box-flex">
  4. <el-form ref="FilterForm" label-position="left" inline>
  5. <template v-if="checkPrivilege('condition', 'condition')">
  6. <el-form-item label="学期:">
  7. <semester-select v-model="filter.semesterId"></semester-select>
  8. </el-form-item>
  9. <el-form-item label="考试:">
  10. <exam-select
  11. v-model="filter.examId"
  12. :semester-id="filter.semesterId"
  13. ></exam-select>
  14. </el-form-item>
  15. </template>
  16. <el-form-item label-width="0px">
  17. <el-button
  18. v-if="checkPrivilege('button', 'select')"
  19. type="primary"
  20. @click="toPage(1)"
  21. >查询</el-button
  22. >
  23. </el-form-item>
  24. </el-form>
  25. </div>
  26. <div class="part-box part-box-pad">
  27. <el-table ref="TableList" :data="dataList">
  28. <el-table-column
  29. prop="thirdRelateId"
  30. label="云阅卷考试ID"
  31. width="120"
  32. ></el-table-column>
  33. <el-table-column
  34. prop="thirdRelateName"
  35. label="云阅卷考试名称"
  36. ></el-table-column>
  37. <el-table-column prop="courseName" label="课程(代码)">
  38. <span slot-scope="scope">
  39. {{ scope.row.courseName }}({{ scope.row.courseCode }})
  40. </span>
  41. </el-table-column>
  42. <el-table-column prop="paperNumber" label="试卷编号"></el-table-column>
  43. <el-table-column
  44. prop="paperType"
  45. label="试卷类型"
  46. width="100"
  47. ></el-table-column>
  48. <el-table-column prop="status" label="状态" width="100">
  49. <template slot-scope="scope">
  50. {{ scope.row.status | markTaskSyncStatusFilter }}
  51. </template>
  52. </el-table-column>
  53. <el-table-column class-name="action-column" label="操作" width="220px">
  54. <template slot-scope="scope">
  55. <el-button
  56. class="btn-primary"
  57. type="text"
  58. @click="toSetParams(scope.row)"
  59. >评卷参数设置</el-button
  60. >
  61. <el-button
  62. class="btn-primary"
  63. type="text"
  64. :disabled="!scope.row.paperInfoJson"
  65. @click="toSetAnswer(scope.row)"
  66. >设置客观题标答</el-button
  67. >
  68. <el-button
  69. v-if="checkPrivilege('link', 'Upload')"
  70. class="btn-primary"
  71. type="text"
  72. :disabled="!scope.row.paperInfoJson"
  73. @click="toUpload(scope.row)"
  74. >上传标答文件</el-button
  75. >
  76. <el-button
  77. v-if="
  78. checkPrivilege('link', 'Preview') &&
  79. scope.row.status === 'FINISH'
  80. "
  81. class="btn-primary"
  82. type="text"
  83. :disabled="!scope.row.paperAnswer"
  84. @click="toViewAnswer(scope.row, scope.row.paperType)"
  85. >查看标答文件</el-button
  86. >
  87. </template>
  88. </el-table-column>
  89. </el-table>
  90. <div class="part-page">
  91. <el-pagination
  92. background
  93. layout="total,prev, pager, next"
  94. :current-page="current"
  95. :total="total"
  96. :page-size="size"
  97. @current-change="toPage"
  98. >
  99. </el-pagination>
  100. </div>
  101. </div>
  102. <UploadPaperAnswerDialog
  103. ref="UploadPaperAnswerDialog"
  104. :instance="curTask"
  105. @modified="delayUpdateList"
  106. />
  107. <ModifyMarkParams
  108. ref="ModifyMarkParams"
  109. :instance="curTask"
  110. @modified="delayUpdateList"
  111. />
  112. <ModifyObjectiveAnswer
  113. ref="ModifyObjectiveAnswer"
  114. :instance="curTask"
  115. @modified="delayUpdateList"
  116. />
  117. </div>
  118. </template>
  119. <script>
  120. import { examStructureListPage } from "../api";
  121. import UploadPaperAnswerDialog from "../components/UploadPaperAnswerDialog";
  122. import ModifyMarkParams from "../components/markParam/ModifyMarkParams";
  123. import ModifyObjectiveAnswer from "../components/markParam/ModifyObjectiveAnswer.vue";
  124. export default {
  125. name: "upload-structure",
  126. components: {
  127. UploadPaperAnswerDialog,
  128. ModifyMarkParams,
  129. ModifyObjectiveAnswer
  130. },
  131. data() {
  132. return {
  133. filter: {
  134. semesterId: "",
  135. examId: ""
  136. },
  137. current: 1,
  138. size: this.GLOBAL.pageSize,
  139. total: 0,
  140. dataList: [],
  141. curTask: {}
  142. };
  143. },
  144. mounted() {
  145. this.toPage(1);
  146. // this.dataList.push({
  147. // thirdRelateId: 1,
  148. // thirdRelateName: "考试1",
  149. // courseName: "语文",
  150. // courseCode: "yw001",
  151. // paperNumber: 112345667,
  152. // paperType: "AB",
  153. // paperTypes: ["A", "B"],
  154. // status: "FINISH"
  155. // });
  156. },
  157. methods: {
  158. delayUpdateList() {
  159. setTimeout(() => {
  160. this.getList();
  161. }, 1000);
  162. },
  163. async getList() {
  164. if (!this.checkPrivilege("list", "list")) return;
  165. const datas = {
  166. ...this.filter,
  167. pageNumber: this.current,
  168. pageSize: this.size
  169. };
  170. const data = await examStructureListPage(datas);
  171. this.dataList = data.records;
  172. this.total = data.total;
  173. },
  174. toPage(page) {
  175. this.current = page;
  176. this.getList();
  177. },
  178. toSetParams(row) {
  179. this.curTask = row;
  180. this.$refs.ModifyMarkParams.open();
  181. },
  182. toSetAnswer(row) {
  183. this.curTask = row;
  184. this.$refs.ModifyObjectiveAnswer.open();
  185. },
  186. toUpload(row) {
  187. this.curTask = row;
  188. this.$refs.UploadPaperAnswerDialog.open();
  189. },
  190. toViewAnswer(row, paperType) {
  191. if (!row.paperAnswer) {
  192. this.$message.error("暂时还没有标答可预览!");
  193. return;
  194. }
  195. const paperAnswer = JSON.parse(row.paperAnswer);
  196. const paper = paperAnswer.find(item => item.paperType === paperType);
  197. if (!paper) {
  198. this.$message.error("标答文件不存在!");
  199. return;
  200. }
  201. window.open(paper.answerUrl);
  202. }
  203. }
  204. };
  205. </script>