StudentTrack.vue 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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 { 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. const { examType, fileServer, subject, userName, splitConfig } =
  37. settingRes.data;
  38. store.initSetting({
  39. examType,
  40. fileServer,
  41. subject,
  42. userName,
  43. splitConfig,
  44. });
  45. if (store.setting.subject?.paperUrl && !store.isScanImage) {
  46. await getPaper(store);
  47. }
  48. }
  49. async function updateTask() {
  50. const mkey = "fetch_task_key";
  51. message.info({ content: "获取任务中...", duration: 1.5, key: mkey });
  52. let res = await getSingleStuTask();
  53. message.success({
  54. content: res.data.libraryId ? "获取成功" : "无任务",
  55. key: mkey,
  56. });
  57. if (res.data.studentId) {
  58. let rawTask = res.data as Task;
  59. rawTask.sliceUrls = rawTask.sliceUrls?.map(
  60. (s) => store.setting.fileServer + s
  61. );
  62. rawTask.sheetUrls = rawTask.sheetUrls?.map(
  63. (s) => store.setting.fileServer + s
  64. );
  65. rawTask.jsonUrl = store.setting.fileServer + rawTask.jsonUrl;
  66. store.currentTask = res.data;
  67. } else {
  68. store.message = res.data.message;
  69. }
  70. }
  71. async function fetchTask() {
  72. await updateTask();
  73. }
  74. onMounted(async () => {
  75. await updateSetting();
  76. await fetchTask();
  77. });
  78. async function getSingleStuTask() {
  79. return getSingleStudentTask(studentId as string);
  80. }
  81. const renderError = () => {
  82. store.currentTask = undefined;
  83. store.message = "加载失败,请重新加载。";
  84. };
  85. </script>
  86. <style scoped>
  87. .my-container {
  88. width: 100%;
  89. }
  90. </style>