LibraryInspect.vue 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. <template>
  2. <div class="my-container">
  3. <mark-header />
  4. <div class="tw-flex tw-gap-1">
  5. <mark-history
  6. @reload="reloadAndfetchTask"
  7. :should-reload="shouldReloadHistory"
  8. />
  9. <mark-body @error="renderError" />
  10. <MarkBoardInspect @inspect="saveTaskToServer" @reject="rejectQuestions" />
  11. </div>
  12. </div>
  13. </template>
  14. <script setup lang="ts">
  15. import { computed, onMounted, ref } from "vue";
  16. import { store } from "@/features/mark/store";
  17. import MarkHeader from "./MarkHeader.vue";
  18. import { useRoute } from "vue-router";
  19. import MarkBody from "./MarkBody.vue";
  20. import MarkHistory from "./MarkHistory.vue";
  21. import MarkBoardInspect from "./MarkBoardInspect.vue";
  22. import type { MarkStore, Question, Task } from "@/types";
  23. import { message } from "ant-design-vue";
  24. import {
  25. clearInspectedTask,
  26. getInspectedSetting,
  27. getInspectedTaskStatus,
  28. getOneOfInspectedTask,
  29. rejectInspectedTask,
  30. saveInspectedTask,
  31. } from "@/api/libraryInspectPage";
  32. const route = useRoute();
  33. let isSingleStudent = !!route.query.libraryId;
  34. const { subjectCode, groupNumber, libraryId } = route.query as {
  35. subjectCode: string;
  36. groupNumber: string;
  37. libraryId: string; // TODO: for未来单一任务
  38. };
  39. async function updateClearTask() {
  40. await clearInspectedTask(subjectCode, groupNumber);
  41. }
  42. async function updateSetting() {
  43. const settingRes = await getInspectedSetting();
  44. store.setting.fileServer = settingRes.data.fileServer;
  45. store.setting.userName = settingRes.data.userName;
  46. store.setting.uiSetting = {
  47. "answer.paper.scale": 1,
  48. "score.board.collapse": false,
  49. } as MarkStore["setting"]["uiSetting"];
  50. store.setting.splitConfig = settingRes.data.splitConfig;
  51. }
  52. async function updateStatus() {
  53. const res = await getInspectedTaskStatus(subjectCode, groupNumber);
  54. if (res.data.valid) store.status = res.data;
  55. }
  56. async function updateTask() {
  57. // const mkey = "fetch_task_key";
  58. message.info({ content: "获取任务中...", duration: 2 });
  59. let res;
  60. // if (isSingleStudent) {
  61. // res = await getSingleStuTask();
  62. // } else {
  63. res = await getOneOfStuTask();
  64. // }
  65. // message.success({ content: "获取成功", key: mkey });
  66. if (res.data.libraryId) {
  67. let rawTask = res.data as Task;
  68. rawTask.sliceUrls = rawTask.sliceUrls?.map(
  69. (s) => store.setting.fileServer + s
  70. );
  71. rawTask.sheetUrls = rawTask.sheetUrls?.map(
  72. (s) => store.setting.fileServer + s
  73. );
  74. rawTask.jsonUrl = store.setting.fileServer + rawTask.jsonUrl;
  75. store.currentTask = res.data;
  76. if (store.currentTask)
  77. store.setting.subject = store.currentTask
  78. .subject as MarkStore["setting"]["subject"];
  79. } else {
  80. store.message = res.data.message;
  81. }
  82. }
  83. const shouldReloadHistory = ref(0);
  84. async function reloadAndfetchTask() {
  85. await updateClearTask();
  86. await updateSetting();
  87. await fetchTask();
  88. }
  89. async function fetchTask() {
  90. !isSingleStudent && (await updateStatus());
  91. await updateTask();
  92. }
  93. onMounted(async () => {
  94. // await updateClearTask();
  95. // fetchTask(); // mark-header 会调用 (watchEffect)
  96. });
  97. async function getSingleStuTask() {
  98. // return getSingleInspectedTask(libraryId);
  99. }
  100. async function getOneOfStuTask() {
  101. return getOneOfInspectedTask(subjectCode, groupNumber);
  102. }
  103. const realLibraryId = computed(
  104. () => (isSingleStudent ? libraryId : store.currentTask?.libraryId) as string
  105. );
  106. const saveTaskToServer = async () => {
  107. console.log("save inspect task to server");
  108. const mkey = "save_task_key";
  109. message.loading({ content: "保存评卷任务...", key: mkey });
  110. const res = (await saveInspectedTask(realLibraryId.value)) as any;
  111. if (res.data.success && store.currentTask) {
  112. message.success({ content: "复核成功", key: mkey, duration: 2 });
  113. if (!store.historyOpen) {
  114. store.currentTask = undefined;
  115. if (!isSingleStudent) fetchTask();
  116. } else {
  117. shouldReloadHistory.value = Date.now();
  118. }
  119. } else if (res.data.message) {
  120. console.log(res.data.message);
  121. message.error({ content: res.data.message, key: mkey, duration: 10 });
  122. } else if (!store.currentTask) {
  123. message.warn({ content: "暂无新任务", key: mkey, duration: 10 });
  124. }
  125. };
  126. const rejectQuestions = async (questions: Array<Question>) => {
  127. if (!store.currentTask) return;
  128. const mkey = "reject_task_key";
  129. message.loading({ content: "打回评卷任务...", key: mkey });
  130. const res = (await rejectInspectedTask(
  131. //realLibraryId.value,
  132. store.currentTask.libraryId + "",
  133. questions
  134. )) as any;
  135. if (res.data.success) {
  136. store.currentTask = undefined;
  137. message.success({ content: "打回成功", key: mkey, duration: 2 });
  138. if (!store.historyOpen) {
  139. store.currentTask = undefined;
  140. if (!isSingleStudent) fetchTask();
  141. } else {
  142. shouldReloadHistory.value = Date.now();
  143. }
  144. } else if (res.data.message) {
  145. console.log(res.data.message);
  146. message.error({ content: res.data.message, key: mkey, duration: 10 });
  147. } else if (!store.currentTask) {
  148. message.warn({ content: "暂无新任务", key: mkey, duration: 10 });
  149. }
  150. };
  151. const renderError = () => {
  152. store.currentTask = undefined;
  153. store.message = "加载失败,请重新加载。";
  154. };
  155. </script>
  156. <style scoped>
  157. .my-container {
  158. width: 100%;
  159. }
  160. </style>