ImportInspect.vue 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <template>
  2. <div class="my-container">
  3. <mark-header />
  4. <div class="tw-flex tw-gap-1">
  5. <mark-body usingImage="sheetUrls" @error="renderError" />
  6. <MarkBoardInspect
  7. :tagged="isCurrentTagged"
  8. :isFirst="isFirst"
  9. :isLast="isLast"
  10. @makeTag="saveTaskToServer"
  11. @fetchTask="fetchTask"
  12. />
  13. </div>
  14. </div>
  15. </template>
  16. <script setup lang="ts">
  17. import { onMounted } from "vue";
  18. import {
  19. getInspectedSetting,
  20. getSingleInspectedTask,
  21. saveInspectedTask,
  22. } from "@/api/importInspectPage";
  23. import { store } from "@/store/store";
  24. import MarkHeader from "./MarkHeader.vue";
  25. import { useRoute } from "vue-router";
  26. import MarkBody from "../inspect/MarkBody.vue";
  27. import MarkBoardInspect from "./MarkBoardInspect.vue";
  28. import type { AdminPageSetting } from "@/types";
  29. import { message } from "ant-design-vue";
  30. import { addFileServerPrefixToTask } from "@/utils/utils";
  31. const route = useRoute();
  32. const { studentId } = route.query as {
  33. studentId: string;
  34. };
  35. let studentIds: number[] = $ref([]);
  36. let tagIds: number[] = $ref([]);
  37. let currentStudentId = $ref(0);
  38. async function updateSetting() {
  39. const settingRes = await getInspectedSetting(studentId);
  40. const { examType, fileServer } = settingRes.data;
  41. store.initSetting({ examType, fileServer } as AdminPageSetting);
  42. store.status.totalCount = settingRes.data.inspectCount;
  43. store.status.markedCount = 0;
  44. if (!settingRes.data.inspectCount) {
  45. store.message = settingRes.data.message;
  46. } else {
  47. studentIds = settingRes.data.studentIds;
  48. tagIds = settingRes.data.tagIds;
  49. }
  50. }
  51. // 要通过fetchTask调用
  52. async function updateTask() {
  53. if (!currentStudentId) {
  54. return;
  55. }
  56. const mkey = "fetch_task_key";
  57. void message.info({ content: "获取任务中...", duration: 1.5, key: mkey });
  58. let res = await getSingleInspectedTask("" + currentStudentId);
  59. void message.success({
  60. content: res.data.studentId ? "获取成功" : "无任务",
  61. key: mkey,
  62. });
  63. if (res.data.studentId) {
  64. let rawTask = res.data;
  65. store.currentTask = addFileServerPrefixToTask(rawTask);
  66. } else {
  67. store.message = res.data.message;
  68. }
  69. }
  70. let isCurrentTagged = $computed(() => tagIds.includes(currentStudentId));
  71. let isFirst = $computed(() => studentIds.indexOf(currentStudentId) === 0);
  72. let isLast = $computed(
  73. () => studentIds.indexOf(currentStudentId) === studentIds.length - 1
  74. );
  75. async function fetchTask(next: boolean, init?: boolean) {
  76. if (init) {
  77. currentStudentId = studentIds[0];
  78. } else if (isLast && next) {
  79. return; // currentStudentId是最后一个不调用
  80. } else if (isFirst && !next) {
  81. return; // currentStudentId是第一个不调用
  82. } else {
  83. currentStudentId =
  84. studentIds[studentIds.indexOf(currentStudentId) + (next ? 1 : -1)];
  85. }
  86. if (!currentStudentId) return; // 无currentStudentId不调用
  87. store.status.markedCount = studentIds.indexOf(currentStudentId) + 1;
  88. await updateTask();
  89. }
  90. onMounted(async () => {
  91. await updateSetting();
  92. await fetchTask(true, true);
  93. });
  94. const saveTaskToServer = async () => {
  95. const mkey = "save_task_key";
  96. void message.loading({ content: "标记评卷任务...", key: mkey });
  97. const res = await saveInspectedTask(
  98. currentStudentId + "",
  99. !isCurrentTagged + ""
  100. );
  101. if (res.data.success) {
  102. void message.success({
  103. content: isCurrentTagged ? "取消标记成功" : "标记成功",
  104. key: mkey,
  105. duration: 2,
  106. });
  107. if (isCurrentTagged) {
  108. tagIds.splice(tagIds.indexOf(currentStudentId), 1);
  109. } else {
  110. tagIds.push(currentStudentId);
  111. }
  112. } else {
  113. console.log(res.data.message);
  114. void message.error({ content: res.data.message, key: mkey, duration: 10 });
  115. }
  116. };
  117. const renderError = () => {
  118. store.currentTask = undefined;
  119. store.message = "加载失败,请重新加载。";
  120. };
  121. </script>
  122. <style scoped>
  123. .my-container {
  124. width: 100%;
  125. overflow: clip;
  126. }
  127. </style>