@logicflow/extension 2.0.12 → 2.0.14
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/.turbo/turbo-build.log +16 -8
- package/CHANGELOG.md +19 -0
- package/dist/index.css +1 -278
- package/dist/index.min.js +2 -0
- package/dist/index.min.js.map +1 -0
- package/es/bpmn-elements/presets/Pool/Pool.d.ts +2 -2
- package/es/components/mini-map/index.d.ts +2 -0
- package/es/components/mini-map/index.js +10 -0
- package/es/components/selection-select/index.js +8 -6
- package/es/dynamic-group/model.d.ts +6 -0
- package/es/dynamic-group/model.js +20 -0
- package/es/dynamic-group/node.d.ts +2 -1
- package/es/dynamic-group/node.js +15 -14
- package/es/index.css +1 -278
- package/es/index.d.ts +1 -0
- package/es/index.js +1 -0
- package/es/style/index.css +1 -278
- package/es/style/raw.d.ts +1 -1
- package/es/style/raw.js +1 -1
- package/es/tools/label/Label.d.ts +5 -0
- package/es/tools/label/Label.js +82 -31
- package/es/tools/label/LabelModel.js +1 -0
- package/es/tools/label/index.d.ts +1 -0
- package/es/tools/label/index.js +51 -4
- package/es/tools/proximity-connect/index.d.ts +42 -0
- package/es/tools/proximity-connect/index.js +337 -0
- package/lib/bpmn-elements/presets/Pool/Pool.d.ts +2 -2
- package/lib/components/mini-map/index.d.ts +2 -0
- package/lib/components/mini-map/index.js +10 -0
- package/lib/components/selection-select/index.js +8 -6
- package/lib/dynamic-group/model.d.ts +6 -0
- package/lib/dynamic-group/model.js +20 -0
- package/lib/dynamic-group/node.d.ts +2 -1
- package/lib/dynamic-group/node.js +15 -14
- package/lib/index.css +1 -278
- package/lib/index.d.ts +1 -0
- package/lib/index.js +1 -0
- package/lib/style/index.css +1 -278
- package/lib/style/raw.d.ts +1 -1
- package/lib/style/raw.js +1 -1
- package/lib/tools/label/Label.d.ts +5 -0
- package/lib/tools/label/Label.js +82 -31
- package/lib/tools/label/LabelModel.js +1 -0
- package/lib/tools/label/index.d.ts +1 -0
- package/lib/tools/label/index.js +50 -3
- package/lib/tools/proximity-connect/index.d.ts +42 -0
- package/lib/tools/proximity-connect/index.js +340 -0
- package/package.json +3 -3
- package/src/components/selection-select/index.ts +8 -6
- package/src/dynamic-group/model.ts +29 -0
- package/src/dynamic-group/node.ts +21 -17
- package/src/tools/label/Label.tsx +9 -0
- package/src/tools/label/index.ts +6 -2
- package/stats.html +1 -1
- package/es/index.less +0 -1
- package/es/style/index.less +0 -327
- package/lib/index.less +0 -1
- package/lib/style/index.less +0 -327
package/lib/style/raw.js
CHANGED
|
@@ -5,4 +5,4 @@ exports.content = void 0;
|
|
|
5
5
|
/**
|
|
6
6
|
* Auto generated file, do not modify it!
|
|
7
7
|
*/
|
|
8
|
-
exports.content = "@import url('medium-editor/dist/css/medium-editor.min.css');\n@import url('medium-editor/dist/css/themes/beagle.min.css');\n@import url('vanilla-picker/dist/vanilla-picker.csp.css');\n/* label */\n.lf-label-overlay {\n width: 0;\n height: 0;\n overflow: visible;\n}\n.lf-label-overlay .lf-label-editor {\n padding: 4px;\n background: #fff;\n border-radius: 5px;\n}\n.lf-label-overlay .lf-label-editor-container {\n position: absolute;\n display: flex;\n align-items: center;\n justify-content: center;\n overflow: visible;\n text-align: center;\n}\n.lf-label-overlay .lf-label-editor-container p {\n margin: 0;\n}\n.lf-label-overlay .lf-label-editor-dragging {\n cursor: move;\n}\n.lf-label-overlay .lf-label-editor-editing {\n border: 2px solid #275dc5;\n outline: none;\n cursor: text;\n}\n.lf-label-overlay .lf-label-editor-hover {\n border: 2px dashed #acacac;\n}\n.lf-label-overlay .lf-label-editor-clip {\n width: 100px;\n /* \u6839\u636E\u9700\u8981\u8C03\u6574\u5BBD\u5EA6 */\n overflow: hidden;\n white-space: nowrap;\n text-overflow: clip;\n}\n.lf-label-overlay .lf-label-editor-ellipsis {\n width: 100px;\n /* \u6839\u636E\u9700\u8981\u8C03\u6574\u5BBD\u5EA6 */\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n.lf-label-overlay .lf-label-editor-wrap {\n width: 100px;\n /* \u6839\u636E\u9700\u8981\u8C03\u6574\u5BBD\u5EA6 */\n white-space: normal;\n overflow-wrap: break-word;\n /* \u5141\u8BB8\u5355\u8BCD\u5185\u6362\u884C */\n}\n.lf-label-overlay .lf-label-editor-nowrap {\n width: 100px;\n /* \u6839\u636E\u9700\u8981\u8C03\u6574\u5BBD\u5EA6 */\n overflow: visible;\n white-space: nowrap;\n}\n.lf-control {\n position: absolute;\n top: 0;\n right: 10px;\n display: flex;\n margin: 5px;\n padding: 0 15px;\n background: rgba(255, 255, 255, 0.8);\n border-radius: 5px;\n box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);\n}\n.lf-control-item {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n padding: 5px 10px;\n cursor: pointer;\n}\n.lf-control-item:hover {\n background: #efefef;\n}\n.lf-control-item.disabled {\n filter: opacity(0.5);\n /* cursor: not-allowed; */\n pointer-events: none;\n}\n.lf-control-item.disabled:hover {\n background: #fff;\n}\n.lf-control-item.disabled i {\n pointer-events: none;\n}\n.lf-control-item i {\n display: inline-block;\n width: 20px;\n height: 20px;\n vertical-align: middle;\n background-size: cover;\n}\n.lf-control-text {\n margin-top: 5px;\n font-size: 12px;\n}\n.lf-control-zoomOut {\n background-image: url('');\n}\n.lf-control-zoomIn {\n background-image: url('');\n}\n.lf-control-fit {\n background-image: url('');\n}\n.lf-control-undo {\n background-image: url('');\n}\n.lf-control-redo {\n background-image: url('');\n}\n/* menu */\n.lf-menu {\n position: absolute;\n z-index: 999;\n display: none;\n width: 150px;\n margin: 0 0 0 10px;\n padding: 10px 0;\n background: #fff;\n border: 1px solid #efefee;\n border-radius: 3px;\n}\n.lf-menu > li {\n position: relative;\n padding: 3px 12px;\n font-size: 12px;\n line-height: 18px;\n list-style: none;\n cursor: pointer;\n transition: all 120ms ease-in-out;\n}\n.lf-menu-item__disabled {\n color: #aaa;\n cursor: default;\n opacity: 0.88;\n pointer-events: none;\n}\n.lf-menu-item:hover {\n background: #f3f3f3;\n}\n/* dndpanel */\n.lf-dndpanel {\n position: absolute;\n margin: 5px;\n padding: 15px 5px;\n background: rgba(255, 255, 255, 0.8);\n border-radius: 5px;\n box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);\n}\n.lf-dnd-item {\n margin-top: 5px;\n font-size: 14px;\n text-align: center;\n}\n.lf-dnd-item.disabled > div {\n color: #a8abb2;\n cursor: not-allowed;\n}\n.lf-dnd-shape {\n width: 36px;\n height: 36px;\n margin: 0 auto;\n background-repeat: no-repeat;\n background-position: center center;\n cursor: grab;\n opacity: 0.99;\n}\n/* \u9009\u533A */\n.lf-selection-select {\n position: absolute;\n border: 2px dashed darkorange;\n}\n/* \u7F29\u7565\u56FE */\n.lf-mini-map {\n position: absolute;\n padding: 8px;\n padding-top: 28px;\n overflow: hidden;\n background: #eaedf2;\n border: 1px solid #93a3b4;\n}\n.lf-mini-map-graph {\n position: relative;\n overflow: hidden;\n}\n.lf-minimap-viewport {\n position: absolute;\n top: 0;\n left: 0;\n background-color: rgba(48, 48, 48, 0.2);\n cursor: grab;\n}\n.lf-mini-map-header {\n position: absolute;\n top: 0;\n right: 0;\n left: 0;\n height: 18px;\n padding: 0 10px;\n line-height: 18px;\n text-shadow: 0 1px 0 rgba(255, 255, 255, 0.33);\n background-color: #a6a6a6;\n background-image: linear-gradient(to bottom, #b2b2b2, #9b9b9b);\n border: 1px solid #999;\n border-top: #bfbfbf solid 1px;\n border-bottom: #666 solid 1px;\n}\n.lf-mini-map-close {\n position: absolute;\n top: 0;\n right: 2px;\n width: 18px;\n height: 18px;\n background-image: url('');\n background-size: contain;\n cursor: pointer;\n}\n.lf-mini-map-no-header {\n padding-top: 8px;\n}\n.lf-mini-map-no-header .lf-mini-map-header {\n display: none;\n}\n.lf-mini-map-no-close-icon .lf-mini-map-close {\n display: none;\n}\n/* \u8282\u70B9\u8C03\u6574 */\n.lf-resize-control-0 {\n cursor: nw-resize;\n}\n.lf-resize-control-1 {\n cursor: ne-resize;\n}\n.lf-resize-control-2 {\n cursor: se-resize;\n}\n.lf-resize-control-3 {\n cursor: sw-resize;\n}\n/* context-menu */\n.lf-inner-context {\n position: absolute;\n display: none;\n /* display: flex; */\n flex-flow: column wrap;\n height: 90px;\n}\n.lf-context-item {\n box-sizing: content-box;\n width: 20px;\n height: 20px;\n margin: 0 2px 2px 0;\n padding: 2px 3px;\n}\n.lf-context-item:hover {\n background: rgba(201, 217, 216, 0.5);\n}\n.lf-context-img {\n width: 20px;\n height: 20px;\n cursor: pointer;\n}\n/* mind map */\n.lf-mindmap_addIcon {\n margin-top: 10px;\n}\n";
|
|
8
|
+
exports.content = "@import url('medium-editor/dist/css/medium-editor.min.css');\n@import url('medium-editor/dist/css/themes/beagle.min.css');\n@import url('vanilla-picker/dist/vanilla-picker.csp.css');\n/* label */\n.lf-label-overlay {\n width: 0;\n height: 0;\n overflow: visible;\n}\n.lf-label-overlay .lf-label-editor {\n padding: 4px;\n background: #fff;\n border-radius: 5px;\n}\n.lf-label-overlay .lf-label-editor-container {\n position: absolute;\n display: flex;\n align-items: center;\n justify-content: center;\n overflow: visible;\n text-align: center;\n}\n.lf-label-overlay .lf-label-editor-container p {\n margin: 0;\n}\n.lf-label-overlay .lf-label-editor-dragging {\n cursor: move;\n}\n.lf-label-overlay .lf-label-editor-editing {\n outline: 2px solid #275dc5;\n cursor: text;\n}\n.lf-label-overlay .lf-label-editor-hover {\n outline: 2px dashed #acacac;\n}\n.lf-label-overlay .lf-label-editor-clip {\n width: 100px;\n /* \u6839\u636E\u9700\u8981\u8C03\u6574\u5BBD\u5EA6 */\n overflow: hidden;\n white-space: nowrap;\n text-overflow: clip;\n}\n.lf-label-overlay .lf-label-editor-ellipsis {\n width: 100px;\n /* \u6839\u636E\u9700\u8981\u8C03\u6574\u5BBD\u5EA6 */\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n.lf-label-overlay .lf-label-editor-wrap {\n white-space: normal;\n overflow-wrap: break-word;\n /* \u5141\u8BB8\u5355\u8BCD\u5185\u6362\u884C */\n}\n.lf-label-overlay .lf-label-editor-nowrap {\n overflow: visible;\n white-space: nowrap;\n}\n.lf-control {\n position: absolute;\n top: 0;\n right: 10px;\n display: flex;\n margin: 5px;\n padding: 0 15px;\n background: rgba(255, 255, 255, 0.8);\n border-radius: 5px;\n box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);\n}\n.lf-control-item {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n padding: 5px 10px;\n cursor: pointer;\n}\n.lf-control-item:hover {\n background: #efefef;\n}\n.lf-control-item.disabled {\n filter: opacity(0.5);\n /* cursor: not-allowed; */\n pointer-events: none;\n}\n.lf-control-item.disabled:hover {\n background: #fff;\n}\n.lf-control-item.disabled i {\n pointer-events: none;\n}\n.lf-control-item i {\n display: inline-block;\n width: 20px;\n height: 20px;\n vertical-align: middle;\n background-size: cover;\n}\n.lf-control-text {\n margin-top: 5px;\n font-size: 12px;\n}\n.lf-control-zoomOut {\n background-image: url('');\n}\n.lf-control-zoomIn {\n background-image: url('');\n}\n.lf-control-fit {\n background-image: url('');\n}\n.lf-control-undo {\n background-image: url('');\n}\n.lf-control-redo {\n background-image: url('');\n}\n/* menu */\n.lf-menu {\n position: absolute;\n z-index: 999;\n display: none;\n width: 150px;\n margin: 0 0 0 10px;\n padding: 10px 0;\n background: #fff;\n border: 1px solid #efefee;\n border-radius: 3px;\n}\n.lf-menu > li {\n position: relative;\n padding: 3px 12px;\n font-size: 12px;\n line-height: 18px;\n list-style: none;\n cursor: pointer;\n transition: all 120ms ease-in-out;\n}\n.lf-menu-item__disabled {\n color: #aaa;\n cursor: default;\n opacity: 0.88;\n pointer-events: none;\n}\n.lf-menu-item:hover {\n background: #f3f3f3;\n}\n/* dndpanel */\n.lf-dndpanel {\n position: absolute;\n z-index: 999;\n margin: 5px;\n padding: 15px 5px;\n background: rgba(255, 255, 255, 0.8);\n border-radius: 5px;\n box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);\n}\n.lf-dnd-item {\n margin-top: 5px;\n font-size: 14px;\n text-align: center;\n}\n.lf-dnd-item.disabled > div {\n color: #a8abb2;\n cursor: not-allowed;\n}\n.lf-dnd-shape {\n width: 36px;\n height: 36px;\n margin: 0 auto;\n background-repeat: no-repeat;\n background-position: center center;\n cursor: grab;\n opacity: 0.99;\n}\n/* \u9009\u533A */\n.lf-selection-select {\n position: absolute;\n border: 2px dashed darkorange;\n}\n/* \u7F29\u7565\u56FE */\n.lf-mini-map {\n position: absolute;\n padding: 8px;\n padding-top: 28px;\n overflow: hidden;\n background: #eaedf2;\n border: 1px solid #93a3b4;\n}\n.lf-mini-map-graph {\n position: relative;\n overflow: hidden;\n}\n.lf-minimap-viewport {\n position: absolute;\n top: 0;\n left: 0;\n background-color: rgba(48, 48, 48, 0.2);\n cursor: grab;\n}\n.lf-mini-map-header {\n position: absolute;\n top: 0;\n right: 0;\n left: 0;\n height: 18px;\n padding: 0 10px;\n line-height: 18px;\n text-shadow: 0 1px 0 rgba(255, 255, 255, 0.33);\n background-color: #a6a6a6;\n background-image: linear-gradient(to bottom, #b2b2b2, #9b9b9b);\n border: 1px solid #999;\n border-top: #bfbfbf solid 1px;\n border-bottom: #666 solid 1px;\n}\n.lf-mini-map-close {\n position: absolute;\n top: 0;\n right: 2px;\n width: 18px;\n height: 18px;\n background-image: url('');\n background-size: contain;\n cursor: pointer;\n}\n.lf-mini-map-no-header {\n padding-top: 8px;\n}\n.lf-mini-map-no-header .lf-mini-map-header {\n display: none;\n}\n.lf-mini-map-no-close-icon .lf-mini-map-close {\n display: none;\n}\n/* \u8282\u70B9\u8C03\u6574 */\n.lf-resize-control-0 {\n cursor: nw-resize;\n}\n.lf-resize-control-1 {\n cursor: ne-resize;\n}\n.lf-resize-control-2 {\n cursor: se-resize;\n}\n.lf-resize-control-3 {\n cursor: sw-resize;\n}\n/* context-menu */\n.lf-inner-context {\n position: absolute;\n display: none;\n /* display: flex; */\n flex-flow: column wrap;\n height: 90px;\n}\n.lf-context-item {\n box-sizing: content-box;\n width: 20px;\n height: 20px;\n margin: 0 2px 2px 0;\n padding: 2px 3px;\n}\n.lf-context-item:hover {\n background: rgba(201, 217, 216, 0.5);\n}\n.lf-context-img {\n width: 20px;\n height: 20px;\n cursor: pointer;\n}\n/* mind map */\n.lf-mindmap_addIcon {\n margin-top: 10px;\n}\n";
|
|
@@ -9,6 +9,7 @@ export interface ILabelState {
|
|
|
9
9
|
isEditing: boolean;
|
|
10
10
|
isHovered: boolean;
|
|
11
11
|
isDragging: boolean;
|
|
12
|
+
isSelected: boolean;
|
|
12
13
|
}
|
|
13
14
|
export declare class Label extends Component<ILabelProps, ILabelState> {
|
|
14
15
|
textRef: import("preact").RefObject<HTMLDivElement>;
|
|
@@ -17,10 +18,14 @@ export declare class Label extends Component<ILabelProps, ILabelState> {
|
|
|
17
18
|
setHoverOn: () => void;
|
|
18
19
|
setHoverOff: () => void;
|
|
19
20
|
handleMouseDown: (e: MouseEvent) => void;
|
|
21
|
+
handleMouseUp: (e: MouseEvent) => void;
|
|
20
22
|
handleDragging: ({ deltaX, deltaY }: IDragParams) => void;
|
|
21
23
|
handleDragEnd: () => void;
|
|
24
|
+
handleClick: (e: MouseEvent) => void;
|
|
22
25
|
handleDbClick: (e: MouseEvent) => void;
|
|
23
26
|
handleBlur: (e: FocusEvent) => void;
|
|
27
|
+
handleInput: (e: InputEvent) => void;
|
|
28
|
+
setElementModelLabelInfo(data: any): void;
|
|
24
29
|
reCalcLabelSize: () => void;
|
|
25
30
|
componentDidMount(): void;
|
|
26
31
|
componentDidUpdate(): void;
|
package/lib/tools/label/Label.js
CHANGED
|
@@ -79,26 +79,31 @@ var Label = /** @class */ (function (_super) {
|
|
|
79
79
|
var _a;
|
|
80
80
|
var _b = _this.props, label = _b.label, graphModel = _b.graphModel;
|
|
81
81
|
var nodeTextDraggable = graphModel.editConfigModel.nodeTextDraggable;
|
|
82
|
-
// 当 label 允许拖拽
|
|
83
|
-
if (((_a = label.draggable) !== null && _a !== void 0 ? _a : nodeTextDraggable) &&
|
|
84
|
-
_this.
|
|
82
|
+
// 当 label 允许拖拽 且不处于拖拽状态、不处于编辑状态时, StepDrag 开启拖拽
|
|
83
|
+
if (((_a = label.draggable) !== null && _a !== void 0 ? _a : nodeTextDraggable) &&
|
|
84
|
+
!_this.state.isDragging &&
|
|
85
|
+
!_this.state.isEditing) {
|
|
85
86
|
_this.stepDrag.handleMouseDown(e);
|
|
86
87
|
}
|
|
87
88
|
};
|
|
89
|
+
_this.handleMouseUp = function (e) {
|
|
90
|
+
if (_this.state.isDragging) {
|
|
91
|
+
_this.stepDrag.handleMouseUp(e);
|
|
92
|
+
}
|
|
93
|
+
};
|
|
88
94
|
_this.handleDragging = function (_a) {
|
|
89
95
|
var deltaX = _a.deltaX, deltaY = _a.deltaY;
|
|
90
|
-
|
|
96
|
+
if (!_this.state.isDragging) {
|
|
97
|
+
_this.setState({ isDragging: true });
|
|
98
|
+
}
|
|
99
|
+
var _b = _this.props, label = _b.label, graphModel = _b.graphModel;
|
|
91
100
|
// DONE: 添加缩放时拖拽的逻辑,对 deltaX 和 deltaY 进行按比例缩放
|
|
92
101
|
var transformModel = graphModel.transformModel;
|
|
93
102
|
var _c = __read(transformModel.fixDeltaXY(deltaX, deltaY), 2), curDeltaX = _c[0], curDeltaY = _c[1];
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
var target = elementLabel[idx];
|
|
99
|
-
elementLabel[idx] = __assign(__assign({}, target), { x: target.x + curDeltaX, y: target.y + curDeltaY });
|
|
100
|
-
var targetElem = graphModel.getElement(element.id);
|
|
101
|
-
targetElem === null || targetElem === void 0 ? void 0 : targetElem.setProperty('_label', elementLabel);
|
|
103
|
+
_this.setElementModelLabelInfo({
|
|
104
|
+
x: label.x + curDeltaX,
|
|
105
|
+
y: label.y + curDeltaY,
|
|
106
|
+
});
|
|
102
107
|
graphModel.eventCenter.emit('label:drag', {
|
|
103
108
|
data: label.getData(),
|
|
104
109
|
model: label,
|
|
@@ -107,6 +112,20 @@ var Label = /** @class */ (function (_super) {
|
|
|
107
112
|
_this.handleDragEnd = function () {
|
|
108
113
|
_this.setState({ isDragging: false });
|
|
109
114
|
};
|
|
115
|
+
_this.handleClick = function (e) {
|
|
116
|
+
var _a = _this.props, label = _a.label, element = _a.element, graphModel = _a.graphModel;
|
|
117
|
+
// 更新当前Label选中状态
|
|
118
|
+
element.setSelected(!_this.state.isSelected);
|
|
119
|
+
_this.setState({ isSelected: !_this.state.isSelected });
|
|
120
|
+
_this.setElementModelLabelInfo({
|
|
121
|
+
isSelected: true,
|
|
122
|
+
});
|
|
123
|
+
graphModel.eventCenter.emit('label:click', {
|
|
124
|
+
data: label.getData(),
|
|
125
|
+
e: e,
|
|
126
|
+
model: element,
|
|
127
|
+
});
|
|
128
|
+
};
|
|
110
129
|
_this.handleDbClick = function (e) {
|
|
111
130
|
var _a = _this.props, label = _a.label, element = _a.element, graphModel = _a.graphModel;
|
|
112
131
|
graphModel.eventCenter.emit('label:dblclick', {
|
|
@@ -145,6 +164,14 @@ var Label = /** @class */ (function (_super) {
|
|
|
145
164
|
_this.setState({
|
|
146
165
|
isDragging: false,
|
|
147
166
|
isHovered: false,
|
|
167
|
+
isSelected: false,
|
|
168
|
+
});
|
|
169
|
+
};
|
|
170
|
+
_this.handleInput = function (e) {
|
|
171
|
+
var _a = _this.props, label = _a.label, graphModel = _a.graphModel;
|
|
172
|
+
graphModel.eventCenter.emit('label:input', {
|
|
173
|
+
e: e,
|
|
174
|
+
data: label.getData(),
|
|
148
175
|
});
|
|
149
176
|
};
|
|
150
177
|
// 重新计算 Label 大小
|
|
@@ -162,32 +189,56 @@ var Label = /** @class */ (function (_super) {
|
|
|
162
189
|
isEditing: false,
|
|
163
190
|
isHovered: false,
|
|
164
191
|
isDragging: false,
|
|
192
|
+
isSelected: false,
|
|
165
193
|
};
|
|
166
194
|
return _this;
|
|
167
195
|
}
|
|
196
|
+
Label.prototype.setElementModelLabelInfo = function (data) {
|
|
197
|
+
var _a = this.props, label = _a.label, element = _a.element, graphModel = _a.graphModel;
|
|
198
|
+
var _label = element.properties._label;
|
|
199
|
+
var elementLabel = _label;
|
|
200
|
+
var idx = (0, lodash_es_1.findIndex)(elementLabel, function (cur) { return cur.id === label.id; });
|
|
201
|
+
var target = elementLabel[idx];
|
|
202
|
+
elementLabel[idx] = __assign(__assign({}, target), data);
|
|
203
|
+
var targetElem = graphModel.getElement(element.id);
|
|
204
|
+
targetElem === null || targetElem === void 0 ? void 0 : targetElem.setProperty('_label', elementLabel);
|
|
205
|
+
};
|
|
168
206
|
// TODO:如何处理 Label zIndex 的问题, Label 永远会比节点层级高
|
|
169
207
|
// 当 Label 被元素遮盖时,隐藏它
|
|
170
208
|
Label.prototype.componentDidMount = function () {
|
|
171
209
|
var _this = this;
|
|
172
210
|
var _a = this.props, label = _a.label, element = _a.element, graphModel = _a.graphModel;
|
|
173
211
|
// 在点击元素、边或者画布 时,结束 Label 的编辑态
|
|
174
|
-
graphModel.eventCenter.on('blank:click,node:click,edge:click', function () {
|
|
175
|
-
var
|
|
176
|
-
|
|
177
|
-
|
|
212
|
+
graphModel.eventCenter.on('blank:click,node:click,edge:click,label:click', function (_a) {
|
|
213
|
+
var _b, _c, _d, _e;
|
|
214
|
+
var data = _a.data;
|
|
215
|
+
// 点击的不是label 、点击的不是当前label、点击的是当前label,且当前 label 处于选中态
|
|
216
|
+
// 则取消选中态
|
|
217
|
+
if ((data === null || data === void 0 ? void 0 : data.type) !== 'label' ||
|
|
218
|
+
(data.type === 'label' && data.id !== label.id) ||
|
|
219
|
+
_this.state.isSelected) {
|
|
220
|
+
_this.setState({ isSelected: false });
|
|
221
|
+
}
|
|
222
|
+
// 点击的不是label 、点击的不是当前label、点击的是当前label,且当前 label 处于编辑态
|
|
223
|
+
// 则结束编辑态
|
|
224
|
+
if (((data === null || data === void 0 ? void 0 : data.type) !== 'label' ||
|
|
225
|
+
(data.type == 'label' && data.id !== label.id)) &&
|
|
226
|
+
_this.state.isEditing) {
|
|
178
227
|
_this.setState({ isEditing: false });
|
|
179
|
-
var value = (
|
|
180
|
-
var content = (
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
var targetElem = graphModel.getElement(element.id);
|
|
187
|
-
targetElem === null || targetElem === void 0 ? void 0 : targetElem.setProperty('_label', elementLabel);
|
|
228
|
+
var value = (_c = (_b = _this.textRef.current) === null || _b === void 0 ? void 0 : _b.innerText) !== null && _c !== void 0 ? _c : '';
|
|
229
|
+
var content = (_e = (_d = _this.textRef.current) === null || _d === void 0 ? void 0 : _d.innerHTML) !== null && _e !== void 0 ? _e : '';
|
|
230
|
+
_this.setElementModelLabelInfo({
|
|
231
|
+
value: value,
|
|
232
|
+
content: content,
|
|
233
|
+
isSelected: false,
|
|
234
|
+
});
|
|
188
235
|
element.setElementState(core_1.ElementState.DEFAULT);
|
|
189
236
|
}
|
|
190
|
-
|
|
237
|
+
// 点击的不是label 、点击的不是当前label、点击的是当前label,且当前 label 的文本DOM存在
|
|
238
|
+
// 则结束文本DOM的编辑态
|
|
239
|
+
if (((data === null || data === void 0 ? void 0 : data.type) !== 'label' ||
|
|
240
|
+
(data.type == 'label' && data.id !== label.id)) &&
|
|
241
|
+
_this.textRef.current) {
|
|
191
242
|
_this.textRef.current.contentEditable = 'false';
|
|
192
243
|
}
|
|
193
244
|
});
|
|
@@ -200,7 +251,7 @@ var Label = /** @class */ (function (_super) {
|
|
|
200
251
|
};
|
|
201
252
|
Label.prototype.componentDidUpdate = function () {
|
|
202
253
|
// snapshot: any, // previousState: Readonly<ILabelState>, // previousProps: Readonly<ILabelProps>,
|
|
203
|
-
console.log('Label componentDidUpdate')
|
|
254
|
+
// console.log('Label componentDidUpdate')
|
|
204
255
|
// console.log('previousProps', previousProps)
|
|
205
256
|
// console.log('previousState', previousState)
|
|
206
257
|
// console.log('snapshot', snapshot)
|
|
@@ -214,7 +265,7 @@ var Label = /** @class */ (function (_super) {
|
|
|
214
265
|
Label.prototype.render = function () {
|
|
215
266
|
var _a;
|
|
216
267
|
var _b = this.props, label = _b.label, element = _b.element, graphModel = _b.graphModel;
|
|
217
|
-
var _c = this.state, isDragging = _c.isDragging, isHovered = _c.isHovered, isEditing = _c.isEditing;
|
|
268
|
+
var _c = this.state, isDragging = _c.isDragging, isHovered = _c.isHovered, isSelected = _c.isSelected, isEditing = _c.isEditing;
|
|
218
269
|
var transformModel = graphModel.transformModel;
|
|
219
270
|
var transform = transformModel.getTransformStyle().transform;
|
|
220
271
|
var id = label.id, x = label.x, y = label.y, zIndex = label.zIndex, vertical = label.vertical, style = label.style, rotate = label.rotate, content = label.content, labelWidth = label.labelWidth, textOverflowMode = label.textOverflowMode;
|
|
@@ -229,13 +280,13 @@ var Label = /** @class */ (function (_super) {
|
|
|
229
280
|
? "".concat(transform, " rotate(").concat(rotate, "deg)")
|
|
230
281
|
: "".concat(transform, " rotate(").concat(vertical ? -0.25 : 0, "turn)"),
|
|
231
282
|
};
|
|
232
|
-
return ((0, jsx_runtime_1.jsx)("div", { id: "element-container-".concat(id), className: (0, classnames_1.default)('lf-label-editor-container'), style: containerStyle, onMouseDown: this.handleMouseDown, onDblClick: this.handleDbClick, onBlur: this.handleBlur, onMouseEnter: this.setHoverOn, onMouseOver: this.setHoverOn, onMouseLeave: this.setHoverOff, children: (0, jsx_runtime_1.jsx)("div", { ref: this.textRef, id: "editor-container-".concat(id), className: (0, classnames_1.default)('lf-label-editor', (_a = {
|
|
283
|
+
return ((0, jsx_runtime_1.jsx)("div", { id: "element-container-".concat(id), className: (0, classnames_1.default)('lf-label-editor-container'), style: containerStyle, onMouseDown: this.handleMouseDown, onMouseUp: this.handleMouseUp, onClick: this.handleClick, onDblClick: this.handleDbClick, onBlur: this.handleBlur, onMouseEnter: this.setHoverOn, onMouseOver: this.setHoverOn, onMouseLeave: this.setHoverOff, children: (0, jsx_runtime_1.jsx)("div", { ref: this.textRef, id: "editor-container-".concat(id), className: (0, classnames_1.default)('lf-label-editor', (_a = {
|
|
233
284
|
'lf-label-editor-dragging': isDragging,
|
|
234
285
|
'lf-label-editor-editing': isEditing,
|
|
235
|
-
'lf-label-editor-hover': !isEditing && isHovered
|
|
286
|
+
'lf-label-editor-hover': !isEditing && (isHovered || isSelected)
|
|
236
287
|
},
|
|
237
288
|
_a["lf-label-editor-".concat(textOverflowMode)] = !isEditing,
|
|
238
|
-
_a)), style: __assign({ maxWidth: "".concat(maxLabelWidth, "px"),
|
|
289
|
+
_a)), onInput: this.handleInput, style: __assign({ maxWidth: "".concat(maxLabelWidth, "px"), boxSizing: 'border-box', display: 'inline-block', background: isEditing || element.BaseType === 'edge' ? '#fff' : 'transparent' }, style), dangerouslySetInnerHTML: { __html: content } }) }));
|
|
239
290
|
};
|
|
240
291
|
Label = __decorate([
|
|
241
292
|
core_1.observer
|
package/lib/tools/label/index.js
CHANGED
|
@@ -37,7 +37,7 @@ var Label = /** @class */ (function () {
|
|
|
37
37
|
// TODO: 2. 做一些插件需要的事件监听
|
|
38
38
|
this.addEventListeners();
|
|
39
39
|
// TODO: 3. 自定义快捷键,比如 delete,选中 label 时,移除 label
|
|
40
|
-
|
|
40
|
+
this.rewriteShortcut();
|
|
41
41
|
// 插件中注册 LabelOverlay 工具,用于 label 的编辑
|
|
42
42
|
lf.tool.registerTool(LabelOverlay_1.default.toolName, LabelOverlay_1.default);
|
|
43
43
|
// LabelOverlay 和 TextEditTool 互斥,所以将它 disable 掉
|
|
@@ -149,7 +149,10 @@ var Label = /** @class */ (function () {
|
|
|
149
149
|
editable: true,
|
|
150
150
|
vertical: false,
|
|
151
151
|
};
|
|
152
|
-
|
|
152
|
+
// 全局的isMultiple为false,或全局isMultiple为true但局部isMultiple指明是false,或当前label长度已经达到上线时,不允许添加多个 label
|
|
153
|
+
if (!isMultiple ||
|
|
154
|
+
(isMultiple && curLabelOption.isMultiple === false) ||
|
|
155
|
+
len >= ((_c = curLabelOption === null || curLabelOption === void 0 ? void 0 : curLabelOption.maxCount) !== null && _c !== void 0 ? _c : maxCount)) {
|
|
153
156
|
return;
|
|
154
157
|
}
|
|
155
158
|
curLabelConfig.push(newLabel);
|
|
@@ -277,7 +280,51 @@ var Label = /** @class */ (function () {
|
|
|
277
280
|
};
|
|
278
281
|
// TODO: others methods ???
|
|
279
282
|
};
|
|
280
|
-
|
|
283
|
+
Label.prototype.rewriteShortcut = function () {
|
|
284
|
+
var _this = this;
|
|
285
|
+
var _a = this.lf, keyboard = _a.keyboard, graphModel = _a.graphModel;
|
|
286
|
+
var keyboardOptions = keyboard.options.keyboard;
|
|
287
|
+
keyboard.off(['backspace']);
|
|
288
|
+
keyboard.on(['backspace'], function () {
|
|
289
|
+
if (!(keyboardOptions === null || keyboardOptions === void 0 ? void 0 : keyboardOptions.enabled))
|
|
290
|
+
return true;
|
|
291
|
+
if (graphModel.textEditElement)
|
|
292
|
+
return true;
|
|
293
|
+
var elements = graphModel.getSelectElements(true);
|
|
294
|
+
_this.lf.clearSelectElements();
|
|
295
|
+
var editConfigModel = _this.lf.graphModel.editConfigModel;
|
|
296
|
+
elements.edges.forEach(function (edge) {
|
|
297
|
+
var properties = edge.properties;
|
|
298
|
+
if (properties &&
|
|
299
|
+
!(0, lodash_es_1.isEmpty)(properties._label) &&
|
|
300
|
+
editConfigModel.textMode === core_1.TextMode.LABEL) {
|
|
301
|
+
var newLabelList = properties._label.filter(function (label) { return !label.isSelected; });
|
|
302
|
+
// 如果两个labelList长度不一致,说明有选中的元素,此时backspace做的动作是删除label
|
|
303
|
+
if (!(0, lodash_es_1.isEqual)(newLabelList.length, properties._label.length)) {
|
|
304
|
+
var edgeModel = graphModel.getEdgeModelById(edge.id);
|
|
305
|
+
edgeModel === null || edgeModel === void 0 ? void 0 : edgeModel.setProperty('_label', newLabelList);
|
|
306
|
+
return;
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
edge.id && _this.lf.deleteEdge(edge.id);
|
|
310
|
+
});
|
|
311
|
+
elements.nodes.forEach(function (node) {
|
|
312
|
+
var properties = node.properties;
|
|
313
|
+
if (properties &&
|
|
314
|
+
!(0, lodash_es_1.isEmpty)(properties._label) &&
|
|
315
|
+
editConfigModel.textMode === core_1.TextMode.LABEL) {
|
|
316
|
+
var newLabelList = properties._label.filter(function (label) { return !label.isSelected; });
|
|
317
|
+
if (!(0, lodash_es_1.isEqual)(newLabelList.length, properties._label.length)) {
|
|
318
|
+
var nodeModel = graphModel.getNodeModelById(node.id);
|
|
319
|
+
nodeModel === null || nodeModel === void 0 ? void 0 : nodeModel.setProperty('_label', newLabelList);
|
|
320
|
+
return;
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
node.id && _this.lf.deleteNode(node.id);
|
|
324
|
+
});
|
|
325
|
+
return false;
|
|
326
|
+
});
|
|
327
|
+
};
|
|
281
328
|
/**
|
|
282
329
|
* 更新当前渲染使用的 Text or Label 模式
|
|
283
330
|
*/
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import LogicFlow, { Model, BaseNodeModel, BaseEdgeModel } from '@logicflow/core';
|
|
2
|
+
import AnchorConfig = Model.AnchorConfig;
|
|
3
|
+
import Point = LogicFlow.Point;
|
|
4
|
+
export type ProximityConnectProps = {
|
|
5
|
+
enable: boolean;
|
|
6
|
+
distance: number;
|
|
7
|
+
reverseDirection: boolean;
|
|
8
|
+
virtualEdgeStyle: Record<string, unknown>;
|
|
9
|
+
};
|
|
10
|
+
export declare class ProximityConnect {
|
|
11
|
+
static pluginName: string;
|
|
12
|
+
enable: boolean;
|
|
13
|
+
lf: LogicFlow;
|
|
14
|
+
closestNode?: BaseNodeModel;
|
|
15
|
+
currentDistance: number;
|
|
16
|
+
thresholdDistance: number;
|
|
17
|
+
currentNode?: BaseNodeModel;
|
|
18
|
+
reverseDirection: boolean;
|
|
19
|
+
currentAnchor?: AnchorConfig;
|
|
20
|
+
closestAnchor?: AnchorConfig;
|
|
21
|
+
virtualEdge?: BaseEdgeModel;
|
|
22
|
+
virtualEdgeStyle: Record<string, unknown>;
|
|
23
|
+
constructor({ lf, options, }: LogicFlow.IExtensionProps & {
|
|
24
|
+
options: ProximityConnectProps;
|
|
25
|
+
});
|
|
26
|
+
render(): void;
|
|
27
|
+
addEventListeners(): void;
|
|
28
|
+
handleNodeDrag(): void;
|
|
29
|
+
handleDrop(): void;
|
|
30
|
+
handleAnchorDrag(clientX: number, clientY: number): void;
|
|
31
|
+
findClosestAnchorOfNode(draggingNode: BaseNodeModel, allNodes: BaseNodeModel[]): void;
|
|
32
|
+
findClosestAnchorOfAnchor(draggingPoint: Point, allNodes: BaseNodeModel[]): void;
|
|
33
|
+
anchorAllowConnect(node: BaseNodeModel, anchor: AnchorConfig, draggingAnchor: AnchorConfig | undefined): boolean | undefined;
|
|
34
|
+
sameEdgeIsExist(edge: BaseEdgeModel): boolean;
|
|
35
|
+
addVirtualEdge(): void;
|
|
36
|
+
addActualEdge(): void;
|
|
37
|
+
setVirtualEdgeStyle(value: Record<string, unknown>): void;
|
|
38
|
+
setThresholdDistance(distance: number): void;
|
|
39
|
+
setReverseDirection(value: boolean): void;
|
|
40
|
+
setEnable(enable: boolean): void;
|
|
41
|
+
resetData(): void;
|
|
42
|
+
}
|