Inspect.vue 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <template>
  2. <div class="my-container">
  3. <mark-header />
  4. <div class="tw-flex tw-gap-1">
  5. <mark-history @reload="reloadAndfetchTask" />
  6. <mark-body />
  7. <MarkBoardInspect @inspect="saveTaskToServer" @reject="rejectQuestions" />
  8. </div>
  9. </div>
  10. </template>
  11. <script lang="ts">
  12. import { computed, defineComponent, onMounted } from "vue";
  13. import {
  14. clearInspectedTask,
  15. getInspectedSetting,
  16. getInspectedTaskStatus,
  17. getOneOfInspectedTask,
  18. getSingleInspectedTask,
  19. rejectInspectedTask,
  20. saveInspectedTask,
  21. } from "@/api/inspectPage";
  22. import { store } from "./store";
  23. import MarkHeader from "./MarkHeader.vue";
  24. import { useRoute } from "vue-router";
  25. import MarkBody from "./MarkBody.vue";
  26. import MarkHistory from "./MarkHistory.vue";
  27. import MarkBoardInspect from "./MarkBoardInspect.vue";
  28. import { Question } from "@/types";
  29. import { message } from "ant-design-vue";
  30. export default defineComponent({
  31. name: "Inspect",
  32. components: {
  33. MarkHeader,
  34. MarkBody,
  35. MarkHistory,
  36. MarkBoardInspect,
  37. },
  38. setup: () => {
  39. const route = useRoute();
  40. let isSingleStudent = !!route.query.studentId;
  41. const {
  42. studentId,
  43. subjectCode,
  44. startScore,
  45. endScore,
  46. mainNumber,
  47. mainStartScore,
  48. mainEndScore,
  49. questionScore,
  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. };
  60. async function updateClearTask() {
  61. await clearInspectedTask(studentId, subjectCode);
  62. }
  63. async function updateSetting() {
  64. const settingRes = await getInspectedSetting();
  65. store.setting.fileServer = settingRes.data.fileServer;
  66. store.setting.userName = settingRes.data.userName;
  67. store.setting.uiSetting = {
  68. "answer.paper.scale": 1,
  69. "score.board.collapse": false,
  70. };
  71. }
  72. async function updateStatus() {
  73. const res = await getInspectedTaskStatus({
  74. subjectCode,
  75. mainNumber,
  76. startScore,
  77. endScore,
  78. mainStartScore,
  79. mainEndScore,
  80. questionScore,
  81. });
  82. if (res.data.valid) store.status = res.data;
  83. }
  84. async function updateTask() {
  85. // const mkey = "fetch_task_key";
  86. message.info({ content: "获取任务中...", duration: 2 });
  87. let res;
  88. if (isSingleStudent) {
  89. res = await getSingleStuTask();
  90. } else {
  91. res = await getOneOfStuTask();
  92. }
  93. // message.success({ content: "获取成功", key: mkey });
  94. store.currentTask = res.data;
  95. if (store.currentTask) store.setting.subject = store.currentTask.subject;
  96. }
  97. async function reloadAndfetchTask() {
  98. await updateClearTask();
  99. await fetchTask();
  100. }
  101. async function fetchTask() {
  102. !isSingleStudent && (await updateStatus());
  103. await updateTask();
  104. }
  105. onMounted(async () => {
  106. await updateClearTask();
  107. updateSetting();
  108. // fetchTask(); // mark-header 会调用 (watchEffect)
  109. });
  110. async function getSingleStuTask() {
  111. return getSingleInspectedTask(studentId);
  112. }
  113. async function getOneOfStuTask() {
  114. return getOneOfInspectedTask({
  115. subjectCode,
  116. mainNumber,
  117. startScore,
  118. endScore,
  119. mainStartScore,
  120. mainEndScore,
  121. questionScore,
  122. });
  123. }
  124. const realStudentId = computed(
  125. () =>
  126. (isSingleStudent ? studentId : store.currentTask?.studentId) 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(realStudentId.value)) as any;
  133. if (res.data.success && store.currentTask) {
  134. store.currentTask = undefined;
  135. message.success({ content: "复核成功", key: mkey, duration: 2 });
  136. if (!isSingleStudent) fetchTask();
  137. } else {
  138. console.log(res.data.message);
  139. message.error({ content: res.data.message, duration: 10 });
  140. }
  141. };
  142. const rejectQuestions = async (questions: Array<Question>) => {
  143. const mkey = "reject_task_key";
  144. message.loading({ content: "打回评卷任务...", key: mkey });
  145. const res = (await rejectInspectedTask(
  146. realStudentId.value,
  147. questions
  148. )) as any;
  149. if (res.data.success && store.currentTask) {
  150. store.currentTask = undefined;
  151. message.success({ content: "打回成功", key: mkey, duration: 2 });
  152. if (!isSingleStudent) fetchTask();
  153. } else {
  154. message.error({ content: res.data.message, duration: 10 });
  155. console.log(res.data.message);
  156. }
  157. };
  158. return {
  159. store,
  160. fetchTask,
  161. reloadAndfetchTask,
  162. saveTaskToServer,
  163. rejectQuestions,
  164. };
  165. },
  166. });
  167. </script>
  168. <style scoped>
  169. .my-container {
  170. width: 100%;
  171. }
  172. a {
  173. color: #42b983;
  174. }
  175. label {
  176. margin: 0 0.5em;
  177. font-weight: bold;
  178. }
  179. code {
  180. background-color: #eee;
  181. padding: 2px 4px;
  182. border-radius: 4px;
  183. color: #304455;
  184. }
  185. </style>