QuestionPreview.vue 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <template>
  2. <el-dialog
  3. class="question-preview"
  4. title="试题预览"
  5. :visible.sync="dialogVisible"
  6. :modal="false"
  7. width="800"
  8. append-to-body
  9. custom-class="side-dialog"
  10. >
  11. <el-form label-position="right" label-width="65px">
  12. <el-form-item label="题型">
  13. <span>{{ quesModel.questionType | questionType }}</span>
  14. </el-form-item>
  15. <el-form-item label="题干">
  16. <rich-text
  17. class="paper-question-body"
  18. :text-json="quesModel.quesBody"
  19. ></rich-text>
  20. </el-form-item>
  21. <template v-if="quesModel.quesOptions && quesModel.quesOptions.length">
  22. <el-form-item
  23. v-for="(quesOption, optIndex) in quesModel.quesOptions"
  24. :key="`option-${optIndex}`"
  25. >
  26. <div class="paper-question-option">
  27. <span>{{ optIndex | optionOrderWordFilter }}. </span>
  28. <rich-text :text-json="quesOption.optionBody"></rich-text>
  29. </div>
  30. </el-form-item>
  31. </template>
  32. <template v-if="quesModel.subQuestions && quesModel.subQuestions.length">
  33. <div
  34. v-for="(subQuestionModel, qindex) in quesModel.subQuestions"
  35. :key="`subq-${qindex}`"
  36. class="sub-question"
  37. >
  38. <div class="sub-question-no">{{ qindex + 1 }}</div>
  39. <el-form-item label="题目">
  40. <rich-text
  41. class="paper-question-body"
  42. :text-json="subQuestionModel.quesBody"
  43. ></rich-text>
  44. </el-form-item>
  45. <template
  46. v-if="
  47. subQuestionModel.quesOptions &&
  48. subQuestionModel.quesOptions.length
  49. "
  50. >
  51. <el-form-item
  52. v-for="(subQuesOption, subIndex) in subQuestionModel.quesOptions"
  53. :key="subIndex"
  54. >
  55. <div class="paper-question-option">
  56. <span>{{ subIndex | optionOrderWordFilter }}. </span>
  57. <rich-text :text-json="subQuesOption.optionBody"></rich-text>
  58. </div>
  59. </el-form-item>
  60. </template>
  61. <el-form-item label="答案">
  62. <question-answer
  63. class="paper-question-body"
  64. :data="subQuestionModel"
  65. ></question-answer>
  66. </el-form-item>
  67. </div>
  68. </template>
  69. <el-form-item
  70. v-if="!quesModel.subQuestions || !quesModel.subQuestions.length"
  71. label="答案"
  72. >
  73. <question-answer
  74. class="paper-question-body"
  75. :data="quesModel"
  76. ></question-answer>
  77. </el-form-item>
  78. </el-form>
  79. </el-dialog>
  80. </template>
  81. <script>
  82. export default {
  83. name: "QuestionPreview",
  84. props: {
  85. quesModel: {
  86. type: Object,
  87. default() {
  88. return {};
  89. },
  90. },
  91. },
  92. data() {
  93. return {
  94. dialogVisible: false,
  95. };
  96. },
  97. methods: {
  98. open() {
  99. this.dialogVisible = true;
  100. },
  101. close() {
  102. this.dialogVisible = false;
  103. },
  104. },
  105. };
  106. </script>