paper-question-hand.vue 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <template>
  2. <div class="text-main mb-3">
  3. 当前查询知识点(从左侧选择):<el-text size="large" type="primary" class="font-bold">{{ knowledgeNode?.name }}</el-text>
  4. </div>
  5. <div class="flex flex-row items-center gap-3">
  6. <el-input v-model="keywordLocal" clearable prefix-icon="search" placeholder="输入题目关键字-回车触发搜索"
  7. style="width: 250px" @keydown.enter="confirmKeyword" @clear="confirmKeyword"/>
  8. <el-select v-model="qtpye" clearable style="width: 220px">
  9. <el-option v-for="t in qTypes" :value="t.dictValue" :label="t.dictLabel"></el-option>
  10. </el-select>
  11. <el-popover width="250">
  12. <span v-if="currentSubject" class="text-sm font-bold">科目:{{ currentSubject.subjectName }}</span>
  13. <div v-for="g in groupedQuestions" class="flex flex-col">
  14. <el-divider style="margin: 10px 0"/>
  15. <span>{{ g.qtpye }}:{{ g.questions.length }}道</span>
  16. <el-link type="danger" plain icon="delete" class="self-end" @click="removeQuestionGroup(g.qtpye)">清除
  17. </el-link>
  18. </div>
  19. <el-divider style="margin: 10px 0"/>
  20. <div class="flex items-center justify-between">
  21. <el-link type="danger" plain icon="delete" @click="clearCart">全部清除</el-link>
  22. <el-button type="primary" @click="buildPaper">生成试卷</el-button>
  23. </div>
  24. <template #reference>
  25. <el-button type="primary" size="large" icon="shopping-cart" class="ml-auto">
  26. 试题篮({{ cart.length }})
  27. </el-button>
  28. </template>
  29. </el-popover>
  30. </div>
  31. <el-divider/>
  32. <el-empty v-if="total==0"/>
  33. <template v-else v-for="q in questionList">
  34. <question-content :question="q" @parse="showParseQuestion=q,showParse=true">
  35. <el-button v-if="!hasQuestion(q)" type="primary" icon="plus" class="ml-auto" @click="addQuestion(q)">
  36. 加入试题篮
  37. </el-button>
  38. <el-button v-else type="danger" plain icon="delete" class="ml-auto" @click="removeQuestion(q)">移出试题篮
  39. </el-button>
  40. </question-content>
  41. <el-divider/>
  42. </template>
  43. <pagination v-show="total>0" :total="total" v-model:page="pageNum" v-model:limit="pageSize"
  44. @pagination="getQuestionList"/>
  45. <el-dialog v-model="showParse" append-to-body show-close @close="showParse=false">
  46. <template #title>ID:{{ showParseQuestion.id }} 试题解析</template>
  47. <div v-if="showParseQuestion.answer0" v-html="`【正确答案】` + showParseQuestion.answer0"/>
  48. <div v-if="showParseQuestion.parse" v-html="`【解析】` + showParseQuestion.parse" class="mt-5"></div>
  49. <div v-if="showParseQuestion.parse0" v-html="`【解析】` + showParseQuestion.parse0" class="mt-5"></div>
  50. <template #footer>
  51. <el-button type="primary" @click="showParse=false">确 定</el-button>
  52. </template>
  53. </el-dialog>
  54. </template>
  55. <script setup name="PaperQuestionHand">
  56. import router from '@/router'
  57. import {ElMessage} from "element-plus";
  58. import {useProvidePaperQuestionCondition} from "@/views/dz/papers/hooks/usePaperQuestionCondition.js";
  59. import {useInjectPaperExactCondition} from "@/views/dz/papers/hooks/usePaperExactCondition.js";
  60. import {useInjectPaperFullCondition} from "@/views/dz/papers/hooks/usePaperFullCondition.js";
  61. import {usePaperStorage} from "@/views/dz/papers/hooks/usePaperStorage.js";
  62. import QuestionContent from "@/views/components/question-content.vue";
  63. const props = defineProps({
  64. allowMultiple: Boolean,
  65. exactMode: Boolean
  66. })
  67. const showParse = ref(false)
  68. const showParseQuestion = ref(null)
  69. const {knowledgeNode, paperArgs} = props.exactMode ? useInjectPaperExactCondition() : useInjectPaperFullCondition()
  70. const {
  71. keyword,
  72. qtpye,
  73. qTypes,
  74. pageNum,
  75. pageSize,
  76. total,
  77. questionList,
  78. getQuestionList,
  79. cart,
  80. groupedQuestions,
  81. currentSubject,
  82. hasQuestion,
  83. addQuestion,
  84. removeQuestion,
  85. removeQuestionGroup,
  86. clearCart
  87. } = useProvidePaperQuestionCondition(props.exactMode, props.allowMultiple)
  88. const keywordLocal = ref('')
  89. const confirmKeyword = (val) => keyword.value = keywordLocal.value
  90. const buildPaper = function () {
  91. // validation
  92. const {batchId} = paperArgs.value
  93. if (!batchId) return ElMessage.error('请选择批次')
  94. if (!knowledgeNode.value) return ElMessage.error('请选择知识点')
  95. if (!cart.value.length) return ElMessage.error('请将试题加入试题篮')
  96. const paper = {...paperArgs.value, questions: cart.value}
  97. usePaperStorage(paper)
  98. router.push({name: 'PaperDetail'})
  99. }
  100. </script>
  101. <style scoped>
  102. </style>