@maketribe/ms-app 3.2.26 → 3.2.28

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (207) hide show
  1. package/dist/cjs/components/basic/doc-editor/core/element-block.js +18 -13
  2. package/dist/cjs/components/basic/doc-editor/core/element-block.js.map +1 -1
  3. package/dist/cjs/components/basic/doc-editor/core/utils.js +20 -13
  4. package/dist/cjs/components/basic/doc-editor/core/utils.js.map +1 -1
  5. package/dist/cjs/components/basic/doc-editor/editor.vue.js.map +1 -1
  6. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/GridNode.js.map +1 -1
  7. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/ImageTextGridNode.js.map +1 -1
  8. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.js +32 -1
  9. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.js.map +1 -1
  10. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.js +13 -0
  11. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.js.map +1 -1
  12. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/TextGridNode.js +11 -0
  13. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/TextGridNode.js.map +1 -1
  14. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/index.vue.js +87 -13
  15. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/index.vue.js.map +1 -1
  16. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/utils.js +114 -7
  17. package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/utils.js.map +1 -1
  18. package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.js +51 -37
  19. package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.js.map +1 -1
  20. package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/index.vue.js +3 -5
  21. package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/index.vue.js.map +1 -1
  22. package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/utils.js +32 -54
  23. package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/utils.js.map +1 -1
  24. package/dist/cjs/components/basic/doc-editor/plugins/ModulePlugin/composables.js +14 -1
  25. package/dist/cjs/components/basic/doc-editor/plugins/ModulePlugin/composables.js.map +1 -1
  26. package/dist/cjs/components/basic/doc-editor/plugins/ModulePlugin/index.vue.js +40 -3
  27. package/dist/cjs/components/basic/doc-editor/plugins/ModulePlugin/index.vue.js.map +1 -1
  28. package/dist/cjs/components/basic/doc-editor/plugins/RichTextPlugin/index.vue.js.map +1 -1
  29. package/dist/cjs/components/basic/doc-editor/plugins/RichTextPlugin/nodes/RichTextNode.js +16 -16
  30. package/dist/cjs/components/basic/doc-editor/plugins/RichTextPlugin/nodes/RichTextNode.js.map +1 -1
  31. package/dist/cjs/components/basic/doc-editor/plugins/ToolbarPlugin/FontStyleTool.vue.js +8 -7
  32. package/dist/cjs/components/basic/doc-editor/plugins/ToolbarPlugin/FontStyleTool.vue.js.map +1 -1
  33. package/dist/cjs/components/basic/doc-editor/plugins/nodes.js.map +1 -1
  34. package/dist/cjs/components/basic/doc-editor/themes/doc-editor-edit.css.js +1 -1
  35. package/dist/cjs/components/basic/doc-editor/themes/doc-editor-edit.css.js.map +1 -1
  36. package/dist/cjs/components/basic/dynamic-form-panel/DynamicFormPanel.js +40 -18
  37. package/dist/cjs/components/basic/dynamic-form-panel/DynamicFormPanel.js.map +1 -1
  38. package/dist/cjs/components/basic/dynamic-form-panel/dialog.js +2 -2
  39. package/dist/cjs/components/basic/dynamic-form-panel/dialog.js.map +1 -1
  40. package/dist/cjs/components/basic/image-cropper/image-cropper-api.js.map +1 -1
  41. package/dist/cjs/components/basic/visual-page-editor/content-editable.vue.js +13 -9
  42. package/dist/cjs/components/basic/visual-page-editor/content-editable.vue.js.map +1 -1
  43. package/dist/cjs/components/basic/visual-page-editor/core/BlockRender.js +38 -0
  44. package/dist/cjs/components/basic/visual-page-editor/core/BlockRender.js.map +1 -0
  45. package/dist/cjs/components/basic/visual-page-editor/core/Dialog.js +76 -0
  46. package/dist/cjs/components/basic/visual-page-editor/core/Dialog.js.map +1 -0
  47. package/dist/cjs/components/basic/visual-page-editor/core/VisvalPageEditor.js +72 -1
  48. package/dist/cjs/components/basic/visual-page-editor/core/VisvalPageEditor.js.map +1 -1
  49. package/dist/cjs/components/basic/visual-page-editor/core/index.js +21 -13
  50. package/dist/cjs/components/basic/visual-page-editor/core/index.js.map +1 -1
  51. package/dist/cjs/components/basic/visual-page-editor/editor.vue.js +2 -29
  52. package/dist/cjs/components/basic/visual-page-editor/editor.vue.js.map +1 -1
  53. package/dist/cjs/components/basic/visual-page-editor/index.js +1 -1
  54. package/dist/cjs/components/basic/visual-page-editor/index.js.map +1 -1
  55. package/dist/cjs/components/basic/visual-page-editor/modules/BaseImageModule.js +10 -0
  56. package/dist/cjs/components/basic/visual-page-editor/modules/BaseImageModule.js.map +1 -0
  57. package/dist/cjs/components/basic/visual-page-editor/toolbar.vue.js +1 -1
  58. package/dist/cjs/components/basic/visual-page-editor/toolbar.vue.js.map +1 -1
  59. package/dist/cjs/modules/cms/cms-settings.js +4 -0
  60. package/dist/cjs/modules/cms/cms-settings.js.map +1 -1
  61. package/dist/cjs/modules/cms/composables/part-extensions.js +6 -6
  62. package/dist/cjs/modules/cms/composables/part-extensions.js.map +1 -1
  63. package/dist/cjs/modules/cms/dataviews/cms-ad-contents/CmsAdContentsForm.js +20 -2
  64. package/dist/cjs/modules/cms/dataviews/cms-ad-contents/CmsAdContentsForm.js.map +1 -1
  65. package/dist/cjs/modules/cms/pages/cms-ad/index.vue2.js +0 -1
  66. package/dist/cjs/modules/cms/pages/cms-ad/index.vue2.js.map +1 -1
  67. package/dist/cjs/modules/cms/pages/cms-contents/article-edit-add-page.vue2.js +3 -1
  68. package/dist/cjs/modules/cms/pages/cms-contents/article-edit-add-page.vue2.js.map +1 -1
  69. package/dist/cjs/modules/cms/pages/cms-contents/components/part-banner-edit.vue.js +32 -9
  70. package/dist/cjs/modules/cms/pages/cms-contents/components/part-banner-edit.vue.js.map +1 -1
  71. package/dist/cjs/modules/cms/pages/cms-contents/index.vue2.js +47 -43
  72. package/dist/cjs/modules/cms/pages/cms-contents/index.vue2.js.map +1 -1
  73. package/dist/cjs/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.js +312 -0
  74. package/dist/cjs/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.js.map +1 -0
  75. package/dist/cjs/modules/cms/pages/cms-settigns/DocModuleEditForm.vue2.js +4 -0
  76. package/dist/cjs/modules/cms/pages/cms-settigns/DocModuleEditForm.vue2.js.map +1 -0
  77. package/dist/cjs/modules/cms/pages/cms-settigns/index.vue2.js +18 -0
  78. package/dist/cjs/modules/cms/pages/cms-settigns/index.vue2.js.map +1 -1
  79. package/dist/cjs/modules/ms/components/image-select/image-select-api.js +14 -2
  80. package/dist/cjs/modules/ms/components/image-select/image-select-api.js.map +1 -1
  81. package/dist/cjs/modules/ms/image-upload-context/index.js +1 -1
  82. package/dist/cjs/modules/ms/image-upload-context/index.js.map +1 -1
  83. package/dist/esm/components/basic/doc-editor/core/element-block.js +18 -13
  84. package/dist/esm/components/basic/doc-editor/core/element-block.js.map +1 -1
  85. package/dist/esm/components/basic/doc-editor/core/utils.js +20 -13
  86. package/dist/esm/components/basic/doc-editor/core/utils.js.map +1 -1
  87. package/dist/esm/components/basic/doc-editor/editor.vue.js.map +1 -1
  88. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/GridNode.js.map +1 -1
  89. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/ImageTextGridNode.js.map +1 -1
  90. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.js +32 -1
  91. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.js.map +1 -1
  92. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.js +13 -0
  93. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.js.map +1 -1
  94. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/TextGridNode.js +11 -0
  95. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/TextGridNode.js.map +1 -1
  96. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/index.vue.js +87 -13
  97. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/index.vue.js.map +1 -1
  98. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/utils.js +114 -7
  99. package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/utils.js.map +1 -1
  100. package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.js +52 -38
  101. package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.js.map +1 -1
  102. package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/index.vue.js +3 -5
  103. package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/index.vue.js.map +1 -1
  104. package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/utils.js +33 -55
  105. package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/utils.js.map +1 -1
  106. package/dist/esm/components/basic/doc-editor/plugins/ModulePlugin/composables.js +14 -1
  107. package/dist/esm/components/basic/doc-editor/plugins/ModulePlugin/composables.js.map +1 -1
  108. package/dist/esm/components/basic/doc-editor/plugins/ModulePlugin/index.vue.js +40 -3
  109. package/dist/esm/components/basic/doc-editor/plugins/ModulePlugin/index.vue.js.map +1 -1
  110. package/dist/esm/components/basic/doc-editor/plugins/RichTextPlugin/index.vue.js.map +1 -1
  111. package/dist/esm/components/basic/doc-editor/plugins/RichTextPlugin/nodes/RichTextNode.js +16 -16
  112. package/dist/esm/components/basic/doc-editor/plugins/RichTextPlugin/nodes/RichTextNode.js.map +1 -1
  113. package/dist/esm/components/basic/doc-editor/plugins/ToolbarPlugin/FontStyleTool.vue.js +11 -10
  114. package/dist/esm/components/basic/doc-editor/plugins/ToolbarPlugin/FontStyleTool.vue.js.map +1 -1
  115. package/dist/esm/components/basic/doc-editor/plugins/nodes.js.map +1 -1
  116. package/dist/esm/components/basic/doc-editor/themes/doc-editor-edit.css.js +1 -1
  117. package/dist/esm/components/basic/doc-editor/themes/doc-editor-edit.css.js.map +1 -1
  118. package/dist/esm/components/basic/dynamic-form-panel/DynamicFormPanel.js +40 -18
  119. package/dist/esm/components/basic/dynamic-form-panel/DynamicFormPanel.js.map +1 -1
  120. package/dist/esm/components/basic/dynamic-form-panel/dialog.js +2 -2
  121. package/dist/esm/components/basic/dynamic-form-panel/dialog.js.map +1 -1
  122. package/dist/esm/components/basic/image-cropper/image-cropper-api.js.map +1 -1
  123. package/dist/esm/components/basic/visual-page-editor/content-editable.vue.js +14 -10
  124. package/dist/esm/components/basic/visual-page-editor/content-editable.vue.js.map +1 -1
  125. package/dist/esm/components/basic/visual-page-editor/core/BlockRender.js +39 -0
  126. package/dist/esm/components/basic/visual-page-editor/core/BlockRender.js.map +1 -0
  127. package/dist/esm/components/basic/visual-page-editor/core/Dialog.js +76 -0
  128. package/dist/esm/components/basic/visual-page-editor/core/Dialog.js.map +1 -0
  129. package/dist/esm/components/basic/visual-page-editor/core/VisvalPageEditor.js +73 -2
  130. package/dist/esm/components/basic/visual-page-editor/core/VisvalPageEditor.js.map +1 -1
  131. package/dist/esm/components/basic/visual-page-editor/core/index.js +21 -13
  132. package/dist/esm/components/basic/visual-page-editor/core/index.js.map +1 -1
  133. package/dist/esm/components/basic/visual-page-editor/editor.vue.js +4 -31
  134. package/dist/esm/components/basic/visual-page-editor/editor.vue.js.map +1 -1
  135. package/dist/esm/components/basic/visual-page-editor/index.js +1 -1
  136. package/dist/esm/components/basic/visual-page-editor/index.js.map +1 -1
  137. package/dist/esm/components/basic/visual-page-editor/modules/BaseImageModule.js +9 -0
  138. package/dist/esm/components/basic/visual-page-editor/modules/BaseImageModule.js.map +1 -0
  139. package/dist/esm/components/basic/visual-page-editor/toolbar.vue.js +2 -2
  140. package/dist/esm/components/basic/visual-page-editor/toolbar.vue.js.map +1 -1
  141. package/dist/esm/modules/cms/cms-settings.js +4 -0
  142. package/dist/esm/modules/cms/cms-settings.js.map +1 -1
  143. package/dist/esm/modules/cms/composables/part-extensions.js +6 -6
  144. package/dist/esm/modules/cms/composables/part-extensions.js.map +1 -1
  145. package/dist/esm/modules/cms/dataviews/cms-ad-contents/CmsAdContentsForm.js +20 -2
  146. package/dist/esm/modules/cms/dataviews/cms-ad-contents/CmsAdContentsForm.js.map +1 -1
  147. package/dist/esm/modules/cms/pages/cms-ad/index.vue2.js +0 -1
  148. package/dist/esm/modules/cms/pages/cms-ad/index.vue2.js.map +1 -1
  149. package/dist/esm/modules/cms/pages/cms-contents/article-edit-add-page.vue2.js +3 -1
  150. package/dist/esm/modules/cms/pages/cms-contents/article-edit-add-page.vue2.js.map +1 -1
  151. package/dist/esm/modules/cms/pages/cms-contents/components/part-banner-edit.vue.js +32 -9
  152. package/dist/esm/modules/cms/pages/cms-contents/components/part-banner-edit.vue.js.map +1 -1
  153. package/dist/esm/modules/cms/pages/cms-contents/index.vue2.js +49 -45
  154. package/dist/esm/modules/cms/pages/cms-contents/index.vue2.js.map +1 -1
  155. package/dist/esm/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.js +313 -0
  156. package/dist/esm/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.js.map +1 -0
  157. package/dist/esm/modules/cms/pages/cms-settigns/DocModuleEditForm.vue2.js +5 -0
  158. package/dist/esm/modules/cms/pages/cms-settigns/DocModuleEditForm.vue2.js.map +1 -0
  159. package/dist/esm/modules/cms/pages/cms-settigns/index.vue2.js +18 -0
  160. package/dist/esm/modules/cms/pages/cms-settigns/index.vue2.js.map +1 -1
  161. package/dist/esm/modules/ms/components/image-select/image-select-api.js +14 -2
  162. package/dist/esm/modules/ms/components/image-select/image-select-api.js.map +1 -1
  163. package/dist/esm/modules/ms/image-upload-context/index.js +1 -1
  164. package/dist/esm/modules/ms/image-upload-context/index.js.map +1 -1
  165. package/dist/style/components/basic/visual-page-editor/index.css +1 -1
  166. package/dist/style/components/index.css +1 -1
  167. package/dist/style/index.css +1 -1
  168. package/dist/style/src/components/basic/visual-page-editor/index.scss +4 -2
  169. package/dist/types/components/basic/doc-editor/core/element-block.d.ts +1 -0
  170. package/dist/types/components/basic/doc-editor/core/utils.d.ts +2 -2
  171. package/dist/types/components/basic/doc-editor/plugins/GridPlugin/ImageTextGridNode.d.ts +1 -1
  172. package/dist/types/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.d.ts +16 -2
  173. package/dist/types/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.d.ts +7 -1
  174. package/dist/types/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.d.ts +25 -12
  175. package/dist/types/components/basic/doc-editor/plugins/ModulePlugin/composables.d.ts +5 -0
  176. package/dist/types/components/basic/doc-editor/utils/getSelectedNode.d.ts +1 -1
  177. package/dist/types/components/basic/dynamic-form-panel/type.d.ts +1 -0
  178. package/dist/types/components/basic/visual-page-editor/core/Dialog.d.ts +15 -0
  179. package/dist/types/components/basic/visual-page-editor/core/ModuleDefine.d.ts +12 -0
  180. package/dist/types/components/basic/visual-page-editor/core/VisvalPageEditor.d.ts +45 -1
  181. package/dist/types/components/basic/visual-page-editor/core/index.d.ts +2 -10
  182. package/dist/types/components/basic/visual-page-editor/editor.vue.d.ts +1 -0
  183. package/dist/types/components/basic/visual-page-editor/index.d.ts +2 -1
  184. package/dist/types/components/basic/visual-page-editor/modules/index.d.ts +1 -0
  185. package/dist/types/modules/cms/cms-settings.d.ts +4 -28
  186. package/dist/types/modules/cms/composables/part-extensions.d.ts +7 -3
  187. package/dist/types/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.d.ts +45 -0
  188. package/dist/types/modules/ms/components/image-select/image-select-api.d.ts +1 -1
  189. package/dist/types/modules/ms/image-upload-context/index.d.ts +1 -1
  190. package/package.json +9 -8
  191. package/dist/cjs/components/basic/visual-page-editor/components/BlockRender.js +0 -31
  192. package/dist/cjs/components/basic/visual-page-editor/components/BlockRender.js.map +0 -1
  193. package/dist/cjs/components/basic/visual-page-editor/utils/Dialog.js +0 -111
  194. package/dist/cjs/components/basic/visual-page-editor/utils/Dialog.js.map +0 -1
  195. package/dist/cjs/components/basic/visual-page-editor/visual-components/ImageRenderComponent.js +0 -29
  196. package/dist/cjs/components/basic/visual-page-editor/visual-components/ImageRenderComponent.js.map +0 -1
  197. package/dist/esm/components/basic/visual-page-editor/components/BlockRender.js +0 -32
  198. package/dist/esm/components/basic/visual-page-editor/components/BlockRender.js.map +0 -1
  199. package/dist/esm/components/basic/visual-page-editor/utils/Dialog.js +0 -111
  200. package/dist/esm/components/basic/visual-page-editor/utils/Dialog.js.map +0 -1
  201. package/dist/esm/components/basic/visual-page-editor/visual-components/ImageRenderComponent.js +0 -28
  202. package/dist/esm/components/basic/visual-page-editor/visual-components/ImageRenderComponent.js.map +0 -1
  203. package/dist/types/components/basic/visual-page-editor/core/RenderComponent.d.ts +0 -16
  204. package/dist/types/components/basic/visual-page-editor/utils/Dialog.d.ts +0 -15
  205. package/dist/types/components/basic/visual-page-editor/visual-components/index.d.ts +0 -1
  206. /package/dist/types/components/basic/visual-page-editor/{components → core}/BlockRender.d.ts +0 -0
  207. /package/dist/types/components/basic/visual-page-editor/{visual-components/ImageRenderComponent.d.ts → modules/BaseImageModule.d.ts} +0 -0
@@ -1,6 +1,24 @@
1
1
  import { showDynamicFormDialoger } from "../../../dynamic-form-panel/dialog.js";
2
2
  import "vue";
3
3
  import "element-plus";
4
+ import "@maketribe/dm";
5
+ import "@element-plus/icons-vue";
6
+ import "@maketribe/utils";
7
+ import "../../../../../core/DataModelDefines.js";
8
+ import "vue-router";
9
+ import "@maketribe/request";
10
+ import "@maketribe/locale";
11
+ import "../../../../../modules/ms/dataviews/ms-config/MsConfigTable.js";
12
+ import "lodash-es";
13
+ import "../../../../../modules/ms/components/material-list/index.js";
14
+ import "../../../image-cropper/index.js";
15
+ import "../../../upload-file/upload-file.js";
16
+ import "../../../upload-file/context/web-file-upload-context.js";
17
+ import "../../../upload-file/context/web-file-upload-context-options.js";
18
+ import "../../../upload-file/ui/upload-image/index.js";
19
+ import "../../../upload-file/ui/upload-file/index.js";
20
+ import "../../../upload-file/ui/upload-video/index.js";
21
+ import "../../../upload-file/upload-file-options.js";
4
22
  import { $isLayoutGridNode } from "./LayoutGridNode.js";
5
23
  import { $isModuleGridNode } from "./ModuleGridNode.js";
6
24
  const showGridEditDialoger = async (node, parent, data) => {
@@ -11,21 +29,110 @@ const showGridEditDialoger = async (node, parent, data) => {
11
29
  { name: "maxWidth", title: "最大宽度(支持%) : ", component: "el-input", props: { clearable: true }, defaultValue: "" },
12
30
  { name: "maxHeight", title: "最大高度(支持%) : ", component: "el-input", props: { clearable: true }, defaultValue: "" }
13
31
  ];
32
+ let title = "容器";
14
33
  if ($isLayoutGridNode(parent)) {
15
34
  options.push({ name: "flex", title: "弹性比例(Flex) : ", component: "el-input", props: { clearable: true }, defaultValue: "" });
35
+ if ($isLayoutGridNode(node)) {
36
+ options.push({
37
+ name: "display",
38
+ title: "容器类型 : ",
39
+ component: "el-radio-group",
40
+ props: {
41
+ data: [
42
+ { value: "block", label: "普通快(block)" },
43
+ { value: "flex", label: "弹性格子(Flex)" }
44
+ ]
45
+ },
46
+ defaultValue: ""
47
+ });
48
+ }
16
49
  }
17
50
  if ($isLayoutGridNode(node)) {
18
51
  options.push(...[
19
- { name: "flexDirection", title: "flex-direction : ", component: "el-input", props: { clearable: true }, defaultValue: "column" },
20
- { name: "flexWrap", title: "flex-wrap) : ", component: "el-input", props: { clearable: true }, defaultValue: "warp" },
21
- { name: "alignContent", title: "align-content : ", component: "el-input", props: { clearable: true }, defaultValue: "" },
22
- { name: "justifyContent", title: "justify-content : ", component: "el-input", props: { clearable: true }, defaultValue: "" },
23
- { name: "alignItems", title: "align-items : ", component: "el-input", props: { clearable: true }, defaultValue: "" }
52
+ {
53
+ name: "flexDirection",
54
+ title: "flex-direction : ",
55
+ component: "el-radio-group",
56
+ props: {
57
+ data: [
58
+ { value: "column", label: "column" },
59
+ { value: "row", label: "row" },
60
+ { value: "row-reverse", label: "row-reverse" },
61
+ { value: "column-reverse", label: "column-reverse" }
62
+ ]
63
+ },
64
+ defaultValue: "",
65
+ condition: (data2) => data2["display"] == "flex"
66
+ },
67
+ {
68
+ name: "flexWrap",
69
+ title: "是否换行 : ",
70
+ component: "el-radio-group",
71
+ props: {
72
+ data: [
73
+ { value: "warp", label: "换行" },
74
+ { value: "nowrap", label: "不换行" }
75
+ ]
76
+ },
77
+ defaultValue: "",
78
+ condition: (data2) => data2["display"] == "flex"
79
+ },
80
+ {
81
+ name: "alignContent",
82
+ title: "align-content : ",
83
+ component: "el-radio-group",
84
+ props: {
85
+ data: [
86
+ { value: "flex-start", label: "左" },
87
+ { value: "center", label: "居中" },
88
+ { value: "flex-end", label: "右" },
89
+ { value: "space-between", label: "两边" },
90
+ { value: "space-around", label: "space-around" },
91
+ { value: "stretch", label: "stretch" }
92
+ ]
93
+ },
94
+ defaultValue: "",
95
+ condition: (data2) => data2["display"] == "flex"
96
+ },
97
+ {
98
+ name: "justifyContent",
99
+ title: "justify-content : ",
100
+ component: "el-radio-group",
101
+ props: {
102
+ data: [
103
+ { value: "flex-start", label: "顶部" },
104
+ { value: "center", label: "居中" },
105
+ { value: "flex-end", label: "底部" },
106
+ { value: "space-between", label: "两边" },
107
+ { value: "space-around", label: "space-around" },
108
+ { value: "space-evenly", label: "space-evenly" }
109
+ ]
110
+ },
111
+ defaultValue: "",
112
+ condition: (data2) => data2["display"] == "flex"
113
+ },
114
+ {
115
+ name: "alignItems",
116
+ title: "align-items : ",
117
+ component: "el-radio-group",
118
+ props: {
119
+ data: [
120
+ { value: "flex-start", label: "左" },
121
+ { value: "center", label: "居中" },
122
+ { value: "flex-end", label: "右" },
123
+ { value: "stretch", label: "stretch" },
124
+ { value: "baseline", label: "baseline" }
125
+ ]
126
+ },
127
+ defaultValue: "",
128
+ condition: (data2) => data2["display"] == "flex"
129
+ }
24
130
  ]);
25
- } else if ($isModuleGridNode(node)) {
131
+ }
132
+ if ($isModuleGridNode(node)) {
26
133
  options.push({ name: "overflowX", title: "横向滚动 : ", component: "el-switch", props: {}, defaultValue: false });
27
134
  }
28
- return await showDynamicFormDialoger("模块容器", options, data);
135
+ return await showDynamicFormDialoger(title, options, data);
29
136
  };
30
137
  export {
31
138
  showGridEditDialoger
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sources":["../../../../../../../src/components/basic/doc-editor/plugins/GridPlugin/utils.ts"],"sourcesContent":["import { LexicalNode } from \"lexical\"\r\n\r\nimport { createDefaultFormData } from \"../../../dynamic-form-panel/utils\"\r\nimport { showDynamicFormDialoger } from \"../../../dynamic-form-panel\"\r\n\r\nimport { GridNode,$isGridNode } from \"./GridNode\"\r\nimport { $isLayoutGridNode } from \"./LayoutGridNode\"\r\nimport { type TextGridNodeAttrType,TextGridNode,INSERT_TEXTGRID_COMMAND } from \"./TextGridNode\"\r\nimport { type ImageTextGridNodeAttrType,ImageTextGridNode,INSERT_IMAGETEXTGRID_COMMAND } from \"./ImageTextGridNode\"\r\nimport { type ModuleGridNodeAttrType,ModuleGridNode,INSERT_MODULEGRID_COMMAND,$isModuleGridNode } from \"./ModuleGridNode\"\r\n\r\nexport const showGridEditDialoger = async (node:GridNode,parent:LexicalNode,data:any)=>{\r\n\r\n // 表单面板\r\n const options = [\r\n { name:\"class\", title:\"标识类名 : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"width\", title:\"宽度(支持%) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"height\", title:\"高度度(支持%) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"maxWidth\", title:\"最大宽度(支持%) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"maxHeight\", title:\"最大高度(支持%) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" }\r\n ];\r\n\r\n if($isLayoutGridNode(parent)){\r\n options.push({ name:\"flex\", title:\"弹性比例(Flex) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" })\r\n }\r\n\r\n // 布局格子\r\n if($isLayoutGridNode(node)){\r\n options.push(...[\r\n { name:\"flexDirection\", title:\"flex-direction : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"column\" },\r\n { name:\"flexWrap\", title:\"flex-wrap) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"warp\" },\r\n { name:\"alignContent\", title:\"align-content : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"justifyContent\", title:\"justify-content : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"alignItems\", title:\"align-items : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" }\r\n ]);\r\n }\r\n else if($isModuleGridNode(node)){\r\n options.push( { name:\"overflowX\", title:\"横向滚动 : \", component:\"el-switch\", props:{ } as any, defaultValue:false as any });\r\n }\r\n\r\n return await showDynamicFormDialoger(\"模块容器\",options,data)\r\n}\r\n"],"names":[],"mappings":";;;;;AAWO,MAAM,uBAAuB,OAAO,MAAc,QAAmB,SAAW;AAGrF,QAAM,UAAU;AAAA,IACd,EAAE,MAAK,SAAS,OAAM,WAAW,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,GAAG;AAAA,IAClG,EAAE,MAAK,SAAS,OAAM,cAAc,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,GAAG;AAAA,IACrG,EAAE,MAAK,UAAU,OAAM,eAAe,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,GAAG;AAAA,IACvG,EAAE,MAAK,YAAY,OAAM,gBAAgB,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,GAAG;AAAA,IAC1G,EAAE,MAAK,aAAa,OAAM,gBAAgB,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,GAAG;AAAA,EAAA;AAG1G,MAAA,kBAAkB,MAAM,GAAE;AAC3B,YAAQ,KAAK,EAAE,MAAK,QAAQ,OAAM,iBAAiB,WAAU,YAAa,OAAM,EAAE,WAAU,KAAQ,GAAA,cAAa,IAAI;AAAA,EACvH;AAGG,MAAA,kBAAkB,IAAI,GAAE;AACzB,YAAQ,KAAK,GAAG;AAAA,MACd,EAAE,MAAK,iBAAiB,OAAM,qBAAqB,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,SAAS;AAAA,MAC1H,EAAE,MAAK,YAAY,OAAM,iBAAiB,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,OAAO;AAAA,MAC/G,EAAE,MAAK,gBAAgB,OAAM,oBAAoB,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,GAAG;AAAA,MAClH,EAAE,MAAK,kBAAkB,OAAM,sBAAsB,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,GAAG;AAAA,MACtH,EAAE,MAAK,cAAc,OAAM,kBAAkB,WAAU,YAAa,OAAM,EAAE,WAAU,QAAQ,cAAa,GAAG;AAAA,IAAA,CAC/G;AAAA,EAAA,WAEK,kBAAkB,IAAI,GAAE;AAC9B,YAAQ,KAAM,EAAE,MAAK,aAAa,OAAM,WAAW,WAAU,aAAc,OAAM,CAAA,GAAY,cAAa,MAAc,CAAA;AAAA,EAC1H;AAEA,SAAO,MAAM,wBAAwB,QAAO,SAAQ,IAAI;AAC1D;"}
1
+ {"version":3,"file":"utils.js","sources":["../../../../../../../src/components/basic/doc-editor/plugins/GridPlugin/utils.ts"],"sourcesContent":["import { LexicalNode } from \"lexical\"\r\n\r\nimport { createDefaultFormData } from \"../../../dynamic-form-panel/utils\"\r\nimport { showDynamicFormDialoger } from \"../../../dynamic-form-panel\"\r\n\r\nimport { GridNode,$isGridNode } from \"./GridNode\"\r\nimport { $isLayoutGridNode } from \"./LayoutGridNode\"\r\nimport { type TextGridNodeAttrType,TextGridNode,INSERT_TEXTGRID_COMMAND } from \"./TextGridNode\"\r\nimport { type ImageTextGridNodeAttrType,ImageTextGridNode,INSERT_IMAGETEXTGRID_COMMAND } from \"./ImageTextGridNode\"\r\nimport { type ModuleGridNodeAttrType,ModuleGridNode,INSERT_MODULEGRID_COMMAND,$isModuleGridNode } from \"./ModuleGridNode\"\r\n\r\nexport const showGridEditDialoger = async (node:GridNode,parent:LexicalNode,data:any)=>{\r\n\r\n // 表单面板\r\n const options:any = [\r\n { name:\"class\", title:\"标识类名 : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"width\", title:\"宽度(支持%) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"height\", title:\"高度度(支持%) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"maxWidth\", title:\"最大宽度(支持%) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" },\r\n { name:\"maxHeight\", title:\"最大高度(支持%) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" }\r\n ];\r\n\r\n let title = \"容器\";\r\n\r\n if($isLayoutGridNode(parent)){\r\n options.push({ name:\"flex\", title:\"弹性比例(Flex) : \", component:\"el-input\", props:{ clearable:true }, defaultValue:\"\" })\r\n\r\n if($isLayoutGridNode(node)){\r\n options.push({ \r\n name:\"display\", title:\"容器类型 : \", component:\"el-radio-group\", props:{ \r\n data:[\r\n { value:\"block\" ,label:\"普通快(block)\"}, { value:\"flex\" ,label:\"弹性格子(Flex)\"}\r\n ]\r\n }, defaultValue:\"\" \r\n });\r\n }\r\n }\r\n\r\n // 布局格子\r\n if($isLayoutGridNode(node)){\r\n options.push(...[\r\n { \r\n name:\"flexDirection\", title:\"flex-direction : \", component:\"el-radio-group\", props:{ \r\n data:[\r\n { value:\"column\" ,label:\"column\"}, { value:\"row\" ,label:\"row\"},\r\n { value:\"row-reverse\" ,label:\"row-reverse\"}, { value:\"column-reverse\" ,label:\"column-reverse\"}\r\n ]\r\n }, defaultValue:\"\" ,condition:(data:any)=>data[\"display\"] == \"flex\"\r\n },\r\n { \r\n name:\"flexWrap\", title:\"是否换行 : \", component:\"el-radio-group\", props:{ \r\n data:[\r\n { value:\"warp\" ,label:\"换行\"}, { value:\"nowrap\" ,label:\"不换行\"}\r\n ]\r\n }, defaultValue:\"\" ,condition:(data:any)=>data[\"display\"] == \"flex\"\r\n },\r\n { \r\n name:\"alignContent\", title:\"align-content : \", component:\"el-radio-group\", props:{ \r\n data:[\r\n { value:\"flex-start\" ,label:\"左\"}, { value:\"center\" ,label:\"居中\"}, { value:\"flex-end\" ,label:\"右\"}, { value:\"space-between\" ,label:\"两边\"},\r\n { value:\"space-around\" ,label:\"space-around\"}, { value:\"stretch\" ,label:\"stretch\"}\r\n ]\r\n }, defaultValue:\"\" ,condition:(data:any)=>data[\"display\"] == \"flex\"\r\n },\r\n { \r\n name:\"justifyContent\", title:\"justify-content : \", component:\"el-radio-group\", props:{ \r\n data:[\r\n { value:\"flex-start\" ,label:\"顶部\"}, { value:\"center\" ,label:\"居中\"}, { value:\"flex-end\" ,label:\"底部\"}, { value:\"space-between\" ,label:\"两边\"},\r\n { value:\"space-around\" ,label:\"space-around\"}, { value:\"space-evenly\" ,label:\"space-evenly\"}\r\n ]\r\n }, defaultValue:\"\" ,condition:(data:any)=>data[\"display\"] == \"flex\"\r\n },\r\n { \r\n name:\"alignItems\", title:\"align-items : \", component:\"el-radio-group\", props:{ \r\n data:[\r\n { value:\"flex-start\" ,label:\"左\"}, { value:\"center\" ,label:\"居中\"}, { value:\"flex-end\" ,label:\"右\"},\r\n { value:\"stretch\" ,label:\"stretch\"}, { value:\"baseline\" ,label:\"baseline\"}\r\n ]\r\n }, defaultValue:\"\" ,condition:(data:any)=>data[\"display\"] == \"flex\"\r\n }\r\n ]);\r\n }\r\n\r\n if($isModuleGridNode(node)){\r\n options.push( { name:\"overflowX\", title:\"横向滚动 : \", component:\"el-switch\", props:{ } as any, defaultValue:false as any });\r\n }\r\n\r\n return await showDynamicFormDialoger(title,options,data)\r\n}\r\n"],"names":["data"],"mappings":"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"}
@@ -1,23 +1,22 @@
1
1
  var __defProp = Object.defineProperty;
2
2
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
3
  var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
- import { TextNode } from "lexical";
4
+ import { DecoratorNode } from "lexical";
5
5
  const ImageDefaultSrc = "";
6
- class ImageNode extends TextNode {
6
+ class ImageNode extends DecoratorNode {
7
7
  constructor(attrs, key) {
8
- super("", key);
8
+ super(key);
9
9
  __publicField(this, "__attrs");
10
10
  this.__attrs = attrs;
11
11
  }
12
12
  static getType() {
13
- return "Image";
13
+ return "image";
14
14
  }
15
15
  static clone(node) {
16
16
  return new ImageNode(node.__attrs, node.__key);
17
17
  }
18
18
  static importJSON(serializedNode) {
19
19
  const node = $createImageNode(serializedNode.attrs);
20
- node.setFormat(serializedNode.format);
21
20
  return node;
22
21
  }
23
22
  static importDOM() {
@@ -47,7 +46,6 @@ class ImageNode extends TextNode {
47
46
  }
48
47
  exportJSON() {
49
48
  return {
50
- ...super.exportJSON(),
51
49
  type: this.getType(),
52
50
  version: 1,
53
51
  attrs: this.__attrs
@@ -77,37 +75,45 @@ class ImageNode extends TextNode {
77
75
  }
78
76
  exportDOM() {
79
77
  const element = document.createElement("img");
78
+ this.updateElementAttr(element);
79
+ return { element };
80
+ }
81
+ /**
82
+ * 更新元素属性
83
+ * @param el
84
+ */
85
+ updateElementAttr(element) {
80
86
  element.setAttribute("src", this.__attrs.src);
81
87
  if (this.__attrs.alt != null) {
82
88
  element.setAttribute("alt", this.__attrs.alt ?? "");
83
89
  }
84
90
  element.setAttribute("style", this.getStyles().join(";"));
85
- return { element };
91
+ }
92
+ /**
93
+ * 更新DOM
94
+ * @param prevNode
95
+ * @param dom
96
+ * @param config
97
+ * @returns
98
+ */
99
+ updateDOM(prevNode, el, config) {
100
+ this.updateElementAttr(el);
101
+ if (!this.__attrs.src) {
102
+ el.setAttribute("src", ImageDefaultSrc);
103
+ }
104
+ return false;
86
105
  }
87
106
  createDOM(config) {
88
107
  const element = document.createElement("img");
89
- element.setAttribute("src", this.__attrs.src || ImageDefaultSrc);
90
- if (this.__attrs.alt != null) {
91
- element.setAttribute("alt", this.__attrs.alt ?? "");
108
+ this.updateElementAttr(element);
109
+ if (!this.__attrs.src) {
110
+ element.setAttribute("src", ImageDefaultSrc);
92
111
  }
93
- element.setAttribute("style", this.getStyles().join(";"));
94
112
  element.setAttribute("node-key", this.__key);
95
- element.setAttribute("class", config.theme.image ?? "");
96
113
  return element;
97
114
  }
98
- updateDOM(prevNode, dom, config) {
99
- const inner = dom.firstChild;
100
- if (inner === null) {
101
- return true;
102
- }
103
- super.updateDOM(prevNode, inner, config);
104
- return false;
105
- }
106
- canHaveFormat() {
107
- return false;
108
- }
109
- isToken() {
110
- return true;
115
+ decorate(editor, config) {
116
+ return null;
111
117
  }
112
118
  /**
113
119
  * 设置属性
@@ -117,12 +123,18 @@ class ImageNode extends TextNode {
117
123
  const writable = this.getWritable();
118
124
  Object.assign(writable.__attrs, data);
119
125
  }
120
- // getTextContent(
121
- // includeInert?: boolean | undefined,
122
- // includeDirectionless?: false | undefined,
123
- // ): string {
124
- // return (this.exportDOM().element as HTMLImageElement).outerHTML;
125
- // }
126
+ isEmpty() {
127
+ return false;
128
+ }
129
+ isIsolated() {
130
+ return false;
131
+ }
132
+ isInline() {
133
+ return true;
134
+ }
135
+ isKeyboardSelectable() {
136
+ return true;
137
+ }
126
138
  }
127
139
  class InlineImageNode extends ImageNode {
128
140
  static getType() {
@@ -133,7 +145,6 @@ class InlineImageNode extends ImageNode {
133
145
  }
134
146
  static importJSON(serializedNode) {
135
147
  const node = $createImageNode(serializedNode.attrs);
136
- node.setFormat(serializedNode.format);
137
148
  return node;
138
149
  }
139
150
  static importDOM() {
@@ -164,12 +175,15 @@ class InlineImageNode extends ImageNode {
164
175
  constructor(attrs, key) {
165
176
  super(attrs, key);
166
177
  }
167
- /**
168
- * 非内联元素
169
- * @returns
170
- */
171
- isInline() {
172
- return false;
178
+ exportJSON() {
179
+ return {
180
+ type: this.getType(),
181
+ version: 1,
182
+ attrs: this.__attrs
183
+ };
184
+ }
185
+ decorate(editor, config) {
186
+ return null;
173
187
  }
174
188
  }
175
189
  function $createImageNode(attrs) {
@@ -1 +1 @@
1
- {"version":3,"file":"ImageNode.js","sources":["../../../../../../../src/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.ts"],"sourcesContent":["\r\nimport type {\r\n DOMConversionMap,\r\n DOMExportOutput,\r\n EditorConfig,\r\n LexicalNode,\r\n NodeKey,\r\n Spread,\r\n SerializedElementNode,\r\n SerializedTextNode\r\n} from 'lexical'\r\nimport { ElementNode,TextNode } from 'lexical'\r\n\r\n\r\n// 默认图片\r\nconst ImageDefaultSrc = \"\";\r\n\r\n\r\n/**\r\n * 图片属性类型\r\n */\r\nexport type ImageAttrType = {\r\n src:string,\r\n alt?:string,\r\n width?:string,\r\n height?:string,\r\n float?:string,\r\n maxWidth?:string,\r\n maxHeight?:string,\r\n margin?:string\r\n};\r\n\r\n/**\r\n * 图片节点序列化\r\n */\r\nexport type SerializedImageNode = Spread<\r\n {\r\n attrs: ImageAttrType\r\n },\r\n SerializedTextNode\r\n>\r\n\r\n/**\r\n * 定义图片节点\r\n */\r\nexport class ImageNode extends TextNode {\r\n __attrs: ImageAttrType\r\n\r\n static getType(): string {\r\n return 'Image'\r\n }\r\n\r\n static clone(node: ImageNode): ImageNode {\r\n return new ImageNode(node.__attrs, node.__key)\r\n }\r\n\r\n static importJSON(serializedNode: SerializedImageNode): ImageNode {\r\n const node = $createImageNode(serializedNode.attrs)\r\n node.setFormat(serializedNode.format)\r\n return node\r\n }\r\n\r\n static importDOM(): DOMConversionMap | null {\r\n return {\r\n img: (el: HTMLElement) => {\r\n\r\n const src = el.getAttribute('src');\r\n const alt = el.getAttribute('alt');\r\n\r\n return el.tagName.toLowerCase() == \"img\" ? {\r\n conversion: (domNode: HTMLElement) => {\r\n\r\n return { \r\n \r\n node:$createImageNode({\r\n src:src,\r\n alt:alt,\r\n width:domNode.style.width,\r\n height:domNode.style.height,\r\n maxWidth:domNode.style.maxWidth || \"100%\",\r\n maxHeight:domNode.style.maxHeight,\r\n margin:domNode.style.margin,\r\n float:\"\"\r\n } as ImageAttrType) \r\n };\r\n },\r\n priority: 0\r\n } : null\r\n },\r\n }\r\n }\r\n\r\n constructor(attrs: ImageAttrType, key?: NodeKey) {\r\n super(\"\",key)\r\n this.__attrs = attrs\r\n }\r\n\r\n exportJSON(): SerializedImageNode {\r\n\r\n return {\r\n ...super.exportJSON(),\r\n type: this.getType(),\r\n version: 1,\r\n attrs: this.__attrs,\r\n }\r\n }\r\n\r\n getStyles():string[]{\r\n\r\n const style : string[] = [];\r\n\r\n if(this.__attrs.width){\r\n style.push(\"width:\"+this.__attrs.width)\r\n }\r\n if(this.__attrs.height){\r\n style.push(\"height:\"+this.__attrs.height)\r\n }\r\n if(this.__attrs.maxWidth){\r\n style.push(\"max-width:\"+this.__attrs.maxWidth)\r\n }\r\n if(this.__attrs.maxHeight){\r\n style.push(\"max-height:\"+this.__attrs.maxHeight)\r\n }\r\n if(this.__attrs.float){\r\n style.push(\"float:\"+this.__attrs.float)\r\n }\r\n if(this.__attrs.margin){\r\n style.push(\"margin:\"+this.__attrs.margin)\r\n }\r\n\r\n return style\r\n }\r\n\r\n exportDOM(): DOMExportOutput {\r\n\r\n \r\n const element = document.createElement('img') \r\n\r\n element.setAttribute('src', this.__attrs.src) \r\n\r\n if(this.__attrs.alt != null){\r\n element.setAttribute('alt', this.__attrs.alt ?? \"\")\r\n }\r\n\r\n element.setAttribute(\"style\",this.getStyles().join(\";\"))\r\n\r\n \r\n return { element }\r\n }\r\n \r\n createDOM(config: EditorConfig): HTMLElement {\r\n\r\n const element = document.createElement('img') \r\n\r\n element.setAttribute('src', this.__attrs.src || ImageDefaultSrc) \r\n\r\n if(this.__attrs.alt != null){\r\n element.setAttribute('alt', this.__attrs.alt ?? \"\")\r\n }\r\n\r\n element.setAttribute(\"style\",this.getStyles().join(\";\"))\r\n element.setAttribute(\"node-key\",this.__key)\r\n element.setAttribute(\"class\",config.theme.image ?? \"\")\r\n\r\n\r\n return element\r\n }\r\n\r\n updateDOM(\r\n prevNode: ImageNode,\r\n dom: HTMLElement,\r\n config: EditorConfig,\r\n ): boolean {\r\n // console.log(prevNode,dom,dom.firstChild,config);\r\n const inner = dom.firstChild\r\n if (inner === null){ return true }\r\n super.updateDOM(prevNode, inner as HTMLElement, config)\r\n return false\r\n }\r\n\r\n canHaveFormat() {\r\n return false;\r\n }\r\n isToken() {\r\n return true;\r\n }\r\n /**\r\n * 设置属性\r\n * @param pos \r\n */\r\n setAttrs(data?:any){\r\n const writable = this.getWritable();\r\n Object.assign(writable.__attrs,data)\r\n }\r\n\r\n // getTextContent(\r\n // includeInert?: boolean | undefined,\r\n // includeDirectionless?: false | undefined,\r\n // ): string { \r\n // return (this.exportDOM().element as HTMLImageElement).outerHTML;\r\n // }\r\n\r\n\r\n}\r\n/**\r\n * 定义内联图片节点\r\n */\r\nexport class InlineImageNode extends ImageNode{\r\n \r\n static getType(): string {\r\n return 'InlineImage'\r\n }\r\n\r\n static clone(node: ImageNode): ImageNode {\r\n return new InlineImageNode(node.__attrs, node.__key)\r\n }\r\n\r\n static importJSON(serializedNode: SerializedImageNode): ImageNode {\r\n const node = $createImageNode(serializedNode.attrs)\r\n node.setFormat(serializedNode.format)\r\n return node\r\n }\r\n\r\n static importDOM(): DOMConversionMap | null {\r\n return {\r\n img: (el: HTMLElement) => {\r\n\r\n const src = el.getAttribute('src');\r\n const alt = el.getAttribute('alt');\r\n\r\n return el.tagName.toLowerCase() == \"img\" && el.style.float ? {\r\n conversion: (domNode: HTMLElement) => {\r\n \r\n // 内联图\r\n return { \r\n node:new InlineImageNode({\r\n src:src,\r\n alt:alt,\r\n width:domNode.style.width,\r\n height:domNode.style.height,\r\n maxWidth:domNode.style.maxWidth || \"100%\",\r\n maxHeight:domNode.style.maxHeight,\r\n margin:domNode.style.margin,\r\n float:domNode.style.float\r\n } as ImageAttrType) \r\n };\r\n },\r\n priority: 1\r\n } : null\r\n },\r\n }\r\n }\r\n\r\n constructor(attrs: ImageAttrType, key?: NodeKey) {\r\n super(attrs,key)\r\n }\r\n\r\n /**\r\n * 非内联元素\r\n * @returns \r\n */\r\n isInline(): boolean {\r\n return false;\r\n }\r\n\r\n\r\n}\r\n\r\n/**\r\n * 创建图片节点\r\n * @param src \r\n * @returns \r\n */\r\nexport function $createImageNode(attrs: ImageAttrType): ImageNode {\r\n return new ImageNode(attrs)\r\n}\r\n\r\n/**\r\n * 判断是否是图片节点\r\n * @param node \r\n * @returns \r\n */\r\nexport function $isImageNode(\r\n node: ImageNode | LexicalNode | null | undefined,\r\n): node is ImageNode {\r\n return node instanceof ImageNode\r\n}\r\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ImageNode.js","sources":["../../../../../../../src/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.ts"],"sourcesContent":["\r\nimport type {\r\n DOMConversionMap,\r\n DOMExportOutput,\r\n EditorConfig,\r\n LexicalNode,\r\n NodeKey,\r\n Spread,\r\n SerializedLexicalNode,\r\n LexicalEditor\r\n} from 'lexical'\r\nimport { DecoratorNode } from 'lexical'\r\nimport { Component } from 'vue';\r\n\r\n\r\n// 默认图片\r\nconst ImageDefaultSrc = \"\";\r\n\r\n/**\r\n * 图片属性类型\r\n */\r\nexport type ImageAttrType = {\r\n src:string,\r\n alt?:string,\r\n width?:string,\r\n height?:string,\r\n float?:string,\r\n maxWidth?:string,\r\n maxHeight?:string,\r\n margin?:string\r\n};\r\n\r\n/**\r\n * 图片节点序列化\r\n */\r\nexport type SerializedImageNode = Spread<{ attrs: ImageAttrType }, SerializedLexicalNode>\r\n\r\n/** \r\n * 定义图片节点\r\n */\r\nexport class ImageNode extends DecoratorNode<Component|null> {\r\n __attrs: ImageAttrType\r\n\r\n static getType(): string {\r\n return 'image'\r\n }\r\n\r\n static clone(node: ImageNode): ImageNode {\r\n return new ImageNode(node.__attrs, node.__key)\r\n }\r\n\r\n static importJSON(serializedNode: SerializedImageNode): ImageNode {\r\n const node = $createImageNode(serializedNode.attrs)\r\n return node\r\n }\r\n\r\n static importDOM(): DOMConversionMap | null {\r\n return {\r\n img: (el: HTMLElement) => {\r\n\r\n const src = el.getAttribute('src');\r\n const alt = el.getAttribute('alt');\r\n\r\n return el.tagName.toLowerCase() == \"img\" ? {\r\n conversion: (domNode: HTMLElement) => {\r\n \r\n return { \r\n \r\n node:$createImageNode({\r\n src:src,\r\n alt:alt,\r\n width:domNode.style.width,\r\n height:domNode.style.height,\r\n maxWidth:domNode.style.maxWidth || \"100%\",\r\n maxHeight:domNode.style.maxHeight,\r\n margin:domNode.style.margin,\r\n float:\"\"\r\n } as ImageAttrType) \r\n };\r\n },\r\n priority: 0\r\n } : null\r\n },\r\n }\r\n }\r\n\r\n constructor(attrs: ImageAttrType, key?: NodeKey) {\r\n super(key)\r\n this.__attrs = attrs\r\n }\r\n\r\n exportJSON(): SerializedImageNode {\r\n\r\n return {\r\n type: this.getType(),\r\n version: 1,\r\n attrs: this.__attrs,\r\n }\r\n }\r\n\r\n getStyles():string[]{\r\n\r\n const style : string[] = [];\r\n\r\n if(this.__attrs.width){\r\n style.push(\"width:\"+this.__attrs.width)\r\n }\r\n if(this.__attrs.height){\r\n style.push(\"height:\"+this.__attrs.height)\r\n }\r\n if(this.__attrs.maxWidth){\r\n style.push(\"max-width:\"+this.__attrs.maxWidth)\r\n }\r\n if(this.__attrs.maxHeight){\r\n style.push(\"max-height:\"+this.__attrs.maxHeight)\r\n }\r\n if(this.__attrs.float){\r\n style.push(\"float:\"+this.__attrs.float)\r\n }\r\n if(this.__attrs.margin){\r\n style.push(\"margin:\"+this.__attrs.margin)\r\n }\r\n\r\n return style\r\n }\r\n\r\n exportDOM(): DOMExportOutput {\r\n\r\n \r\n const element = document.createElement('img') \r\n\r\n this.updateElementAttr(element);\r\n\r\n \r\n return { element }\r\n }\r\n\r\n /**\r\n * 更新元素属性\r\n * @param el \r\n */\r\n updateElementAttr(element:HTMLElement){\r\n // 更新属性\r\n element.setAttribute('src', this.__attrs.src) \r\n\r\n if(this.__attrs.alt != null){\r\n element.setAttribute('alt', this.__attrs.alt ?? \"\")\r\n }\r\n\r\n element.setAttribute(\"style\",this.getStyles().join(\";\"))\r\n }\r\n\r\n /**\r\n * 更新DOM\r\n * @param prevNode \r\n * @param dom \r\n * @param config \r\n * @returns \r\n */\r\n updateDOM(prevNode: ImageNode, el: HTMLElement, config: EditorConfig): boolean {\r\n // 更新属性\r\n this.updateElementAttr(el);\r\n\r\n if(!this.__attrs.src){\r\n el.setAttribute('src', ImageDefaultSrc) \r\n }\r\n return false\r\n }\r\n \r\n createDOM(config: EditorConfig): HTMLElement {\r\n\r\n const element = document.createElement('img') \r\n // 更新属性\r\n this.updateElementAttr(element);\r\n\r\n if(!this.__attrs.src){\r\n element.setAttribute('src', ImageDefaultSrc) \r\n }\r\n\r\n element.setAttribute(\"node-key\",this.__key)\r\n\r\n return element\r\n }\r\n \r\n decorate(editor: LexicalEditor, config: EditorConfig): Component | null {\r\n return null;\r\n }\r\n\r\n /**\r\n * 设置属性\r\n * @param pos \r\n */\r\n setAttrs(data?:any){\r\n const writable = this.getWritable();\r\n Object.assign(writable.__attrs,data)\r\n }\r\n\r\n isEmpty(){\r\n return false;\r\n }\r\n\r\n isIsolated() {\r\n return false;\r\n }\r\n isInline() {\r\n return true;\r\n }\r\n isKeyboardSelectable() {\r\n return true;\r\n }\r\n}\r\n/**\r\n * 定义内联图片节点\r\n */\r\nexport class InlineImageNode extends ImageNode{\r\n \r\n static getType(): string {\r\n return 'InlineImage'\r\n }\r\n\r\n static clone(node: ImageNode): ImageNode {\r\n return new InlineImageNode(node.__attrs, node.__key)\r\n }\r\n\r\n static importJSON(serializedNode: SerializedImageNode): ImageNode {\r\n const node = $createImageNode(serializedNode.attrs)\r\n return node\r\n }\r\n \r\n\r\n static importDOM(): DOMConversionMap | null {\r\n return {\r\n img: (el: HTMLElement) => {\r\n\r\n const src = el.getAttribute('src');\r\n const alt = el.getAttribute('alt');\r\n\r\n return el.tagName.toLowerCase() == \"img\" && el.style.float ? {\r\n conversion: (domNode: HTMLElement) => {\r\n \r\n // 内联图\r\n return { \r\n node:new InlineImageNode({\r\n src:src,\r\n alt:alt,\r\n width:domNode.style.width,\r\n height:domNode.style.height,\r\n maxWidth:domNode.style.maxWidth || \"100%\",\r\n maxHeight:domNode.style.maxHeight,\r\n margin:domNode.style.margin,\r\n float:domNode.style.float\r\n } as ImageAttrType) \r\n };\r\n },\r\n priority: 1\r\n } : null\r\n },\r\n }\r\n }\r\n\r\n constructor(attrs: ImageAttrType, key?: NodeKey) {\r\n super(attrs,key)\r\n }\r\n\r\n exportJSON(): SerializedImageNode {\r\n\r\n return {\r\n type: this.getType(),\r\n version: 1,\r\n attrs: this.__attrs,\r\n }\r\n }\r\n decorate(editor: LexicalEditor, config: EditorConfig): Component | null {\r\n return null;\r\n }\r\n}\r\n\r\n/**\r\n * 创建图片节点\r\n * @param src \r\n * @returns \r\n */\r\nexport function $createImageNode(attrs: ImageAttrType): ImageNode {\r\n return new ImageNode(attrs)\r\n}\r\n\r\n/**\r\n * 判断是否是图片节点\r\n * @param node \r\n * @returns \r\n */\r\nexport function $isImageNode(\r\n node: ImageNode | LexicalNode | null | undefined,\r\n): node is ImageNode {\r\n return node instanceof ImageNode\r\n}\r\n"],"names":[],"mappings":"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"}
@@ -41,7 +41,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
41
41
  editor.dispatchCommand(INSERT_IMAGE_COMMAND, data);
42
42
  });
43
43
  },
44
- sort: 11
44
+ sort: 90
45
45
  });
46
46
  const editor = useLexicalComposer();
47
47
  const uploadhandle = async (pathList) => {
@@ -111,9 +111,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
111
111
  const data = await showImageEditDialog(node.__attrs);
112
112
  const result = await uploadhandle([data.src]);
113
113
  data.src = result[0];
114
- editor.update(() => {
115
- node.setAttrs(data);
116
- });
114
+ editor.update(() => node.setAttrs(data));
117
115
  }
118
116
  });
119
117
  return toolbarList;
@@ -160,7 +158,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
160
158
  return (_ctx, _cache) => {
161
159
  return unref(isSelected) ? (openBlock(), createElementBlock("div", {
162
160
  key: 0,
163
- class: "mk-doc-active-mark",
161
+ class: "mk-doc-active-element-block-mark",
164
162
  style: normalizeStyle(unref(curSelectPos))
165
163
  }, null, 4)) : createCommentVNode("", true);
166
164
  };
@@ -1 +1 @@
1
- {"version":3,"file":"index.vue.js","sources":["../../../../../../../src/components/basic/doc-editor/plugins/ImagePlugin/index.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { $insertNodeToNearestRoot,mergeRegister,mediaFileReader,isMimeType } from '@lexical/utils'\r\nimport { \r\n COMMAND_PRIORITY_EDITOR,COMMAND_PRIORITY_LOW,$isParagraphNode,\r\n $getSelection,$createParagraphNode,$isNodeSelection, $getNodeByKey,\r\nElementNode\r\n} from 'lexical'\r\nimport { DRAG_DROP_PASTE } from '@lexical/rich-text'\r\nimport { useLexicalComposer,useMounted } from 'lexical-vue'\r\nimport { onMounted, } from 'vue'\r\nimport { INSERT_IMAGE_COMMAND,$createImageNode,ImageNode,type ImageAttrType } from './index'\r\nimport { $isImageTextGridNode } from '../GridPlugin'\r\nimport { registerDocEditorToolbarExtend,type ToolbarExtendPlugin } from \"../../core\"\r\nimport { showImageEditDialog,imageUpload } from \"./utils\"\r\nimport { useElementBlockSelection } from '../../core'\r\nimport { ElLoading } from 'element-plus'\r\n\r\n// 图片类型\r\nconst ACCEPTABLE_IMAGE_TYPES = [\r\n 'image/',\r\n 'image/heic',\r\n 'image/heif',\r\n 'image/gif',\r\n 'image/webp',\r\n]\r\n \r\n// 注册到工具条\r\nregisterDocEditorToolbarExtend({\r\n icon:\"Picture\",\r\n text:\"图片\",\r\n action:async ()=>{\r\n // 显示图片编辑面板\r\n showImageEditDialog({\r\n src:\"\", alt:\"\", width:\"\", height:\"\", maxWidth:\"100%\", maxHeight:\"\", margin:\"\"\r\n }).then(async (data:any)=>{\r\n const result = await uploadhandle([data.src])\r\n data.src = result[0];\r\n editor.dispatchCommand(INSERT_IMAGE_COMMAND,data)\r\n });\r\n },\r\n sort:11\r\n} as ToolbarExtendPlugin)\r\n\r\nconst editor = useLexicalComposer()\r\n\r\n// 上传处理函数\r\nconst uploadhandle = async (pathList:Array<string>)=>{\r\n\r\n if(pathList.length){\r\n\r\n const loadingInstance = ElLoading.service({ fullscreen: true,text:\"图片上传中...\" })\r\n\r\n const reesult = await Promise.all(pathList.map(path=>{\r\n return imageUpload(path)\r\n }))\r\n\r\n loadingInstance.close();\r\n\r\n return reesult;\r\n }\r\n\r\n return [];\r\n}\r\n\r\n// 使用元素模块 集成了模块选中删除以及工具条\r\nconst { isSelected, curSelectKey, curSelectPos } = useElementBlockSelection(el=>{\r\n return el.tagName.toLowerCase() == \"img\" ? el : null\r\n},(selection)=>{\r\n \r\n const node = $getNodeByKey(curSelectKey.value) as ImageNode;\r\n\r\n if(node != null){\r\n \r\n const parent = node.getParent();\r\n const isImageText = $isImageTextGridNode(parent)\r\n\r\n // 工具条\r\n const toolbarList = [];\r\n\r\n if($isParagraphNode(parent) || isImageText){\r\n toolbarList.push({ title: isImageText ? \"居左\" : \"左对齐\",icon:`doc-align-left`,action(){\r\n editor.update(()=>{\r\n if(isImageText){\r\n node.setAttrs({float:\"left\"})\r\n }\r\n else{\r\n parent.setFormat(\"left\")\r\n }\r\n })\r\n } \r\n });\r\n }\r\n\r\n if($isParagraphNode(parent)){\r\n toolbarList.push({ title: \"居中对齐\",icon:`doc-align-center`,action(){\r\n editor.update(()=>{ \r\n parent.setFormat(\"center\") \r\n })\r\n } \r\n });\r\n }\r\n\r\n if($isParagraphNode(parent) || isImageText){\r\n toolbarList.push({ title: isImageText ? \"居右\" : \"右对齐\",icon:`doc-align-right`,action(){\r\n editor.update(()=>{\r\n\r\n if(isImageText){\r\n node.setAttrs({float:\"right\"})\r\n }\r\n else{\r\n parent.setFormat(\"right\")\r\n }\r\n })\r\n } \r\n });\r\n }\r\n\r\n // 编辑\r\n toolbarList.push({ \r\n title:\"编辑\",icon:\"Edit\",action:async ()=>{\r\n\r\n // 显示图片编辑面板\r\n const data:any = await showImageEditDialog(node.__attrs);\r\n const result = await uploadhandle([data.src])\r\n data.src = result[0];\r\n editor.update(()=>{\r\n node.setAttrs(data)\r\n })\r\n }\r\n });\r\n\r\n return toolbarList;\r\n }\r\n\r\n return null;\r\n})\r\n\r\n\r\n// 编辑器挂载\r\nuseMounted(()=>{\r\n // 注册事件\r\n return mergeRegister(\r\n // 插入图片\r\n editor.registerCommand<ImageAttrType>(INSERT_IMAGE_COMMAND,(payload) => {\r\n\r\n const selection = $getSelection()\r\n const elementNode = $isNodeSelection(selection) ? selection?.getNodes()[0] as ElementNode : null;\r\n\r\n if (elementNode) {\r\n elementNode.append($createImageNode(payload));\r\n }\r\n else{\r\n const p = $createParagraphNode()\r\n p.append($createImageNode(payload))\r\n $insertNodeToNearestRoot(p)\r\n }\r\n return true\r\n },COMMAND_PRIORITY_EDITOR),\r\n\r\n // 剪切板图片\r\n editor.registerCommand(DRAG_DROP_PASTE,(files) => {\r\n\r\n (async () => {\r\n\r\n const filesResult = await mediaFileReader(files, [ACCEPTABLE_IMAGE_TYPES].flatMap((x) => x))\r\n \r\n const result = await uploadhandle(filesResult.filter(f=>isMimeType(f.file, ACCEPTABLE_IMAGE_TYPES)).map(f=>f.result))\r\n\r\n result.forEach(path=>{\r\n editor.dispatchCommand(INSERT_IMAGE_COMMAND, {\r\n src:path, alt:\"\", maxWidth:\":100%\"\r\n } as ImageAttrType)\r\n })\r\n\r\n })()\r\n\r\n return true\r\n },COMMAND_PRIORITY_LOW)\r\n )\r\n})\r\n\r\n// 当前插件挂载\r\nonMounted(() => {\r\n\r\n if (!editor.hasNodes([ImageNode])){\r\n throw new Error('ImagePlugin: 图片节点未注册!')\r\n }\r\n\r\n})\r\n\r\n</script>\r\n\r\n<template>\r\n <div class=\"mk-doc-active-mark\" v-if=\"isSelected\" :style=\"curSelectPos\">\r\n </div>\r\n</template>\r\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.vue.js","sources":["../../../../../../../src/components/basic/doc-editor/plugins/ImagePlugin/index.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { $insertNodeToNearestRoot,mergeRegister,mediaFileReader,isMimeType } from '@lexical/utils'\r\nimport { \r\n COMMAND_PRIORITY_EDITOR,COMMAND_PRIORITY_LOW,$isParagraphNode,\r\n $getSelection,$createParagraphNode,$isNodeSelection, $getNodeByKey,\r\nElementNode\r\n} from 'lexical'\r\nimport { DRAG_DROP_PASTE } from '@lexical/rich-text'\r\nimport { useLexicalComposer,useMounted } from 'lexical-vue'\r\nimport { onMounted, } from 'vue'\r\nimport { INSERT_IMAGE_COMMAND,$createImageNode,ImageNode,type ImageAttrType } from './index'\r\nimport { $isImageTextGridNode } from '../GridPlugin'\r\nimport { registerDocEditorToolbarExtend,type ToolbarExtendPlugin } from \"../../core\"\r\nimport { showImageEditDialog,imageUpload } from \"./utils\"\r\nimport { useElementBlockSelection } from '../../core'\r\nimport { ElLoading } from 'element-plus'\r\n\r\n// 图片类型\r\nconst ACCEPTABLE_IMAGE_TYPES = [\r\n 'image/',\r\n 'image/heic',\r\n 'image/heif',\r\n 'image/gif',\r\n 'image/webp',\r\n]\r\n \r\n// 注册到工具条\r\nregisterDocEditorToolbarExtend({\r\n icon:\"Picture\",\r\n text:\"图片\",\r\n action:async ()=>{\r\n // 显示图片编辑面板\r\n showImageEditDialog({\r\n src:\"\", alt:\"\", width:\"\", height:\"\", maxWidth:\"100%\", maxHeight:\"\", margin:\"\"\r\n }).then(async (data:any)=>{\r\n const result = await uploadhandle([data.src])\r\n data.src = result[0];\r\n editor.dispatchCommand(INSERT_IMAGE_COMMAND,data)\r\n });\r\n },\r\n sort:90\r\n} as ToolbarExtendPlugin)\r\n\r\nconst editor = useLexicalComposer()\r\n\r\n// 上传处理函数\r\nconst uploadhandle = async (pathList:Array<string>)=>{\r\n\r\n if(pathList.length){\r\n\r\n const loadingInstance = ElLoading.service({ fullscreen: true,text:\"图片上传中...\" })\r\n\r\n const reesult = await Promise.all(pathList.map(path=>{\r\n return imageUpload(path)\r\n }))\r\n\r\n loadingInstance.close();\r\n\r\n return reesult;\r\n }\r\n\r\n return [];\r\n}\r\n\r\n// 使用元素模块 集成了模块选中删除以及工具条\r\nconst { isSelected, curSelectKey, curSelectPos } = useElementBlockSelection(el=>{\r\n return el.tagName.toLowerCase() == \"img\" ? el : null\r\n},(selection)=>{\r\n \r\n const node = $getNodeByKey(curSelectKey.value) as ImageNode;\r\n\r\n if(node != null){\r\n \r\n const parent = node.getParent();\r\n const isImageText = $isImageTextGridNode(parent)\r\n\r\n // 工具条\r\n const toolbarList = [];\r\n\r\n if($isParagraphNode(parent) || isImageText){\r\n toolbarList.push({ title: isImageText ? \"居左\" : \"左对齐\",icon:`doc-align-left`,action(){\r\n editor.update(()=>{\r\n if(isImageText){\r\n node.setAttrs({float:\"left\"})\r\n }\r\n else{\r\n parent.setFormat(\"left\")\r\n }\r\n })\r\n } \r\n });\r\n }\r\n\r\n if($isParagraphNode(parent)){\r\n toolbarList.push({ title: \"居中对齐\",icon:`doc-align-center`,action(){\r\n editor.update(()=>{ \r\n parent.setFormat(\"center\") \r\n })\r\n } \r\n });\r\n }\r\n\r\n if($isParagraphNode(parent) || isImageText){\r\n toolbarList.push({ title: isImageText ? \"居右\" : \"右对齐\",icon:`doc-align-right`,action(){\r\n editor.update(()=>{\r\n\r\n if(isImageText){\r\n node.setAttrs({float:\"right\"})\r\n }\r\n else{\r\n parent.setFormat(\"right\")\r\n }\r\n })\r\n } \r\n });\r\n }\r\n\r\n // 编辑\r\n toolbarList.push({ \r\n title:\"编辑\",icon:\"Edit\",action:async ()=>{\r\n // 显示图片编辑面板\r\n const data:any = await showImageEditDialog(node.__attrs);\r\n const result = await uploadhandle([data.src])\r\n data.src = result[0];\r\n editor.update(()=>node.setAttrs(data))\r\n }\r\n });\r\n\r\n return toolbarList;\r\n }\r\n\r\n return null;\r\n})\r\n\r\n// 编辑器挂载\r\nuseMounted(()=>{\r\n // 注册事件\r\n return mergeRegister(\r\n // 插入图片\r\n editor.registerCommand<ImageAttrType>(INSERT_IMAGE_COMMAND,(payload) => {\r\n\r\n const selection = $getSelection()\r\n const elementNode = $isNodeSelection(selection) ? selection?.getNodes()[0] as ElementNode : null;\r\n\r\n if (elementNode) {\r\n elementNode.append($createImageNode(payload));\r\n }\r\n else{\r\n const p = $createParagraphNode()\r\n p.append($createImageNode(payload))\r\n $insertNodeToNearestRoot(p)\r\n }\r\n return true\r\n },COMMAND_PRIORITY_EDITOR),\r\n\r\n // 剪切板图片\r\n editor.registerCommand(DRAG_DROP_PASTE,(files) => {\r\n\r\n (async () => {\r\n\r\n const filesResult = await mediaFileReader(files, [ACCEPTABLE_IMAGE_TYPES].flatMap((x) => x))\r\n \r\n const result = await uploadhandle(filesResult.filter(f=>isMimeType(f.file, ACCEPTABLE_IMAGE_TYPES)).map(f=>f.result))\r\n\r\n result.forEach(path=>{\r\n editor.dispatchCommand(INSERT_IMAGE_COMMAND, {\r\n src:path, alt:\"\", maxWidth:\":100%\"\r\n } as ImageAttrType)\r\n })\r\n\r\n })()\r\n\r\n return true\r\n },COMMAND_PRIORITY_LOW)\r\n )\r\n})\r\n\r\n// 当前插件挂载\r\nonMounted(() => {\r\n\r\n if (!editor.hasNodes([ImageNode])){\r\n throw new Error('ImagePlugin: 图片节点未注册!')\r\n }\r\n\r\n})\r\n\r\n</script>\r\n\r\n<template>\r\n <div class=\"mk-doc-active-element-block-mark\" v-if=\"isSelected\" :style=\"curSelectPos\">\r\n </div>\r\n</template>\r\n"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { ref, computed, h, createVNode, createTextVNode, Fragment, defineComponent, reactive, mergeProps, isVNode } from "vue";
1
+ import { ref, computed, h, createVNode, createTextVNode, Fragment, defineComponent, reactive, watch, mergeProps, isVNode } from "vue";
2
2
  import { Messager, Dialoger } from "@maketribe/dm";
3
3
  import { ElButton, ElImage, ElIcon, ElTabs, ElTabPane, ElInput, ElRow, ElCol, ElForm, ElFormItem } from "element-plus";
4
4
  import { Picture, UploadFilled, Share } from "@element-plus/icons-vue";
@@ -42,70 +42,48 @@ const ImageEditPanelComponent = /* @__PURE__ */ defineComponent({
42
42
  }) {
43
43
  const attrs = reactive(props.attrs);
44
44
  const materialTable = reactive(new MsMaterialTable());
45
- const margin = computed(() => {
46
- var vals = attrs.margin.split(/[\s]+/g);
47
- if (vals.length == 1) {
48
- return {
45
+ const margin = ref({
46
+ t: 0,
47
+ r: 0,
48
+ b: 0,
49
+ l: 0
50
+ });
51
+ watch(() => `${margin.value.t} ${margin.value.r} ${margin.value.b} ${margin.value.l}`, (v) => {
52
+ attrs.margin = v;
53
+ });
54
+ watch(() => props.attrs, () => {
55
+ var vals = props.attrs.margin.split(/[\s]+/g);
56
+ if (vals.length == 1 && vals[0]) {
57
+ margin.value = {
49
58
  t: vals[0],
50
59
  r: vals[0],
51
60
  b: vals[0],
52
61
  l: vals[0]
53
62
  };
54
63
  } else if (vals.length == 2) {
55
- return {
64
+ margin.value = {
56
65
  t: vals[0],
57
66
  r: vals[1],
58
67
  b: vals[0],
59
68
  l: vals[1]
60
69
  };
61
70
  } else if (vals.length == 3) {
62
- return {
71
+ margin.value = {
63
72
  t: vals[0],
64
73
  r: vals[1],
65
74
  b: vals[2],
66
75
  l: vals[1]
67
76
  };
68
- } else if (vals.length <= 0) {
69
- vals = ["0", "0", "0", "0"];
70
- }
71
- return {
72
- t: vals[0],
73
- r: vals[1],
74
- b: vals[2],
75
- l: vals[3]
76
- };
77
- });
78
- const marginT = computed({
79
- set(v) {
80
- attrs.margin = `${v} ${margin.value.r} ${margin.value.b} ${margin.value.l}`;
81
- },
82
- get() {
83
- return margin.value.t || 0;
84
- }
85
- });
86
- const marginR = computed({
87
- set(v) {
88
- attrs.margin = `${margin.value.t} ${v} ${margin.value.b} ${margin.value.l}`;
89
- },
90
- get() {
91
- return margin.value.r || 0;
92
- }
93
- });
94
- const marginB = computed({
95
- set(v) {
96
- attrs.margin = `${margin.value.t} ${margin.value.r} ${v} ${margin.value.l}`;
97
- },
98
- get() {
99
- return margin.value.b || 0;
100
- }
101
- });
102
- const marginL = computed({
103
- set(v) {
104
- attrs.margin = `${margin.value.t} ${margin.value.r} ${margin.value.b} ${v}`;
105
- },
106
- get() {
107
- return margin.value.l || 0;
77
+ } else if (vals.length == 4) {
78
+ margin.value = {
79
+ t: vals[0],
80
+ r: vals[1],
81
+ b: vals[2],
82
+ l: vals[3]
83
+ };
108
84
  }
85
+ }, {
86
+ immediate: true
109
87
  });
110
88
  materialTable.selectionChangeEvent.on(() => {
111
89
  var _a;
@@ -257,20 +235,20 @@ const ImageEditPanelComponent = /* @__PURE__ */ defineComponent({
257
235
  default: () => [createVNode("div", {
258
236
  "style": "display: flex;flex-wrap: nowrap;gap: 10px;justify-content: space-around;"
259
237
  }, [createVNode("div", null, [createTextVNode("上:"), createVNode(ElInput, {
260
- "modelValue": marginT.value,
261
- "onUpdate:modelValue": ($event) => marginT.value = $event,
238
+ "modelValue": margin.value.t,
239
+ "onUpdate:modelValue": ($event) => margin.value.t = $event,
262
240
  "placeholder": ""
263
241
  }, null)]), createVNode("div", null, [createTextVNode("右:"), createVNode(ElInput, {
264
- "modelValue": marginR.value,
265
- "onUpdate:modelValue": ($event) => marginR.value = $event,
242
+ "modelValue": margin.value.r,
243
+ "onUpdate:modelValue": ($event) => margin.value.r = $event,
266
244
  "placeholder": ""
267
245
  }, null)]), createVNode("div", null, [createTextVNode("下:"), createVNode(ElInput, {
268
- "modelValue": marginB.value,
269
- "onUpdate:modelValue": ($event) => marginB.value = $event,
246
+ "modelValue": margin.value.b,
247
+ "onUpdate:modelValue": ($event) => margin.value.b = $event,
270
248
  "placeholder": ""
271
249
  }, null)]), createVNode("div", null, [createTextVNode("左:"), createVNode(ElInput, {
272
- "modelValue": marginL.value,
273
- "onUpdate:modelValue": ($event) => marginL.value = $event,
250
+ "modelValue": margin.value.l,
251
+ "onUpdate:modelValue": ($event) => margin.value.l = $event,
274
252
  "placeholder": ""
275
253
  }, null)])])]
276
254
  })]