2
0

LibraryInspect.vue 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  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. :groupNumber="groupNumber"
  9. orderTimeField="inspectTime"
  10. :getHistory="getLibraryInspectedHistoryOfLibraryInspect"
  11. />
  12. <mark-body @error="renderError" />
  13. <MarkBoardInspect @inspect="saveTaskToServer" @reject="rejectQuestions" />
  14. </div>
  15. </div>
  16. <MinimapModal />
  17. </template>
  18. <script setup lang="ts">
  19. import { onMounted, watch } from "vue";
  20. import { store } from "@/store/store";
  21. import MarkHeader from "./MarkHeader.vue";
  22. import MinimapModal from "@/features/mark/MinimapModal.vue";
  23. import { useRoute } from "vue-router";
  24. import MarkBody from "./MarkBody.vue";
  25. import MarkHistory from "@/features/mark/MarkHistory.vue";
  26. import MarkBoardInspect from "./MarkBoardInspect.vue";
  27. import type { Question } from "@/types";
  28. import { message } from "ant-design-vue";
  29. import {
  30. clearInspectedTaskOfLibraryInspect,
  31. getInspectedTaskStatusOfLibraryInspect,
  32. getLibraryInspectedHistoryOfLibraryInspect,
  33. getOneOfInspectedTaskOfLibraryInspect,
  34. rejectInspectedTaskOfLibraryInspect,
  35. saveInspectedTaskOfLibraryInspect,
  36. } from "@/api/libraryInspectPage";
  37. import { getPaper } from "@/api/jsonMark";
  38. import { getAdminPageSetting } from "@/api/inspectPage";
  39. import EventBus from "@/plugins/eventBus";
  40. import { addFileServerPrefixToTask } from "@/utils/utils";
  41. const route = useRoute();
  42. let isSingleStudent = !!route.query.libraryId;
  43. const {
  44. subjectCode,
  45. groupNumber,
  46. libraryId,
  47. markerId,
  48. examNumber,
  49. secretNumber,
  50. startScore,
  51. endScore,
  52. questionScore,
  53. } = route.query as {
  54. subjectCode: string;
  55. groupNumber: string;
  56. libraryId: string; // TODO: for未来单一任务
  57. markerId: string;
  58. examNumber: string;
  59. secretNumber: string;
  60. startScore: string;
  61. endScore: string;
  62. questionScore: string;
  63. };
  64. async function updateClearTask() {
  65. await clearInspectedTaskOfLibraryInspect(subjectCode, groupNumber);
  66. }
  67. async function updateSetting() {
  68. const settingRes = await getAdminPageSetting(subjectCode);
  69. const { examType, fileServer, subject, userName, splitConfig } =
  70. settingRes.data;
  71. store.initSetting({
  72. examType,
  73. fileServer,
  74. subject,
  75. userName,
  76. splitConfig,
  77. });
  78. if (store.setting.subject?.paperUrl && store.isMultiMedia) {
  79. await getPaper(store);
  80. }
  81. }
  82. async function updateStatus() {
  83. const res = await getInspectedTaskStatusOfLibraryInspect({
  84. subjectCode,
  85. groupNumber,
  86. markerId,
  87. examNumber,
  88. secretNumber,
  89. startScore,
  90. endScore,
  91. questionScore,
  92. });
  93. if (res.data.valid) Object.assign(store.status, res.data);
  94. }
  95. async function updateTask() {
  96. const mkey = "fetch_task_key";
  97. void message.info({ content: "获取任务中...", duration: 1.5, key: mkey });
  98. let res = await getOneOfStuTask();
  99. void message.success({
  100. content: res.data.studentId ? "获取成功" : "无任务",
  101. key: mkey,
  102. });
  103. if (res.data.studentId) {
  104. let rawTask = res.data;
  105. store.currentTask = addFileServerPrefixToTask(rawTask);
  106. } else {
  107. store.message = res.data.message;
  108. }
  109. }
  110. watch(
  111. () => store.historyOpen,
  112. async () => {
  113. if (!store.historyOpen) {
  114. await updateClearTask();
  115. await fetchTask();
  116. }
  117. }
  118. );
  119. async function fetchTask() {
  120. !isSingleStudent && (await updateStatus());
  121. await updateTask();
  122. }
  123. onMounted(async () => {
  124. await updateClearTask();
  125. await updateSetting();
  126. await fetchTask();
  127. });
  128. async function getOneOfStuTask() {
  129. return getOneOfInspectedTaskOfLibraryInspect({
  130. subjectCode,
  131. groupNumber,
  132. markerId,
  133. examNumber,
  134. secretNumber,
  135. startScore,
  136. endScore,
  137. questionScore,
  138. });
  139. }
  140. const realLibraryId = $computed(
  141. () => (isSingleStudent ? libraryId : store.currentTask?.libraryId) as string
  142. );
  143. const saveTaskToServer = async () => {
  144. console.log("save inspect task to server");
  145. const mkey = "save_task_key";
  146. void message.loading({ content: "保存评卷任务...", key: mkey });
  147. const res = await saveInspectedTaskOfLibraryInspect(realLibraryId);
  148. if (res.data.success && store.currentTask) {
  149. void message.success({ content: "复核成功", key: mkey, duration: 2 });
  150. if (!store.historyOpen) {
  151. store.currentTask = undefined;
  152. if (!isSingleStudent) await fetchTask();
  153. } else {
  154. EventBus.emit("should-reload-history");
  155. }
  156. } else if (res.data.message) {
  157. console.log(res.data.message);
  158. void message.error({ content: res.data.message, key: mkey, duration: 10 });
  159. } else if (!store.currentTask) {
  160. void message.warn({ content: "暂无新任务", key: mkey, duration: 10 });
  161. }
  162. };
  163. const rejectQuestions = async (questions: Array<Question>) => {
  164. if (!store.currentTask) return;
  165. const mkey = "reject_task_key";
  166. void message.loading({ content: "打回评卷任务...", key: mkey });
  167. const res = await rejectInspectedTaskOfLibraryInspect(
  168. store.currentTask.libraryId + "",
  169. questions
  170. );
  171. if (res.data.success) {
  172. store.currentTask = undefined;
  173. void message.success({ content: "打回成功", key: mkey, duration: 2 });
  174. if (!store.historyOpen) {
  175. store.currentTask = undefined;
  176. if (!isSingleStudent) await fetchTask();
  177. } else {
  178. EventBus.emit("should-reload-history");
  179. }
  180. } else if (res.data.message) {
  181. console.log(res.data.message);
  182. void message.error({ content: res.data.message, key: mkey, duration: 10 });
  183. } else if (!store.currentTask) {
  184. void message.warn({ content: "暂无新任务", key: mkey, duration: 10 });
  185. }
  186. };
  187. const renderError = () => {
  188. store.currentTask = undefined;
  189. store.message = "加载失败,请重新加载。";
  190. };
  191. </script>
  192. <style scoped>
  193. .my-container {
  194. width: 100%;
  195. overflow: clip;
  196. }
  197. </style>