Inspect.vue 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  1. <template>
  2. <div class="my-container">
  3. <mark-header />
  4. <div class="tw-flex tw-gap-1">
  5. <mark-history
  6. v-if="!isSingleStudent"
  7. :subjectCode="subjectCode"
  8. orderTimeField="inspectTime"
  9. :get-history="getInspectedHistory"
  10. />
  11. <mark-body @error="renderError" />
  12. <MarkBoardInspect @inspect="saveTaskToServer" @reject="rejectQuestions" />
  13. </div>
  14. </div>
  15. </template>
  16. <script setup lang="ts">
  17. import { computed, onMounted, watch } from "vue";
  18. import {
  19. clearInspectedTask,
  20. getInspectedSetting,
  21. getInspectedTaskStatus,
  22. getOneOfInspectedTask,
  23. getSingleInspectedTask,
  24. rejectInspectedTask,
  25. saveInspectedTask,
  26. } from "@/api/inspectPage";
  27. import { store } from "@/store/store";
  28. import MarkHeader from "./MarkHeader.vue";
  29. import { useRoute } from "vue-router";
  30. import MarkBody from "./MarkBody.vue";
  31. import MarkHistory from "@/features/mark/MarkHistory.vue";
  32. import MarkBoardInspect from "./MarkBoardInspect.vue";
  33. import type { Question, Task, Setting } from "@/types";
  34. import { message } from "ant-design-vue";
  35. import { getPaper } from "@/api/jsonMark";
  36. import { getInspectedHistory } from "@/api/inspectPage";
  37. import EventBus from "@/plugins/eventBus";
  38. const route = useRoute();
  39. let isSingleStudent = !!route.query.studentId;
  40. const {
  41. studentId,
  42. subjectCode,
  43. startScore,
  44. endScore,
  45. mainNumber,
  46. mainStartScore,
  47. mainEndScore,
  48. questionScore,
  49. unselective,
  50. } = route.query as {
  51. studentId: string;
  52. subjectCode: string;
  53. startScore: string;
  54. endScore: string;
  55. mainNumber: string;
  56. mainStartScore: string;
  57. mainEndScore: string;
  58. questionScore: string;
  59. unselective: string;
  60. };
  61. async function updateClearTask() {
  62. await clearInspectedTask(studentId, subjectCode);
  63. }
  64. async function updateSetting() {
  65. const settingRes = await getInspectedSetting(subjectCode);
  66. store.setting.examType = settingRes.data.examType;
  67. store.setting.fileServer = settingRes.data.fileServer;
  68. store.setting.subject = settingRes.data.subject;
  69. store.setting.userName = settingRes.data.userName;
  70. store.setting.uiSetting = {
  71. "answer.paper.scale": 1,
  72. "score.board.collapse": false,
  73. "normal.mode": "keyboard",
  74. } as Setting["uiSetting"];
  75. store.setting.splitConfig = settingRes.data.splitConfig;
  76. if (store.setting.subject?.paperUrl) {
  77. store.setting.subject.paperUrl =
  78. store.setting.fileServer + store.setting.subject?.paperUrl;
  79. if (!store.isScanImage) {
  80. await getPaper(store);
  81. }
  82. }
  83. }
  84. async function updateStatus() {
  85. const res = await getInspectedTaskStatus({
  86. subjectCode,
  87. mainNumber,
  88. startScore,
  89. endScore,
  90. mainStartScore,
  91. mainEndScore,
  92. questionScore,
  93. unselective,
  94. });
  95. if (res.data.valid) store.status = res.data;
  96. }
  97. async function updateTask() {
  98. const mkey = "fetch_task_key";
  99. message.info({ content: "获取任务中...", duration: 1.5, key: mkey });
  100. let res;
  101. if (isSingleStudent) {
  102. res = await getSingleStuTask();
  103. } else {
  104. res = await getOneOfStuTask();
  105. }
  106. message.success({
  107. content: res.data.libraryId ? "获取成功" : "无任务",
  108. key: mkey,
  109. });
  110. if (res.data.studentId) {
  111. let rawTask = res.data as Task;
  112. rawTask.sliceUrls = rawTask.sliceUrls?.map(
  113. (s) => store.setting.fileServer + s
  114. );
  115. rawTask.sheetUrls = rawTask.sheetUrls?.map(
  116. (s) => store.setting.fileServer + s
  117. );
  118. rawTask.jsonUrl = store.setting.fileServer + rawTask.jsonUrl;
  119. store.currentTask = res.data;
  120. if (res.data.subject) store.setting.subject = res.data.subject;
  121. // if (store.currentTask)
  122. // Object.assign(store.setting.subject, store.currentTask.subject);
  123. } else {
  124. store.message = res.data.message;
  125. }
  126. }
  127. // async function reloadAndfetchTask() {
  128. // await updateClearTask();
  129. // await updateSetting();
  130. // await fetchTask();
  131. // }
  132. watch(
  133. () => store.historyOpen,
  134. async () => {
  135. if (!store.historyOpen) {
  136. await updateClearTask();
  137. await updateSetting();
  138. await fetchTask();
  139. }
  140. }
  141. );
  142. async function fetchTask() {
  143. !isSingleStudent && (await updateStatus());
  144. await updateTask();
  145. }
  146. onMounted(async () => {
  147. await updateClearTask();
  148. await updateSetting();
  149. await fetchTask();
  150. });
  151. async function getSingleStuTask() {
  152. return getSingleInspectedTask(studentId);
  153. }
  154. async function getOneOfStuTask() {
  155. return getOneOfInspectedTask({
  156. subjectCode,
  157. mainNumber,
  158. startScore,
  159. endScore,
  160. mainStartScore,
  161. mainEndScore,
  162. questionScore,
  163. unselective,
  164. });
  165. }
  166. const realStudentId = $computed(
  167. () => (isSingleStudent ? studentId : store.currentTask?.studentId) as string
  168. );
  169. const saveTaskToServer = async () => {
  170. console.log("save inspect task to server");
  171. const mkey = "save_task_key";
  172. message.loading({ content: "保存评卷任务...", key: mkey });
  173. const res = (await saveInspectedTask(realStudentId)) as any;
  174. if (res.data.success && store.currentTask) {
  175. message.success({ content: "复核成功", key: mkey, duration: 2 });
  176. if (!store.historyOpen) {
  177. store.currentTask = undefined;
  178. if (!isSingleStudent) fetchTask();
  179. } else {
  180. EventBus.emit("should-reload-history");
  181. }
  182. } else if (res.data.message) {
  183. console.log(res.data.message);
  184. message.error({ content: res.data.message, key: mkey, duration: 10 });
  185. } else if (!store.currentTask) {
  186. message.warn({ content: "暂无新任务", key: mkey, duration: 10 });
  187. }
  188. };
  189. const rejectQuestions = async (questions: Array<Question>) => {
  190. const mkey = "reject_task_key";
  191. message.loading({ content: "打回评卷任务...", key: mkey });
  192. const res = (await rejectInspectedTask(realStudentId, questions)) as any;
  193. if (res.data.success && store.currentTask) {
  194. store.currentTask = undefined;
  195. message.success({ content: "打回成功", key: mkey, duration: 2 });
  196. if (!store.historyOpen) {
  197. store.currentTask = undefined;
  198. if (!isSingleStudent) fetchTask();
  199. } else {
  200. EventBus.emit("should-reload-history");
  201. }
  202. } else if (res.data.message) {
  203. // console.log(res.data.message);
  204. message.error({ content: res.data.message, key: mkey, duration: 10 });
  205. } else if (!store.currentTask) {
  206. message.warn({ content: "暂无新任务", key: mkey, duration: 10 });
  207. }
  208. };
  209. const renderError = () => {
  210. store.currentTask = undefined;
  211. store.message = "加载失败,请重新加载。";
  212. };
  213. </script>
  214. <style scoped>
  215. .my-container {
  216. width: 100%;
  217. overflow: clip;
  218. }
  219. </style>