UploadStructure.vue 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  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="statusStr" label="状态" width="100">
  49. </el-table-column>
  50. <el-table-column class-name="action-column" label="操作" width="220px">
  51. <template slot-scope="scope">
  52. <el-button
  53. class="btn-primary"
  54. type="text"
  55. :disabled="scope.row.taskStatus === 'RUNNING'"
  56. @click="toSetParams(scope.row)"
  57. >评卷参数设置</el-button
  58. >
  59. <el-button
  60. class="btn-primary"
  61. type="text"
  62. :disabled="
  63. !scope.row.paperInfoJson || scope.row.taskStatus === 'RUNNING'
  64. "
  65. @click="toSetAnswer(scope.row)"
  66. >设置客观题标答</el-button
  67. >
  68. <el-button
  69. class="btn-primary"
  70. type="text"
  71. :disabled="
  72. !scope.row.paperInfoJson || scope.row.taskStatus === 'RUNNING'
  73. "
  74. @click="toBindMarkLeader(scope.row)"
  75. >绑定科组长</el-button
  76. >
  77. <el-button
  78. v-if="checkPrivilege('link', 'Upload')"
  79. class="btn-primary"
  80. type="text"
  81. :disabled="scope.row.taskStatus === 'RUNNING'"
  82. @click="toUpload(scope.row)"
  83. >上传标答文件</el-button
  84. >
  85. <el-button
  86. v-if="checkPrivilege('link', 'Preview')"
  87. class="btn-primary"
  88. type="text"
  89. :disabled="!scope.row.paperAnswer"
  90. @click="toViewAnswer(scope.row, scope.row.paperType)"
  91. >查看标答文件</el-button
  92. >
  93. </template>
  94. </el-table-column>
  95. </el-table>
  96. <div class="part-page">
  97. <el-pagination
  98. background
  99. layout="total,prev, pager, next"
  100. :current-page="current"
  101. :total="total"
  102. :page-size="size"
  103. @current-change="toPage"
  104. >
  105. </el-pagination>
  106. </div>
  107. </div>
  108. <UploadPaperAnswerDialog
  109. ref="UploadPaperAnswerDialog"
  110. :instance="curTask"
  111. @modified="delayUpdateList"
  112. />
  113. <ModifyMarkParams
  114. ref="ModifyMarkParams"
  115. :instance="curTask"
  116. @modified="delayUpdateList"
  117. />
  118. <ModifyObjectiveAnswer
  119. ref="ModifyObjectiveAnswer"
  120. :instance="curTask"
  121. @modified="delayUpdateList"
  122. />
  123. <SelectTypeUser
  124. ref="SelectTypeUser"
  125. special-privilege="SUBJECT_HEADER"
  126. :user-ids="curMarkLeaders"
  127. :user-limit-count="0"
  128. @confirm="headerBind"
  129. />
  130. </div>
  131. </template>
  132. <script>
  133. import { examStructureListPage, examBindMarkLeader } from "../api";
  134. import UploadPaperAnswerDialog from "../components/UploadPaperAnswerDialog";
  135. import ModifyMarkParams from "../components/markParam/ModifyMarkParams";
  136. import ModifyObjectiveAnswer from "../components/markParam/ModifyObjectiveAnswer.vue";
  137. import SelectTypeUser from "../components/SelectTypeUser.vue";
  138. export default {
  139. name: "upload-structure",
  140. components: {
  141. UploadPaperAnswerDialog,
  142. ModifyMarkParams,
  143. ModifyObjectiveAnswer,
  144. SelectTypeUser
  145. },
  146. data() {
  147. return {
  148. filter: {
  149. semesterId: "",
  150. examId: ""
  151. },
  152. current: 1,
  153. size: this.GLOBAL.pageSize,
  154. total: 0,
  155. dataList: [],
  156. curTask: {},
  157. curMarkLeaders: []
  158. };
  159. },
  160. mounted() {
  161. this.toPage(1);
  162. // this.dataList.push({
  163. // thirdRelateId: 1,
  164. // thirdRelateName: "考试1",
  165. // courseName: "语文",
  166. // courseCode: "yw001",
  167. // paperNumber: 112345667,
  168. // paperType: "AB",
  169. // paperTypes: ["A", "B"],
  170. // status: "FINISH"
  171. // });
  172. },
  173. methods: {
  174. delayUpdateList() {
  175. setTimeout(() => {
  176. this.getList();
  177. }, 1000);
  178. },
  179. async getList() {
  180. if (!this.checkPrivilege("list", "list")) return;
  181. const datas = {
  182. ...this.filter,
  183. pageNumber: this.current,
  184. pageSize: this.size
  185. };
  186. const data = await examStructureListPage(datas);
  187. this.dataList = data.records;
  188. this.total = data.total;
  189. },
  190. toPage(page) {
  191. this.current = page;
  192. this.getList();
  193. },
  194. toSetParams(row) {
  195. this.curTask = row;
  196. this.$refs.ModifyMarkParams.open();
  197. },
  198. toSetAnswer(row) {
  199. this.curTask = row;
  200. this.$refs.ModifyObjectiveAnswer.open();
  201. },
  202. toUpload(row) {
  203. this.curTask = row;
  204. this.$refs.UploadPaperAnswerDialog.open();
  205. },
  206. toViewAnswer(row, paperType) {
  207. if (!row.paperAnswer) {
  208. this.$message.error("暂时还没有标答可预览!");
  209. return;
  210. }
  211. const paperAnswer = JSON.parse(row.paperAnswer);
  212. const paper = paperAnswer.find(item => item.paperType === paperType);
  213. if (!paper) {
  214. this.$message.error("标答文件不存在!");
  215. return;
  216. }
  217. window.open(paper.answerUrl);
  218. },
  219. toBindMarkLeader(row) {
  220. this.curTask = row;
  221. const markLeaders = row.markLeader ? JSON.parse(row.markLeader) : [];
  222. this.curMarkLeaders = markLeaders.map(item => item.id);
  223. this.$refs.SelectTypeUser.open();
  224. },
  225. async headerBind(users) {
  226. await examBindMarkLeader({
  227. id: this.curTask.id,
  228. markLeader: users.map(item => {
  229. return {
  230. id: item.id,
  231. loginName: item.loginName
  232. };
  233. })
  234. });
  235. this.$message.success("绑定成功!");
  236. this.getList();
  237. }
  238. }
  239. };
  240. </script>