question-hand.vue 4.6 KB

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