TopicElementEdit.vue 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  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 EditTopicHead from "../elements/topic-head/TopicHead";
  46. import ElementResize from "./common/ElementResize";
  47. import TopicNumber from "./common/TopicNumber";
  48. export default {
  49. name: "topic-element-edit",
  50. components: {
  51. EditCardHead,
  52. EditTopicHead,
  53. EditFillQuestion,
  54. EditFillLine,
  55. EditExplain,
  56. EditComposition,
  57. ElementResize,
  58. TopicNumber
  59. },
  60. props: {
  61. data: {
  62. type: Object
  63. }
  64. },
  65. data() {
  66. return {
  67. elemData: {
  68. x: 0,
  69. y: 0,
  70. w: 0,
  71. h: 0,
  72. init: false
  73. }
  74. };
  75. },
  76. computed: {
  77. ...mapState("card", ["curElement"]),
  78. elementName() {
  79. return this.data.type.toLowerCase().replace("_", "-");
  80. },
  81. compName() {
  82. return `edit-${this.elementName}`;
  83. },
  84. classes() {
  85. return [
  86. "topic-design",
  87. "element-item",
  88. `element-item-${this.elementName}`,
  89. this.data["isLast"]
  90. ? `element-item-type-last`
  91. : "element-item-type-pre",
  92. {
  93. "element-item-error": this.data.isCovered
  94. }
  95. ];
  96. }
  97. },
  98. created() {
  99. this.init();
  100. },
  101. methods: {
  102. ...mapMutations("card", ["setCurElement"]),
  103. ...mapActions("card", ["modifyTopic", "rebuildPages"]),
  104. init() {
  105. this.elemData = objAssign(this.elemData, this.data);
  106. },
  107. activeCurElement() {
  108. this.setCurElement(this.data);
  109. },
  110. sizeChange() {
  111. this.data.isCovered = checkElementisCovered(this.data.id, this.data.type);
  112. },
  113. resizeOver() {
  114. this.modifyTopic(Object.assign({}, this.curElement, this.elemData));
  115. // 注意:当前组件并没有实时更新元件的尺寸信息,只是在rebuildPages时统一更新。
  116. this.$nextTick(() => {
  117. this.rebuildPages();
  118. });
  119. }
  120. }
  121. };
  122. </script>