LibraryInspect.vue 5.5 KB

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