@logicflow/extension 2.0.10 → 2.0.12

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 (51) hide show
  1. package/.turbo/turbo-build.log +9 -17
  2. package/CHANGELOG.md +37 -0
  3. package/dist/index.css +278 -1
  4. package/es/bpmn-elements/presets/Pool/Pool.d.ts +2 -2
  5. package/es/dynamic-group/index.d.ts +2 -1
  6. package/es/dynamic-group/index.js +21 -19
  7. package/es/dynamic-group/model.js +1 -5
  8. package/es/dynamic-group/node.d.ts +8 -1
  9. package/es/dynamic-group/node.js +87 -22
  10. package/es/index.css +278 -1
  11. package/es/index.less +1 -0
  12. package/es/materials/group/GroupNode.d.ts +5 -5
  13. package/es/materials/group/GroupNode.js +3 -3
  14. package/es/materials/group/index.js +5 -5
  15. package/es/materials/node-selection/index.d.ts +6 -6
  16. package/es/materials/node-selection/index.js +90 -10
  17. package/es/style/index.css +278 -1
  18. package/es/style/index.less +327 -0
  19. package/lib/bpmn-elements/presets/Pool/Pool.d.ts +2 -2
  20. package/lib/dynamic-group/index.d.ts +2 -1
  21. package/lib/dynamic-group/index.js +21 -19
  22. package/lib/dynamic-group/model.js +1 -5
  23. package/lib/dynamic-group/node.d.ts +8 -1
  24. package/lib/dynamic-group/node.js +87 -22
  25. package/lib/index.css +278 -1
  26. package/lib/index.less +1 -0
  27. package/lib/materials/group/GroupNode.d.ts +5 -5
  28. package/lib/materials/group/GroupNode.js +3 -3
  29. package/lib/materials/group/index.js +5 -5
  30. package/lib/materials/node-selection/index.d.ts +6 -6
  31. package/lib/materials/node-selection/index.js +89 -9
  32. package/lib/style/index.css +278 -1
  33. package/lib/style/index.less +327 -0
  34. package/package.json +3 -3
  35. package/src/components/mini-map/index.ts +11 -0
  36. package/src/dynamic-group/index.ts +29 -8
  37. package/src/dynamic-group/model.ts +1 -6
  38. package/src/dynamic-group/node.ts +136 -85
  39. package/src/index.ts +1 -0
  40. package/src/materials/group/GroupNode.ts +3 -3
  41. package/src/materials/group/index.ts +5 -5
  42. package/src/materials/node-selection/index.ts +115 -14
  43. package/src/style/index.less +3 -5
  44. package/src/style/raw.ts +3 -7
  45. package/src/tools/label/Label.tsx +106 -55
  46. package/src/tools/label/LabelModel.ts +1 -0
  47. package/src/tools/label/index.ts +64 -3
  48. package/src/tools/proximity-connect/index.ts +399 -0
  49. package/stats.html +1 -1
  50. package/dist/index.min.js +0 -2
  51. package/dist/index.min.js.map +0 -1
@@ -0,0 +1,327 @@
1
+ @import url('medium-editor/dist/css/medium-editor.min.css');
2
+ @import url('medium-editor/dist/css/themes/beagle.min.css');
3
+ @import url('vanilla-picker/dist/vanilla-picker.csp.css');
4
+
5
+ /* label */
6
+ .lf-label-overlay {
7
+ width: 0;
8
+ height: 0;
9
+ overflow: visible;
10
+
11
+ .lf-label-editor {
12
+ //box-sizing: content-box;
13
+ padding: 4px;
14
+ background: #fff;
15
+ border-radius: 5px;
16
+
17
+ &-container {
18
+ position: absolute;
19
+ display: flex;
20
+ align-items: center;
21
+ justify-content: center;
22
+ overflow: visible;
23
+ text-align: center;
24
+
25
+ p {
26
+ margin: 0;
27
+ }
28
+ }
29
+
30
+ &-dragging {
31
+ cursor: move;
32
+ }
33
+
34
+ &-editing {
35
+ border: 2px solid #275dc5;
36
+ outline: none;
37
+ cursor: text;
38
+ }
39
+
40
+ &-hover {
41
+ border: 2px dashed #acacac;
42
+ }
43
+
44
+ // textOverflowMode
45
+ &-clip {
46
+ width: 100px; /* 根据需要调整宽度 */
47
+ overflow: hidden;
48
+ white-space: nowrap;
49
+ text-overflow: clip;
50
+ }
51
+
52
+ &-ellipsis {
53
+ width: 100px; /* 根据需要调整宽度 */
54
+ overflow: hidden;
55
+ white-space: nowrap;
56
+ text-overflow: ellipsis;
57
+ }
58
+
59
+ &-wrap {
60
+ width: 100px; /* 根据需要调整宽度 */
61
+ white-space: normal;
62
+ overflow-wrap: break-word; /* 允许单词内换行 */
63
+ }
64
+
65
+ &-nowrap {
66
+ width: 100px; /* 根据需要调整宽度 */
67
+ overflow: visible;
68
+ white-space: nowrap;
69
+ }
70
+ }
71
+ }
72
+
73
+ .lf-control {
74
+ position: absolute;
75
+ top: 0;
76
+ right: 10px;
77
+ display: flex;
78
+ margin: 5px;
79
+ padding: 0 15px;
80
+ background: rgb(255 255 255 / 80%);
81
+ border-radius: 5px;
82
+ box-shadow: 0 1px 4px rgb(0 0 0 / 30%);
83
+ }
84
+
85
+ .lf-control-item {
86
+ display: flex;
87
+ flex-direction: column;
88
+ align-items: center;
89
+ justify-content: center;
90
+ padding: 5px 10px;
91
+ cursor: pointer;
92
+ }
93
+
94
+ .lf-control-item:hover {
95
+ background: #efefef;
96
+ }
97
+
98
+ .lf-control-item.disabled {
99
+ filter: opacity(0.5);
100
+ /* cursor: not-allowed; */
101
+ pointer-events: none;
102
+ }
103
+
104
+ .lf-control-item.disabled:hover {
105
+ background: #fff;
106
+ }
107
+
108
+ .lf-control-item.disabled i {
109
+ pointer-events: none;
110
+ }
111
+
112
+ .lf-control-item i {
113
+ display: inline-block;
114
+ width: 20px;
115
+ height: 20px;
116
+ vertical-align: middle;
117
+ background-size: cover;
118
+ }
119
+
120
+ .lf-control-text {
121
+ margin-top: 5px;
122
+ font-size: 12px;
123
+ }
124
+
125
+ .lf-control-zoomOut {
126
+ background-image: url('');
127
+ }
128
+
129
+ .lf-control-zoomIn {
130
+ background-image: url('');
131
+ }
132
+
133
+ .lf-control-fit {
134
+ background-image: url('');
135
+ }
136
+
137
+ .lf-control-undo {
138
+ background-image: url('');
139
+ }
140
+
141
+ .lf-control-redo {
142
+ background-image: url('');
143
+ }
144
+
145
+ /* menu */
146
+ .lf-menu {
147
+ position: absolute;
148
+ z-index: 999;
149
+ display: none;
150
+ width: 150px;
151
+ margin: 0 0 0 10px;
152
+ padding: 10px 0;
153
+ background: #fff;
154
+ border: 1px solid #efefee;
155
+ border-radius: 3px;
156
+ }
157
+
158
+ .lf-menu > li {
159
+ position: relative;
160
+ padding: 3px 12px;
161
+ font-size: 12px;
162
+ line-height: 18px;
163
+ list-style: none;
164
+ cursor: pointer;
165
+ transition: all 120ms ease-in-out;
166
+ }
167
+
168
+ .lf-menu-item__disabled {
169
+ color: #aaa;
170
+ cursor: default;
171
+ opacity: 0.88;
172
+ pointer-events: none;
173
+ }
174
+
175
+ .lf-menu-item:hover {
176
+ background: #f3f3f3;
177
+ }
178
+
179
+ /* dndpanel */
180
+ .lf-dndpanel {
181
+ position: absolute;
182
+ margin: 5px;
183
+ padding: 15px 5px;
184
+ background: rgb(255 255 255 / 80%);
185
+ border-radius: 5px;
186
+ box-shadow: 0 1px 4px rgb(0 0 0 / 30%);
187
+ }
188
+
189
+ .lf-dnd-item {
190
+ margin-top: 5px;
191
+ font-size: 14px;
192
+ text-align: center;
193
+ }
194
+
195
+ .lf-dnd-item.disabled > div {
196
+ color: #a8abb2;
197
+ cursor: not-allowed;
198
+ }
199
+
200
+ .lf-dnd-shape {
201
+ width: 36px;
202
+ height: 36px;
203
+ margin: 0 auto;
204
+ background-repeat: no-repeat;
205
+ background-position: center center;
206
+ cursor: grab;
207
+ opacity: 0.99;
208
+ }
209
+
210
+ /* 选区 */
211
+ .lf-selection-select {
212
+ position: absolute;
213
+ border: 2px dashed darkorange;
214
+ }
215
+
216
+ /* 缩略图 */
217
+ .lf-mini-map {
218
+ position: absolute;
219
+ padding: 8px;
220
+ padding-top: 28px;
221
+ overflow: hidden;
222
+ background: #eaedf2;
223
+ border: 1px solid #93a3b4;
224
+ }
225
+
226
+ .lf-mini-map-graph {
227
+ position: relative;
228
+ overflow: hidden;
229
+ }
230
+
231
+ .lf-minimap-viewport {
232
+ position: absolute;
233
+ top: 0;
234
+ left: 0;
235
+ // border: 2px solid rgb(24 125 255);
236
+ background-color: rgb(48 48 48 / 20%);
237
+ cursor: grab;
238
+ }
239
+
240
+ .lf-mini-map-header {
241
+ position: absolute;
242
+ top: 0;
243
+ right: 0;
244
+ left: 0;
245
+ height: 18px;
246
+ padding: 0 10px;
247
+ line-height: 18px;
248
+ text-shadow: 0 1px 0 rgb(255 255 255 / 33%);
249
+ background-color: #a6a6a6;
250
+ background-image: linear-gradient(to bottom, #b2b2b2, #9b9b9b);
251
+ border: 1px solid #999;
252
+ border-top: #bfbfbf solid 1px;
253
+ border-bottom: #666 solid 1px;
254
+ }
255
+
256
+ .lf-mini-map-close {
257
+ position: absolute;
258
+ top: 0;
259
+ right: 2px;
260
+ width: 18px;
261
+ height: 18px;
262
+ background-image: url('');
263
+ background-size: contain;
264
+ cursor: pointer;
265
+ }
266
+
267
+ .lf-mini-map-no-header {
268
+ padding-top: 8px;
269
+ }
270
+
271
+ .lf-mini-map-no-header .lf-mini-map-header {
272
+ display: none;
273
+ }
274
+
275
+ .lf-mini-map-no-close-icon .lf-mini-map-close {
276
+ display: none;
277
+ }
278
+
279
+ /* 节点调整 */
280
+
281
+ .lf-resize-control-0 {
282
+ cursor: nw-resize;
283
+ }
284
+
285
+ .lf-resize-control-1 {
286
+ cursor: ne-resize;
287
+ }
288
+
289
+ .lf-resize-control-2 {
290
+ cursor: se-resize;
291
+ }
292
+
293
+ .lf-resize-control-3 {
294
+ cursor: sw-resize;
295
+ }
296
+
297
+ /* context-menu */
298
+ .lf-inner-context {
299
+ position: absolute;
300
+ display: none;
301
+ /* display: flex; */
302
+ flex-flow: column wrap;
303
+ height: 90px;
304
+ }
305
+
306
+ .lf-context-item {
307
+ box-sizing: content-box;
308
+ width: 20px;
309
+ height: 20px;
310
+ margin: 0 2px 2px 0;
311
+ padding: 2px 3px;
312
+ }
313
+
314
+ .lf-context-item:hover {
315
+ background: rgb(201 217 216 / 50%);
316
+ }
317
+
318
+ .lf-context-img {
319
+ width: 20px;
320
+ height: 20px;
321
+ cursor: pointer;
322
+ }
323
+
324
+ /* mind map */
325
+ .lf-mindmap_addIcon {
326
+ margin-top: 10px;
327
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@logicflow/extension",
3
- "version": "2.0.10",
3
+ "version": "2.0.12",
4
4
  "description": "LogicFlow Extensions",
5
5
  "main": "lib/index.js",
6
6
  "module": "es/index.js",
@@ -20,7 +20,7 @@
20
20
  "author": "Logicflow-Team",
21
21
  "license": "Apache-2.0",
22
22
  "peerDependencies": {
23
- "@logicflow/core": "2.0.6"
23
+ "@logicflow/core": "2.0.8"
24
24
  },
25
25
  "dependencies": {
26
26
  "@antv/hierarchy": "^0.6.11",
@@ -31,7 +31,7 @@
31
31
  "preact": "^10.17.1",
32
32
  "rangy": "^1.3.1",
33
33
  "vanilla-picker": "^2.12.3",
34
- "@logicflow/core": "2.0.6"
34
+ "@logicflow/core": "2.0.8"
35
35
  },
36
36
  "devDependencies": {
37
37
  "less": "^4.1.1",
@@ -195,6 +195,14 @@ export class MiniMap {
195
195
  this.elementAreaBounds = boundsInit
196
196
  this.viewPortBounds = boundsInit
197
197
  this.initMiniMap()
198
+ lf.on('graph:resize', this.onGraphResize)
199
+ }
200
+
201
+ onGraphResize = () => {
202
+ this.updateViewPortBounds()
203
+ if (this.isShow) {
204
+ this.updateViewPort()
205
+ }
198
206
  }
199
207
 
200
208
  render = (_: LogicFlow, container: HTMLElement) => {
@@ -661,6 +669,9 @@ export class MiniMap {
661
669
  },
662
670
  })
663
671
  }
672
+ destroy() {
673
+ this.lf.off('graph:resize', this.onGraphResize)
674
+ }
664
675
  }
665
676
 
666
677
  export default MiniMap
@@ -86,7 +86,9 @@ export class DynamicGroup {
86
86
  } else {
87
87
  let topZIndexGroup = groups[count - 1]
88
88
  for (let i = count - 2; i >= 0; i--) {
89
- topZIndexGroup = groups[i]
89
+ if (groups[i].zIndex > topZIndexGroup.zIndex) {
90
+ topZIndexGroup = groups[i]
91
+ }
90
92
  }
91
93
  return topZIndexGroup as DynamicGroupNodeModel
92
94
  }
@@ -240,8 +242,11 @@ export class DynamicGroup {
240
242
  }
241
243
  }
242
244
 
243
- removeNodeFromGroup = ({ data: node }: CallbackArgs<'node:delete'>) => {
244
- if (node.isGroup && node.children) {
245
+ removeNodeFromGroup = ({
246
+ data: node,
247
+ model,
248
+ }: CallbackArgs<'node:delete'>) => {
249
+ if (model.isGroup && node.children) {
245
250
  forEach(
246
251
  Array.from((node as DynamicGroupNodeModel).children),
247
252
  (childId) => {
@@ -420,6 +425,17 @@ export class DynamicGroup {
420
425
  this.calibrateTopGroupZIndex(data.nodes)
421
426
  }
422
427
 
428
+ removeChildrenInGroupNodeData<
429
+ T extends LogicFlow.NodeData | LogicFlow.NodeConfig,
430
+ >(nodeData: T) {
431
+ const newNodeData = cloneDeep(nodeData)
432
+ delete newNodeData.children
433
+ if (newNodeData.properties?.children) {
434
+ delete newNodeData.properties.children
435
+ }
436
+ return newNodeData
437
+ }
438
+
423
439
  /**
424
440
  * 创建一个 Group 类型节点内部所有子节点的副本
425
441
  * 并且在遍历所有 nodes 的过程中,顺便拿到所有 edges (只在 Group 范围的 edges)
@@ -440,10 +456,14 @@ export class DynamicGroup {
440
456
  forEach(Array.from(children), (childId: string) => {
441
457
  const childNode = this.lf.getNodeModelById(childId)
442
458
  if (childNode) {
459
+ const childNodeChildren = childNode.children
443
460
  const childNodeData = childNode.getData()
444
461
  const eventType = EventType.NODE_GROUP_COPY || 'node:group-copy-add'
445
462
 
446
- const newNodeConfig = transformNodeData(childNodeData, distance)
463
+ const newNodeConfig = transformNodeData(
464
+ this.removeChildrenInGroupNodeData(childNodeData),
465
+ distance,
466
+ )
447
467
  const tempChildNode = this.lf.addNode(newNodeConfig, eventType)
448
468
  curGroup.addChild(tempChildNode.id)
449
469
 
@@ -455,10 +475,10 @@ export class DynamicGroup {
455
475
  ...[...tempChildNode.incoming.edges, ...tempChildNode.outgoing.edges],
456
476
  )
457
477
 
458
- if (children instanceof Set) {
478
+ if (childNodeChildren instanceof Set) {
459
479
  const { childNodes, edgesData } = this.initGroupChildNodes(
460
480
  nodeIdMap,
461
- children,
481
+ childNodeChildren,
462
482
  tempChildNode as DynamicGroupNodeModel,
463
483
  distance,
464
484
  )
@@ -667,8 +687,9 @@ export class DynamicGroup {
667
687
 
668
688
  forEach(selectedNodes, (node) => {
669
689
  const originId = node.id
670
- const { children, ...rest } = node
671
- const model = lf.addNode(rest)
690
+ const children = node.properties?.children ?? node.children
691
+
692
+ const model = lf.addNode(this.removeChildrenInGroupNodeData(node))
672
693
 
673
694
  if (originId) nodeIdMap[originId] = model.id
674
695
  elements.nodes.push(model) // 此时为 group 的 nodeModel
@@ -159,11 +159,6 @@ export class DynamicGroupNodeModel extends RectNodeModel<IGroupNodeProperties> {
159
159
 
160
160
  setAttributes() {
161
161
  super.setAttributes()
162
-
163
- // 初始化时,如果 this.isCollapsed 为 true,则主动触发一次折叠操作
164
- if (this.isCollapsed) {
165
- this.toggleCollapse(true)
166
- }
167
162
  }
168
163
 
169
164
  getData(): NodeData {
@@ -445,8 +440,8 @@ export class DynamicGroupNodeModel extends RectNodeModel<IGroupNodeProperties> {
445
440
  * TODO: 如何重写该方法呢?
446
441
  * @param _nodeData
447
442
  */
443
+ // eslint-disable-next-line
448
444
  isAllowAppendIn(_nodeData: NodeData) {
449
- console.info('_nodeData', _nodeData)
450
445
  // TODO: 此处使用 this.properties.groupAddable 还是 this.groupAddable
451
446
  // this.groupAddable 是否存在更新不及时的问题
452
447
  return true