TopicElementEdit.vue 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <template>
  2. <div class="topic-element-edit">
  3. <div
  4. :class="classes"
  5. :id="data.id"
  6. :data-type="data.type"
  7. v-if="data.type === 'CARD_HEAD' || data.type === 'TOPIC_HEAD'"
  8. >
  9. <!-- card-head 和 topic-head不需要调整高度 -->
  10. <component :is="compName" :data="data"></component>
  11. </div>
  12. <element-resize
  13. v-model="elemData"
  14. :class="{ 'element-resize-act': curElement.id === data.id }"
  15. :active="['b']"
  16. :move="false"
  17. :min-height="data.minHeight"
  18. :fit-parent="['h']"
  19. @on-click="activeCurElement"
  20. @resize-over="resizeOver"
  21. @change="sizeChange"
  22. v-else
  23. >
  24. <div :class="classes" :id="data.id" :data-type="data.type">
  25. <component :is="compName" :data="data"></component>
  26. </div>
  27. <!-- topic-number -->
  28. <topic-number
  29. :data="data.topicNo"
  30. title="点击选中当前题目"
  31. @click="activeCurElement"
  32. ></topic-number>
  33. </element-resize>
  34. </div>
  35. </template>
  36. <script>
  37. import { mapState, mapMutations, mapActions } from "vuex";
  38. import { objAssign } from "../plugins/utils";
  39. import { checkElementisCovered } from "../store/card";
  40. import EditCardHead from "../elements/card-head/CardHead";
  41. import EditFillQuestion from "../elements/fill-question/ElemFillQuestion";
  42. import EditFillLine from "../elements/fill-line/ElemFillLine";
  43. import EditExplain from "../elements/explain/ElemExplainEdit";
  44. import EditComposition from "../elements/composition/ElemCompositionEdit";
  45. import EditForbidArea from "../elements/forbid-area/ElemForbidArea.vue";
  46. import EditTopicHead from "../elements/topic-head/TopicHead";
  47. import ElementResize from "./common/ElementResize";
  48. import TopicNumber from "./common/TopicNumber";
  49. export default {
  50. name: "topic-element-edit",
  51. components: {
  52. EditCardHead,
  53. EditTopicHead,
  54. EditFillQuestion,
  55. EditFillLine,
  56. EditExplain,
  57. EditForbidArea,
  58. EditComposition,
  59. ElementResize,
  60. TopicNumber,
  61. },
  62. props: {
  63. data: {
  64. type: Object,
  65. },
  66. },
  67. data() {
  68. return {
  69. elemData: {
  70. x: 0,
  71. y: 0,
  72. w: 0,
  73. h: 0,
  74. init: false,
  75. },
  76. };
  77. },
  78. computed: {
  79. ...mapState("card", ["curElement"]),
  80. elementName() {
  81. return this.data.type.toLowerCase().replace("_", "-");
  82. },
  83. compName() {
  84. return `edit-${this.elementName}`;
  85. },
  86. classes() {
  87. return [
  88. "topic-design",
  89. "element-item",
  90. `element-item-${this.elementName}`,
  91. this.data["isLast"]
  92. ? `element-item-type-last`
  93. : "element-item-type-pre",
  94. {
  95. "element-item-error": this.data.isCovered,
  96. },
  97. ];
  98. },
  99. },
  100. created() {
  101. this.init();
  102. },
  103. methods: {
  104. ...mapMutations("card", ["setCurElement"]),
  105. ...mapActions("card", ["modifyTopic", "rebuildPages"]),
  106. init() {
  107. this.elemData = objAssign(this.elemData, this.data);
  108. },
  109. activeCurElement() {
  110. this.setCurElement(this.data);
  111. },
  112. sizeChange() {
  113. this.data.isCovered = checkElementisCovered(this.data.id, this.data.type);
  114. },
  115. resizeOver() {
  116. this.modifyTopic(Object.assign({}, this.curElement, this.elemData));
  117. // 注意:当前组件并没有实时更新元件的尺寸信息,只是在rebuildPages时统一更新。
  118. this.$nextTick(() => {
  119. this.rebuildPages();
  120. });
  121. },
  122. },
  123. };
  124. </script>