TopicElementEdit.vue 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <template>
  2. <div class="topic-element">
  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 :data="data.topicNo"></topic-number>
  29. </element-resize>
  30. </div>
  31. </template>
  32. <script>
  33. import { mapState, mapMutations, mapActions } from "vuex";
  34. import { objAssign } from "../plugins/utils";
  35. import EditCardHead from "../elements/card-head/CardHead";
  36. import EditFillQuestion from "../elements/fill-question/ElemFillQuestion";
  37. import EditFillLine from "../elements/fill-line/ElemFillLine";
  38. import EditExplain from "../elements/explain/ElemExplainEdit";
  39. import EditComposition from "../elements/composition/ElemCompositionEdit";
  40. import EditTopicHead from "../elements/topic-head/TopicHead";
  41. import ElementResize from "./common/ElementResize";
  42. import TopicNumber from "./common/TopicNumber";
  43. export default {
  44. name: "topic-design",
  45. components: {
  46. EditCardHead,
  47. EditTopicHead,
  48. EditFillQuestion,
  49. EditFillLine,
  50. EditExplain,
  51. EditComposition,
  52. ElementResize,
  53. TopicNumber
  54. },
  55. props: {
  56. data: {
  57. type: Object
  58. }
  59. },
  60. data() {
  61. return {
  62. elemData: {
  63. x: 0,
  64. y: 0,
  65. w: 0,
  66. h: 0,
  67. init: false
  68. }
  69. };
  70. },
  71. computed: {
  72. ...mapState("card", ["curElement"]),
  73. elementName() {
  74. return this.data.type.toLowerCase().replace("_", "-");
  75. },
  76. compName() {
  77. return `edit-${this.elementName}`;
  78. },
  79. classes() {
  80. return [
  81. "topic-design",
  82. "element-item",
  83. `element-item-${this.elementName}`,
  84. this.data["isLast"]
  85. ? `element-item-type-last`
  86. : "element-item-type-pre",
  87. {
  88. "element-item-error": this.data.isCovered
  89. }
  90. ];
  91. }
  92. },
  93. created() {
  94. this.init();
  95. },
  96. methods: {
  97. ...mapMutations("card", ["setCurElement"]),
  98. ...mapActions("card", ["modifyTopic", "rebuildPages"]),
  99. init() {
  100. this.elemData = objAssign(this.elemData, this.data);
  101. },
  102. activeCurElement() {
  103. this.setCurElement(this.data);
  104. },
  105. sizeChange() {
  106. const elementDom = document.getElementById(this.data.id);
  107. this.data.isCovered =
  108. elementDom.offsetHeight < elementDom.firstChild.offsetHeight;
  109. },
  110. resizeOver() {
  111. this.modifyTopic(Object.assign({}, this.curElement, this.elemData));
  112. // 注意:当前组件并没有实时更新元件的尺寸信息,只是在rebuildPages时统一更新。
  113. this.$nextTick(() => {
  114. this.rebuildPages();
  115. });
  116. }
  117. }
  118. };
  119. </script>