hookehuyr

新增功能测试

1 /* 1 /*
2 * @Date: 2025-03-10 13:07:05 2 * @Date: 2025-03-10 13:07:05
3 * @LastEditors: hookehuyr hookehuyr@gmail.com 3 * @LastEditors: hookehuyr hookehuyr@gmail.com
4 - * @LastEditTime: 2025-03-10 15:50:42 4 + * @LastEditTime: 2025-03-10 18:07:51
5 * @FilePath: /logic-flow2/src/main.js 5 * @FilePath: /logic-flow2/src/main.js
6 * @Description: 文件描述 6 * @Description: 文件描述
7 */ 7 */
...@@ -15,8 +15,13 @@ import ElementPlus from 'element-plus' ...@@ -15,8 +15,13 @@ import ElementPlus from 'element-plus'
15 import 'element-plus/dist/index.css' 15 import 'element-plus/dist/index.css'
16 16
17 import LogicFlow from '@logicflow/core'; 17 import LogicFlow from '@logicflow/core';
18 -import { Menu } from "@logicflow/extension"; 18 +import { Menu, DndPanel, SelectionSelect, Control, InsertNodeInPolyline, Highlight } from "@logicflow/extension";
19 LogicFlow.use(Menu) // 右键菜单 19 LogicFlow.use(Menu) // 右键菜单
20 +LogicFlow.use(DndPanel) // 拖拽面板
21 +LogicFlow.use(SelectionSelect) // 选中元素
22 +LogicFlow.use(Control) // 控制面板
23 +LogicFlow.use(InsertNodeInPolyline) // 边上插入节点
24 +LogicFlow.use(Highlight) // 高亮
20 25
21 const app = createApp(App) 26 const app = createApp(App)
22 app.use(ElementPlus) 27 app.use(ElementPlus)
......
1 /* 1 /*
2 * @Date: 2025-03-10 13:15:30 2 * @Date: 2025-03-10 13:15:30
3 * @LastEditors: hookehuyr hookehuyr@gmail.com 3 * @LastEditors: hookehuyr hookehuyr@gmail.com
4 - * @LastEditTime: 2025-03-10 15:49:17 4 + * @LastEditTime: 2025-03-10 17:13:56
5 * @FilePath: /logic-flow2/src/router/index.js 5 * @FilePath: /logic-flow2/src/router/index.js
6 * @Description: 文件描述 6 * @Description: 文件描述
7 */ 7 */
...@@ -20,6 +20,16 @@ const router = createRouter({ ...@@ -20,6 +20,16 @@ const router = createRouter({
20 name: 'menu', 20 name: 'menu',
21 component: () => import('../views/menu.vue') 21 component: () => import('../views/menu.vue')
22 }, 22 },
23 + {
24 + path: '/DndPanel',
25 + name: 'DndPanel',
26 + component: () => import('../views/DndPanel.vue')
27 + },
28 + {
29 + path: '/control',
30 + name: 'control',
31 + component: () => import('../views/control.vue')
32 + },
23 ] 33 ]
24 }) 34 })
25 35
......
1 +<!--
2 + * @Date: 2025-03-10 16:52:35
3 + * @LastEditors: hookehuyr hookehuyr@gmail.com
4 + * @LastEditTime: 2025-03-10 17:40:05
5 + * @FilePath: /logic-flow2/src/views/DndPanel.vue
6 + * @Description: 拖拽面板
7 +-->
8 +<template>
9 + <div class="container">
10 + <div ref="container" class="flow-container"></div>
11 + </div>
12 +</template>
13 +
14 +<script setup>
15 +import LogicFlow from '@logicflow/core';
16 +import { ProximityConnect } from "@logicflow/extension";
17 +const container = ref(null);
18 +let lf = null;
19 +
20 +onMounted(() => {
21 + lf = new LogicFlow({
22 + container: container.value,
23 + grid: true,
24 + plugins: [ProximityConnect],
25 + pluginsOptions: {
26 + proximityConnect: {
27 + enable: true, // 插件是否启用
28 + // distance, // 渐进连线阈值
29 + // reverseDirection, // 连线方向
30 + // virtualEdgeStyle, // 虚拟线样式
31 + }
32 + },
33 + });
34 +
35 + lf.extension.dndPanel.setPatternItems([
36 + {
37 + label: '选区',
38 + icon: '',
39 + callback: () => {
40 + lf.extension.selectionSelect.openSelectionSelect();
41 + lf.once('selection:selected', () => {
42 + lf.extension.selectionSelect.closeSelectionSelect();
43 + });
44 + }
45 + },
46 + {
47 + type: 'circle',
48 + text: '开始',
49 + label: '开始节点',
50 + icon: '',
51 + },
52 + {
53 + type: 'rect',
54 + label: '用户任务',
55 + icon: '',
56 + className: 'important-node'
57 + },
58 + {
59 + type: 'rect',
60 + label: '系统任务',
61 + icon: '',
62 + className: 'import_icon'
63 + },
64 + {
65 + type: 'diamond',
66 + label: '条件判断',
67 + icon: '',
68 + },
69 + {
70 + type: 'circle',
71 + text: '结束',
72 + label: '结束节点',
73 + icon: '',
74 + }
75 + ]);
76 +
77 + lf.render({
78 + nodes: [
79 + { id: 'node1', type: 'rect', x: 200, y: 100 },
80 + { id: 'node2', type: 'circle', x: 400, y: 100 },
81 + ],
82 + edges: [{ id: 'edge1', sourceNodeId: 'node1', targetNodeId: 'node2' }],
83 + });
84 +
85 +});
86 +</script>
87 +
88 +
89 +<style scoped>
90 +.container {
91 + width: 100vw;
92 + height: 100vh;
93 + display: flex;
94 + flex-direction: column;
95 +}
96 +
97 +.flow-container {
98 + flex: 1;
99 + width: 100%;
100 + height: 100%;
101 +}
102 +</style>
1 +<!--
2 + * @Date: 2025-03-10 16:52:35
3 + * @LastEditors: hookehuyr hookehuyr@gmail.com
4 + * @LastEditTime: 2025-03-10 17:16:39
5 + * @FilePath: /logic-flow2/src/views/control.vue
6 + * @Description: 拖拽面板
7 +-->
8 +<template>
9 + <div class="container">
10 + <div ref="container" class="flow-container"></div>
11 + </div>
12 +</template>
13 +
14 +<script setup>
15 +import LogicFlow from '@logicflow/core';
16 +import { MiniMap } from "@logicflow/extension";
17 +const container = ref(null);
18 +let lf = null;
19 +
20 +onMounted(() => {
21 + lf = new LogicFlow({
22 + container: container.value,
23 + grid: true,
24 + plugins: [MiniMap]
25 + });
26 +
27 + lf.extension.control.addItem({
28 + key: 'mini-map',
29 + iconClass: 'custom-minimap',
30 + title: '',
31 + text: '导航',
32 + onMouseEnter: (lf, ev) => {
33 + const position = lf.getPointByClient(ev.x, ev.y)
34 + lf.extension.miniMap.show(
35 + position.domOverlayPosition.x - 120,
36 + position.domOverlayPosition.y + 35,
37 + )
38 + },
39 + onClick: (lf, ev) => {
40 + const position = lf.getPointByClient(ev.x, ev.y)
41 + lf.extension.miniMap.show(
42 + position.domOverlayPosition.x - 120,
43 + position.domOverlayPosition.y + 35,
44 + )
45 + },
46 + });
47 +
48 + // lf.extension.control.removeItem('mini-map')
49 +
50 + lf.render({
51 + nodes: [
52 + { id: 'node1', type: 'rect', x: 200, y: 100 },
53 + { id: 'node2', type: 'circle', x: 400, y: 100 },
54 + ],
55 + edges: [{ id: 'edge1', sourceNodeId: 'node1', targetNodeId: 'node2' }],
56 + });
57 +});
58 +</script>
59 +
60 +
61 +<style scoped>
62 +.container {
63 + width: 100vw;
64 + height: 100vh;
65 + display: flex;
66 + flex-direction: column;
67 +}
68 +
69 +.flow-container {
70 + flex: 1;
71 + width: 100%;
72 + height: 100%;
73 +}
74 +</style>
1 <!-- 1 <!--
2 * @Date: 2025-03-10 14:37:31 2 * @Date: 2025-03-10 14:37:31
3 * @LastEditors: hookehuyr hookehuyr@gmail.com 3 * @LastEditors: hookehuyr hookehuyr@gmail.com
4 - * @LastEditTime: 2025-03-10 15:47:42 4 + * @LastEditTime: 2025-03-10 17:14:06
5 - * @FilePath: /logic-flow2/src/views/Home.vue 5 + * @FilePath: /logic-flow2/src/views/home.vue
6 * @Description: 文件描述 6 * @Description: 文件描述
7 --> 7 -->
8 <template> 8 <template>
9 <div>插件</div> 9 <div>插件</div>
10 <el-button type="primary" @click="goTo('menu')">Menu</el-button> 10 <el-button type="primary" @click="goTo('menu')">Menu</el-button>
11 + <el-button type="primary" @click="goTo('DndPanel')">DndPanel</el-button>
12 + <el-button type="primary" @click="goTo('control')">control</el-button>
11 </template> 13 </template>
12 14
13 <script setup> 15 <script setup>
......
1 +<!--
2 + * @Date: 2025-03-10 16:52:35
3 + * @LastEditors: hookehuyr hookehuyr@gmail.com
4 + * @LastEditTime: 2025-03-10 16:58:14
5 + * @FilePath: /logic-flow2/src/views/temp.vue
6 + * @Description: 拖拽面板
7 +-->
8 +<template>
9 + <div class="container">
10 + <div ref="container" class="flow-container"></div>
11 + </div>
12 +</template>
13 +
14 +<script setup>
15 +import LogicFlow from '@logicflow/core';
16 +
17 +const container = ref(null);
18 +let lf = null;
19 +
20 +onMounted(() => {
21 + lf = new LogicFlow({
22 + container: container.value,
23 + grid: true,
24 + });
25 +
26 + lf.render({
27 + nodes: [
28 + { id: 'node1', type: 'rect', x: 200, y: 100 },
29 + { id: 'node2', type: 'circle', x: 400, y: 100 },
30 + ],
31 + edges: [{ id: 'edge1', sourceNodeId: 'node1', targetNodeId: 'node2' }],
32 + });
33 +});
34 +</script>
35 +
36 +
37 +<style scoped>
38 +.container {
39 + width: 100vw;
40 + height: 100vh;
41 + display: flex;
42 + flex-direction: column;
43 +}
44 +
45 +.flow-container {
46 + flex: 1;
47 + width: 100%;
48 + height: 100%;
49 +}
50 +</style>