@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.
- package/dist/cjs/components/basic/doc-editor/core/element-block.js +18 -13
- package/dist/cjs/components/basic/doc-editor/core/element-block.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/core/utils.js +20 -13
- package/dist/cjs/components/basic/doc-editor/core/utils.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/editor.vue.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/GridNode.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/ImageTextGridNode.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.js +32 -1
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.js +13 -0
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/TextGridNode.js +11 -0
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/TextGridNode.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/index.vue.js +87 -13
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/index.vue.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/utils.js +114 -7
- package/dist/cjs/components/basic/doc-editor/plugins/GridPlugin/utils.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.js +51 -37
- package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/index.vue.js +3 -5
- package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/index.vue.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/utils.js +32 -54
- package/dist/cjs/components/basic/doc-editor/plugins/ImagePlugin/utils.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/ModulePlugin/composables.js +14 -1
- package/dist/cjs/components/basic/doc-editor/plugins/ModulePlugin/composables.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/ModulePlugin/index.vue.js +40 -3
- package/dist/cjs/components/basic/doc-editor/plugins/ModulePlugin/index.vue.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/RichTextPlugin/index.vue.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/RichTextPlugin/nodes/RichTextNode.js +16 -16
- package/dist/cjs/components/basic/doc-editor/plugins/RichTextPlugin/nodes/RichTextNode.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/ToolbarPlugin/FontStyleTool.vue.js +8 -7
- package/dist/cjs/components/basic/doc-editor/plugins/ToolbarPlugin/FontStyleTool.vue.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/plugins/nodes.js.map +1 -1
- package/dist/cjs/components/basic/doc-editor/themes/doc-editor-edit.css.js +1 -1
- package/dist/cjs/components/basic/doc-editor/themes/doc-editor-edit.css.js.map +1 -1
- package/dist/cjs/components/basic/dynamic-form-panel/DynamicFormPanel.js +40 -18
- package/dist/cjs/components/basic/dynamic-form-panel/DynamicFormPanel.js.map +1 -1
- package/dist/cjs/components/basic/dynamic-form-panel/dialog.js +2 -2
- package/dist/cjs/components/basic/dynamic-form-panel/dialog.js.map +1 -1
- package/dist/cjs/components/basic/image-cropper/image-cropper-api.js.map +1 -1
- package/dist/cjs/components/basic/visual-page-editor/content-editable.vue.js +13 -9
- package/dist/cjs/components/basic/visual-page-editor/content-editable.vue.js.map +1 -1
- package/dist/cjs/components/basic/visual-page-editor/core/BlockRender.js +38 -0
- package/dist/cjs/components/basic/visual-page-editor/core/BlockRender.js.map +1 -0
- package/dist/cjs/components/basic/visual-page-editor/core/Dialog.js +76 -0
- package/dist/cjs/components/basic/visual-page-editor/core/Dialog.js.map +1 -0
- package/dist/cjs/components/basic/visual-page-editor/core/VisvalPageEditor.js +72 -1
- package/dist/cjs/components/basic/visual-page-editor/core/VisvalPageEditor.js.map +1 -1
- package/dist/cjs/components/basic/visual-page-editor/core/index.js +21 -13
- package/dist/cjs/components/basic/visual-page-editor/core/index.js.map +1 -1
- package/dist/cjs/components/basic/visual-page-editor/editor.vue.js +2 -29
- package/dist/cjs/components/basic/visual-page-editor/editor.vue.js.map +1 -1
- package/dist/cjs/components/basic/visual-page-editor/index.js +1 -1
- package/dist/cjs/components/basic/visual-page-editor/index.js.map +1 -1
- package/dist/cjs/components/basic/visual-page-editor/modules/BaseImageModule.js +10 -0
- package/dist/cjs/components/basic/visual-page-editor/modules/BaseImageModule.js.map +1 -0
- package/dist/cjs/components/basic/visual-page-editor/toolbar.vue.js +1 -1
- package/dist/cjs/components/basic/visual-page-editor/toolbar.vue.js.map +1 -1
- package/dist/cjs/modules/cms/cms-settings.js +4 -0
- package/dist/cjs/modules/cms/cms-settings.js.map +1 -1
- package/dist/cjs/modules/cms/composables/part-extensions.js +6 -6
- package/dist/cjs/modules/cms/composables/part-extensions.js.map +1 -1
- package/dist/cjs/modules/cms/dataviews/cms-ad-contents/CmsAdContentsForm.js +20 -2
- package/dist/cjs/modules/cms/dataviews/cms-ad-contents/CmsAdContentsForm.js.map +1 -1
- package/dist/cjs/modules/cms/pages/cms-ad/index.vue2.js +0 -1
- package/dist/cjs/modules/cms/pages/cms-ad/index.vue2.js.map +1 -1
- package/dist/cjs/modules/cms/pages/cms-contents/article-edit-add-page.vue2.js +3 -1
- package/dist/cjs/modules/cms/pages/cms-contents/article-edit-add-page.vue2.js.map +1 -1
- package/dist/cjs/modules/cms/pages/cms-contents/components/part-banner-edit.vue.js +32 -9
- package/dist/cjs/modules/cms/pages/cms-contents/components/part-banner-edit.vue.js.map +1 -1
- package/dist/cjs/modules/cms/pages/cms-contents/index.vue2.js +47 -43
- package/dist/cjs/modules/cms/pages/cms-contents/index.vue2.js.map +1 -1
- package/dist/cjs/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.js +312 -0
- package/dist/cjs/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.js.map +1 -0
- package/dist/cjs/modules/cms/pages/cms-settigns/DocModuleEditForm.vue2.js +4 -0
- package/dist/cjs/modules/cms/pages/cms-settigns/DocModuleEditForm.vue2.js.map +1 -0
- package/dist/cjs/modules/cms/pages/cms-settigns/index.vue2.js +18 -0
- package/dist/cjs/modules/cms/pages/cms-settigns/index.vue2.js.map +1 -1
- package/dist/cjs/modules/ms/components/image-select/image-select-api.js +14 -2
- package/dist/cjs/modules/ms/components/image-select/image-select-api.js.map +1 -1
- package/dist/cjs/modules/ms/image-upload-context/index.js +1 -1
- package/dist/cjs/modules/ms/image-upload-context/index.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/core/element-block.js +18 -13
- package/dist/esm/components/basic/doc-editor/core/element-block.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/core/utils.js +20 -13
- package/dist/esm/components/basic/doc-editor/core/utils.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/editor.vue.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/GridNode.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/ImageTextGridNode.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.js +32 -1
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.js +13 -0
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/TextGridNode.js +11 -0
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/TextGridNode.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/index.vue.js +87 -13
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/index.vue.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/utils.js +114 -7
- package/dist/esm/components/basic/doc-editor/plugins/GridPlugin/utils.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.js +52 -38
- package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/index.vue.js +3 -5
- package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/index.vue.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/utils.js +33 -55
- package/dist/esm/components/basic/doc-editor/plugins/ImagePlugin/utils.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/ModulePlugin/composables.js +14 -1
- package/dist/esm/components/basic/doc-editor/plugins/ModulePlugin/composables.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/ModulePlugin/index.vue.js +40 -3
- package/dist/esm/components/basic/doc-editor/plugins/ModulePlugin/index.vue.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/RichTextPlugin/index.vue.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/RichTextPlugin/nodes/RichTextNode.js +16 -16
- package/dist/esm/components/basic/doc-editor/plugins/RichTextPlugin/nodes/RichTextNode.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/ToolbarPlugin/FontStyleTool.vue.js +11 -10
- package/dist/esm/components/basic/doc-editor/plugins/ToolbarPlugin/FontStyleTool.vue.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/plugins/nodes.js.map +1 -1
- package/dist/esm/components/basic/doc-editor/themes/doc-editor-edit.css.js +1 -1
- package/dist/esm/components/basic/doc-editor/themes/doc-editor-edit.css.js.map +1 -1
- package/dist/esm/components/basic/dynamic-form-panel/DynamicFormPanel.js +40 -18
- package/dist/esm/components/basic/dynamic-form-panel/DynamicFormPanel.js.map +1 -1
- package/dist/esm/components/basic/dynamic-form-panel/dialog.js +2 -2
- package/dist/esm/components/basic/dynamic-form-panel/dialog.js.map +1 -1
- package/dist/esm/components/basic/image-cropper/image-cropper-api.js.map +1 -1
- package/dist/esm/components/basic/visual-page-editor/content-editable.vue.js +14 -10
- package/dist/esm/components/basic/visual-page-editor/content-editable.vue.js.map +1 -1
- package/dist/esm/components/basic/visual-page-editor/core/BlockRender.js +39 -0
- package/dist/esm/components/basic/visual-page-editor/core/BlockRender.js.map +1 -0
- package/dist/esm/components/basic/visual-page-editor/core/Dialog.js +76 -0
- package/dist/esm/components/basic/visual-page-editor/core/Dialog.js.map +1 -0
- package/dist/esm/components/basic/visual-page-editor/core/VisvalPageEditor.js +73 -2
- package/dist/esm/components/basic/visual-page-editor/core/VisvalPageEditor.js.map +1 -1
- package/dist/esm/components/basic/visual-page-editor/core/index.js +21 -13
- package/dist/esm/components/basic/visual-page-editor/core/index.js.map +1 -1
- package/dist/esm/components/basic/visual-page-editor/editor.vue.js +4 -31
- package/dist/esm/components/basic/visual-page-editor/editor.vue.js.map +1 -1
- package/dist/esm/components/basic/visual-page-editor/index.js +1 -1
- package/dist/esm/components/basic/visual-page-editor/index.js.map +1 -1
- package/dist/esm/components/basic/visual-page-editor/modules/BaseImageModule.js +9 -0
- package/dist/esm/components/basic/visual-page-editor/modules/BaseImageModule.js.map +1 -0
- package/dist/esm/components/basic/visual-page-editor/toolbar.vue.js +2 -2
- package/dist/esm/components/basic/visual-page-editor/toolbar.vue.js.map +1 -1
- package/dist/esm/modules/cms/cms-settings.js +4 -0
- package/dist/esm/modules/cms/cms-settings.js.map +1 -1
- package/dist/esm/modules/cms/composables/part-extensions.js +6 -6
- package/dist/esm/modules/cms/composables/part-extensions.js.map +1 -1
- package/dist/esm/modules/cms/dataviews/cms-ad-contents/CmsAdContentsForm.js +20 -2
- package/dist/esm/modules/cms/dataviews/cms-ad-contents/CmsAdContentsForm.js.map +1 -1
- package/dist/esm/modules/cms/pages/cms-ad/index.vue2.js +0 -1
- package/dist/esm/modules/cms/pages/cms-ad/index.vue2.js.map +1 -1
- package/dist/esm/modules/cms/pages/cms-contents/article-edit-add-page.vue2.js +3 -1
- package/dist/esm/modules/cms/pages/cms-contents/article-edit-add-page.vue2.js.map +1 -1
- package/dist/esm/modules/cms/pages/cms-contents/components/part-banner-edit.vue.js +32 -9
- package/dist/esm/modules/cms/pages/cms-contents/components/part-banner-edit.vue.js.map +1 -1
- package/dist/esm/modules/cms/pages/cms-contents/index.vue2.js +49 -45
- package/dist/esm/modules/cms/pages/cms-contents/index.vue2.js.map +1 -1
- package/dist/esm/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.js +313 -0
- package/dist/esm/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.js.map +1 -0
- package/dist/esm/modules/cms/pages/cms-settigns/DocModuleEditForm.vue2.js +5 -0
- package/dist/esm/modules/cms/pages/cms-settigns/DocModuleEditForm.vue2.js.map +1 -0
- package/dist/esm/modules/cms/pages/cms-settigns/index.vue2.js +18 -0
- package/dist/esm/modules/cms/pages/cms-settigns/index.vue2.js.map +1 -1
- package/dist/esm/modules/ms/components/image-select/image-select-api.js +14 -2
- package/dist/esm/modules/ms/components/image-select/image-select-api.js.map +1 -1
- package/dist/esm/modules/ms/image-upload-context/index.js +1 -1
- package/dist/esm/modules/ms/image-upload-context/index.js.map +1 -1
- package/dist/style/components/basic/visual-page-editor/index.css +1 -1
- package/dist/style/components/index.css +1 -1
- package/dist/style/index.css +1 -1
- package/dist/style/src/components/basic/visual-page-editor/index.scss +4 -2
- package/dist/types/components/basic/doc-editor/core/element-block.d.ts +1 -0
- package/dist/types/components/basic/doc-editor/core/utils.d.ts +2 -2
- package/dist/types/components/basic/doc-editor/plugins/GridPlugin/ImageTextGridNode.d.ts +1 -1
- package/dist/types/components/basic/doc-editor/plugins/GridPlugin/LayoutGridNode.d.ts +16 -2
- package/dist/types/components/basic/doc-editor/plugins/GridPlugin/ModuleGridNode.d.ts +7 -1
- package/dist/types/components/basic/doc-editor/plugins/ImagePlugin/ImageNode.d.ts +25 -12
- package/dist/types/components/basic/doc-editor/plugins/ModulePlugin/composables.d.ts +5 -0
- package/dist/types/components/basic/doc-editor/utils/getSelectedNode.d.ts +1 -1
- package/dist/types/components/basic/dynamic-form-panel/type.d.ts +1 -0
- package/dist/types/components/basic/visual-page-editor/core/Dialog.d.ts +15 -0
- package/dist/types/components/basic/visual-page-editor/core/ModuleDefine.d.ts +12 -0
- package/dist/types/components/basic/visual-page-editor/core/VisvalPageEditor.d.ts +45 -1
- package/dist/types/components/basic/visual-page-editor/core/index.d.ts +2 -10
- package/dist/types/components/basic/visual-page-editor/editor.vue.d.ts +1 -0
- package/dist/types/components/basic/visual-page-editor/index.d.ts +2 -1
- package/dist/types/components/basic/visual-page-editor/modules/index.d.ts +1 -0
- package/dist/types/modules/cms/cms-settings.d.ts +4 -28
- package/dist/types/modules/cms/composables/part-extensions.d.ts +7 -3
- package/dist/types/modules/cms/pages/cms-settigns/DocModuleEditForm.vue.d.ts +45 -0
- package/dist/types/modules/ms/components/image-select/image-select-api.d.ts +1 -1
- package/dist/types/modules/ms/image-upload-context/index.d.ts +1 -1
- package/package.json +9 -8
- package/dist/cjs/components/basic/visual-page-editor/components/BlockRender.js +0 -31
- package/dist/cjs/components/basic/visual-page-editor/components/BlockRender.js.map +0 -1
- package/dist/cjs/components/basic/visual-page-editor/utils/Dialog.js +0 -111
- package/dist/cjs/components/basic/visual-page-editor/utils/Dialog.js.map +0 -1
- package/dist/cjs/components/basic/visual-page-editor/visual-components/ImageRenderComponent.js +0 -29
- package/dist/cjs/components/basic/visual-page-editor/visual-components/ImageRenderComponent.js.map +0 -1
- package/dist/esm/components/basic/visual-page-editor/components/BlockRender.js +0 -32
- package/dist/esm/components/basic/visual-page-editor/components/BlockRender.js.map +0 -1
- package/dist/esm/components/basic/visual-page-editor/utils/Dialog.js +0 -111
- package/dist/esm/components/basic/visual-page-editor/utils/Dialog.js.map +0 -1
- package/dist/esm/components/basic/visual-page-editor/visual-components/ImageRenderComponent.js +0 -28
- package/dist/esm/components/basic/visual-page-editor/visual-components/ImageRenderComponent.js.map +0 -1
- package/dist/types/components/basic/visual-page-editor/core/RenderComponent.d.ts +0 -16
- package/dist/types/components/basic/visual-page-editor/utils/Dialog.d.ts +0 -15
- package/dist/types/components/basic/visual-page-editor/visual-components/index.d.ts +0 -1
- /package/dist/types/components/basic/visual-page-editor/{components → core}/BlockRender.d.ts +0 -0
- /package/dist/types/components/basic/visual-page-editor/{visual-components/ImageRenderComponent.d.ts → modules/BaseImageModule.d.ts} +0 -0
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { defineComponent, ref, resolveComponent, h } from "vue";
|
|
2
2
|
import { ElFormItem, ElForm } from "element-plus";
|
|
3
|
+
import { ImageUploadContext } from "../../../modules/ms/image-upload-context/index.js";
|
|
3
4
|
const DynamicFormPanel = /* @__PURE__ */ defineComponent({
|
|
4
5
|
name: "DynamicFormPanel",
|
|
5
6
|
props: {
|
|
@@ -13,33 +14,54 @@ const DynamicFormPanel = /* @__PURE__ */ defineComponent({
|
|
|
13
14
|
setup: (props, {
|
|
14
15
|
emit
|
|
15
16
|
}) => {
|
|
16
|
-
var _a;
|
|
17
17
|
const dataRef = ref(props.data);
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
}, {
|
|
24
|
-
default: () => {
|
|
25
|
-
return [h(component, {
|
|
26
|
-
...item.props,
|
|
27
|
-
"modelValue": dataRef.value[item.name],
|
|
28
|
-
"onUpdate:modelValue": (v) => {
|
|
29
|
-
dataRef.value[item.name] = v;
|
|
30
|
-
}
|
|
31
|
-
})];
|
|
18
|
+
return () => {
|
|
19
|
+
var _a;
|
|
20
|
+
const formItems = (_a = props.options) == null ? void 0 : _a.filter((item) => {
|
|
21
|
+
if (item.condition) {
|
|
22
|
+
return item.condition(dataRef.value);
|
|
32
23
|
}
|
|
24
|
+
return true;
|
|
25
|
+
}).map((item) => {
|
|
26
|
+
const resloveComponent = typeof item.component == "string" ? resolveComponent(item.component) : item.component;
|
|
27
|
+
let defaultSlot = () => [];
|
|
28
|
+
if (item.component == "el-radio-group") {
|
|
29
|
+
defaultSlot = () => item.props.data.map((dt) => {
|
|
30
|
+
return h(resolveComponent("el-radio-button"), {
|
|
31
|
+
label: dt.label,
|
|
32
|
+
value: dt.value
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
} else if (item.component == "MKUploadImage") {
|
|
36
|
+
if (item.props.cutSize) {
|
|
37
|
+
item.props.uploadContext = new ImageUploadContext(item.props.cutSize);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
return h(ElFormItem, {
|
|
41
|
+
label: item.title,
|
|
42
|
+
prop: item.name
|
|
43
|
+
}, {
|
|
44
|
+
default: () => {
|
|
45
|
+
return [h(resloveComponent, {
|
|
46
|
+
...item.props,
|
|
47
|
+
"modelValue": dataRef.value[item.name],
|
|
48
|
+
"onUpdate:modelValue": (v) => {
|
|
49
|
+
dataRef.value[item.name] = v;
|
|
50
|
+
}
|
|
51
|
+
}, {
|
|
52
|
+
default: defaultSlot
|
|
53
|
+
})];
|
|
54
|
+
}
|
|
55
|
+
});
|
|
33
56
|
});
|
|
34
|
-
});
|
|
35
|
-
return () => {
|
|
36
57
|
return h(ElForm, {
|
|
37
58
|
labelPosition: "top",
|
|
38
59
|
model: props.data,
|
|
39
60
|
labelWidth: "auto",
|
|
40
61
|
style: {
|
|
41
62
|
height: "600px",
|
|
42
|
-
overflow: "auto"
|
|
63
|
+
overflow: "auto",
|
|
64
|
+
padding: "10px"
|
|
43
65
|
}
|
|
44
66
|
}, {
|
|
45
67
|
default: () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamicFormPanel.js","sources":["../../../../../src/components/basic/dynamic-form-panel/DynamicFormPanel.tsx"],"sourcesContent":["import { defineComponent,resolveComponent,h,ref } from \"vue\"\r\nimport { ElButton,ElForm,ElFormItem,ElCollapse,ElCollapseItem,ElInput } from \"element-plus\";\r\nimport { type DynamicFormItemType } from \"./type\"\r\n\r\nexport default defineComponent({\r\n name:\"DynamicFormPanel\",\r\n props:{\r\n data:{ type:Object },\r\n options:{ type:Array<DynamicFormItemType> }\r\n },\r\n setup:(props,{ emit })=>{\r\n\r\n // 编辑\r\n const dataRef = ref<any>(props.data);\r\n\r\n // 生成的表单项\r\n
|
|
1
|
+
{"version":3,"file":"DynamicFormPanel.js","sources":["../../../../../src/components/basic/dynamic-form-panel/DynamicFormPanel.tsx"],"sourcesContent":["import { defineComponent,resolveComponent,h,ref } from \"vue\"\r\nimport { ElButton,ElForm,ElFormItem,ElCollapse,ElCollapseItem,ElInput } from \"element-plus\";\r\nimport { type DynamicFormItemType } from \"./type\"\r\nimport { ImageUploadContext } from \"../../../modules/ms/image-upload-context\";\r\n\r\nexport default defineComponent({\r\n name:\"DynamicFormPanel\",\r\n props:{\r\n data:{ type:Object },\r\n options:{ type:Array<DynamicFormItemType> }\r\n },\r\n setup:(props,{ emit })=>{\r\n\r\n // 编辑\r\n const dataRef = ref<any>(props.data);\r\n\r\n\r\n return ()=>{\r\n\r\n // 生成的表单项\r\n const formItems = props.options?.filter(item=>{\r\n if(item.condition){\r\n return item.condition(dataRef.value);\r\n }\r\n return true;\r\n }).map(item=>{\r\n\r\n const resloveComponent = typeof item.component == \"string\" ? resolveComponent(item.component) : item.component;\r\n let defaultSlot:any = ()=>[];\r\n\r\n // 特殊处理的组件\r\n if(item.component == \"el-radio-group\"){\r\n defaultSlot = ()=>item.props.data.map((dt:any)=>{\r\n return h(resolveComponent(\"el-radio-button\"),{ label:dt.label, value:dt.value })\r\n })\r\n }\r\n else if(item.component == \"MKUploadImage\"){\r\n if(item.props.cutSize){\r\n item.props.uploadContext = new ImageUploadContext(item.props.cutSize)\r\n }\r\n }\r\n\r\n return h(ElFormItem,{ \r\n label:item.title,prop:item.name,\r\n },{\r\n default:()=>{\r\n return [\r\n h(resloveComponent,{ \r\n ...item.props,\r\n \"modelValue\" : dataRef.value[item.name],\r\n \"onUpdate:modelValue\" : (v:any) => {\r\n dataRef.value[item.name] = v;\r\n }\r\n },{ default:defaultSlot })\r\n ]\r\n }\r\n })\r\n });\r\n\r\n return h(ElForm,{ \r\n labelPosition:\"top\",model:props.data,labelWidth:\"auto\",\r\n style:{ height:\"600px\",overflow:\"auto\",padding:\"10px\" }\r\n },{\r\n default:()=>{\r\n return formItems\r\n }\r\n })\r\n }\r\n }\r\n});\r\n"],"names":["defineComponent","name","props","data","type","Object","options","Array","setup","emit","dataRef","ref","formItems","filter","item","condition","value","map","resloveComponent","component","resolveComponent","defaultSlot","dt","h","label","cutSize","uploadContext","ImageUploadContext","ElFormItem","title","prop","default","v","ElForm","labelPosition","model","labelWidth","style","height","overflow","padding"],"mappings":";;;AAKA,MAAeA,mDAAgB;AAAA,EAC7BC,MAAK;AAAA,EACLC,OAAM;AAAA,IACJC,MAAK;AAAA,MAAEC,MAAKC;AAAAA,IAAQ;AAAA,IACpBC,SAAQ;AAAA,MAAEF,MAAKG;AAAAA,IAA2B;AAAA,EAC3C;AAAA,EACDC,OAAMA,CAACN,OAAM;AAAA,IAAEO;AAAAA,EAAK,MAAI;AAGtB,UAAMC,UAAUC,IAAST,MAAMC,IAAI;AAGnC,WAAO,MAAI;;AAGT,YAAMS,aAAYV,WAAMI,YAANJ,mBAAeW,OAAOC,UAAM;AAC5C,YAAGA,KAAKC,WAAU;AACd,iBAAOD,KAAKC,UAAUL,QAAQM,KAAK;AAAA,QACvC;AACA,eAAO;AAAA,MACT,GAAGC,IAAIH,UAAM;AAEX,cAAMI,mBAAmB,OAAOJ,KAAKK,aAAa,WAAWC,iBAAiBN,KAAKK,SAAS,IAAIL,KAAKK;AACrG,YAAIE,cAAkBA,MAAI;AAG1B,YAAGP,KAAKK,aAAa,kBAAiB;AACpCE,wBAAcA,MAAIP,KAAKZ,MAAMC,KAAKc,IAAKK,QAAS;AAC9C,mBAAOC,EAAEH,iBAAiB,iBAAiB,GAAE;AAAA,cAAEI,OAAMF,GAAGE;AAAAA,cAAOR,OAAMM,GAAGN;AAAAA,YAAM,CAAC;AAAA,UACjF,CAAC;AAAA,QACH,WACQF,KAAKK,aAAa,iBAAgB;AACxC,cAAGL,KAAKZ,MAAMuB,SAAQ;AACpBX,iBAAKZ,MAAMwB,gBAAgB,IAAIC,mBAAmBb,KAAKZ,MAAMuB,OAAO;AAAA,UACtE;AAAA,QACF;AAEA,eAAOF,EAAEK,YAAW;AAAA,UAClBJ,OAAMV,KAAKe;AAAAA,UAAMC,MAAKhB,KAAKb;AAAAA,QAC7B,GAAE;AAAA,UACA8B,SAAQA,MAAI;AACV,mBAAO,CACLR,EAAEL,kBAAiB;AAAA,cACjB,GAAGJ,KAAKZ;AAAAA,cACR,cAAeQ,QAAQM,MAAMF,KAAKb,IAAI;AAAA,cACtC,uBAAyB+B,OAAU;AACjCtB,wBAAQM,MAAMF,KAAKb,IAAI,IAAI+B;AAAAA,cAC7B;AAAA,YACF,GAAE;AAAA,cAAGD,SAAQV;AAAAA,YAAa,CAAA,CAAC;AAAA,UAE/B;AAAA,QACF,CAAC;AAAA,MACH;AAEA,aAAOE,EAAEU,QAAO;AAAA,QACdC,eAAc;AAAA,QAAMC,OAAMjC,MAAMC;AAAAA,QAAKiC,YAAW;AAAA,QAChDC,OAAM;AAAA,UAAEC,QAAO;AAAA,UAAQC,UAAS;AAAA,UAAOC,SAAQ;AAAA,QAAO;AAAA,MACxD,GAAE;AAAA,QACAT,SAAQA,MAAI;AACV,iBAAOnB;AAAAA,QACT;AAAA,MACF,CAAC;AAAA;EAEL;AACF,CAAC;"}
|
|
@@ -19,8 +19,8 @@ const showDynamicFormDialoger = async (title, options, data) => {
|
|
|
19
19
|
};
|
|
20
20
|
const dialogInstance = Dialoger.customRender({
|
|
21
21
|
title: isAdd ? `添加${title}` : `编辑${title}`,
|
|
22
|
-
class: "mk-
|
|
23
|
-
width: "
|
|
22
|
+
class: "mk-dynamic-form-editor-dialog",
|
|
23
|
+
width: "700px",
|
|
24
24
|
onClose: () => {
|
|
25
25
|
dialogInstance.destroy();
|
|
26
26
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dialog.js","sources":["../../../../../src/components/basic/dynamic-form-panel/dialog.ts"],"sourcesContent":["\r\nimport { h ,type Component,Fragment,reactive } from 'vue'\r\nimport { Dialoger } from '@maketribe/dm'\r\nimport { ElButton,ElForm,ElFormItem,ElCollapse,ElCollapseItem,ElInput } from \"element-plus\";\r\nimport DynamicFormPanel from \"./DynamicFormPanel\"\r\nimport { type DynamicFormItemType } from \"./type\"\r\nimport { createDefaultFormData } from \"./utils\"\r\n\r\n/**\r\n * 显示动态表单弹窗\r\n * @param title 标题\r\n * @param options 表单配置\r\n * @param data 表单数据\r\n * @returns \r\n */\r\nexport const showDynamicFormDialoger = async (title:string,options:DynamicFormItemType[],data:any) => {\r\n return new Promise(resolve => {\r\n\r\n // 是否是新增\r\n const isAdd = data == null;\r\n\r\n // 新增的话\r\n if(isAdd){ \r\n data = createDefaultFormData(options); \r\n }\r\n\r\n // 响应数据\r\n const reactiveData = reactive(data)\r\n\r\n // 取消编辑\r\n const handleCancelClick = () => {\r\n dialogInstance.destroy();\r\n };\r\n\r\n // 确认编辑\r\n const handleConfirmClick = () => {\r\n dialogInstance.destroy();\r\n resolve(data);\r\n };\r\n\r\n const dialogInstance = Dialoger.customRender({\r\n title: isAdd ? `添加${title}` : `编辑${title}`,\r\n class: \"mk-
|
|
1
|
+
{"version":3,"file":"dialog.js","sources":["../../../../../src/components/basic/dynamic-form-panel/dialog.ts"],"sourcesContent":["\r\nimport { h ,type Component,Fragment,reactive } from 'vue'\r\nimport { Dialoger } from '@maketribe/dm'\r\nimport { ElButton,ElForm,ElFormItem,ElCollapse,ElCollapseItem,ElInput } from \"element-plus\";\r\nimport DynamicFormPanel from \"./DynamicFormPanel\"\r\nimport { type DynamicFormItemType } from \"./type\"\r\nimport { createDefaultFormData } from \"./utils\"\r\n\r\n/**\r\n * 显示动态表单弹窗\r\n * @param title 标题\r\n * @param options 表单配置\r\n * @param data 表单数据\r\n * @returns \r\n */\r\nexport const showDynamicFormDialoger = async (title:string,options:DynamicFormItemType[],data:any) => {\r\n return new Promise(resolve => {\r\n\r\n // 是否是新增\r\n const isAdd = data == null;\r\n\r\n // 新增的话\r\n if(isAdd){ \r\n data = createDefaultFormData(options); \r\n }\r\n\r\n // 响应数据\r\n const reactiveData = reactive(data)\r\n\r\n // 取消编辑\r\n const handleCancelClick = () => {\r\n dialogInstance.destroy();\r\n };\r\n\r\n // 确认编辑\r\n const handleConfirmClick = () => {\r\n dialogInstance.destroy();\r\n resolve(data);\r\n };\r\n\r\n const dialogInstance = Dialoger.customRender({\r\n title: isAdd ? `添加${title}` : `编辑${title}`,\r\n class: \"mk-dynamic-form-editor-dialog\",\r\n width: \"700px\",\r\n onClose: () => {\r\n dialogInstance.destroy();\r\n },\r\n body: () => {\r\n return h(DynamicFormPanel,{ data,options })\r\n },\r\n footer: () => {\r\n return h(Fragment,{},[\r\n h(ElButton,{ onClick:()=>handleCancelClick() },{ default:()=>\"取消\" }),\r\n h(ElButton,{ type:\"primary\" , onClick:()=>handleConfirmClick() },{ default:()=>\"确定\" })\r\n ]) \r\n },\r\n });\r\n });\r\n}\r\n\r\n\r\n\r\n"],"names":[],"mappings":";;;;;AAeO,MAAM,0BAA0B,OAAQ,OAAa,SAA8B,SAAa;AAC9F,SAAA,IAAI,QAAQ,CAAW,YAAA;AAG5B,UAAM,QAAQ,QAAQ;AAGtB,QAAG,OAAM;AACP,aAAO,sBAAsB,OAAO;AAAA,IACtC;AAGqB,aAAS,IAAI;AAGlC,UAAM,oBAAoB,MAAM;AAC9B,qBAAe,QAAQ;AAAA,IAAA;AAIzB,UAAM,qBAAqB,MAAM;AAC/B,qBAAe,QAAQ;AACvB,cAAQ,IAAI;AAAA,IAAA;AAGR,UAAA,iBAAiB,SAAS,aAAa;AAAA,MAC3C,OAAO,QAAQ,KAAK,KAAK,KAAK,KAAK,KAAK;AAAA,MACxC,OAAO;AAAA,MACP,OAAO;AAAA,MACP,SAAS,MAAM;AACb,uBAAe,QAAQ;AAAA,MACzB;AAAA,MACA,MAAM,MAAM;AACV,eAAO,EAAE,kBAAiB,EAAE,MAAK,QAAS,CAAA;AAAA,MAC5C;AAAA,MACA,QAAQ,MAAM;AACL,eAAA,EAAE,UAAS,IAAG;AAAA,UACnB,EAAE,UAAS,EAAE,SAAQ,MAAI,kBAAoB,EAAA,GAAE,EAAE,SAAQ,MAAI,MAAM;AAAA,UACnE,EAAE,UAAS,EAAE,MAAK,WAAY,SAAQ,MAAI,mBAAmB,KAAI,EAAE,SAAQ,MAAI,MAAM;AAAA,QAAA,CACtF;AAAA,MACH;AAAA,IAAA,CACD;AAAA,EAAA,CACF;AACH;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"image-cropper-api.js","sources":["../../../../../src/components/basic/image-cropper/image-cropper-api.tsx"],"sourcesContent":["import { Dialoger } from \"@maketribe/dm\";\r\nimport ImageCropperContent, {\r\n ImageCropperRatioOption,\r\n} from \"./image-cropper-content\";\r\nimport { Fragment } from \"vue/jsx-runtime\";\r\nimport { ElButton } from \"element-plus\";\r\nimport { ref, Ref, unref } from \"vue\";\r\n\r\nexport type MKImageCropperOptions = {\r\n src: string;\r\n ratioOptions?: Array<ImageCropperRatioOption>;\r\n fixedBox?: boolean;\r\n maxWidth?:number;\r\n maxHeight?:number;\r\n};\r\nexport type MKImageCropperResult = {\r\n isConfirm: boolean;\r\n data: string;\r\n size: { width: number; height: number };\r\n};\r\n\r\nexport async function ImageCropper(\r\n options: MKImageCropperOptions\r\n): Promise<MKImageCropperResult> {\r\n const ratioOptions = options.ratioOptions ?? [];\r\n const fixedBox = options.fixedBox ?? false;\r\n\r\n return new Promise((resolve) => {\r\n const imageCropperContentEl: Ref<typeof ImageCropperContent | null> =\r\n ref(null);\r\n\r\n const handleCancelClick = () => {\r\n dialogInstance.destroy();\r\n\r\n resolve({\r\n isConfirm: false,\r\n data: \"\",\r\n size: { width: 0, height: 0 },\r\n });\r\n };\r\n\r\n const handleConfirmClick = async () => {\r\n dialogInstance.destroy();\r\n\r\n const cropperRef = unref(imageCropperContentEl)!.cropperRef;\r\n\r\n resolve({\r\n isConfirm: true,\r\n data: await new Promise(cropperRef.getCropData.bind(cropperRef)),\r\n size: { width: cropperRef.cropW, height: cropperRef.cropH },\r\n });\r\n };\r\n\r\n const dialogInstance = Dialoger.customRender({\r\n title: \"图片裁切\",\r\n onClose: handleCancelClick,\r\n body: () => {\r\n return (\r\n <ImageCropperContent\r\n ref={((el: any) => (imageCropperContentEl.value = el)) as any}\r\n src={options.src}\r\n fixedBox={fixedBox}\r\n ratioOptions={ratioOptions}\r\n maxHeight={options.maxHeight}\r\n maxWidth={options.maxWidth}\r\n />\r\n );\r\n },\r\n footer: () => {\r\n return (\r\n <Fragment>\r\n <ElButton onClick={handleCancelClick}>取消</ElButton>\r\n <ElButton type=\"primary\" onClick={handleConfirmClick}>\r\n 确认\r\n </ElButton>\r\n </Fragment>\r\n );\r\n },\r\n });\r\n });\r\n}\r\n"],"names":["ImageCropper","options","ratioOptions","fixedBox","Promise","resolve","imageCropperContentEl","ref","handleCancelClick","dialogInstance","destroy","isConfirm","data","size","width","height","handleConfirmClick","cropperRef","unref","getCropData","bind","cropW","cropH","Dialoger","customRender","title","onClose","body","_createVNode","ImageCropperContent","el","value","src","maxHeight","maxWidth","footer","_Fragment","ElButton","default","_createTextVNode"],"mappings":";;;;;AAqBO,eAAeA,aACpBC,SAC+B;AAC/B,QAAMC,eAAeD,QAAQC,gBAAgB;AAC7C,QAAMC,WAAWF,QAAQE,YAAY;AAErC,SAAO,IAAIC,QAASC,aAAY;AAC9B,UAAMC,wBACJC,IAAI,IAAI;AAEV,UAAMC,oBAAoBA,MAAM;AAC9BC,qBAAeC,QAAO;AAEtBL,cAAQ;AAAA,QACNM,WAAW;AAAA,QACXC,MAAM;AAAA,QACNC,MAAM;AAAA,UAAEC,OAAO;AAAA,UAAGC,QAAQ;AAAA,QAAE;AAAA,MAC9B,CAAC;AAAA;AAGH,UAAMC,qBAAqB,YAAY;AACrCP,qBAAeC,QAAO;AAEtB,YAAMO,aAAaC,MAAMZ,qBAAqB,EAAGW;AAEjDZ,cAAQ;AAAA,QACNM,WAAW;AAAA,QACXC,MAAM,MAAM,IAAIR,QAAQa,WAAWE,YAAYC,KAAKH,UAAU,CAAC;AAAA,QAC/DJ,MAAM;AAAA,UAAEC,OAAOG,WAAWI;AAAAA,UAAON,QAAQE,WAAWK;AAAAA,QAAM;AAAA,MAC5D,CAAC;AAAA;AAGH,UAAMb,iBAAiBc,SAASC,aAAa;AAAA,MAC3CC,OAAO;AAAA,MACPC,SAASlB;AAAAA,MACTmB,MAAMA,MAAM;AACV,eAAAC,YAAAC,qBAAA;AAAA,UAAA,OAEWC,QAAaxB,sBAAsByB,QAAQD;AAAAA,UAAG,OAChD7B,QAAQ+B;AAAAA,UAAG,YACN7B;AAAAA,UAAQ,gBACJD;AAAAA,UAAY,aACfD,QAAQgC;AAAAA,UAAS,YAClBhC,QAAQiC;AAAAA,QAAQ,GAAA,IAAA;AAAA,MAG/B;AAAA,MACDC,QAAQA,MAAM;AACZ,eAAAP,YAAAQ,UAAAR,MAAAA,CAAAA,YAAAS,UAAA;AAAA,UAAA,WAEuB7B;AAAAA,QAAiB,GAAA;AAAA,UAAA8B,SAAAA,MAAA,CAAAC,gBAAA,IAAA,CAAA;AAAA,SAAAX,GAAAA,YAAAS,UAAA;AAAA,UAAA,QAAA;AAAA,UAAA,WACFrB;AAAAA,QAAkB,GAAA;AAAA,UAAAsB,SAAAA,MAAA,CAAAC,gBAAA,IAAA,CAAA;AAAA,QAAA,CAAA,CAAA,CAAA;AAAA,MAK1D;AAAA,IACF,CAAC;AAAA,EACH,CAAC;AACH;"}
|
|
1
|
+
{"version":3,"file":"image-cropper-api.js","sources":["../../../../../src/components/basic/image-cropper/image-cropper-api.tsx"],"sourcesContent":["import { Dialoger } from \"@maketribe/dm\";\r\nimport ImageCropperContent, {\r\n ImageCropperRatioOption,\r\n} from \"./image-cropper-content\";\r\nimport { Fragment } from \"vue/jsx-runtime\";\r\nimport { ElButton } from \"element-plus\";\r\nimport { ref, Ref, unref } from \"vue\";\r\n\r\nexport type MKImageCropperOptions = {\r\n src: string;\r\n ratioOptions?: Array<ImageCropperRatioOption>;\r\n fixedBox?: boolean;\r\n maxWidth?:number;\r\n maxHeight?:number;\r\n};\r\nexport type MKImageCropperResult = {\r\n isConfirm: boolean;\r\n data: string;\r\n size: { width: number; height: number };\r\n};\r\n\r\nexport async function ImageCropper(\r\n options: MKImageCropperOptions\r\n): Promise<MKImageCropperResult> {\r\n const ratioOptions = options.ratioOptions ?? [];\r\n const fixedBox = options.fixedBox ?? false;\r\n\r\n return new Promise((resolve) => {\r\n const imageCropperContentEl: Ref<typeof ImageCropperContent | null> =\r\n ref(null);\r\n\r\n const handleCancelClick = () => {\r\n dialogInstance.destroy();\r\n\r\n resolve({\r\n isConfirm: false,\r\n data: \"\",\r\n size: { width: 0, height: 0 },\r\n });\r\n };\r\n\r\n const handleConfirmClick = async () => {\r\n dialogInstance.destroy();\r\n\r\n const cropperRef = unref(imageCropperContentEl)!.cropperRef;\r\n \r\n resolve({\r\n isConfirm: true,\r\n data: await new Promise(cropperRef.getCropData.bind(cropperRef)),\r\n size: { width: cropperRef.cropW, height: cropperRef.cropH },\r\n });\r\n };\r\n\r\n const dialogInstance = Dialoger.customRender({\r\n title: \"图片裁切\",\r\n onClose: handleCancelClick,\r\n body: () => {\r\n return (\r\n <ImageCropperContent\r\n ref={((el: any) => (imageCropperContentEl.value = el)) as any}\r\n src={options.src}\r\n fixedBox={fixedBox}\r\n ratioOptions={ratioOptions}\r\n maxHeight={options.maxHeight}\r\n maxWidth={options.maxWidth}\r\n />\r\n );\r\n },\r\n footer: () => {\r\n return (\r\n <Fragment>\r\n <ElButton onClick={handleCancelClick}>取消</ElButton>\r\n <ElButton type=\"primary\" onClick={handleConfirmClick}>\r\n 确认\r\n </ElButton>\r\n </Fragment>\r\n );\r\n },\r\n });\r\n });\r\n}\r\n"],"names":["ImageCropper","options","ratioOptions","fixedBox","Promise","resolve","imageCropperContentEl","ref","handleCancelClick","dialogInstance","destroy","isConfirm","data","size","width","height","handleConfirmClick","cropperRef","unref","getCropData","bind","cropW","cropH","Dialoger","customRender","title","onClose","body","_createVNode","ImageCropperContent","el","value","src","maxHeight","maxWidth","footer","_Fragment","ElButton","default","_createTextVNode"],"mappings":";;;;;AAqBO,eAAeA,aACpBC,SAC+B;AAC/B,QAAMC,eAAeD,QAAQC,gBAAgB;AAC7C,QAAMC,WAAWF,QAAQE,YAAY;AAErC,SAAO,IAAIC,QAASC,aAAY;AAC9B,UAAMC,wBACJC,IAAI,IAAI;AAEV,UAAMC,oBAAoBA,MAAM;AAC9BC,qBAAeC,QAAO;AAEtBL,cAAQ;AAAA,QACNM,WAAW;AAAA,QACXC,MAAM;AAAA,QACNC,MAAM;AAAA,UAAEC,OAAO;AAAA,UAAGC,QAAQ;AAAA,QAAE;AAAA,MAC9B,CAAC;AAAA;AAGH,UAAMC,qBAAqB,YAAY;AACrCP,qBAAeC,QAAO;AAEtB,YAAMO,aAAaC,MAAMZ,qBAAqB,EAAGW;AAEjDZ,cAAQ;AAAA,QACNM,WAAW;AAAA,QACXC,MAAM,MAAM,IAAIR,QAAQa,WAAWE,YAAYC,KAAKH,UAAU,CAAC;AAAA,QAC/DJ,MAAM;AAAA,UAAEC,OAAOG,WAAWI;AAAAA,UAAON,QAAQE,WAAWK;AAAAA,QAAM;AAAA,MAC5D,CAAC;AAAA;AAGH,UAAMb,iBAAiBc,SAASC,aAAa;AAAA,MAC3CC,OAAO;AAAA,MACPC,SAASlB;AAAAA,MACTmB,MAAMA,MAAM;AACV,eAAAC,YAAAC,qBAAA;AAAA,UAAA,OAEWC,QAAaxB,sBAAsByB,QAAQD;AAAAA,UAAG,OAChD7B,QAAQ+B;AAAAA,UAAG,YACN7B;AAAAA,UAAQ,gBACJD;AAAAA,UAAY,aACfD,QAAQgC;AAAAA,UAAS,YAClBhC,QAAQiC;AAAAA,QAAQ,GAAA,IAAA;AAAA,MAG/B;AAAA,MACDC,QAAQA,MAAM;AACZ,eAAAP,YAAAQ,UAAAR,MAAAA,CAAAA,YAAAS,UAAA;AAAA,UAAA,WAEuB7B;AAAAA,QAAiB,GAAA;AAAA,UAAA8B,SAAAA,MAAA,CAAAC,gBAAA,IAAA,CAAA;AAAA,SAAAX,GAAAA,YAAAS,UAAA;AAAA,UAAA,QAAA;AAAA,UAAA,WACFrB;AAAAA,QAAkB,GAAA;AAAA,UAAAsB,SAAAA,MAAA,CAAAC,gBAAA,IAAA,CAAA;AAAA,QAAA,CAAA,CAAA,CAAA;AAAA,MAK1D;AAAA,IACF,CAAC;AAAA,EACH,CAAC;AACH;"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { defineComponent, ref, reactive, onMounted, onBeforeUnmount, resolveComponent, openBlock, createElementBlock, createElementVNode, normalizeStyle, unref, Fragment, renderList, createBlock, createVNode, withCtx, createTextVNode, withModifiers, createCommentVNode } from "vue";
|
|
2
|
-
import {
|
|
3
|
-
import BlockRender from "./
|
|
4
|
-
import {
|
|
2
|
+
import { useVisualPageEditor } from "./core/index.js";
|
|
3
|
+
import BlockRender from "./core/BlockRender.js";
|
|
4
|
+
import { showModuleSelectPanel, showEditPanel } from "./core/Dialog.js";
|
|
5
5
|
const _hoisted_1 = { class: "mk-visual-page-editor__stage_editable_addblock" };
|
|
6
6
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
7
7
|
__name: "content-editable",
|
|
8
8
|
setup(__props) {
|
|
9
|
-
const { PageEditor, ViewDevice } =
|
|
9
|
+
const { PageEditor, ViewDevice } = useVisualPageEditor();
|
|
10
10
|
const editableRef = ref(null);
|
|
11
11
|
const selectIndex = ref(null);
|
|
12
12
|
const clickHandle = (data) => {
|
|
@@ -24,11 +24,13 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
24
24
|
}
|
|
25
25
|
};
|
|
26
26
|
const addHandle = async (pos, index) => {
|
|
27
|
-
await
|
|
27
|
+
await showModuleSelectPanel();
|
|
28
28
|
};
|
|
29
29
|
const editHandle = async (index) => {
|
|
30
30
|
const item = PageEditor.get(index);
|
|
31
|
-
|
|
31
|
+
const module = PageEditor.findModule(item.componentInfo);
|
|
32
|
+
const result = await showEditPanel(module, { ...item.componentProps });
|
|
33
|
+
PageEditor.edit(index, result);
|
|
32
34
|
};
|
|
33
35
|
onMounted(() => {
|
|
34
36
|
var _a;
|
|
@@ -40,8 +42,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
40
42
|
PageEditor.setContent({
|
|
41
43
|
version: "1.0.0",
|
|
42
44
|
contents: [
|
|
43
|
-
{ componentInfo: "
|
|
44
|
-
{ componentInfo: "
|
|
45
|
+
{ componentInfo: "base-image", componentProps: { src: "https://vgcnminisite.oss-cn-shanghai.aliyuncs.com/uploads/2024/07/03/ffd6b7c7f24f42dab3ae1220e18c3723.jpg", id: 1 } },
|
|
46
|
+
{ componentInfo: "base-image", componentProps: { src: "https://vgcnminisite.oss-cn-shanghai.aliyuncs.com/uploads/2024/07/03/b9e0baefbd784d70a83e04bea7cd6113.jpg", id: 2 } }
|
|
45
47
|
]
|
|
46
48
|
});
|
|
47
49
|
});
|
|
@@ -154,11 +156,13 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
154
156
|
]),
|
|
155
157
|
_: 1
|
|
156
158
|
}),
|
|
157
|
-
createVNode(_component_el_button, {
|
|
159
|
+
createVNode(_component_el_button, {
|
|
160
|
+
text: "",
|
|
161
|
+
onClick: _cache[5] || (_cache[5] = ($event) => editHandle(selectIndex.value))
|
|
162
|
+
}, {
|
|
158
163
|
default: withCtx(() => [
|
|
159
164
|
createVNode(_component_MKSvgIcon, {
|
|
160
165
|
iconClass: "Edit",
|
|
161
|
-
onClick: _cache[5] || (_cache[5] = ($event) => editHandle(selectIndex.value)),
|
|
162
166
|
style: { "margin-right": "10px" }
|
|
163
167
|
}),
|
|
164
168
|
createTextVNode(" 编辑 ")
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"content-editable.vue.js","sources":["../../../../../src/components/basic/visual-page-editor/content-editable.vue"],"sourcesContent":["<template>\r\n <div class=\"mk-visual-page-editor__stage_body\" @click=\"clickStageHandle\">\r\n <div class=\"mk-visual-page-editor__stage_editable\" :style=\"{width:(ViewDevice=='pc'?'900px':'640px')}\"
|
|
1
|
+
{"version":3,"file":"content-editable.vue.js","sources":["../../../../../src/components/basic/visual-page-editor/content-editable.vue"],"sourcesContent":["<template>\r\n <div class=\"mk-visual-page-editor__stage_body\" @click=\"clickStageHandle\">\r\n <div class=\"mk-visual-page-editor__stage_editable\" :style=\"{ width: (ViewDevice == 'pc' ? '900px' : '640px') }\"\r\n ref=\"editableRef\">\r\n <BlockRender v-for=\"(item, index) in PageEditor.getContent().contents\" :key=\"index\" :index=\"index\" :node=\"item\"\r\n :active=\"selectIndex == index\" @click=\"clickHandle\"></BlockRender>\r\n <div class=\"mk-visual-page-editor__stage_editable_addblock\">\r\n <el-button text type=\"primary\" size=\"large\" @click=\"addHandle()\">\r\n <MKSvgIcon iconClass=\"Plus\" style=\"margin-right:10px\" />\r\n 添加\r\n </el-button>\r\n </div>\r\n <div class=\"mk-visual-page-editor-inline-toolbar\" @click..stop :style=\"toolsPos\" v-if=\"selectIndex != null\">\r\n <el-button-group>\r\n <el-button text v-if=\"selectIndex > 0\" @click=\"PageEditor.exchange(selectIndex, selectIndex - 1); selectIndex--\">\r\n <MKSvgIcon iconClass=\"CaretTop\" style=\"margin-right:10px\" />\r\n 上移\r\n </el-button>\r\n <el-button text @click=\"PageEditor.exchange(selectIndex, selectIndex + 1); selectIndex++\"\r\n v-if=\"selectIndex < PageEditor.size() - 1\">\r\n <MKSvgIcon iconClass=\"CaretBottom\" style=\"margin-right:10px\" />\r\n 下移\r\n </el-button>\r\n <el-button text @click=\"addHandle(selectIndex, selectIndex - 1)\">\r\n <MKSvgIcon iconClass=\"Fold\" style=\"margin-right:10px\" />\r\n 插入\r\n </el-button>\r\n <el-button text @click=\"addHandle(selectIndex, selectIndex + 1)\">\r\n <MKSvgIcon iconClass=\"Plus\" style=\"margin-right:10px\" />\r\n 添加\r\n </el-button>\r\n <el-button text @click=\"editHandle(selectIndex)\">\r\n <MKSvgIcon iconClass=\"Edit\" style=\"margin-right:10px\" />\r\n 编辑\r\n </el-button>\r\n <el-button text type=\"danger\" @click=\"PageEditor.remove(selectIndex); selectIndex = null\">\r\n <MKSvgIcon iconClass=\"Delete\" style=\"margin-right:10px\" />\r\n 删除\r\n </el-button>\r\n </el-button-group>\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { nextTick, defineProps, defineEmits, computed, ref, onMounted, onBeforeUnmount, reactive, watch } from \"vue\"\r\nimport { useVisualPageEditor, showEditPanel, showModuleSelectPanel } from \"./core\"\r\nimport BlockRender from \"./core/BlockRender\"\r\nimport { ModuleType } from \"./core/ModuleDefine\";\r\n\r\nconst { PageEditor, ViewDevice } = useVisualPageEditor();\r\nconst editableRef = ref<HTMLDivElement | null>(null);\r\nconst selectIndex = ref(null);\r\n\r\n// 点击块\r\nconst clickHandle = (data: any) => {\r\n data.event.stopPropagation();\r\n updateToolsPos();\r\n selectIndex.value = data.index;\r\n}\r\nconst clickStageHandle = () => {\r\n selectIndex.value = null;\r\n}\r\n// 工具条位置\r\nconst toolsPos = reactive({ top: \"0px\" });\r\n// 更新工具条位置\r\nconst updateToolsPos = () => {\r\n if (editableRef.value != null) {\r\n toolsPos.top = Math.max(editableRef.value.parentElement!.scrollTop + editableRef.value.parentElement!.offsetHeight / 2 - 100, 5) + \"px\"\r\n }\r\n}\r\n\r\n// 编辑\r\nconst addHandle = async (pos?: any, index?: any) => {\r\n\r\n const result = await showModuleSelectPanel();\r\n\r\n}\r\n\r\n// 编辑\r\nconst editHandle = async (index: any) => {\r\n\r\n const item = PageEditor.get(index)\r\n const module = PageEditor.findModule(item.componentInfo)\r\n const result = await showEditPanel(module as ModuleType, { ...item.componentProps });\r\n PageEditor.edit(index, result as any);\r\n}\r\n\r\nonMounted(() => {\r\n editableRef.value?.parentElement!.addEventListener(\"scroll\", updateToolsPos, false);\r\n onBeforeUnmount(() => {\r\n editableRef.value?.parentElement!.removeEventListener(\"scroll\", updateToolsPos);\r\n });\r\n\r\n PageEditor.setContent({\r\n version: \"1.0.0\",\r\n contents: [\r\n { componentInfo: \"base-image\", componentProps: { src: \"https://vgcnminisite.oss-cn-shanghai.aliyuncs.com/uploads/2024/07/03/ffd6b7c7f24f42dab3ae1220e18c3723.jpg\", id: 1 } },\r\n { componentInfo: \"base-image\", componentProps: { src: \"https://vgcnminisite.oss-cn-shanghai.aliyuncs.com/uploads/2024/07/03/b9e0baefbd784d70a83e04bea7cd6113.jpg\", id: 2 } }\r\n ]\r\n })\r\n\r\n});\r\n</script>\r\n./core/ModuleDefine./core/BlockRender\r\n./core/Dialog\r\n"],"names":["_a"],"mappings":";;;;;;;;AAmDA,UAAM,EAAE,YAAY,WAAW,IAAI,oBAAoB;AACjD,UAAA,cAAc,IAA2B,IAAI;AAC7C,UAAA,cAAc,IAAI,IAAI;AAGtB,UAAA,cAAc,CAAC,SAAc;AACjC,WAAK,MAAM;AACI;AACf,kBAAY,QAAQ,KAAK;AAAA,IAAA;AAE3B,UAAM,mBAAmB,MAAM;AAC7B,kBAAY,QAAQ;AAAA,IAAA;AAGtB,UAAM,WAAW,SAAS,EAAE,KAAK,MAAO,CAAA;AAExC,UAAM,iBAAiB,MAAM;AACvB,UAAA,YAAY,SAAS,MAAM;AAC7B,iBAAS,MAAM,KAAK,IAAI,YAAY,MAAM,cAAe,YAAY,YAAY,MAAM,cAAe,eAAe,IAAI,KAAK,CAAC,IAAI;AAAA,MACrI;AAAA,IAAA;AAII,UAAA,YAAY,OAAO,KAAW,UAAgB;AAEnC,YAAM,sBAAsB;AAAA,IAAA;AAKvC,UAAA,aAAa,OAAO,UAAe;AAEjC,YAAA,OAAO,WAAW,IAAI,KAAK;AACjC,YAAM,SAAS,WAAW,WAAW,KAAK,aAAa;AACjD,YAAA,SAAS,MAAM,cAAc,QAAsB,EAAE,GAAG,KAAK,gBAAgB;AACxE,iBAAA,KAAK,OAAO,MAAa;AAAA,IAAA;AAGtC,cAAU,MAAM;;AACd,wBAAY,UAAZ,mBAAmB,cAAe,iBAAiB,UAAU,gBAAgB;AAC7E,sBAAgB,MAAM;;AACpB,SAAAA,MAAA,YAAY,UAAZ,gBAAAA,IAAmB,cAAe,oBAAoB,UAAU;AAAA,MAAc,CAC/E;AAED,iBAAW,WAAW;AAAA,QACpB,SAAS;AAAA,QACT,UAAU;AAAA,UACR,EAAE,eAAe,cAAc,gBAAgB,EAAE,KAAK,6GAA6G,IAAI,IAAI;AAAA,UAC3K,EAAE,eAAe,cAAc,gBAAgB,EAAE,KAAK,6GAA6G,IAAI,IAAI;AAAA,QAC7K;AAAA,MAAA,CACD;AAAA,IAAA,CAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { defineComponent, h } from "vue";
|
|
2
|
+
import { useVisualPageEditor } from "./index.js";
|
|
3
|
+
const BlockRender = defineComponent({
|
|
4
|
+
name: "BlockRender",
|
|
5
|
+
emits: ["click"],
|
|
6
|
+
props: {
|
|
7
|
+
node: { type: Object },
|
|
8
|
+
parent: { type: Object },
|
|
9
|
+
index: { type: Number },
|
|
10
|
+
active: { type: Boolean }
|
|
11
|
+
},
|
|
12
|
+
setup: (props, { emit }) => {
|
|
13
|
+
const { PageEditor } = useVisualPageEditor();
|
|
14
|
+
return () => {
|
|
15
|
+
const content = props.node;
|
|
16
|
+
const module = PageEditor.findModule(content.componentInfo);
|
|
17
|
+
if (module != null) {
|
|
18
|
+
const vnode = typeof module.component === "function" ? module.component(content.componentProps) : h(module.component, content.componentProps);
|
|
19
|
+
return h("div", { class: "mk-visual-page-editor__stage_block" }, [
|
|
20
|
+
vnode,
|
|
21
|
+
h("div", {
|
|
22
|
+
class: { "mk-visual-page-editor__stage_block_mask": true, active: props.active },
|
|
23
|
+
onClick: (ev) => {
|
|
24
|
+
emit("click", { node: content, options: module, index: props.index, parent: props.parent, event: ev });
|
|
25
|
+
}
|
|
26
|
+
})
|
|
27
|
+
]);
|
|
28
|
+
} else {
|
|
29
|
+
return h("div", { class: "mk-visual-page-editor__stage_block" }, [
|
|
30
|
+
`未知的模块【${content.componentInfo}】!请注册!`
|
|
31
|
+
]);
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
export {
|
|
37
|
+
BlockRender as default
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=BlockRender.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BlockRender.js","sources":["../../../../../../src/components/basic/visual-page-editor/core/BlockRender.ts"],"sourcesContent":["import { defineComponent,defineProps,defineEmits,computed,ref,onMounted,watch,h,type Component } from \"vue\"\r\nimport { ContentBlockType } from \"./ContentConfig\"\r\nimport { useVisualPageEditor } from \".\"\r\n\r\nexport default defineComponent({\r\n name:\"BlockRender\",\r\n emits:[\"click\"],\r\n props:{\r\n node:{type:Object},\r\n parent:{type:Object},\r\n index:{type:Number},\r\n active:{type:Boolean}\r\n },\r\n setup:(props,{ emit })=>{\r\n\r\n const { PageEditor } = useVisualPageEditor();\r\n\r\n return ()=>{\r\n\r\n const content = props.node as ContentBlockType;\r\n const module = PageEditor.findModule(content.componentInfo);\r\n\r\n if(module != null){\r\n\r\n const vnode = typeof module.component === \"function\" ? (module.component as any)(content.componentProps) : h(module.component,content.componentProps);\r\n\r\n return h(\"div\",{class:\"mk-visual-page-editor__stage_block\"},[\r\n vnode,\r\n h(\"div\",{ \r\n class:{\"mk-visual-page-editor__stage_block_mask\":true,active:props.active},\r\n onClick:ev=>{\r\n emit(\"click\",{ node:content,options:module,index:props.index,parent:props.parent,event:ev })\r\n }\r\n })\r\n ])\r\n }\r\n else{\r\n return h(\"div\",{class:\"mk-visual-page-editor__stage_block\"},[\r\n `未知的模块【${content.componentInfo}】!请注册!`\r\n ])\r\n }\r\n\r\n \r\n }\r\n }\r\n});\r\n"],"names":[],"mappings":";;AAIA,MAAA,cAAe,gBAAgB;AAAA,EAC7B,MAAK;AAAA,EACL,OAAM,CAAC,OAAO;AAAA,EACd,OAAM;AAAA,IACJ,MAAK,EAAC,MAAK,OAAM;AAAA,IACjB,QAAO,EAAC,MAAK,OAAM;AAAA,IACnB,OAAM,EAAC,MAAK,OAAM;AAAA,IAClB,QAAO,EAAC,MAAK,QAAO;AAAA,EACtB;AAAA,EACA,OAAM,CAAC,OAAM,EAAE,WAAS;AAEhB,UAAA,EAAE,eAAe;AAEvB,WAAO,MAAI;AAET,YAAM,UAAU,MAAM;AACtB,YAAM,SAAS,WAAW,WAAW,QAAQ,aAAa;AAE1D,UAAG,UAAU,MAAK;AAEhB,cAAM,QAAQ,OAAO,OAAO,cAAc,aAAc,OAAO,UAAkB,QAAQ,cAAc,IAAI,EAAE,OAAO,WAAU,QAAQ,cAAc;AAEpJ,eAAO,EAAE,OAAM,EAAC,OAAM,wCAAsC;AAAA,UAC1D;AAAA,UACA,EAAE,OAAM;AAAA,YACN,OAAM,EAAC,2CAA0C,MAAK,QAAO,MAAM,OAAM;AAAA,YACzE,SAAQ,CAAI,OAAA;AACV,mBAAK,SAAQ,EAAE,MAAK,SAAQ,SAAQ,QAAO,OAAM,MAAM,OAAM,QAAO,MAAM,QAAO,OAAM,IAAI;AAAA,YAC7F;AAAA,UAAA,CACD;AAAA,QAAA,CACF;AAAA,MAAA,OAEC;AACF,eAAO,EAAE,OAAM,EAAC,OAAM,wCAAsC;AAAA,UAC3D,SAAS,QAAQ,aAAa;AAAA,QAAA,CAC9B;AAAA,MACH;AAAA,IAAA;AAAA,EAIJ;AACF,CAAC;"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { ref, createVNode, Fragment, createTextVNode } from "vue";
|
|
2
|
+
import { Dialoger } from "@maketribe/dm";
|
|
3
|
+
import { ElInput, ElCollapse, ElCollapseItem, ElButton } from "element-plus";
|
|
4
|
+
import { showDynamicFormDialoger } from "../../dynamic-form-panel/dialog.js";
|
|
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";
|
|
22
|
+
import "./index.js";
|
|
23
|
+
const showEditPanel = async (moduleOptons, props) => {
|
|
24
|
+
return await showDynamicFormDialoger(moduleOptons.title, moduleOptons.options, props);
|
|
25
|
+
};
|
|
26
|
+
const showModuleSelectPanel = async () => {
|
|
27
|
+
return new Promise((resolve) => {
|
|
28
|
+
const selectComponentOption = ref(null);
|
|
29
|
+
const handleCancelClick = () => {
|
|
30
|
+
dialogInstance.destroy();
|
|
31
|
+
};
|
|
32
|
+
const handleConfirmClick = () => {
|
|
33
|
+
dialogInstance.destroy();
|
|
34
|
+
resolve(selectComponentOption.value);
|
|
35
|
+
};
|
|
36
|
+
const dialogInstance = Dialoger.customRender({
|
|
37
|
+
title: "模块库",
|
|
38
|
+
class: "mk-html-editor-dialog",
|
|
39
|
+
width: "70%",
|
|
40
|
+
onClose: () => {
|
|
41
|
+
dialogInstance.destroy();
|
|
42
|
+
},
|
|
43
|
+
body: () => {
|
|
44
|
+
return createVNode("div", null, [createVNode(ElInput, null, null), createVNode(ElCollapse, null, {
|
|
45
|
+
default: () => [createVNode(ElCollapseItem, {
|
|
46
|
+
"title": "基础模块",
|
|
47
|
+
"name": "base"
|
|
48
|
+
}, null), createVNode(ElCollapseItem, {
|
|
49
|
+
"title": "业务模块",
|
|
50
|
+
"name": "business"
|
|
51
|
+
}, null), createVNode(ElCollapseItem, {
|
|
52
|
+
"title": "自定义模块",
|
|
53
|
+
"name": "custom"
|
|
54
|
+
}, null)]
|
|
55
|
+
})]);
|
|
56
|
+
},
|
|
57
|
+
footer: () => {
|
|
58
|
+
return createVNode(Fragment, null, [createVNode(ElButton, {
|
|
59
|
+
"onClick": handleCancelClick
|
|
60
|
+
}, {
|
|
61
|
+
default: () => [createTextVNode("取消")]
|
|
62
|
+
}), createVNode(ElButton, {
|
|
63
|
+
"type": "primary",
|
|
64
|
+
"onClick": handleConfirmClick
|
|
65
|
+
}, {
|
|
66
|
+
default: () => [createTextVNode("确定")]
|
|
67
|
+
})]);
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
};
|
|
72
|
+
export {
|
|
73
|
+
showEditPanel,
|
|
74
|
+
showModuleSelectPanel
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=Dialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Dialog.js","sources":["../../../../../../src/components/basic/visual-page-editor/core/Dialog.tsx"],"sourcesContent":["\r\nimport { Fragment, ref, unref, resolveComponent, h, reactive } from 'vue'\r\nimport { Dialoger } from '@maketribe/dm'\r\nimport { ElButton, ElForm, ElFormItem, ElCollapse, ElCollapseItem, ElInput } from \"element-plus\";\r\nimport { ModuleType } from \"./ModuleDefine\"\r\nimport { showDynamicFormDialoger } from \"../../dynamic-form-panel\"\r\nimport { useVisualPageEditor } from \".\"\r\n\r\n/**\r\n * \r\n * @param data \r\n * @param props \r\n * @returns \r\n */\r\nexport const showEditPanel = async (moduleOptons: ModuleType, props: any) => {\r\n\r\n return await showDynamicFormDialoger(moduleOptons.title,moduleOptons.options,props)\r\n}\r\n\r\n/**\r\n * \r\n * @param data \r\n * @param props \r\n * @returns \r\n */\r\nexport const showModuleSelectPanel = async () => {\r\n return new Promise(resolve => {\r\n\r\n const { PageEditor } = useVisualPageEditor();\r\n\r\n const selectComponentOption = ref(null);\r\n\r\n // 取消编辑\r\n const handleCancelClick = () => {\r\n dialogInstance.destroy();\r\n };\r\n\r\n // 确认编辑\r\n const handleConfirmClick = () => {\r\n dialogInstance.destroy();\r\n resolve(selectComponentOption.value);\r\n };\r\n\r\n const dialogInstance = Dialoger.customRender({\r\n title: \"模块库\",\r\n class: \"mk-html-editor-dialog\",\r\n width: \"70%\",\r\n onClose: () => {\r\n dialogInstance.destroy();\r\n },\r\n body: () => {\r\n return <div>\r\n <ElInput />\r\n <ElCollapse>\r\n <ElCollapseItem title=\"基础模块\" name=\"base\">\r\n\r\n </ElCollapseItem>\r\n <ElCollapseItem title=\"业务模块\" name=\"business\">\r\n\r\n </ElCollapseItem>\r\n <ElCollapseItem title=\"自定义模块\" name=\"custom\">\r\n\r\n </ElCollapseItem>\r\n </ElCollapse>\r\n </div>\r\n },\r\n footer: () => {\r\n return <Fragment>\r\n <ElButton onClick={handleCancelClick}>取消</ElButton>\r\n <ElButton type=\"primary\" onClick={handleConfirmClick}>\r\n 确定\r\n </ElButton>\r\n </Fragment>\r\n },\r\n });\r\n });\r\n}\r\n"],"names":["showEditPanel","moduleOptons","props","showDynamicFormDialoger","title","options","showModuleSelectPanel","Promise","resolve","selectComponentOption","ref","handleCancelClick","dialogInstance","destroy","handleConfirmClick","value","Dialoger","customRender","class","width","onClose","body","_createVNode","ElInput","ElCollapse","default","ElCollapseItem","footer","_Fragment","ElButton","_createTextVNode"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAcO,MAAMA,gBAAgB,OAAOC,cAA0BC,UAAe;AAE3E,SAAO,MAAMC,wBAAwBF,aAAaG,OAAMH,aAAaI,SAAQH,KAAK;AACpF;AAQaI,MAAAA,wBAAwB,YAAY;AAC/C,SAAO,IAAIC,QAAQC,aAAW;AAI5B,UAAMC,wBAAwBC,IAAI,IAAI;AAGtC,UAAMC,oBAAoBA,MAAM;AAC9BC,qBAAeC,QAAO;AAAA;AAIxB,UAAMC,qBAAqBA,MAAM;AAC/BF,qBAAeC,QAAO;AACtBL,cAAQC,sBAAsBM,KAAK;AAAA;AAGrC,UAAMH,iBAAiBI,SAASC,aAAa;AAAA,MAC3Cb,OAAO;AAAA,MACPc,OAAO;AAAA,MACPC,OAAO;AAAA,MACPC,SAASA,MAAM;AACbR,uBAAeC,QAAO;AAAA,MACvB;AAAA,MACDQ,MAAMA,MAAM;AACV,eAAAC,0BAAAA,YAAAC,SAAAD,MAAAA,IAAAA,GAAAA,YAAAE,YAAA,MAAA;AAAA,UAAAC,SAAAA,MAAAH,CAAAA,YAAAI,gBAAA;AAAA,YAAA,SAAA;AAAA,YAAA,QAAA;AAAA,aAAAJ,IAAAA,GAAAA,YAAAI,gBAAA;AAAA,YAAA,SAAA;AAAA,YAAA,QAAA;AAAA,aAAAJ,IAAAA,GAAAA,YAAAI,gBAAA;AAAA,YAAA,SAAA;AAAA,YAAA,QAAA;AAAA,UAAA,GAAA,IAAA,CAAA;AAAA,QAAA,CAAA,CAAA,CAAA;AAAA,MAcD;AAAA,MACDC,QAAQA,MAAM;AACZ,eAAAL,YAAAM,UAAAN,MAAAA,CAAAA,YAAAO,UAAA;AAAA,UAAA,WACqBlB;AAAAA,QAAiB,GAAA;AAAA,UAAAc,SAAAA,MAAA,CAAAK,gBAAA,IAAA,CAAA;AAAA,SAAAR,GAAAA,YAAAO,UAAA;AAAA,UAAA,QAAA;AAAA,UAAA,WACFf;AAAAA,QAAkB,GAAA;AAAA,UAAAW,SAAAA,MAAA,CAAAK,gBAAA,IAAA,CAAA;AAAA,QAAA,CAAA,CAAA,CAAA;AAAA,MAIxD;AAAA,IACF,CAAC;AAAA,EACH,CAAC;AACH;"}
|
|
@@ -1,13 +1,73 @@
|
|
|
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 {
|
|
4
|
+
import { reactive } from "vue";
|
|
5
5
|
class VisualPageEditor {
|
|
6
6
|
constructor() {
|
|
7
7
|
__publicField(this, "_version");
|
|
8
8
|
__publicField(this, "_content");
|
|
9
|
+
__publicField(this, "_modules");
|
|
9
10
|
this._version = "1.0.0";
|
|
10
11
|
this._content = null;
|
|
12
|
+
this._modules = [];
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* 模块列表
|
|
16
|
+
*/
|
|
17
|
+
get baseModuleList() {
|
|
18
|
+
return this._modules.filter((itme) => itme.group == "base");
|
|
19
|
+
}
|
|
20
|
+
get businessModuleList() {
|
|
21
|
+
return this._modules.filter((itme) => itme.group == "business");
|
|
22
|
+
}
|
|
23
|
+
get customModuleList() {
|
|
24
|
+
return this._modules.filter((itme) => itme.group == "custom");
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* 注册基础模块
|
|
28
|
+
* @param name
|
|
29
|
+
* @param title
|
|
30
|
+
* @param component
|
|
31
|
+
* @param options
|
|
32
|
+
*/
|
|
33
|
+
registerBaseModule(name, title, component, options) {
|
|
34
|
+
if (this._modules.find((m) => m.name == name)) {
|
|
35
|
+
throw new Error(`重复的模块【${title}】`);
|
|
36
|
+
}
|
|
37
|
+
this._modules.push({ name, title, group: "base", component, options });
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* 注册业务模块
|
|
41
|
+
* @param name
|
|
42
|
+
* @param title
|
|
43
|
+
* @param component
|
|
44
|
+
* @param options
|
|
45
|
+
*/
|
|
46
|
+
registerBusinessModule(name, title, component, options) {
|
|
47
|
+
if (this._modules.find((m) => m.name == name)) {
|
|
48
|
+
throw new Error(`重复的模块【${title}】`);
|
|
49
|
+
}
|
|
50
|
+
this._modules.push({ name, title, group: "business", component, options });
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* 注册自定义模块
|
|
54
|
+
* @param name
|
|
55
|
+
* @param title
|
|
56
|
+
* @param component
|
|
57
|
+
* @param options
|
|
58
|
+
*/
|
|
59
|
+
registerCustomModule(name, title, component, options) {
|
|
60
|
+
if (this._modules.find((m) => m.name == name)) {
|
|
61
|
+
throw new Error(`重复的模块【${title}】`);
|
|
62
|
+
}
|
|
63
|
+
this._modules.push({ name, title, group: "custom", component, options });
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* 查找
|
|
67
|
+
* @param name
|
|
68
|
+
*/
|
|
69
|
+
findModule(name) {
|
|
70
|
+
return this._modules.find((m) => m.name == name);
|
|
11
71
|
}
|
|
12
72
|
/**
|
|
13
73
|
* 内容大小
|
|
@@ -40,7 +100,7 @@ class VisualPageEditor {
|
|
|
40
100
|
* @param content
|
|
41
101
|
*/
|
|
42
102
|
setContent(content) {
|
|
43
|
-
this._content =
|
|
103
|
+
this._content = reactive(content);
|
|
44
104
|
}
|
|
45
105
|
/**
|
|
46
106
|
* 获取内容
|
|
@@ -50,6 +110,17 @@ class VisualPageEditor {
|
|
|
50
110
|
var _a;
|
|
51
111
|
return (_a = this._content) == null ? void 0 : _a.contents[index];
|
|
52
112
|
}
|
|
113
|
+
/**
|
|
114
|
+
* 获取内容
|
|
115
|
+
* @returns
|
|
116
|
+
*/
|
|
117
|
+
edit(index, data) {
|
|
118
|
+
var _a;
|
|
119
|
+
if ((_a = this._content) == null ? void 0 : _a.contents[index]) {
|
|
120
|
+
this._content.contents[index].componentProps = data;
|
|
121
|
+
console.log(this._content);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
53
124
|
/**
|
|
54
125
|
* 获取内容
|
|
55
126
|
* @returns
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VisvalPageEditor.js","sources":["../../../../../../src/components/basic/visual-page-editor/core/VisvalPageEditor.ts"],"sourcesContent":["import { type ContentConfigType,type ContentBlockType } from \"./ContentConfig\"\r\
|
|
1
|
+
{"version":3,"file":"VisvalPageEditor.js","sources":["../../../../../../src/components/basic/visual-page-editor/core/VisvalPageEditor.ts"],"sourcesContent":["import { DynamicFormItemType } from \"../../dynamic-form-panel\"\r\nimport { type ContentConfigType,type ContentBlockType } from \"./ContentConfig\"\r\nimport { ModuleType } from \"./ModuleDefine\"\r\nimport { Component, VNode,reactive } from \"vue\"\r\n\r\n\r\n/**\r\n * 页面编辑器\r\n */\r\nexport default class VisualPageEditor{\r\n\r\n _version:string\r\n _content: ContentConfigType|null\r\n _modules:ModuleType[];\r\n\r\n constructor(){\r\n this._version = \"1.0.0\"\r\n this._content = null;\r\n this._modules = [];\r\n }\r\n\r\n /**\r\n * 模块列表\r\n */\r\n get baseModuleList(){\r\n return this._modules.filter(itme=>itme.group == \"base\");\r\n }\r\n get businessModuleList(){\r\n return this._modules.filter(itme=>itme.group == \"business\");\r\n }\r\n get customModuleList(){\r\n return this._modules.filter(itme=>itme.group == \"custom\");\r\n }\r\n /**\r\n * 注册基础模块\r\n * @param name \r\n * @param title \r\n * @param component \r\n * @param options \r\n */\r\n registerBaseModule(name : string, title : string, component: Component|((props:unknown)=>VNode), options:DynamicFormItemType[]){\r\n if(this._modules.find(m=>m.name == name)){\r\n throw new Error(`重复的模块【${title}】`);\r\n }\r\n this._modules.push({ name,title,group:\"base\",component,options });\r\n }\r\n\r\n /**\r\n * 注册业务模块\r\n * @param name \r\n * @param title \r\n * @param component \r\n * @param options \r\n */\r\n registerBusinessModule(name : string, title : string, component: Component|((props:unknown)=>VNode), options:DynamicFormItemType[]){\r\n if(this._modules.find(m=>m.name == name)){\r\n throw new Error(`重复的模块【${title}】`);\r\n }\r\n this._modules.push({ name,title,group:\"business\",component,options });\r\n }\r\n\r\n /**\r\n * 注册自定义模块\r\n * @param name \r\n * @param title \r\n * @param component \r\n * @param options \r\n */\r\n registerCustomModule(name : string, title : string, component: Component|((props:unknown)=>VNode), options:DynamicFormItemType[]){\r\n if(this._modules.find(m=>m.name == name)){\r\n throw new Error(`重复的模块【${title}】`);\r\n }\r\n this._modules.push({ name,title,group:\"custom\",component,options });\r\n }\r\n /**\r\n * 查找\r\n * @param name \r\n */\r\n findModule(name:string):ModuleType|null|undefined{\r\n return this._modules.find(m=>m.name == name)\r\n }\r\n\r\n /**\r\n * 内容大小\r\n * @returns \r\n */\r\n size(){\r\n return this._content?.contents.length as number;\r\n }\r\n\r\n /**\r\n * 删除\r\n * @param index \r\n */\r\n remove(index:number){\r\n this._content?.contents.splice(index,1)\r\n }\r\n\r\n /**\r\n * 交换\r\n * @param index \r\n * @param exchangeIndex \r\n */\r\n exchange(index:number,exchangeIndex:number){\r\n const item = this._content?.contents.splice(index,1)\r\n this._content?.contents.splice(exchangeIndex,0,item![0])\r\n }\r\n\r\n /**\r\n * 设置内容\r\n * @param content \r\n */\r\n setContent(content:ContentConfigType){\r\n this._content = reactive(content);\r\n }\r\n\r\n /**\r\n * 获取内容\r\n * @returns \r\n */\r\n get(index:number):ContentBlockType {\r\n return this._content?.contents[index] as ContentBlockType;\r\n }\r\n /**\r\n * 获取内容\r\n * @returns \r\n */\r\n edit(index:number,data:object) {\r\n if(this._content?.contents[index]){\r\n this._content.contents[index].componentProps = data;\r\n console.log(this._content);\r\n }\r\n }\r\n /**\r\n * 获取内容\r\n * @returns \r\n */\r\n getContent():ContentConfigType {\r\n return this._content || {version:this._version ,contents:[]}\r\n }\r\n\r\n}\r\n"],"names":[],"mappings":";;;;AASA,MAAqB,iBAAgB;AAAA,EAMnC,cAAa;AAJb;AACA;AACA;AAGE,SAAK,WAAW;AAChB,SAAK,WAAW;AAChB,SAAK,WAAW;EAClB;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,iBAAgB;AAClB,WAAO,KAAK,SAAS,OAAO,CAAM,SAAA,KAAK,SAAS,MAAM;AAAA,EACxD;AAAA,EACA,IAAI,qBAAoB;AACtB,WAAO,KAAK,SAAS,OAAO,CAAM,SAAA,KAAK,SAAS,UAAU;AAAA,EAC5D;AAAA,EACA,IAAI,mBAAkB;AACpB,WAAO,KAAK,SAAS,OAAO,CAAM,SAAA,KAAK,SAAS,QAAQ;AAAA,EAC1D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,mBAAmB,MAAe,OAAgB,WAA+C,SAA8B;AAC7H,QAAG,KAAK,SAAS,KAAK,OAAG,EAAE,QAAQ,IAAI,GAAE;AACvC,YAAM,IAAI,MAAM,SAAS,KAAK,GAAG;AAAA,IACnC;AACK,SAAA,SAAS,KAAK,EAAE,MAAK,OAAM,OAAM,QAAO,WAAU,QAAA,CAAS;AAAA,EAClE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,uBAAuB,MAAe,OAAgB,WAA+C,SAA8B;AACjI,QAAG,KAAK,SAAS,KAAK,OAAG,EAAE,QAAQ,IAAI,GAAE;AACvC,YAAM,IAAI,MAAM,SAAS,KAAK,GAAG;AAAA,IACnC;AACK,SAAA,SAAS,KAAK,EAAE,MAAK,OAAM,OAAM,YAAW,WAAU,QAAA,CAAS;AAAA,EACtE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,qBAAqB,MAAe,OAAgB,WAA+C,SAA8B;AAC/H,QAAG,KAAK,SAAS,KAAK,OAAG,EAAE,QAAQ,IAAI,GAAE;AACvC,YAAM,IAAI,MAAM,SAAS,KAAK,GAAG;AAAA,IACnC;AACK,SAAA,SAAS,KAAK,EAAE,MAAK,OAAM,OAAM,UAAS,WAAU,QAAA,CAAS;AAAA,EACpE;AAAA;AAAA;AAAA;AAAA;AAAA,EAKA,WAAW,MAAsC;AAC/C,WAAO,KAAK,SAAS,KAAK,CAAG,MAAA,EAAE,QAAQ,IAAI;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAM;;AACG,YAAA,UAAK,aAAL,mBAAe,SAAS;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,OAAa;;AAClB,eAAK,aAAL,mBAAe,SAAS,OAAO,OAAM;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,SAAS,OAAa,eAAqB;;AACzC,UAAM,QAAO,UAAK,aAAL,mBAAe,SAAS,OAAO,OAAM;AAClD,eAAK,aAAL,mBAAe,SAAS,OAAO,eAAc,GAAE,KAAM,CAAC;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,WAAW,SAA0B;AAC9B,SAAA,WAAW,SAAS,OAAO;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,IAAI,OAA+B;;AAC1B,YAAA,UAAK,aAAL,mBAAe,SAAS;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA,EAKA,KAAK,OAAa,MAAa;;AAC7B,SAAG,UAAK,aAAL,mBAAe,SAAS,QAAO;AAChC,WAAK,SAAS,SAAS,KAAK,EAAE,iBAAiB;AACvC,cAAA,IAAI,KAAK,QAAQ;AAAA,IAC3B;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAKA,aAA+B;AACtB,WAAA,KAAK,YAAY,EAAC,SAAQ,KAAK,UAAU,UAAS,CAAA;EAC3D;AAEF;"}
|
|
@@ -1,22 +1,30 @@
|
|
|
1
1
|
import { shallowReactive, ref } from "vue";
|
|
2
2
|
import VisualPageEditor from "./VisvalPageEditor.js";
|
|
3
|
-
|
|
3
|
+
import "@maketribe/dm";
|
|
4
|
+
import "element-plus";
|
|
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
|
const PageEditor = shallowReactive(new VisualPageEditor());
|
|
5
23
|
const ViewDevice = ref("pc");
|
|
6
|
-
const
|
|
7
|
-
RenderComponents.push(options);
|
|
8
|
-
};
|
|
9
|
-
const useRenderComponent = () => {
|
|
10
|
-
return {
|
|
11
|
-
RenderComponents,
|
|
12
|
-
RegisterRenderComponent
|
|
13
|
-
};
|
|
14
|
-
};
|
|
15
|
-
const usePageEditor = () => {
|
|
24
|
+
const useVisualPageEditor = () => {
|
|
16
25
|
return { PageEditor, ViewDevice };
|
|
17
26
|
};
|
|
18
27
|
export {
|
|
19
|
-
|
|
20
|
-
useRenderComponent
|
|
28
|
+
useVisualPageEditor
|
|
21
29
|
};
|
|
22
30
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../../../../src/components/basic/visual-page-editor/core/index.ts"],"sourcesContent":["\r\nimport { shallowReactive,ref } from \"vue\"\r\n\r\nimport
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../../src/components/basic/visual-page-editor/core/index.ts"],"sourcesContent":["\r\nimport { shallowReactive,ref } from \"vue\"\r\n\r\nimport VisualPageEditor from \"./VisvalPageEditor\"\r\n\r\n// 页面编辑器\r\nconst PageEditor = shallowReactive<VisualPageEditor>(new VisualPageEditor())\r\n\r\n// pc | mobile\r\nconst ViewDevice = ref('pc')\r\n\r\n\r\nexport * from \"./Dialog\"\r\n\r\n/**\r\n * \r\n * @returns \r\n */\r\nexport const useVisualPageEditor = ()=>{\r\n return { PageEditor, ViewDevice }\r\n}\r\n\r\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAMA,MAAM,aAAa,gBAAkC,IAAI,iBAAA,CAAkB;AAG3E,MAAM,aAAa,IAAI,IAAI;AASpB,MAAM,sBAAsB,MAAI;AAC9B,SAAA,EAAE,YAAY;AACvB;"}
|