Skip to content

Commit

Permalink
fix(draw-canvas): new event: edge.add
Browse files Browse the repository at this point in the history
  • Loading branch information
weareoutman committed Aug 30, 2024
1 parent ae302a2 commit 620ddbb
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 25 deletions.
15 changes: 10 additions & 5 deletions bricks/diagram/docs/eo-draw-canvas.md
Original file line number Diff line number Diff line change
Expand Up @@ -369,6 +369,11 @@
args:
- targetCell
- <% EVENT.detail.cell %>
edge.add:
action: message.info
args:
- |
<% `Added an nice edge: ${JSON.stringify(EVENT.detail)}` %>
decorator.text.change:
action: message.info
args:
Expand Down Expand Up @@ -424,11 +429,11 @@
- <% CTX.targetCell.id %>
callback:
success:
target: eo-draw-canvas
method: addEdge
args:
- source: <% EVENT.detail.source.id %>
target: <% EVENT.detail.target.id %>
- target: eo-draw-canvas
method: addEdge
args:
- source: <% EVENT.detail.source.id %>
target: <% EVENT.detail.target.id %>
```
### Force layout
Expand Down
8 changes: 6 additions & 2 deletions bricks/diagram/src/draw-canvas/LineConnectorComponent.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,17 +9,20 @@ const HELPER_IMAGE =
"";
const HELPER_RADIUS = 5;
const HELPER_BG_RADIUS = 8;
const HALF_HELPER_RADIUS = HELPER_RADIUS / 2;

export interface LineConnectorComponentProps {
activeTarget: ActiveTarget | null;
transform: TransformLiteral;
smartConnectLineState: ConnectLineState | null;
disabled?: boolean;
}

export function LineConnectorComponent({
activeTarget,
transform,
smartConnectLineState,
disabled,
}: LineConnectorComponentProps): JSX.Element | null {
const { unsetHoverStateTimeoutRef, hoverState, setHoverState } =
useHoverStateContext();
Expand Down Expand Up @@ -47,6 +50,7 @@ export function LineConnectorComponent({
}, [setHoverState, unsetHoverStateTimeoutRef]);

const available =
!disabled &&
hoverState &&
(!!smartConnectLineState || !targetIsActive(hoverState.cell, activeTarget));

Expand Down Expand Up @@ -204,8 +208,8 @@ function ConnectPointComponent({
fill="transparent"
/>
<image
x={point.x - HELPER_RADIUS / 2}
y={point.y - HELPER_RADIUS / 2}
x={point.x - HALF_HELPER_RADIUS}
y={point.y - HALF_HELPER_RADIUS}
width={HELPER_RADIUS}
height={HELPER_RADIUS}
xlinkHref={HELPER_IMAGE}
Expand Down
39 changes: 28 additions & 11 deletions bricks/diagram/src/draw-canvas/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -341,6 +341,16 @@ class EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {
this.#cellContextMenu.emit(detail);
};

/**
* 通过画布绘图的方式添加边(手动调用 `addEdge` 方法不会触发该事件)。
*/
@event({ type: "edge.add" })
accessor #edgeAdd!: EventEmitter<EdgeCell>;

#handleEdgeAdd = (edge: EdgeCell) => {
this.#edgeAdd.emit(edge);

Check warning on line 351 in bricks/diagram/src/draw-canvas/index.tsx

View check run for this annotation

Codecov / codecov/patch

bricks/diagram/src/draw-canvas/index.tsx#L351

Added line #L351 was not covered by tests
};

@event({ type: "decorator.text.change" })
accessor #decoratorTextChange!: EventEmitter<DecoratorTextChangeDetail>;

Expand Down Expand Up @@ -547,6 +557,7 @@ class EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {
onCellResize={this.#handleCellResize}
onCellDelete={this.#handleCellDelete}
onCellsDelete={this.#handleCellsDelete}
onEdgeAdd={this.#handleEdgeAdd}
onCellContextMenu={this.#handleCellContextMenu}
onDecoratorTextChange={this.#handleDecoratorTextChange}
onContainerContainerChange={this.#handleContainerContainerChange}
Expand All @@ -566,6 +577,7 @@ export interface EoDrawCanvasComponentProps extends EoDrawCanvasProps {
onCellsMove(info: MoveCellPayload[]): void;
onCellsDelete(cells: Cell[]): void;
onCellContextMenu(detail: CellContextMenuDetail): void;
onEdgeAdd(detail: EdgeCell): void;
onDecoratorTextChange(detail: DecoratorTextChangeDetail): void;
onContainerContainerChange(detail: MoveCellPayload[]): void;
onScaleChange(scale: number): void;
Expand Down Expand Up @@ -620,6 +632,7 @@ function LegacyEoDrawCanvasComponent(
onCellsMove,
onCellsDelete,
onCellContextMenu,
onEdgeAdd,
onDecoratorTextChange,
onScaleChange,
onContainerContainerChange,
Expand Down Expand Up @@ -1021,22 +1034,24 @@ function LegacyEoDrawCanvasComponent(
exitPosition: NodePosition,
entryPosition: NodePosition
) {
const newEdge: EdgeCell = {

Check warning on line 1037 in bricks/diagram/src/draw-canvas/index.tsx

View check run for this annotation

Codecov / codecov/patch

bricks/diagram/src/draw-canvas/index.tsx#L1037

Added line #L1037 was not covered by tests
type: "edge",
source: source.id,
target: target.id,
view: {
exitPosition,
entryPosition,
...(isObject(lineConnector) ? lineConnector : null),
},
};
dispatch({

Check warning on line 1047 in bricks/diagram/src/draw-canvas/index.tsx

View check run for this annotation

Codecov / codecov/patch

bricks/diagram/src/draw-canvas/index.tsx#L1047

Added line #L1047 was not covered by tests
type: "add-edge",
payload: {
type: "edge",
source: source.id,
target: target.id,
view: {
exitPosition,
entryPosition,
...(isObject(lineConnector) ? lineConnector : null),
},
},
payload: newEdge,
});
onEdgeAdd(newEdge);

Check warning on line 1051 in bricks/diagram/src/draw-canvas/index.tsx

View check run for this annotation

Codecov / codecov/patch

bricks/diagram/src/draw-canvas/index.tsx#L1051

Added line #L1051 was not covered by tests
},
}),
[smartConnectLineState, hoverState, lineConnector]
[smartConnectLineState, hoverState, lineConnector, onEdgeAdd]
);

useEffect(() => {
Expand Down Expand Up @@ -1088,6 +1103,7 @@ function LegacyEoDrawCanvasComponent(
root.removeEventListener("mousedown", onMouseDown);
};
}, [transform, cells, dragBehavior, onSwitchActiveTarget]);

return (
<HoverStateContext.Provider value={hoverStateContextValue}>
<svg
Expand Down Expand Up @@ -1183,6 +1199,7 @@ function LegacyEoDrawCanvasComponent(
<LineConnectorComponent
activeTarget={activeTarget}
transform={transform}
disabled={!!connectLineState}
smartConnectLineState={smartConnectLineState}
/>
)}
Expand Down
7 changes: 0 additions & 7 deletions bricks/diagram/src/draw-canvas/interfaces.ts
Original file line number Diff line number Diff line change
Expand Up @@ -198,13 +198,6 @@ export interface SmartConnectLineState {
exitPosition: NodeConnectPoint;
}

export interface SmartConnectLineState {
source: NodeCell;
from: PositionTuple;
offset: PositionTuple;
exitPosition: NodeConnectPoint;
}

export interface Deferred<T> {
resolve: (value: T) => void;
reject: (reason: unknown) => void;
Expand Down

0 comments on commit 620ddbb

Please sign in to comment.