@gct-paas/design 0.1.5-test.2 → 0.1.6-dev.0

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 (203) hide show
  1. package/dist/index.min.css +1 -1
  2. package/dist/loader.esm.min.js +1 -1
  3. package/es/components/design/design-content/design-content.css +76 -0
  4. package/es/components/design/design-content/design-content.d.ts +190 -0
  5. package/es/components/design/design-content/design-content.mjs +274 -0
  6. package/es/components/design/design-drag-item/design-drag-item.css +179 -0
  7. package/es/components/design/design-drag-item/design-drag-item.d.ts +56 -0
  8. package/es/components/design/design-drag-item/design-drag-item.mjs +237 -0
  9. package/es/components/design/design-drop-container/design-drop-container.css +103 -0
  10. package/es/components/design/design-drop-container/design-drop-container.d.ts +92 -0
  11. package/es/components/design/design-drop-container/design-drop-container.mjs +182 -0
  12. package/es/components/design/design-drop-line/design-drop-line.css +165 -0
  13. package/es/components/design/design-drop-line/design-drop-line.d.ts +73 -0
  14. package/es/components/design/design-drop-line/design-drop-line.mjs +136 -0
  15. package/es/components/design/design-item-actions/design-item-actions.css +97 -0
  16. package/es/components/design/design-item-actions/design-item-actions.d.ts +42 -0
  17. package/es/components/design/design-item-actions/design-item-actions.mjs +147 -0
  18. package/es/components/design/design-item-highlighter/design-item-highlighter.css +70 -0
  19. package/es/components/design/design-item-highlighter/design-item-highlighter.d.ts +168 -0
  20. package/es/components/design/design-item-highlighter/design-item-highlighter.mjs +155 -0
  21. package/es/components/design/design-item-highlighter-container/design-item-highlighter-container.css +85 -0
  22. package/es/components/design/design-item-highlighter-container/design-item-highlighter-container.d.ts +53 -0
  23. package/es/components/design/design-item-highlighter-container/design-item-highlighter-container.mjs +169 -0
  24. package/es/components/design/design-item-hover-title/design-item-hover-title.css +12 -0
  25. package/es/components/design/design-item-hover-title/design-item-hover-title.d.ts +60 -0
  26. package/es/components/design/design-item-hover-title/design-item-hover-title.mjs +60 -0
  27. package/es/components/design/design-item-preview/design-item-preview.css +91 -0
  28. package/es/components/design/design-item-preview/design-item-preview.d.ts +1 -0
  29. package/es/components/design/design-item-preview/design-item-preview.mjs +32 -0
  30. package/es/components/design/design-not-drag-item/design-not-drag-item.css +67 -0
  31. package/es/components/design/design-not-drag-item/design-not-drag-item.d.ts +50 -0
  32. package/es/components/design/design-not-drag-item/design-not-drag-item.mjs +68 -0
  33. package/es/components/design/design-not-found/design-not-found.css +68 -0
  34. package/es/components/design/design-not-found/design-not-found.d.ts +14 -0
  35. package/es/components/design/design-not-found/design-not-found.mjs +19 -0
  36. package/es/components/design/index.d.ts +2 -0
  37. package/es/components/design/index.mjs +2 -0
  38. package/es/components/design-save-tip/design-save-tip.mjs +1 -1
  39. package/es/components/editor/index.mjs +2 -0
  40. package/es/components/editor/length-unit-editor/length-unit-editor.vue.d.ts +13 -0
  41. package/es/components/editor/length-unit-editor/length-unit-editor.vue.mjs +5 -0
  42. package/es/components/editor/length-unit-editor/length-unit-editor.vue_vue_type_script_setup_true_name_length-unit-editor_lang.mjs +47 -0
  43. package/es/components/field-transfer/components/field-transfer-modal.vue.d.ts +5 -1
  44. package/es/components/field-transfer/components/field-transfer-modal.vue.mjs +2 -2
  45. package/es/components/field-transfer/components/field-transfer-modal.vue_vue_type_script_setup_true_name_field-transfer-modal_lang.mjs +2 -1
  46. package/es/components/field-transfer/components/field-transfer-modal.vue_vue_type_style_index_0_scoped_711e6992_lang.css +8 -0
  47. package/es/components/field-transfer/index.d.ts +2 -0
  48. package/es/components/field-transfer/index.mjs +1 -0
  49. package/es/components/index.d.ts +5 -2
  50. package/es/components/index.mjs +10 -2
  51. package/es/components/material/index.d.ts +1 -0
  52. package/es/components/material/index.mjs +1 -0
  53. package/es/components/material/material-content/material-content.css +86 -0
  54. package/es/components/material/material-content/material-content.d.ts +1 -0
  55. package/es/components/material/material-content/material-content.mjs +49 -0
  56. package/es/components/material/material-module/material-module.css +104 -0
  57. package/es/components/material/material-module/material-module.d.ts +60 -0
  58. package/es/components/material/material-module/material-module.mjs +67 -0
  59. package/es/components/material/material-module-drag-container/material-module-drag-container.css +69 -0
  60. package/es/components/material/material-module-drag-container/material-module-drag-container.d.ts +56 -0
  61. package/es/components/material/material-module-drag-container/material-module-drag-container.mjs +21 -0
  62. package/es/components/material/material-module-drag-item/material-module-drag-item.css +83 -0
  63. package/es/components/material/material-module-drag-item/material-module-drag-item.d.ts +13 -0
  64. package/es/components/material/material-module-drag-item/material-module-drag-item.mjs +66 -0
  65. package/es/components/material/material-outline-tree/material-outline-tree.css +81 -0
  66. package/es/components/material/material-outline-tree/material-outline-tree.d.ts +13 -0
  67. package/es/components/material/material-outline-tree/material-outline-tree.mjs +67 -0
  68. package/es/components/material/material-tab-pane/material-tab-pane.css +68 -0
  69. package/es/components/material/material-tab-pane/material-tab-pane.d.ts +13 -0
  70. package/es/components/material/material-tab-pane/material-tab-pane.mjs +19 -0
  71. package/es/components/material/material-tabs/material-tabs.css +105 -0
  72. package/es/components/material/material-tabs/material-tabs.d.ts +103 -0
  73. package/es/components/material/material-tabs/material-tabs.mjs +44 -0
  74. package/es/components/modal-name-editor/modal-name-editor.d.ts +1 -11
  75. package/es/components/modal-name-editor/modal-name-editor.mjs +27 -38
  76. package/es/components/multi-field/index.d.ts +2 -0
  77. package/es/components/multi-field/index.mjs +1 -0
  78. package/es/components/multi-field/multi-field-display.vue.d.ts +8 -0
  79. package/es/components/multi-field/multi-field-display.vue.mjs +7 -0
  80. package/es/components/multi-field/multi-field-display.vue_vue_type_script_setup_true_lang.mjs +32 -0
  81. package/es/components/multi-field/multi-field-display.vue_vue_type_style_index_0_scoped_802ade7b_lang.css +4 -0
  82. package/es/components/multi-field/multi-field-item.vue.d.ts +6 -0
  83. package/es/components/multi-field/multi-field-item.vue.mjs +7 -0
  84. package/es/components/multi-field/multi-field-item.vue_vue_type_script_setup_true_lang.mjs +47 -0
  85. package/es/components/multi-field/multi-field-item.vue_vue_type_style_index_0_scoped_881cb08e_lang.css +31 -0
  86. package/es/components/panel/index.d.ts +1 -0
  87. package/es/components/panel/index.mjs +1 -0
  88. package/es/components/panel/panel-content/panel-content.css +189 -0
  89. package/es/components/panel/panel-content/panel-content.d.ts +19 -0
  90. package/es/components/panel/panel-content/panel-content.mjs +48 -0
  91. package/es/components/panel/panel-form/panel-form.css +67 -0
  92. package/es/components/panel/panel-form/panel-form.d.ts +62 -0
  93. package/es/components/panel/panel-form/panel-form.mjs +59 -0
  94. package/es/components/panel/panel-path/panel-path.css +89 -0
  95. package/es/components/panel/panel-path/panel-path.d.ts +35 -0
  96. package/es/components/panel/panel-path/panel-path.mjs +52 -0
  97. package/es/components/user-occupy/user-occupy.vue.mjs +2 -2
  98. package/es/components/user-occupy/user-occupy.vue_vue_type_script_setup_true_lang.mjs +2 -2
  99. package/es/components/user-occupy/{user-occupy.vue_vue_type_style_index_0_scoped_24cb9749_lang.css → user-occupy.vue_vue_type_style_index_0_scoped_9b136922_lang.css} +6 -6
  100. package/es/controller/index.d.ts +1 -0
  101. package/es/controller/index.mjs +1 -0
  102. package/es/controller/view/design-view.controller.d.ts +48 -0
  103. package/es/controller/view/design-view.controller.mjs +150 -0
  104. package/es/create-app-vue.mjs +2 -0
  105. package/es/editor/content-tag-style/content-tag-style.css +164 -0
  106. package/es/editor/content-tag-style/content-tag-style.d.ts +112 -0
  107. package/es/editor/content-tag-style/content-tag-style.mjs +80 -0
  108. package/es/editor/content-tag-style/index.d.ts +8 -0
  109. package/es/editor/content-tag-style/index.mjs +11 -0
  110. package/es/editor/field-info-editor/field-info-editor.css +125 -0
  111. package/es/editor/field-info-editor/field-info-editor.d.ts +111 -0
  112. package/es/editor/field-info-editor/field-info-editor.mjs +38 -0
  113. package/es/editor/field-info-editor/index.d.ts +8 -0
  114. package/es/editor/field-info-editor/index.mjs +9 -0
  115. package/es/editor/index.d.ts +5 -0
  116. package/es/editor/index.mjs +19 -0
  117. package/es/editor/model-field-select/index.d.ts +8 -0
  118. package/es/editor/model-field-select/index.mjs +9 -0
  119. package/es/editor/model-field-select/model-field-select.css +148 -0
  120. package/es/editor/model-field-select/model-field-select.d.ts +42 -0
  121. package/es/editor/model-field-select/model-field-select.mjs +217 -0
  122. package/es/editor/style-border/index.d.ts +4 -0
  123. package/es/editor/style-border/index.mjs +11 -0
  124. package/es/editor/style-border/style-border.d.ts +35 -0
  125. package/es/editor/style-border/style-border.mjs +38 -0
  126. package/es/editor/style-font/index.d.ts +4 -0
  127. package/es/editor/style-font/index.mjs +11 -0
  128. package/es/editor/style-font/style-font.css +86 -0
  129. package/es/editor/style-font/style-font.d.ts +35 -0
  130. package/es/editor/style-font/style-font.mjs +36 -0
  131. package/es/editor/style-position/index.d.ts +4 -0
  132. package/es/editor/style-position/index.mjs +11 -0
  133. package/es/editor/style-position/style-position.d.ts +35 -0
  134. package/es/editor/style-position/style-position.mjs +35 -0
  135. package/es/editor/style-spacing/index.d.ts +4 -0
  136. package/es/editor/style-spacing/index.mjs +11 -0
  137. package/es/editor/style-spacing/style-spacing.d.ts +34 -0
  138. package/es/editor/style-spacing/style-spacing.mjs +60 -0
  139. package/es/hooks/design-view/designer/useDesignSave.mjs +3 -1
  140. package/es/hooks/design-view/layout/useToolkit.mjs +3 -3
  141. package/es/hooks/index.d.ts +2 -1
  142. package/es/hooks/index.mjs +3 -2
  143. package/es/hooks/use-design-view-controller/use-design-view-controller.d.ts +11 -0
  144. package/es/hooks/use-design-view-controller/use-design-view-controller.mjs +31 -0
  145. package/es/index.d.ts +5 -2
  146. package/es/index.mjs +24 -8
  147. package/es/interface/controller/i-design-view.controller.d.ts +3 -5
  148. package/es/interface/form-editor/child-list-editor/child-list-editor.d.ts +114 -0
  149. package/es/interface/form-editor/index.d.ts +9 -0
  150. package/es/interface/form-editor/style-border/i-style-border.controller.d.ts +11 -0
  151. package/es/interface/form-editor/style-border/i-style-border.d.ts +22 -0
  152. package/es/interface/form-editor/style-font/i-style-font.controller.d.ts +11 -0
  153. package/es/interface/form-editor/style-font/i-style-font.d.ts +13 -0
  154. package/es/interface/form-editor/style-position/i-style-position.controller.d.ts +11 -0
  155. package/es/interface/form-editor/style-position/i-style-position.d.ts +13 -0
  156. package/es/interface/form-editor/style-spacing/i-style-spacing.controller.d.ts +11 -0
  157. package/es/interface/form-editor/style-spacing/i-style-spacing.d.ts +22 -0
  158. package/es/interface/index.d.ts +2 -0
  159. package/es/interface/provider/i-node-provider.d.ts +140 -0
  160. package/es/locale/sys/app.d.ts +4 -0
  161. package/es/locale/sys/appDesigner.d.ts +5 -0
  162. package/es/locale/sys/cardDesign.d.ts +13 -0
  163. package/es/locale/sys/component.d.ts +19 -0
  164. package/es/locale/sys/model.d.ts +6 -0
  165. package/es/locale/sys/pageDesigner.d.ts +28 -0
  166. package/es/locale/sys/platform.d.ts +7 -0
  167. package/es/locale/sys.d.ts +22 -0
  168. package/es/provider/design-editor-node/design-editor-node.provider.d.ts +41 -0
  169. package/es/provider/design-editor-node/design-editor-node.provider.mjs +57 -0
  170. package/es/provider/index.d.ts +2 -0
  171. package/es/provider/index.mjs +2 -0
  172. package/es/provider/node-base/node-base.provider.d.ts +25 -0
  173. package/es/provider/node-base/node-base.provider.mjs +34 -0
  174. package/es/register/index.d.ts +1 -0
  175. package/es/register/index.mjs +1 -0
  176. package/es/register/node/node.register.d.ts +113 -0
  177. package/es/register/node/node.register.mjs +141 -0
  178. package/es/store/index.d.ts +1 -0
  179. package/es/store/index.mjs +1 -0
  180. package/es/store/view/design-view.store.d.ts +12 -0
  181. package/es/store/view/design-view.store.mjs +327 -0
  182. package/es/utils/can-drop/can-drop.d.ts +12 -0
  183. package/es/utils/can-drop/can-drop.mjs +48 -0
  184. package/es/utils/design-plugin-pkg-util/design-plugin-pkg-util.d.ts +1 -1
  185. package/es/utils/design-plugin-pkg-util/design-plugin-pkg-util.mjs +29 -1
  186. package/es/utils/expression/index.d.ts +1 -0
  187. package/es/utils/expression/index.mjs +43 -0
  188. package/es/utils/index.d.ts +2 -0
  189. package/es/utils/index.mjs +2 -0
  190. package/package.json +12 -11
  191. package/es/components/field-cascader/index.d.ts +0 -2
  192. package/es/components/field-cascader/index.mjs +0 -1
  193. package/es/components/field-cascader/src/FieldCascader.vue.d.ts +0 -87
  194. package/es/components/field-cascader/src/FieldCascader.vue.mjs +0 -6
  195. package/es/components/field-cascader/src/FieldCascader.vue_vue_type_script_setup_true_lang.mjs +0 -115
  196. package/es/components/field-cascader/src/FieldCascader.vue_vue_type_style_index_0_lang.css +0 -69
  197. package/es/components/field-cascader/src/SearchInput.vue.d.ts +0 -11
  198. package/es/components/field-cascader/src/SearchInput.vue.mjs +0 -7
  199. package/es/components/field-cascader/src/SearchInput.vue_vue_type_script_setup_true_lang.mjs +0 -38
  200. package/es/components/field-cascader/src/SearchInput.vue_vue_type_style_index_0_scoped_512c4b38_lang.css +0 -9
  201. package/es/components/field-cascader/src/hooks.d.ts +0 -129
  202. package/es/components/field-cascader/src/hooks.mjs +0 -163
  203. package/es/components/field-transfer/components/field-transfer-modal.vue_vue_type_style_index_0_scoped_0c9dd8a1_lang.css +0 -5
@@ -0,0 +1,67 @@
1
+ @charset "UTF-8";
2
+ /* stylelint-disable scss/no-global-function-names */
3
+ /* bem('block', 'element', 'modifier') => 'ibiz-block__element--modifier' */
4
+ /**
5
+ * 定义 Block 块
6
+ * @param {String} $block - Block 块名称
7
+ * @example
8
+ * @include b('button') {
9
+ * padding: 10px;
10
+ * }
11
+ */
12
+ /**
13
+ * 定义 Element 元素
14
+ * @param {String|List} $element - Element 元素名称,支持单个或多个
15
+ * @example
16
+ * @include b('button') {
17
+ * @include e('text') {
18
+ * color: #000;
19
+ * }
20
+ * }
21
+ * // 或传入多个元素
22
+ * @include b('button') {
23
+ * @include e(('text', 'icon')) {
24
+ * margin: 5px;
25
+ * }
26
+ * }
27
+ */
28
+ /**
29
+ * 定义 Modifier 修饰符
30
+ * @param {String|List} $modifier - Modifier 修饰符名称,支持单个或多个
31
+ * @example
32
+ * @include b('button') {
33
+ * @include m('primary') {
34
+ * background: blue;
35
+ * }
36
+ * }
37
+ * // 或传入多个修饰符
38
+ * @include b('button') {
39
+ * @include m(('primary', 'large')) {
40
+ * background: blue;
41
+ * font-size: 16px;
42
+ * }
43
+ * }
44
+ */
45
+ /**
46
+ * 定义状态选择器
47
+ * @param {String} $state - 状态名称
48
+ * @example
49
+ * @include b('button') {
50
+ * @include when('disabled') {
51
+ * opacity: 0.5;
52
+ * }
53
+ * }
54
+ */
55
+ /**
56
+ * 深色主题样式
57
+ * @param {String} $block - Block 块名称
58
+ * @example
59
+ * @include dark('button') {
60
+ * background: #333;
61
+ * color: #fff;
62
+ * }
63
+ */
64
+ /* stylelint-disable scss/no-global-function-names */
65
+ .gct-design-panel-form {
66
+ height: 100%;
67
+ }
@@ -0,0 +1,62 @@
1
+ import { PropType } from 'vue';
2
+ import { IEditForm } from '@gct-paas/core-web';
3
+ import { IDesignNode, IDesignNodeData } from '@gct-paas/schema';
4
+ export declare const PanelForm: import('vue').DefineComponent<import('vue').ExtractPropTypes<{
5
+ model: {
6
+ type: PropType<IEditForm>;
7
+ required: true;
8
+ };
9
+ node: {
10
+ type: PropType<IDesignNode>;
11
+ required: true;
12
+ };
13
+ context: {
14
+ type: PropType<IContext>;
15
+ default: () => {};
16
+ };
17
+ }>, {
18
+ ns: import('@gct-paas/core').Namespace;
19
+ data: import('vue').Ref<{
20
+ id: string;
21
+ order?: number | undefined;
22
+ label: string;
23
+ type: string;
24
+ updateDate: number;
25
+ data: {
26
+ [x: string]: any;
27
+ [x: symbol]: any;
28
+ name?: string | undefined;
29
+ };
30
+ parentId?: string | undefined;
31
+ clone: () => IDesignNode;
32
+ }, IDesignNode<IDesignNodeData> | {
33
+ id: string;
34
+ order?: number | undefined;
35
+ label: string;
36
+ type: string;
37
+ updateDate: number;
38
+ data: {
39
+ [x: string]: any;
40
+ [x: symbol]: any;
41
+ name?: string | undefined;
42
+ };
43
+ parentId?: string | undefined;
44
+ clone: () => IDesignNode;
45
+ }>;
46
+ formData: import('vue').WritableComputedRef<IDesignNodeData, IDesignNodeData>;
47
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<{
48
+ model: {
49
+ type: PropType<IEditForm>;
50
+ required: true;
51
+ };
52
+ node: {
53
+ type: PropType<IDesignNode>;
54
+ required: true;
55
+ };
56
+ context: {
57
+ type: PropType<IContext>;
58
+ default: () => {};
59
+ };
60
+ }>> & Readonly<{}>, {
61
+ context: IContext;
62
+ }, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
@@ -0,0 +1,59 @@
1
+ import { useDesignViewController } from "../../../hooks/use-design-view-controller/use-design-view-controller.mjs";
2
+ import "../../../hooks/index.mjs";
3
+ import './panel-form.css';/* empty css */
4
+ import { useNamespace } from "@gct-paas/core";
5
+ import { computed, createVNode, defineComponent, ref, resolveComponent } from "vue";
6
+ //#region src/components/panel/panel-form/panel-form.tsx
7
+ var PanelForm = /* @__PURE__ */ defineComponent({
8
+ name: "PanelForm",
9
+ props: {
10
+ model: {
11
+ type: Object,
12
+ required: true
13
+ },
14
+ node: {
15
+ type: Object,
16
+ required: true
17
+ },
18
+ context: {
19
+ type: Object,
20
+ default: () => {
21
+ return {};
22
+ }
23
+ }
24
+ },
25
+ setup(props) {
26
+ const ns = useNamespace("design-panel-form");
27
+ const c = useDesignViewController();
28
+ const data = ref(props.node);
29
+ return {
30
+ ns,
31
+ data,
32
+ formData: computed({
33
+ get() {
34
+ return data.value.data;
35
+ },
36
+ set(val) {
37
+ Object.assign(data.value.data, val);
38
+ console.debug("[ 保存的val ] >", data.value.data);
39
+ c.store.updateNode(data.value);
40
+ }
41
+ })
42
+ };
43
+ },
44
+ render() {
45
+ return createVNode("div", { "class": this.ns.b() }, [createVNode(resolveComponent("gct-edit-form"), {
46
+ "class": "h-full",
47
+ "embed": true,
48
+ "model": this.model,
49
+ "data": this.formData,
50
+ "onUpdate:data": ($event) => this.formData = $event,
51
+ "context": {
52
+ ...this.context,
53
+ id: void 0
54
+ }
55
+ }, null)]);
56
+ }
57
+ });
58
+ //#endregion
59
+ export { PanelForm };
@@ -0,0 +1,89 @@
1
+ @charset "UTF-8";
2
+ /* stylelint-disable scss/no-global-function-names */
3
+ /* bem('block', 'element', 'modifier') => 'ibiz-block__element--modifier' */
4
+ /**
5
+ * 定义 Block 块
6
+ * @param {String} $block - Block 块名称
7
+ * @example
8
+ * @include b('button') {
9
+ * padding: 10px;
10
+ * }
11
+ */
12
+ /**
13
+ * 定义 Element 元素
14
+ * @param {String|List} $element - Element 元素名称,支持单个或多个
15
+ * @example
16
+ * @include b('button') {
17
+ * @include e('text') {
18
+ * color: #000;
19
+ * }
20
+ * }
21
+ * // 或传入多个元素
22
+ * @include b('button') {
23
+ * @include e(('text', 'icon')) {
24
+ * margin: 5px;
25
+ * }
26
+ * }
27
+ */
28
+ /**
29
+ * 定义 Modifier 修饰符
30
+ * @param {String|List} $modifier - Modifier 修饰符名称,支持单个或多个
31
+ * @example
32
+ * @include b('button') {
33
+ * @include m('primary') {
34
+ * background: blue;
35
+ * }
36
+ * }
37
+ * // 或传入多个修饰符
38
+ * @include b('button') {
39
+ * @include m(('primary', 'large')) {
40
+ * background: blue;
41
+ * font-size: 16px;
42
+ * }
43
+ * }
44
+ */
45
+ /**
46
+ * 定义状态选择器
47
+ * @param {String} $state - 状态名称
48
+ * @example
49
+ * @include b('button') {
50
+ * @include when('disabled') {
51
+ * opacity: 0.5;
52
+ * }
53
+ * }
54
+ */
55
+ /**
56
+ * 深色主题样式
57
+ * @param {String} $block - Block 块名称
58
+ * @example
59
+ * @include dark('button') {
60
+ * background: #333;
61
+ * color: #fff;
62
+ * }
63
+ */
64
+ /* stylelint-disable scss/no-global-function-names */
65
+ .gct-design-panel-path {
66
+ display: flex;
67
+ align-items: center;
68
+ width: 100%;
69
+ height: 100%;
70
+ padding: 0 12px;
71
+ overflow: auto hidden;
72
+ font-size: 12px;
73
+ color: #797A7D;
74
+ white-space: nowrap;
75
+ border-bottom: 1px solid #E0E3EA;
76
+ }
77
+ .gct-design-panel-path__arrow {
78
+ padding: 0 6px;
79
+ }
80
+ .gct-design-panel-path__arrow > .iconfont {
81
+ font-size: 10px;
82
+ }
83
+
84
+ .gct-design-panel-path__item {
85
+ cursor: pointer;
86
+ }
87
+ .gct-design-panel-path__item:last-child {
88
+ color: #212528;
89
+ }
@@ -0,0 +1,35 @@
1
+ import { IDesignNode, IDesignNodeData } from '@gct-paas/schema';
2
+ export declare const PanelPath: import('vue').DefineComponent<{}, {
3
+ ns: import('@gct-paas/core').Namespace;
4
+ c: import('../../..').IDesignViewController;
5
+ rootRef: import('vue').Ref<HTMLDivElement | null, HTMLDivElement | null>;
6
+ paths: import('vue').Ref<{
7
+ id: string;
8
+ order?: number | undefined;
9
+ label: string;
10
+ type: string;
11
+ updateDate: number;
12
+ data: {
13
+ [x: string]: any;
14
+ [x: symbol]: any;
15
+ name?: string | undefined;
16
+ };
17
+ parentId?: string | undefined;
18
+ clone: () => IDesignNode;
19
+ }[], IDesignNode<IDesignNodeData>[] | {
20
+ id: string;
21
+ order?: number | undefined;
22
+ label: string;
23
+ type: string;
24
+ updateDate: number;
25
+ data: {
26
+ [x: string]: any;
27
+ [x: symbol]: any;
28
+ name?: string | undefined;
29
+ };
30
+ parentId?: string | undefined;
31
+ clone: () => IDesignNode;
32
+ }[]>;
33
+ onActive: (item: IDesignNode<IDesignNodeData> | null) => void;
34
+ onActivePage: () => void;
35
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
@@ -0,0 +1,52 @@
1
+ import { useDesignViewController } from "../../../hooks/use-design-view-controller/use-design-view-controller.mjs";
2
+ import "../../../hooks/index.mjs";
3
+ import './panel-path.css';/* empty css */
4
+ import { useNamespace } from "@gct-paas/core";
5
+ import { Fragment, createVNode, defineComponent, nextTick, ref, watch } from "vue";
6
+ //#region src/components/panel/panel-path/panel-path.tsx
7
+ var PanelPath = /* @__PURE__ */ defineComponent({
8
+ name: "PanelPath",
9
+ setup() {
10
+ const ns = useNamespace("design-panel-path");
11
+ const rootRef = ref(null);
12
+ const c = useDesignViewController();
13
+ const paths = ref([]);
14
+ watch(() => c.store.selected, (val) => {
15
+ if (val) paths.value = c.store.getPaths(val.id);
16
+ else paths.value = [];
17
+ });
18
+ watch(paths, () => {
19
+ nextTick(() => {
20
+ if (rootRef.value) rootRef.value.scrollTo(rootRef.value.scrollWidth, 0);
21
+ });
22
+ });
23
+ const onActive = (item) => {
24
+ c.store.setActive(item);
25
+ };
26
+ const onActivePage = () => {
27
+ c.store.setActive(c.store.pageNode);
28
+ };
29
+ return {
30
+ ns,
31
+ c,
32
+ rootRef,
33
+ paths,
34
+ onActive,
35
+ onActivePage
36
+ };
37
+ },
38
+ render() {
39
+ return createVNode("div", {
40
+ "ref": "rootRef",
41
+ "class": this.ns.b()
42
+ }, [createVNode("span", {
43
+ "class": this.ns.e("item"),
44
+ "onClick": this.onActivePage
45
+ }, [this.c.store.rootExpLabel]), this.paths.map((item) => createVNode(Fragment, null, [createVNode("span", { "class": this.ns.e("arrow") }, [createVNode("i", { "class": "iconfont icon-a-Rightarrow" }, null)]), createVNode("span", {
46
+ "class": this.ns.e("item"),
47
+ "onClick": () => this.onActive(item)
48
+ }, [item.label])]))]);
49
+ }
50
+ });
51
+ //#endregion
52
+ export { PanelPath };
@@ -1,7 +1,7 @@
1
1
  import _plugin_vue_export_helper_default from "../../_virtual/_plugin-vue_export-helper.mjs";
2
2
  import user_occupy_vue_vue_type_script_setup_true_lang_default from "./user-occupy.vue_vue_type_script_setup_true_lang.mjs";
3
- import './user-occupy.vue_vue_type_style_index_0_scoped_24cb9749_lang.css';/* empty css */
3
+ import './user-occupy.vue_vue_type_style_index_0_scoped_9b136922_lang.css';/* empty css */
4
4
  //#region src/components/user-occupy/user-occupy.vue
5
- var user_occupy_default = /* @__PURE__ */ _plugin_vue_export_helper_default(user_occupy_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-24cb9749"]]);
5
+ var user_occupy_default = /* @__PURE__ */ _plugin_vue_export_helper_default(user_occupy_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-9b136922"]]);
6
6
  //#endregion
7
7
  export { user_occupy_default as default };
@@ -17,9 +17,9 @@ var user_occupy_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ de
17
17
  return occupyInfo.value.occupyName.substring(0, 12) + "...";
18
18
  });
19
19
  return (_ctx, _cache) => {
20
- const _component_svg_icon = resolveComponent("svg-icon");
20
+ const _component_assets_svg_icon = resolveComponent("assets-svg-icon");
21
21
  return unref(occupyInfo).occupyId ? (openBlock(), createElementBlock("div", _hoisted_1, [
22
- createVNode(_component_svg_icon, { src: "/assets/design-view/icon_shejizhong.svg" }),
22
+ createVNode(_component_assets_svg_icon, { src: "/extras-assets/design-view/icon_shejizhong.svg" }),
23
23
  createTextVNode(" " + toDisplayString(unref(t)("sys.user")) + "\xA0", 1),
24
24
  createElementVNode("span", {
25
25
  class: "user-occupy__username",
@@ -1,25 +1,25 @@
1
- .gct-svg-icon[data-v-24cb9749] {
1
+ .gct-svg-icon[data-v-9b136922] {
2
2
  margin-right: 8px;
3
3
  font-size: 16px;
4
4
  }
5
- .user-occupy[data-v-24cb9749] {
5
+ .user-occupy[data-v-9b136922] {
6
6
  color: #fff;
7
7
  display: flex;
8
8
  align-items: center;
9
9
  line-height: 1em;
10
10
  font-size: 12px;
11
11
  }
12
- .user-occupy__username[data-v-24cb9749] {
12
+ .user-occupy__username[data-v-9b136922] {
13
13
  color: var(--ant-primary-color);
14
14
  display: inline-block;
15
15
  white-space: nowrap;
16
16
  overflow: hidden;
17
17
  vertical-align: bottom;
18
18
  }
19
- .user-occupy .iconfont[data-v-24cb9749] {
19
+ .user-occupy .iconfont[data-v-9b136922] {
20
20
  margin-right: 6px;
21
21
  }
22
- .designer-stage .user-occupy[data-v-24cb9749],
23
- .so-toolbar .user-occupy[data-v-24cb9749] {
22
+ .designer-stage .user-occupy[data-v-9b136922],
23
+ .so-toolbar .user-occupy[data-v-9b136922] {
24
24
  color: #5c616a;
25
25
  }
@@ -0,0 +1 @@
1
+ export { DesignViewController } from './view/design-view.controller';
@@ -0,0 +1 @@
1
+ import "./view/design-view.controller.mjs";
@@ -0,0 +1,48 @@
1
+ import { IDesignViewController } from '../../interface';
2
+ import { DesignViewHooks } from '../../hooks/designer.hooks';
3
+ import { IDesignNode } from '@gct-paas/schema';
4
+ import { IFormItemBasic } from '@gct-paas/core-web';
5
+ /**
6
+ * 设计界面控制器
7
+ *
8
+ * @author zhanghanrui
9
+ * @date 2024-07-05 14:07:35
10
+ * @export
11
+ * @class DesignViewController
12
+ * @implements {IDesignViewController}
13
+ */
14
+ export declare class DesignViewController implements IDesignViewController {
15
+ readonly store: import('pinia').Store<string, import('../..').IDesignViewState, IObject, import('../..').IDesignViewActions>;
16
+ readonly hooks: DesignViewHooks;
17
+ protected expansionTimer: number | null;
18
+ protected findModelPaths(paths: IFormItemBasic[], items: IFormItemBasic[], model: IFormItemBasic): IFormItemBasic[] | null;
19
+ /**
20
+ * 效验整个设计页面的表单数据
21
+ *
22
+ * @author zhanghanrui
23
+ * @date 2024-08-04 14:08:35
24
+ * @return {*} {Promise<boolean>}
25
+ */
26
+ validate(): Promise<boolean>;
27
+ /**
28
+ * 设置展开节点
29
+ *
30
+ * @param {string[]} ids 只指定自身需要额外设置的节点,默认会根据当前往上取3层展开
31
+ * @returns {*} {void}
32
+ */
33
+ setExpansion(ids: string[]): void;
34
+ /**
35
+ * 取消展开容器
36
+ */
37
+ cancelExpansion(): void;
38
+ /**
39
+ * 当前节点左右子节点类型
40
+ *
41
+ * @param {IDesignNode} node
42
+ * @returns {*} {string[]}
43
+ */
44
+ types(node: IDesignNode): string[];
45
+ mounted(): void;
46
+ unmounted(): void;
47
+ dropEnd(): void;
48
+ }
@@ -0,0 +1,150 @@
1
+ import { NodeRegister } from "../../register/node/node.register.mjs";
2
+ import "../../register/index.mjs";
3
+ import { useDesignViewStore } from "../../store/view/design-view.store.mjs";
4
+ import "../../store/index.mjs";
5
+ import { DesignViewHooks } from "../../hooks/designer.hooks.mjs";
6
+ import { isFunction } from "lodash-es";
7
+ import { h } from "vue";
8
+ import { EditFormController } from "@gct-paas/core-web";
9
+ import { message } from "ant-design-vue";
10
+ import AsyncValidator from "async-validator";
11
+ //#region src/controller/view/design-view.controller.ts
12
+ /**
13
+ * 设计界面控制器
14
+ *
15
+ * @author zhanghanrui
16
+ * @date 2024-07-05 14:07:35
17
+ * @export
18
+ * @class DesignViewController
19
+ * @implements {IDesignViewController}
20
+ */
21
+ var DesignViewController = class {
22
+ store = useDesignViewStore();
23
+ hooks = new DesignViewHooks();
24
+ expansionTimer = null;
25
+ findModelPaths(paths, items, model) {
26
+ if (items.findIndex((item) => {
27
+ const container = item;
28
+ if (container.children) {
29
+ if (this.findModelPaths(paths, container.children, model) !== null) {
30
+ paths.push(item);
31
+ return true;
32
+ }
33
+ return false;
34
+ }
35
+ if (item.name === model.name) return true;
36
+ return false;
37
+ }) !== -1) return paths;
38
+ return null;
39
+ }
40
+ /**
41
+ * 效验整个设计页面的表单数据
42
+ *
43
+ * @author zhanghanrui
44
+ * @date 2024-08-04 14:08:35
45
+ * @return {*} {Promise<boolean>}
46
+ */
47
+ async validate() {
48
+ const data = this.store.getData();
49
+ for (const node of data.nodes) {
50
+ const provider = NodeRegister.get(node.type, this.store.prefix);
51
+ if (provider) {
52
+ const model = provider.model;
53
+ if (model) {
54
+ const formC = new EditFormController(isFunction(model) ? model({}, node) : model);
55
+ Object.assign(formC.state.data, node.data);
56
+ formC.loaded();
57
+ formC.validate = async () => {
58
+ const rules = {};
59
+ const keys = Object.keys(formC.item);
60
+ for (const key of keys) {
61
+ const item = formC.item[key];
62
+ if (item.type === "item" && item.model.rules) rules[key] = item.model.rules;
63
+ }
64
+ if (rules && Object.keys(rules).length > 0) {
65
+ const validator = new AsyncValidator(rules);
66
+ validator.validate(formC.state.data);
67
+ return new Promise((resolve) => {
68
+ validator.validate(formC.state.data, (errors, _fields) => {
69
+ if (errors && errors.length > 0) {
70
+ const { field } = errors[0];
71
+ const c = formC.item[field];
72
+ const pathModels = this.findModelPaths([], formC.model.children, c.model)?.filter((_) => {
73
+ return _.title;
74
+ }).reverse();
75
+ console.log("pathModels", pathModels);
76
+ message.warn(h("span", {}, [h("span", {}, [`【${c.data.name}】组件 - 【${pathModels ? pathModels.map((_) => `${_.title} - `).join("") : null}${c.model.label}】必填`])]));
77
+ resolve(false);
78
+ } else resolve(true);
79
+ });
80
+ });
81
+ }
82
+ return true;
83
+ };
84
+ if (await formC.validate() !== true) return false;
85
+ }
86
+ }
87
+ }
88
+ return true;
89
+ }
90
+ /**
91
+ * 设置展开节点
92
+ *
93
+ * @param {string[]} ids 只指定自身需要额外设置的节点,默认会根据当前往上取3层展开
94
+ * @returns {*} {void}
95
+ */
96
+ setExpansion(ids) {
97
+ if (this.store.isDragging !== true) return;
98
+ if (this.expansionTimer) {
99
+ clearTimeout(this.expansionTimer);
100
+ this.expansionTimer = null;
101
+ }
102
+ this.expansionTimer = setTimeout(() => {
103
+ ids.forEach((id) => {
104
+ this.store.expansions.add(id);
105
+ });
106
+ const keys = this.hooks.expansion.callSync([]);
107
+ keys.slice(keys.length - 3).forEach((id) => {
108
+ this.store.expansions.add(id);
109
+ });
110
+ this.store.countAdd();
111
+ }, 2e3);
112
+ }
113
+ /**
114
+ * 取消展开容器
115
+ */
116
+ cancelExpansion() {
117
+ if (this.expansionTimer) {
118
+ clearTimeout(this.expansionTimer);
119
+ this.expansionTimer = null;
120
+ }
121
+ this.store.expansions.clear();
122
+ this.store.countAdd();
123
+ }
124
+ /**
125
+ * 当前节点左右子节点类型
126
+ *
127
+ * @param {IDesignNode} node
128
+ * @returns {*} {string[]}
129
+ */
130
+ types(node) {
131
+ const items = this.store.getChildren(node);
132
+ const types = [];
133
+ items.forEach((item) => {
134
+ types.push(item.type);
135
+ types.push(...this.types(item));
136
+ });
137
+ return types;
138
+ }
139
+ mounted() {}
140
+ unmounted() {
141
+ this.store.history.clearAll();
142
+ this.store.$reset();
143
+ }
144
+ dropEnd() {
145
+ this.cancelExpansion();
146
+ this.store.dropContainer = null;
147
+ }
148
+ };
149
+ //#endregion
150
+ export { DesignViewController };
@@ -1,4 +1,5 @@
1
1
  import components_default from "./components/index.mjs";
2
+ import editor_default from "./editor/index.mjs";
2
3
  //#region src/create-app-vue.ts
3
4
  /**
4
5
  * 创建 Vue 应用并配置全局错误处理
@@ -8,6 +9,7 @@ import components_default from "./components/index.mjs";
8
9
  */
9
10
  async function designCreateAppVue(app) {
10
11
  app.use(components_default);
12
+ app.use(editor_default);
11
13
  }
12
14
  //#endregion
13
15
  export { designCreateAppVue };