StudentTrack.vue 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. <template>
  2. <div class="my-container">
  3. <mark-header />
  4. <div class="tw-flex tw-gap-1">
  5. <mark-body
  6. v-if="store.setting.examType === 'SCAN_IMAGE'"
  7. @error="renderError"
  8. />
  9. <CommonMarkBody
  10. v-else
  11. :useMarkResult="false"
  12. :store="store"
  13. @error="renderError"
  14. :makeTrack="() => {}"
  15. />
  16. </div>
  17. </div>
  18. </template>
  19. <script setup lang="ts">
  20. import { onMounted } from "vue";
  21. import { isScanImage, store } from "@/store/store";
  22. import MarkHeader from "./MarkHeader.vue";
  23. import { useRoute } from "vue-router";
  24. import MarkBody from "../inspect/MarkBody.vue";
  25. import CommonMarkBody from "@/features/mark/CommonMarkBody.vue";
  26. import type { Task, Setting } from "@/types";
  27. import { message } from "ant-design-vue";
  28. import { getSingleStudentTask } from "@/api/studentTrackPage";
  29. import { getInspectedSetting } from "@/api/inspectPage";
  30. import { getPaper } from "@/api/jsonMark";
  31. const route = useRoute();
  32. let studentId = route.query.studentId;
  33. let subjectCode = route.query.subjectCode as string;
  34. async function updateSetting() {
  35. const settingRes = await getInspectedSetting(subjectCode);
  36. store.setting.examType = settingRes.data.examType;
  37. store.setting.fileServer = settingRes.data.fileServer;
  38. store.setting.userName = settingRes.data.userName;
  39. store.setting.uiSetting = {
  40. "answer.paper.scale": 1,
  41. "score.board.collapse": false,
  42. "normal.mode": "keyboard",
  43. } as Setting["uiSetting"];
  44. store.setting.splitConfig = settingRes.data.splitConfig;
  45. store.setting.subject = settingRes.data.subject;
  46. if (store.setting.subject?.answerUrl) {
  47. store.setting.subject.answerUrl =
  48. store.setting.fileServer + store.setting.subject?.answerUrl;
  49. }
  50. if (store.setting.subject?.paperUrl) {
  51. store.setting.subject.paperUrl =
  52. store.setting.fileServer + store.setting.subject?.paperUrl;
  53. if (!isScanImage()) {
  54. await getPaper(store);
  55. }
  56. }
  57. }
  58. async function updateTask() {
  59. // const mkey = "fetch_task_key";
  60. message.info({ content: "获取任务中...", duration: 1.5 });
  61. let res = await getSingleStuTask();
  62. // message.success({ content: "获取成功", key: mkey });
  63. // if (res.data.sliceUrls) {
  64. // store.setting.fileServer = res.data.fileServer;
  65. // store.setting.uiSetting = {
  66. // "answer.paper.scale": 1,
  67. // "score.board.collapse": false,
  68. // };
  69. // let task = {} as Task;
  70. // task.examNumber = res.data.examNumber;
  71. // task.sliceUrls = res.data.sliceUrls.map(
  72. // (s: string) => store.setting.fileServer + s
  73. // );
  74. // // 目前api并没有区分score和tag
  75. // task.questionList = [
  76. // // @ts-ignore
  77. // // { trackList: res.data.tagList.filter((q) => !q.tagName) },
  78. // ];
  79. // // @ts-ignore
  80. // task.specialTagList = res.data.tagList.filter((q) => q.tagName);
  81. // store.currentTask = task;
  82. if (res.data.studentId) {
  83. let rawTask = res.data as Task;
  84. rawTask.sliceUrls = rawTask.sliceUrls?.map(
  85. (s) => store.setting.fileServer + s
  86. );
  87. rawTask.sheetUrls = rawTask.sheetUrls?.map(
  88. (s) => store.setting.fileServer + s
  89. );
  90. rawTask.jsonUrl = store.setting.fileServer + rawTask.jsonUrl;
  91. store.currentTask = res.data;
  92. } else {
  93. store.message = res.data.message;
  94. }
  95. }
  96. async function fetchTask() {
  97. await updateTask();
  98. }
  99. onMounted(async () => {
  100. await updateSetting();
  101. await fetchTask();
  102. });
  103. async function getSingleStuTask() {
  104. return getSingleStudentTask(studentId as string);
  105. }
  106. const renderError = () => {
  107. store.currentTask = undefined;
  108. store.message = "加载失败,请重新加载。";
  109. };
  110. </script>
  111. <style scoped>
  112. .my-container {
  113. width: 100%;
  114. }
  115. </style>