service-flow-designer 1.1.3 → 1.1.4

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 (151) hide show
  1. package/dist/es/designer/common/components/file-upload.css +7 -0
  2. package/dist/es/designer/common/components/file-upload.vue.d.ts +20 -0
  3. package/dist/es/designer/common/components/file-upload.vue.js +7 -0
  4. package/dist/es/designer/common/components/file-upload.vue2.js +99 -0
  5. package/dist/es/designer/common/components/json-view/index.d.ts +4 -0
  6. package/dist/es/designer/common/components/json-view/json-view-dialog.vue.d.ts +36 -0
  7. package/dist/es/designer/common/components/json-view/json-view-dialog.vue.js +61 -0
  8. package/dist/es/designer/common/components/json-view/json-view-dialog.vue2.js +4 -0
  9. package/dist/es/designer/common/components/json-view/json-view.vue.d.ts +32 -0
  10. package/dist/es/designer/common/components/json-view/json-view.vue.js +142 -0
  11. package/dist/es/designer/common/components/json-view/json-view.vue2.js +4 -0
  12. package/dist/es/designer/common/components/value-set-input/index.d.ts +3 -0
  13. package/dist/es/designer/common/components/value-set-input/index.js +4 -0
  14. package/dist/es/designer/common/components/value-set-input/option.d.ts +12 -0
  15. package/dist/es/designer/common/components/value-set-input/option.js +62 -0
  16. package/dist/es/designer/common/components/value-set-input/value-set-input.css +14 -0
  17. package/dist/es/designer/common/components/value-set-input/value-set-input.vue.d.ts +145 -0
  18. package/dist/es/designer/common/components/value-set-input/value-set-input.vue.js +7 -0
  19. package/dist/es/designer/common/components/value-set-input/value-set-input.vue2.js +420 -0
  20. package/dist/es/designer/common/types/common-type.d.ts +18 -0
  21. package/dist/es/designer/common/types/select.d.ts +7 -0
  22. package/dist/es/designer/common/util/node-util.d.ts +27 -0
  23. package/dist/es/designer/common/util/node-util.js +56 -0
  24. package/dist/es/designer/desginer-index.css +23 -3
  25. package/dist/es/designer/desginer-index.vue.d.ts +13 -1
  26. package/dist/es/designer/desginer-index.vue.js +1 -1
  27. package/dist/es/designer/desginer-index.vue2.js +94 -10
  28. package/dist/es/designer/flow/edge/CustomLine.d.ts +25 -0
  29. package/dist/es/designer/flow/edge/CustomLine.js +49 -0
  30. package/dist/es/designer/service-flow-view/flow-tool-util.d.ts +2 -0
  31. package/dist/es/designer/service-flow-view/flow-tool-util.js +44 -0
  32. package/dist/es/designer/service-flow-view/flow-util.d.ts +53 -0
  33. package/dist/es/designer/service-flow-view/flow-util.js +111 -0
  34. package/dist/es/designer/service-flow-view/service-flow-tool.css +130 -0
  35. package/dist/es/designer/service-flow-view/service-flow-tool.vue.d.ts +33 -0
  36. package/dist/es/designer/service-flow-view/service-flow-tool.vue.js +7 -0
  37. package/dist/es/designer/service-flow-view/service-flow-tool.vue2.js +188 -0
  38. package/dist/es/designer/service-flow-view/service-node-config.css +10 -0
  39. package/dist/es/designer/service-flow-view/service-node-config.vue.d.ts +49 -0
  40. package/dist/es/designer/service-flow-view/service-node-config.vue.js +7 -0
  41. package/dist/es/designer/service-flow-view/service-node-config.vue2.js +139 -0
  42. package/dist/es/designer/service-flow-view/service-params.vue.d.ts +18 -0
  43. package/dist/es/designer/service-flow-view/service-params.vue.js +387 -0
  44. package/dist/es/designer/service-flow-view/service-params.vue2.js +4 -0
  45. package/dist/es/designer/service-flow-view/service-result.vue.d.ts +18 -0
  46. package/dist/es/designer/service-flow-view/service-result.vue.js +274 -0
  47. package/dist/es/designer/service-flow-view/service-result.vue2.js +4 -0
  48. package/dist/es/designer/service-flow-view/service-test/request-params.vue.d.ts +16 -0
  49. package/dist/es/designer/service-flow-view/service-test/request-params.vue.js +309 -0
  50. package/dist/es/designer/service-flow-view/service-test/request-params.vue2.js +4 -0
  51. package/dist/es/designer/service-flow-view/service-test/service-test.vue.d.ts +47 -0
  52. package/dist/es/designer/service-flow-view/service-test/service-test.vue.js +440 -0
  53. package/dist/es/designer/service-flow-view/service-test/service-test.vue2.js +4 -0
  54. package/dist/es/designer/service-flow-view/service-update-log.css +5 -0
  55. package/dist/es/designer/service-flow-view/service-update-log.vue.d.ts +41 -0
  56. package/dist/es/designer/service-flow-view/service-update-log.vue.js +7 -0
  57. package/dist/es/designer/service-flow-view/service-update-log.vue2.js +205 -0
  58. package/dist/es/designer/service-flow-view/view-index.css +102 -0
  59. package/dist/es/designer/service-flow-view/view-index.vue.d.ts +40 -0
  60. package/dist/es/designer/service-flow-view/view-index.vue.js +7 -0
  61. package/dist/es/designer/service-flow-view/view-index.vue2.js +347 -0
  62. package/dist/es/designer/service-panel/component-panel.css +66 -0
  63. package/dist/es/designer/service-panel/component-panel.vue.d.ts +6 -0
  64. package/dist/es/designer/service-panel/component-panel.vue.js +7 -0
  65. package/dist/es/designer/service-panel/component-panel.vue2.js +86 -0
  66. package/dist/es/designer/service-panel/service-list.css +36 -0
  67. package/dist/es/designer/service-panel/service-list.vue.d.ts +22 -0
  68. package/dist/es/designer/service-panel/service-list.vue.js +7 -0
  69. package/dist/es/designer/service-panel/service-list.vue2.js +341 -0
  70. package/dist/es/designer/service-panel/service-panel.css +41 -0
  71. package/dist/es/designer/service-panel/service-panel.vue.d.ts +35 -0
  72. package/dist/es/designer/service-panel/service-panel.vue.js +7 -0
  73. package/dist/es/designer/service-panel/service-panel.vue2.js +80 -0
  74. package/dist/es/stores/page-store.d.ts +23 -0
  75. package/dist/es/stores/page-store.js +79 -0
  76. package/dist/lib/designer/common/components/file-upload.css +7 -0
  77. package/dist/lib/designer/common/components/file-upload.vue.d.ts +20 -0
  78. package/dist/lib/designer/common/components/file-upload.vue.js +6 -0
  79. package/dist/lib/designer/common/components/file-upload.vue2.js +98 -0
  80. package/dist/lib/designer/common/components/json-view/index.d.ts +4 -0
  81. package/dist/lib/designer/common/components/json-view/json-view-dialog.vue.d.ts +36 -0
  82. package/dist/lib/designer/common/components/json-view/json-view-dialog.vue.js +60 -0
  83. package/dist/lib/designer/common/components/json-view/json-view-dialog.vue2.js +3 -0
  84. package/dist/lib/designer/common/components/json-view/json-view.vue.d.ts +32 -0
  85. package/dist/lib/designer/common/components/json-view/json-view.vue.js +141 -0
  86. package/dist/lib/designer/common/components/json-view/json-view.vue2.js +3 -0
  87. package/dist/lib/designer/common/components/value-set-input/index.d.ts +3 -0
  88. package/dist/lib/designer/common/components/value-set-input/index.js +3 -0
  89. package/dist/lib/designer/common/components/value-set-input/option.d.ts +12 -0
  90. package/dist/lib/designer/common/components/value-set-input/option.js +62 -0
  91. package/dist/lib/designer/common/components/value-set-input/value-set-input.css +14 -0
  92. package/dist/lib/designer/common/components/value-set-input/value-set-input.vue.d.ts +145 -0
  93. package/dist/lib/designer/common/components/value-set-input/value-set-input.vue.js +6 -0
  94. package/dist/lib/designer/common/components/value-set-input/value-set-input.vue2.js +419 -0
  95. package/dist/lib/designer/common/types/common-type.d.ts +18 -0
  96. package/dist/lib/designer/common/types/select.d.ts +7 -0
  97. package/dist/lib/designer/common/util/node-util.d.ts +27 -0
  98. package/dist/lib/designer/common/util/node-util.js +56 -0
  99. package/dist/lib/designer/desginer-index.css +23 -3
  100. package/dist/lib/designer/desginer-index.vue.d.ts +13 -1
  101. package/dist/lib/designer/desginer-index.vue.js +1 -1
  102. package/dist/lib/designer/desginer-index.vue2.js +93 -9
  103. package/dist/lib/designer/flow/edge/CustomLine.d.ts +25 -0
  104. package/dist/lib/designer/flow/edge/CustomLine.js +48 -0
  105. package/dist/lib/designer/service-flow-view/flow-tool-util.d.ts +2 -0
  106. package/dist/lib/designer/service-flow-view/flow-tool-util.js +44 -0
  107. package/dist/lib/designer/service-flow-view/flow-util.d.ts +53 -0
  108. package/dist/lib/designer/service-flow-view/flow-util.js +111 -0
  109. package/dist/lib/designer/service-flow-view/service-flow-tool.css +130 -0
  110. package/dist/lib/designer/service-flow-view/service-flow-tool.vue.d.ts +33 -0
  111. package/dist/lib/designer/service-flow-view/service-flow-tool.vue.js +6 -0
  112. package/dist/lib/designer/service-flow-view/service-flow-tool.vue2.js +187 -0
  113. package/dist/lib/designer/service-flow-view/service-node-config.css +10 -0
  114. package/dist/lib/designer/service-flow-view/service-node-config.vue.d.ts +49 -0
  115. package/dist/lib/designer/service-flow-view/service-node-config.vue.js +6 -0
  116. package/dist/lib/designer/service-flow-view/service-node-config.vue2.js +138 -0
  117. package/dist/lib/designer/service-flow-view/service-params.vue.d.ts +18 -0
  118. package/dist/lib/designer/service-flow-view/service-params.vue.js +386 -0
  119. package/dist/lib/designer/service-flow-view/service-params.vue2.js +3 -0
  120. package/dist/lib/designer/service-flow-view/service-result.vue.d.ts +18 -0
  121. package/dist/lib/designer/service-flow-view/service-result.vue.js +273 -0
  122. package/dist/lib/designer/service-flow-view/service-result.vue2.js +3 -0
  123. package/dist/lib/designer/service-flow-view/service-test/request-params.vue.d.ts +16 -0
  124. package/dist/lib/designer/service-flow-view/service-test/request-params.vue.js +308 -0
  125. package/dist/lib/designer/service-flow-view/service-test/request-params.vue2.js +3 -0
  126. package/dist/lib/designer/service-flow-view/service-test/service-test.vue.d.ts +47 -0
  127. package/dist/lib/designer/service-flow-view/service-test/service-test.vue.js +439 -0
  128. package/dist/lib/designer/service-flow-view/service-test/service-test.vue2.js +3 -0
  129. package/dist/lib/designer/service-flow-view/service-update-log.css +5 -0
  130. package/dist/lib/designer/service-flow-view/service-update-log.vue.d.ts +41 -0
  131. package/dist/lib/designer/service-flow-view/service-update-log.vue.js +6 -0
  132. package/dist/lib/designer/service-flow-view/service-update-log.vue2.js +204 -0
  133. package/dist/lib/designer/service-flow-view/view-index.css +102 -0
  134. package/dist/lib/designer/service-flow-view/view-index.vue.d.ts +40 -0
  135. package/dist/lib/designer/service-flow-view/view-index.vue.js +6 -0
  136. package/dist/lib/designer/service-flow-view/view-index.vue2.js +346 -0
  137. package/dist/lib/designer/service-panel/component-panel.css +66 -0
  138. package/dist/lib/designer/service-panel/component-panel.vue.d.ts +6 -0
  139. package/dist/lib/designer/service-panel/component-panel.vue.js +6 -0
  140. package/dist/lib/designer/service-panel/component-panel.vue2.js +86 -0
  141. package/dist/lib/designer/service-panel/service-list.css +36 -0
  142. package/dist/lib/designer/service-panel/service-list.vue.d.ts +22 -0
  143. package/dist/lib/designer/service-panel/service-list.vue.js +6 -0
  144. package/dist/lib/designer/service-panel/service-list.vue2.js +340 -0
  145. package/dist/lib/designer/service-panel/service-panel.css +41 -0
  146. package/dist/lib/designer/service-panel/service-panel.vue.d.ts +35 -0
  147. package/dist/lib/designer/service-panel/service-panel.vue.js +6 -0
  148. package/dist/lib/designer/service-panel/service-panel.vue2.js +79 -0
  149. package/dist/lib/stores/page-store.d.ts +23 -0
  150. package/dist/lib/stores/page-store.js +79 -0
  151. package/package.json +1 -1
@@ -1,21 +1,105 @@
1
- import { defineComponent, resolveComponent, openBlock, createElementBlock, createVNode, withCtx, unref, pushScopeId, popScopeId, createElementVNode } from "vue";
2
- import { Search } from "@element-plus/icons-vue";
3
- const _withScopeId = (n) => (pushScopeId("data-v-abdd91ce"), n = n(), popScopeId(), n);
4
- const _hoisted_1 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createElementVNode("button", null, "Editoraaaaa", -1));
1
+ import { defineComponent, ref, computed, onMounted, resolveComponent, openBlock, createElementBlock, createVNode, withCtx, normalizeStyle } from "vue";
2
+ import ServicePanel from "./service-panel/service-panel.vue.js";
3
+ import ServiceFlowView from "./service-flow-view/view-index.vue.js";
4
+ import { useServiceFlowStore } from "../stores/page-store.js";
5
+ import http from "agilebuilder-ui/src/utils/request";
5
6
  const _sfc_main = /* @__PURE__ */ defineComponent({
6
7
  __name: "desginer-index",
8
+ props: {
9
+ pageContext: {
10
+ type: Object,
11
+ default: () => ({})
12
+ }
13
+ },
7
14
  setup(__props) {
15
+ const props = __props;
16
+ const serviceTreeData = ref([]);
17
+ const serviceFlowStoreUtil = useServiceFlowStore();
18
+ serviceFlowStoreUtil.setPageContext(props.pageContext);
19
+ const logicFlowInstance = ref(null);
20
+ const serviceFlowViewRef = ref();
21
+ const winHeight = ref();
22
+ const containerHeightStyle = computed(() => {
23
+ return {
24
+ height: winHeight.value - 60 + "px"
25
+ };
26
+ });
27
+ const serviceFlowContainerRef = ref();
28
+ onMounted(() => {
29
+ loadTreeData();
30
+ if (serviceFlowContainerRef.value) {
31
+ const rect = serviceFlowContainerRef.value.getBoundingClientRect();
32
+ if (rect.y || rect.y === 0) {
33
+ winHeight.value = window.innerHeight - rect.y;
34
+ }
35
+ }
36
+ });
37
+ const loadTreeData = () => {
38
+ http.get(
39
+ "/component/super-page-design/service-flow/tree/" + props.pageContext.systemCode + "/" + props.pageContext.systemVersion
40
+ ).then((res) => {
41
+ if (res) {
42
+ serviceTreeData.value = res.children;
43
+ }
44
+ });
45
+ };
46
+ const dragNode = (serviceComponent) => {
47
+ console.log("dragNode");
48
+ serviceFlowViewRef.value.onDragNode(serviceComponent);
49
+ };
50
+ const onServiceClick = (service) => {
51
+ console.log("service-click", service);
52
+ serviceFlowViewRef.value.onServiceClick(service);
53
+ };
54
+ const clearFlowCanvas = () => {
55
+ serviceFlowViewRef.value.clearFlowCanvas();
56
+ logicFlowInstance.value = null;
57
+ };
8
58
  return (_ctx, _cache) => {
9
- const _component_el_icon = resolveComponent("el-icon");
10
- return openBlock(), createElementBlock("div", null, [
11
- _hoisted_1,
12
- createVNode(_component_el_icon, null, {
59
+ const _component_el_aside = resolveComponent("el-aside");
60
+ const _component_el_main = resolveComponent("el-main");
61
+ const _component_el_container = resolveComponent("el-container");
62
+ return openBlock(), createElementBlock("div", {
63
+ ref_key: "serviceFlowContainerRef",
64
+ ref: serviceFlowContainerRef
65
+ }, [
66
+ createVNode(_component_el_container, { class: "amb-container" }, {
13
67
  default: withCtx(() => [
14
- createVNode(unref(Search))
68
+ createVNode(_component_el_aside, { class: "amb-container-left" }, {
69
+ default: withCtx(() => [
70
+ createVNode(ServicePanel, {
71
+ logicFlowInstance: logicFlowInstance.value,
72
+ "onUpdate:logicFlowInstance": _cache[0] || (_cache[0] = ($event) => logicFlowInstance.value = $event),
73
+ serviceTreeData: serviceTreeData.value,
74
+ onServiceClick,
75
+ onClearFlowCanvas: clearFlowCanvas,
76
+ onLoadTreeData: loadTreeData,
77
+ onDragNode: dragNode,
78
+ style: normalizeStyle(containerHeightStyle.value)
79
+ }, null, 8, ["logicFlowInstance", "serviceTreeData", "style"])
80
+ ]),
81
+ _: 1
82
+ }),
83
+ createVNode(_component_el_main, {
84
+ class: "amb-container-main",
85
+ style: normalizeStyle(containerHeightStyle.value)
86
+ }, {
87
+ default: withCtx(() => [
88
+ createVNode(ServiceFlowView, {
89
+ logicFlowInstance: logicFlowInstance.value,
90
+ "onUpdate:logicFlowInstance": _cache[1] || (_cache[1] = ($event) => logicFlowInstance.value = $event),
91
+ serviceTreeData: serviceTreeData.value,
92
+ onLoadTreeData: loadTreeData,
93
+ ref_key: "serviceFlowViewRef",
94
+ ref: serviceFlowViewRef
95
+ }, null, 8, ["logicFlowInstance", "serviceTreeData"])
96
+ ]),
97
+ _: 1
98
+ }, 8, ["style"])
15
99
  ]),
16
100
  _: 1
17
101
  })
18
- ]);
102
+ ], 512);
19
103
  };
20
104
  }
21
105
  });
@@ -0,0 +1,25 @@
1
+ import { PolylineEdge, PolylineEdgeModel } from '@logicflow/core';
2
+
3
+ declare class CustomLine extends PolylineEdge {
4
+ }
5
+ /**
6
+ * 自定义线条model
7
+ */
8
+ declare class CustomLineModel extends PolylineEdgeModel {
9
+ getEdgeStyle(): {
10
+ [x: string]: any;
11
+ fill?: string;
12
+ stroke?: string;
13
+ strokeWidth?: number;
14
+ };
15
+ getTextPosition(): {
16
+ x: number;
17
+ y: number;
18
+ };
19
+ }
20
+ declare const _default: {
21
+ type: string;
22
+ view: typeof CustomLine;
23
+ model: typeof CustomLineModel;
24
+ };
25
+ export default _default;
@@ -0,0 +1,49 @@
1
+ import { PolylineEdge, PolylineEdgeModel } from "@logicflow/core";
2
+ class CustomLine extends PolylineEdge {
3
+ }
4
+ class CustomLineModel extends PolylineEdgeModel {
5
+ getEdgeStyle() {
6
+ const style = super.getEdgeStyle();
7
+ style.strokeWidth = 2;
8
+ style.stroke = this.isSelected ? "#ff7f0e" : "#C8CDD4";
9
+ return style;
10
+ }
11
+ getTextPosition() {
12
+ const position = super.getTextPosition();
13
+ const currentPositionList = this.points.split(" ");
14
+ currentPositionList && currentPositionList.forEach((item) => {
15
+ item.split(",");
16
+ });
17
+ if (currentPositionList.length > 1) {
18
+ let [x1, y1] = currentPositionList[0].split(",");
19
+ let [x2, y2] = currentPositionList[1].split(",");
20
+ let distence = 50;
21
+ const newX1 = Number(x1);
22
+ const newY1 = Number(y1);
23
+ const newx2 = Number(x2);
24
+ const newy2 = Number(y2);
25
+ if (newX1 === newx2) {
26
+ if (newy2 < newY1) {
27
+ distence = -50;
28
+ }
29
+ position.y = newY1 + distence;
30
+ position.x = newX1;
31
+ } else {
32
+ if (newx2 < newX1) {
33
+ distence = -50;
34
+ }
35
+ position.x = newX1 + distence;
36
+ position.y = newY1 - 10;
37
+ }
38
+ }
39
+ return position;
40
+ }
41
+ }
42
+ const CustomLine$1 = {
43
+ type: "customLine",
44
+ view: CustomLine,
45
+ model: CustomLineModel
46
+ };
47
+ export {
48
+ CustomLine$1 as default
49
+ };
@@ -0,0 +1,2 @@
1
+ export declare function customControlClick(lf: any, item: any): void;
2
+ export declare function beautify(lf: any): void;
@@ -0,0 +1,44 @@
1
+ function customControlClick(lf, item) {
2
+ switch (item.type) {
3
+ case "zoomOut":
4
+ lf.zoom(false);
5
+ break;
6
+ case "zoomIn":
7
+ lf.zoom(true);
8
+ break;
9
+ case "fit":
10
+ lf.fitView();
11
+ break;
12
+ case "undo":
13
+ lf.undo();
14
+ break;
15
+ case "redo":
16
+ lf.redo();
17
+ break;
18
+ case "reset":
19
+ lf.resetZoom();
20
+ lf.resetTranslate();
21
+ break;
22
+ case "select":
23
+ lf.extension.selectionSelect.openSelectionSelect();
24
+ break;
25
+ case "beautify":
26
+ beautify(lf);
27
+ break;
28
+ }
29
+ }
30
+ function beautify(lf) {
31
+ if (lf) {
32
+ lf.extension.dagre.layout({
33
+ rankdir: "TB",
34
+ align: "DR",
35
+ nodesep: 20,
36
+ ranksep: 20,
37
+ begin: [200, 50]
38
+ });
39
+ }
40
+ }
41
+ export {
42
+ beautify,
43
+ customControlClick
44
+ };
@@ -0,0 +1,53 @@
1
+ import { default as LogicFlow } from '@logicflow/core';
2
+
3
+ export declare const customControl: ({
4
+ type: string;
5
+ desc: string;
6
+ class: string;
7
+ clickStyle?: undefined;
8
+ } | {
9
+ type: string;
10
+ desc: string;
11
+ class: string;
12
+ clickStyle: boolean;
13
+ })[];
14
+ interface ServiceVariable {
15
+ [otherProp: string]: any;
16
+ }
17
+ interface ServiceNode {
18
+ [otherProp: string]: any;
19
+ }
20
+ export declare function newLogicFlow(container: any): LogicFlow;
21
+ export declare function addInitNode(lf: any): void;
22
+ /**
23
+ * 注册节点
24
+ * @param lf logicFlow实例
25
+ */
26
+ export declare const registerNode: (lf: any) => void;
27
+ export declare function getRuntimeJson(service: any): {
28
+ code: any;
29
+ name: any;
30
+ returnValues: any;
31
+ errorMessage: any;
32
+ log: any;
33
+ variables: ServiceVariable[];
34
+ nodes: ServiceNode[];
35
+ };
36
+ declare const _default: {
37
+ customControl: ({
38
+ type: string;
39
+ desc: string;
40
+ class: string;
41
+ clickStyle?: undefined;
42
+ } | {
43
+ type: string;
44
+ desc: string;
45
+ class: string;
46
+ clickStyle: boolean;
47
+ })[];
48
+ getRuntimeJson: typeof getRuntimeJson;
49
+ newLogicFlow: typeof newLogicFlow;
50
+ registerNode: (lf: any) => void;
51
+ addInitNode: typeof addInitNode;
52
+ };
53
+ export default _default;
@@ -0,0 +1,111 @@
1
+ import { getNextNodeById } from "../common/util/node-util.js";
2
+ import CustomLine from "../flow/edge/CustomLine.js";
3
+ import LogicFlow from "@logicflow/core";
4
+ import { Dagre } from "@logicflow/layout";
5
+ import { Menu, DndPanel, SelectionSelect, MiniMap, Group } from "@logicflow/extension";
6
+ const customControl = [
7
+ { type: "zoomOut", desc: "缩小", class: "control-item-zoomOut" },
8
+ { type: "zoomIn", desc: "放大", class: "control-item-zoomIn" },
9
+ { type: "fit", desc: "适应", class: "control-item-fit" },
10
+ { type: "undo", desc: "上一步", class: "control-item-undo" },
11
+ { type: "redo", desc: "下一步", class: "control-item-redo" },
12
+ { type: "reset", desc: "定位还原", class: "custom-reset" },
13
+ { type: "select", desc: "框选", class: "custom-select", clickStyle: true },
14
+ { type: "beautify", desc: "一键美化", class: "custom-beautify" }
15
+ ];
16
+ function newLogicFlow(container) {
17
+ return new LogicFlow({
18
+ // 通过选项指定了渲染的容器和需要显示网格
19
+ container,
20
+ grid: {
21
+ // 设置原背景不显示
22
+ visible: false,
23
+ // 控制拖拽节点时每次移动的像素
24
+ size: 2
25
+ },
26
+ // 背景
27
+ background: {},
28
+ plugins: [Menu, DndPanel, SelectionSelect, MiniMap, Group, Dagre]
29
+ });
30
+ }
31
+ function addInitNode(lf) {
32
+ lf.addNode({
33
+ id: "start",
34
+ type: "start",
35
+ x: 620,
36
+ y: 50,
37
+ properties: {}
38
+ });
39
+ lf.addNode({
40
+ type: "end",
41
+ x: 620,
42
+ y: 550,
43
+ properties: {}
44
+ });
45
+ }
46
+ const registerNode = (lf) => {
47
+ if (!lf) {
48
+ return;
49
+ }
50
+ lf.register(CustomLine);
51
+ lf.setDefaultEdgeType("customLine");
52
+ };
53
+ function getRuntimeJson(service) {
54
+ const runTimeJson = {
55
+ code: service.code,
56
+ name: service.name,
57
+ returnValues: service.returnValues,
58
+ errorMessage: service.errorMessage,
59
+ log: service.log,
60
+ variables: [],
61
+ nodes: []
62
+ };
63
+ const tempVars = [];
64
+ if (service.variables) {
65
+ service.variables.forEach((variable) => {
66
+ tempVars.push(convertVariable(variable));
67
+ });
68
+ }
69
+ runTimeJson.variables = tempVars;
70
+ const tempNodes = [];
71
+ service.flow.nodes.forEach((node) => {
72
+ const tempNode = {};
73
+ tempNode.code = node.id;
74
+ tempNode.type = node.type;
75
+ tempNode.props = node.properties;
76
+ if (node.type === "loop") {
77
+ tempNode.children = node.children;
78
+ }
79
+ tempNode.tos = [];
80
+ const nextNodes = getNextNodeById(node, service.flow);
81
+ nextNodes.forEach((nextNode) => {
82
+ tempNode.tos.push({ code: nextNode.id });
83
+ });
84
+ tempNodes.push(tempNode);
85
+ });
86
+ runTimeJson.nodes = tempNodes;
87
+ console.log(runTimeJson, "runTimeJson");
88
+ return runTimeJson;
89
+ }
90
+ function convertVariable(variable) {
91
+ const tempVar = {};
92
+ tempVar.name = variable.name;
93
+ tempVar.alias = variable.alias;
94
+ tempVar.type = variable.type;
95
+ tempVar.defaultValue = variable.defaultValue;
96
+ if (variable.items && variable.items.length > 0) {
97
+ const items = [];
98
+ variable.items.forEach((item) => {
99
+ items.push(convertVariable(item));
100
+ });
101
+ tempVar.items = items;
102
+ }
103
+ return tempVar;
104
+ }
105
+ export {
106
+ addInitNode,
107
+ customControl,
108
+ getRuntimeJson,
109
+ newLogicFlow,
110
+ registerNode
111
+ };
@@ -0,0 +1,130 @@
1
+ .control-item[data-v-fdc6ec07] {
2
+ top: -5px;
3
+ position: relative;
4
+ cursor: pointer;
5
+ }
6
+ .control-item[data-v-fdc6ec07]:hover {
7
+ background: #efefef;
8
+ }
9
+ .control-item-click[data-v-fdc6ec07] {
10
+ background: rgba(11, 45, 101, 0.105);
11
+ }
12
+ .control-item + .control-item[data-v-fdc6ec07] {
13
+ margin-left: 20px;
14
+ }
15
+ .control-item i[data-v-fdc6ec07] {
16
+ display: inline-block;
17
+ width: 20px;
18
+ height: 20px;
19
+ vertical-align: middle;
20
+ background-size: cover;
21
+ }
22
+ .control-item-zoomOut[data-v-fdc6ec07] {
23
+ background-image: url();
24
+ }
25
+ .control-item-zoomIn[data-v-fdc6ec07] {
26
+ background-image: url();
27
+ }
28
+ .control-item-fit[data-v-fdc6ec07] {
29
+ background-image: url();
30
+ }
31
+ .control-item-undo[data-v-fdc6ec07] {
32
+ background-image: url();
33
+ }
34
+ .control-item-redo[data-v-fdc6ec07] {
35
+ background-image: url();
36
+ }
37
+ .custom-reset[data-v-fdc6ec07] {
38
+ background-image: url('');
39
+ }
40
+ .custom-select[data-v-fdc6ec07] {
41
+ background-image: url('');
42
+ }
43
+ .custom-beautify[data-v-fdc6ec07] {
44
+ background-image: url('');
45
+ }
46
+ .amb-design-content[data-v-fdc6ec07] {
47
+ overflow: auto;
48
+ display: block;
49
+ flex: none;
50
+ position: relative;
51
+ width: 100%;
52
+ height: 100%;
53
+ }
54
+ .amb-design-content[data-v-fdc6ec07]::-webkit-scrollbar {
55
+ width: 1px;
56
+ }
57
+ .amb-design-tool[data-v-fdc6ec07] {
58
+ position: -webkit-sticky; /**Safari */
59
+ position: sticky;
60
+ width: 100%;
61
+ top: 14px;
62
+ background: #ffffff;
63
+ height: 40px;
64
+ line-height: 40px;
65
+ padding-top: 10px;
66
+ box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.08);
67
+ border-radius: 6px 6px 6px 6px;
68
+ z-index: 0;
69
+ }
70
+ .amb-page-type[data-v-fdc6ec07] {
71
+ padding-top: 11px;
72
+ padding-left: 6px;
73
+ padding-right: 6px;
74
+ margin-right: 10px;
75
+ border-radius: 4px 4px 4px 4px;
76
+ cursor: pointer;
77
+ }
78
+ .amb-page-type[data-v-fdc6ec07]:hover {
79
+ background: rgba(11, 45, 101, 0.105);
80
+ }
81
+ .amb-page-type.selected[data-v-fdc6ec07] {
82
+ background: #5893ef;
83
+ color: #ffffff;
84
+ }
85
+ .amb-page-type > label[data-v-fdc6ec07] {
86
+ font-size: 14px;
87
+ padding-left: 6px;
88
+ padding-right: 6px;
89
+ padding-bottom: 15px;
90
+ top: -5px;
91
+ position: relative;
92
+ cursor: pointer;
93
+ }
94
+ .amb-design-tool-split[data-v-fdc6ec07] {
95
+ height: 25px;
96
+ margin-top: -12px;
97
+ }
98
+ .amb-design-board[data-v-fdc6ec07] {
99
+ margin: 0 auto;
100
+ margin-top: 28px;
101
+ overflow-y: auto;
102
+ overflow-x: auto;
103
+ background: #ffffff;
104
+ border-radius: 2px 2px 2px 2px;
105
+ box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.08);
106
+ padding-bottom: 20px;
107
+ }
108
+ .container[data-v-fdc6ec07] {
109
+ height: 100%;
110
+ width: 100%;
111
+ }
112
+ .amb-item-ghost[data-v-fdc6ec07] {
113
+ background-color: #5893ef;
114
+ height: 5px;
115
+ line-height: 5px;
116
+ overflow: hidden;
117
+ }
118
+ /* 将你的自定义样式添加到这里 */
119
+ .draggable-placeholder[data-v-fdc6ec07] {
120
+ background-color: red;
121
+ border: 1px dashed #ddd;
122
+ margin: 5px;
123
+ padding: 10px;
124
+ }
125
+ #LF-view[data-v-fdc6ec07] {
126
+ width: calc(100% - 100px);
127
+ height: 80%;
128
+ outline: none;
129
+ margin-left: 50px;
130
+ }