@xyflow/system 0.0.15 → 0.0.16
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/dist/esm/index.js +82 -63
- package/dist/esm/index.mjs +82 -63
- package/dist/esm/types/general.d.ts +1 -1
- package/dist/esm/types/general.d.ts.map +1 -1
- package/dist/esm/types/nodes.d.ts +3 -4
- package/dist/esm/types/nodes.d.ts.map +1 -1
- package/dist/esm/utils/general.d.ts +1 -0
- package/dist/esm/utils/general.d.ts.map +1 -1
- package/dist/esm/utils/graph.d.ts +25 -6
- package/dist/esm/utils/graph.d.ts.map +1 -1
- package/dist/esm/utils/marker.d.ts +3 -1
- package/dist/esm/utils/marker.d.ts.map +1 -1
- package/dist/esm/xydrag/XYDrag.d.ts +5 -5
- package/dist/esm/xydrag/XYDrag.d.ts.map +1 -1
- package/dist/esm/xyhandle/XYHandle.d.ts.map +1 -1
- package/dist/umd/index.js +1 -1
- package/dist/umd/types/general.d.ts +1 -1
- package/dist/umd/types/general.d.ts.map +1 -1
- package/dist/umd/types/nodes.d.ts +3 -4
- package/dist/umd/types/nodes.d.ts.map +1 -1
- package/dist/umd/utils/general.d.ts +1 -0
- package/dist/umd/utils/general.d.ts.map +1 -1
- package/dist/umd/utils/graph.d.ts +25 -6
- package/dist/umd/utils/graph.d.ts.map +1 -1
- package/dist/umd/utils/marker.d.ts +3 -1
- package/dist/umd/utils/marker.d.ts.map +1 -1
- package/dist/umd/xydrag/XYDrag.d.ts +5 -5
- package/dist/umd/xydrag/XYDrag.d.ts.map +1 -1
- package/dist/umd/xyhandle/XYHandle.d.ts.map +1 -1
- package/package.json +2 -2
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { type Transform, type XYPosition, type Rect, type NodeOrigin, type NodeBase, type EdgeBase, type FitViewParamsBase, type FitViewOptionsBase,
|
|
1
|
+
import { type Transform, type XYPosition, type Rect, type NodeOrigin, type NodeBase, type EdgeBase, type FitViewParamsBase, type FitViewOptionsBase, CoordinateExtent, OnError, OnBeforeDeleteBase, NodeLookup } from '../types';
|
|
2
2
|
/**
|
|
3
3
|
* Test whether an object is useable as an Edge
|
|
4
4
|
* @public
|
|
@@ -37,18 +37,24 @@ export declare const getOutgoers: <NodeType extends NodeBase<any, string | undef
|
|
|
37
37
|
export declare const getIncomers: <NodeType extends NodeBase<any, string | undefined> = NodeBase<any, string | undefined>, EdgeType extends EdgeBase<any> = EdgeBase<any>>(node: NodeType | {
|
|
38
38
|
id: string;
|
|
39
39
|
}, nodes: NodeType[], edges: EdgeType[]) => NodeType[];
|
|
40
|
-
export declare const getNodePositionWithOrigin: (node: NodeBase | undefined, nodeOrigin?: NodeOrigin) =>
|
|
40
|
+
export declare const getNodePositionWithOrigin: (node: NodeBase | undefined, nodeOrigin?: NodeOrigin) => {
|
|
41
|
+
position: XYPosition;
|
|
41
42
|
positionAbsolute: XYPosition;
|
|
42
43
|
};
|
|
44
|
+
export type GetNodesBoundsParams = {
|
|
45
|
+
nodeOrigin?: NodeOrigin;
|
|
46
|
+
useRelativePosition?: boolean;
|
|
47
|
+
};
|
|
43
48
|
/**
|
|
44
49
|
* Determines a bounding box that contains all given nodes in an array
|
|
45
50
|
* @public
|
|
46
51
|
* @remarks Useful when combined with {@link getViewportForBounds} to calculate the correct transform to fit the given nodes in a viewport.
|
|
47
52
|
* @param nodes - Nodes to calculate the bounds for
|
|
48
|
-
* @param nodeOrigin - Origin of the nodes: [0, 0] - top left, [0.5, 0.5] - center
|
|
53
|
+
* @param params.nodeOrigin - Origin of the nodes: [0, 0] - top left, [0.5, 0.5] - center
|
|
54
|
+
* @param params.useRelativePosition - Whether to use the relative or absolute node positions
|
|
49
55
|
* @returns Bounding box enclosing all nodes
|
|
50
56
|
*/
|
|
51
|
-
export declare const getNodesBounds: (nodes: NodeBase[],
|
|
57
|
+
export declare const getNodesBounds: (nodes: NodeBase[], params?: GetNodesBoundsParams) => Rect;
|
|
52
58
|
export declare const getNodesInside: <NodeType extends NodeBase<any, string | undefined>>(nodes: NodeType[], rect: Rect, [tx, ty, tScale]?: Transform, partially?: boolean, excludeNonSelectableNodes?: boolean, nodeOrigin?: NodeOrigin) => NodeType[];
|
|
53
59
|
/**
|
|
54
60
|
* Get all connecting edges for a given set of nodes
|
|
@@ -58,7 +64,20 @@ export declare const getNodesInside: <NodeType extends NodeBase<any, string | un
|
|
|
58
64
|
*/
|
|
59
65
|
export declare const getConnectedEdges: <NodeType extends NodeBase<any, string | undefined> = NodeBase<any, string | undefined>, EdgeType extends EdgeBase<any> = EdgeBase<any>>(nodes: NodeType[], edges: EdgeType[]) => EdgeType[];
|
|
60
66
|
export declare function fitView<Params extends FitViewParamsBase<NodeBase>, Options extends FitViewOptionsBase<NodeBase>>({ nodes, width, height, panZoom, minZoom, maxZoom, nodeOrigin }: Params, options?: Options): boolean;
|
|
61
|
-
|
|
67
|
+
/**
|
|
68
|
+
* This function calculates the next position of a node, taking into account the node's extent, parent node, and origin.
|
|
69
|
+
*
|
|
70
|
+
* @internal
|
|
71
|
+
* @returns position, positionAbsolute
|
|
72
|
+
*/
|
|
73
|
+
export declare function calculateNodePosition<NodeType extends NodeBase>({ nodeId, nextPosition, nodeLookup, nodeOrigin, nodeExtent, onError, }: {
|
|
74
|
+
nodeId: string;
|
|
75
|
+
nextPosition: XYPosition;
|
|
76
|
+
nodeLookup: NodeLookup<NodeType>;
|
|
77
|
+
nodeOrigin?: NodeOrigin;
|
|
78
|
+
nodeExtent?: CoordinateExtent;
|
|
79
|
+
onError?: OnError;
|
|
80
|
+
}): {
|
|
62
81
|
position: XYPosition;
|
|
63
82
|
positionAbsolute: XYPosition;
|
|
64
83
|
};
|
|
@@ -77,7 +96,7 @@ export declare function getElementsToRemove<NodeType extends NodeBase = NodeBase
|
|
|
77
96
|
edgesToRemove: Partial<EdgeType>[];
|
|
78
97
|
nodes: NodeType[];
|
|
79
98
|
edges: EdgeType[];
|
|
80
|
-
onBeforeDelete?:
|
|
99
|
+
onBeforeDelete?: OnBeforeDeleteBase<NodeType, EdgeType>;
|
|
81
100
|
}): Promise<{
|
|
82
101
|
nodes: NodeType[];
|
|
83
102
|
edges: EdgeType[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"graph.d.ts","sourceRoot":"","sources":["../../src/utils/graph.ts"],"names":[],"mappings":"AAYA,OAAO,EACL,KAAK,SAAS,EACd,KAAK,UAAU,EACf,KAAK,IAAI,EACT,KAAK,UAAU,EACf,KAAK,QAAQ,EACb,KAAK,QAAQ,EACb,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,
|
|
1
|
+
{"version":3,"file":"graph.d.ts","sourceRoot":"","sources":["../../src/utils/graph.ts"],"names":[],"mappings":"AAYA,OAAO,EACL,KAAK,SAAS,EACd,KAAK,UAAU,EACf,KAAK,IAAI,EACT,KAAK,UAAU,EACf,KAAK,QAAQ,EACb,KAAK,QAAQ,EACb,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,gBAAgB,EAChB,OAAO,EACP,kBAAkB,EAClB,UAAU,EACX,MAAM,UAAU,CAAC;AAGlB;;;;;;GAMG;AACH,eAAO,MAAM,UAAU,4DAAmD,GAAG,wBACd,CAAC;AAEhE;;;;;;GAMG;AACH,eAAO,MAAM,UAAU,oGAAmD,GAAG,wBACR,CAAC;AAEtE;;;;;;;GAOG;AACH,eAAO,MAAM,WAAW;QACC,MAAM;sDAgB9B,CAAC;AAEF;;;;;;;GAOG;AACH,eAAO,MAAM,WAAW;QACC,MAAM;sDAe9B,CAAC;AAEF,eAAO,MAAM,yBAAyB,SAC9B,QAAQ,GAAG,SAAS;cAEb,UAAU;sBAAoB,UAAU;CA+BtD,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG;IACjC,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,mBAAmB,CAAC,EAAE,OAAO,CAAC;CAC/B,CAAC;AAEF;;;;;;;;GAQG;AACH,eAAO,MAAM,cAAc,UAClB,QAAQ,EAAE,WACT,oBAAoB,KAC3B,IAqBF,CAAC;AAEF,eAAO,MAAM,cAAc,gFAEnB,IAAI,gIAqCX,CAAC;AAEF;;;;;GAKG;AACH,eAAO,MAAM,iBAAiB,8LAU7B,CAAC;AAEF,wBAAgB,OAAO,CAAC,MAAM,SAAS,iBAAiB,CAAC,QAAQ,CAAC,EAAE,OAAO,SAAS,kBAAkB,CAAC,QAAQ,CAAC,EAC9G,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,UAAmB,EAAE,EAAE,MAAM,EAChF,OAAO,CAAC,EAAE,OAAO,WA8BlB;AAoBD;;;;;GAKG;AACH,wBAAgB,qBAAqB,CAAC,QAAQ,SAAS,QAAQ,EAAE,EAC/D,MAAM,EACN,YAAY,EACZ,UAAU,EACV,UAAmB,EACnB,UAAU,EACV,OAAO,GACR,EAAE;IACD,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,UAAU,CAAC;IACzB,UAAU,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;IACjC,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,UAAU,CAAC,EAAE,gBAAgB,CAAC;IAC9B,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,GAAG;IAAE,QAAQ,EAAE,UAAU,CAAC;IAAC,gBAAgB,EAAE,UAAU,CAAA;CAAE,CA8CzD;AAED;;;;;;;;;GASG;AACH,wBAAsB,mBAAmB,CAAC,QAAQ,SAAS,QAAQ,GAAG,QAAQ,EAAE,QAAQ,SAAS,QAAQ,GAAG,QAAQ,EAAE,EACpH,aAAkB,EAClB,aAAkB,EAClB,KAAK,EACL,KAAK,EACL,cAAc,GACf,EAAE;IACD,aAAa,EAAE,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;IACnC,aAAa,EAAE,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;IACnC,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,cAAc,CAAC,EAAE,kBAAkB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;CACzD,GAAG,OAAO,CAAC;IACV,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,KAAK,EAAE,QAAQ,EAAE,CAAC;CACnB,CAAC,CA+CD"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import type { EdgeBase, EdgeMarkerType, MarkerProps } from '../types';
|
|
2
2
|
export declare function getMarkerId(marker: EdgeMarkerType | undefined, id?: string | null): string;
|
|
3
|
-
export declare function createMarkerIds(edges: EdgeBase[], { id, defaultColor }: {
|
|
3
|
+
export declare function createMarkerIds(edges: EdgeBase[], { id, defaultColor, defaultMarkerStart, defaultMarkerEnd, }: {
|
|
4
4
|
id?: string | null;
|
|
5
5
|
defaultColor?: string;
|
|
6
|
+
defaultMarkerStart?: EdgeMarkerType;
|
|
7
|
+
defaultMarkerEnd?: EdgeMarkerType;
|
|
6
8
|
}): MarkerProps[];
|
|
7
9
|
//# sourceMappingURL=marker.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"marker.d.ts","sourceRoot":"","sources":["../../src/utils/marker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAc,cAAc,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAElF,wBAAgB,WAAW,CAAC,MAAM,EAAE,cAAc,GAAG,SAAS,EAAE,EAAE,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,MAAM,CAe1F;AAED,wBAAgB,eAAe,CAC7B,KAAK,EAAE,QAAQ,EAAE,EACjB,
|
|
1
|
+
{"version":3,"file":"marker.d.ts","sourceRoot":"","sources":["../../src/utils/marker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAc,cAAc,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAElF,wBAAgB,WAAW,CAAC,MAAM,EAAE,cAAc,GAAG,SAAS,EAAE,EAAE,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,MAAM,CAe1F;AAED,wBAAgB,eAAe,CAC7B,KAAK,EAAE,QAAQ,EAAE,EACjB,EACE,EAAE,EACF,YAAY,EACZ,kBAAkB,EAClB,gBAAgB,GACjB,EAAE;IACD,EAAE,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,kBAAkB,CAAC,EAAE,cAAc,CAAC;IACpC,gBAAgB,CAAC,EAAE,cAAc,CAAC;CACnC,iBAmBF"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import type { NodeBase, NodeDragItem, EdgeBase, CoordinateExtent, NodeOrigin, OnError, SnapGrid, Transform, PanBy,
|
|
1
|
+
import type { NodeBase, NodeDragItem, EdgeBase, CoordinateExtent, NodeOrigin, OnError, SnapGrid, Transform, PanBy, OnSelectionDrag, UpdateNodePositions } from '../types';
|
|
2
2
|
export type OnDrag = (event: MouseEvent, dragItems: NodeDragItem[], node: NodeBase, nodes: NodeBase[]) => void;
|
|
3
|
-
type StoreItems = {
|
|
3
|
+
type StoreItems<OnNodeDrag> = {
|
|
4
4
|
nodes: NodeBase[];
|
|
5
5
|
nodeLookup: Map<string, NodeBase>;
|
|
6
6
|
edges: EdgeBase[];
|
|
@@ -29,9 +29,9 @@ type StoreItems = {
|
|
|
29
29
|
onSelectionDragStop?: OnSelectionDrag;
|
|
30
30
|
updateNodePositions: UpdateNodePositions;
|
|
31
31
|
};
|
|
32
|
-
export type XYDragParams = {
|
|
32
|
+
export type XYDragParams<OnNodeDrag> = {
|
|
33
33
|
domNode: Element;
|
|
34
|
-
getStoreItems: () => StoreItems
|
|
34
|
+
getStoreItems: () => StoreItems<OnNodeDrag>;
|
|
35
35
|
onDragStart?: OnDrag;
|
|
36
36
|
onDrag?: OnDrag;
|
|
37
37
|
onDragStop?: OnDrag;
|
|
@@ -48,6 +48,6 @@ export type DragUpdateParams = {
|
|
|
48
48
|
nodeId?: string;
|
|
49
49
|
domNode: Element;
|
|
50
50
|
};
|
|
51
|
-
export declare function XYDrag({ domNode, onNodeMouseDown, getStoreItems, onDragStart, onDrag, onDragStop, }: XYDragParams): XYDragInstance;
|
|
51
|
+
export declare function XYDrag<OnNodeDrag extends (e: any, nodes: any, node: any) => void | undefined>({ domNode, onNodeMouseDown, getStoreItems, onDragStart, onDrag, onDragStop, }: XYDragParams<OnNodeDrag>): XYDragInstance;
|
|
52
52
|
export {};
|
|
53
53
|
//# sourceMappingURL=XYDrag.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"XYDrag.d.ts","sourceRoot":"","sources":["../../src/xydrag/XYDrag.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EACV,QAAQ,EACR,YAAY,EAGZ,QAAQ,EACR,gBAAgB,EAChB,UAAU,EACV,OAAO,EACP,QAAQ,EACR,SAAS,EACT,KAAK,EACL,
|
|
1
|
+
{"version":3,"file":"XYDrag.d.ts","sourceRoot":"","sources":["../../src/xydrag/XYDrag.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EACV,QAAQ,EACR,YAAY,EAGZ,QAAQ,EACR,gBAAgB,EAChB,UAAU,EACV,OAAO,EACP,QAAQ,EACR,SAAS,EACT,KAAK,EACL,eAAe,EACf,mBAAmB,EAEpB,MAAM,UAAU,CAAC;AAElB,MAAM,MAAM,MAAM,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,IAAI,CAAC;AAE/G,KAAK,UAAU,CAAC,UAAU,IAAI;IAC5B,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IAClC,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,UAAU,EAAE,gBAAgB,CAAC;IAC7B,QAAQ,EAAE,QAAQ,CAAC;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,UAAU,CAAC;IACvB,oBAAoB,EAAE,OAAO,CAAC;IAC9B,OAAO,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IACzB,SAAS,EAAE,SAAS,CAAC;IACrB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,cAAc,EAAE,OAAO,CAAC;IACxB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,KAAK,EAAE,KAAK,CAAC;IACb,qBAAqB,EAAE,CAAC,MAAM,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,QAAQ,EAAE,CAAC;QAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,CAAA;KAAE,KAAK,IAAI,CAAC;IACrF,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,eAAe,CAAC,EAAE,UAAU,CAAC;IAC7B,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,cAAc,CAAC,EAAE,UAAU,CAAC;IAC5B,oBAAoB,CAAC,EAAE,eAAe,CAAC;IACvC,eAAe,CAAC,EAAE,eAAe,CAAC;IAClC,mBAAmB,CAAC,EAAE,eAAe,CAAC;IACtC,mBAAmB,EAAE,mBAAmB,CAAC;CAC1C,CAAC;AAEF,MAAM,MAAM,YAAY,CAAC,UAAU,IAAI;IACrC,OAAO,EAAE,OAAO,CAAC;IACjB,aAAa,EAAE,MAAM,UAAU,CAAC,UAAU,CAAC,CAAC;IAC5C,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;CACxC,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,MAAM,EAAE,CAAC,MAAM,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC3C,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,OAAO,CAAC;CAClB,CAAC;AAGF,wBAAgB,MAAM,CAAC,UAAU,SAAS,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,GAAG,SAAS,EAAE,EAC7F,OAAO,EACP,eAAe,EACf,aAAa,EACb,WAAW,EACX,MAAM,EACN,UAAU,GACX,EAAE,YAAY,CAAC,UAAU,CAAC,GAAG,cAAc,CAyP3C"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"XYHandle.d.ts","sourceRoot":"","sources":["../../src/xyhandle/XYHandle.ts"],"names":[],"mappings":"AACA,OAAO,EACL,cAAc,EACd,KAAK,SAAS,EACd,KAAK,cAAc,EACnB,KAAK,UAAU,EACf,KAAK,UAAU,EACf,KAAK,KAAK,EACV,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,KAAK,gBAAgB,EACrB,KAAK,YAAY,EACjB,KAAK,gBAAgB,EACrB,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EACtB,MAAM,UAAU,CAAC;AAIlB,MAAM,MAAM,mBAAmB,GAAG;IAChC,gBAAgB,EAAE,OAAO,CAAC;IAC1B,cAAc,EAAE,cAAc,CAAC;IAC/B,gBAAgB,EAAE,MAAM,CAAC;IACzB,OAAO,EAAE,cAAc,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,eAAe,CAAC,EAAE,UAAU,CAAC;IAC7B,gBAAgB,EAAE,gBAAgB,CAAC;IACnC,KAAK,EAAE,KAAK,CAAC;IACb,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,iBAAiB,CAAC,EAAE,iBAAiB,CAAC;IACtC,eAAe,CAAC,EAAE,CAAC,GAAG,EAAE,UAAU,GAAG,UAAU,KAAK,IAAI,CAAC;IACzD,YAAY,EAAE,MAAM,SAAS,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,MAAM,EAAE,IAAI,CAAC,gBAAgB,EAAE,QAAQ,GAAG,IAAI,GAAG,MAAM,CAAC,GAAG,IAAI,CAAC;IAChE,cAAc,EAAE,cAAc,CAAC;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,QAAQ,EAAE,UAAU,CAAC;IACrB,iBAAiB,CAAC,EAAE,iBAAiB,CAAC;IACtC,GAAG,EAAE,QAAQ,GAAG,UAAU,CAAC;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,aAAa,EAAE,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU,EAAE,MAAM,EAAE,mBAAmB,KAAK,IAAI,CAAC;IACrF,OAAO,EAAE,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU,EAAE,MAAM,EAAE,aAAa,KAAK,MAAM,CAAC;CAC5E,CAAC;AAEF,KAAK,MAAM,GAAG;IACZ,aAAa,EAAE,OAAO,GAAG,IAAI,CAAC;IAC9B,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC;IAC9B,SAAS,EAAE,gBAAgB,GAAG,IAAI,CAAC;CACpC,CAAC;
|
|
1
|
+
{"version":3,"file":"XYHandle.d.ts","sourceRoot":"","sources":["../../src/xyhandle/XYHandle.ts"],"names":[],"mappings":"AACA,OAAO,EACL,cAAc,EACd,KAAK,SAAS,EACd,KAAK,cAAc,EACnB,KAAK,UAAU,EACf,KAAK,UAAU,EACf,KAAK,KAAK,EACV,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,KAAK,gBAAgB,EACrB,KAAK,YAAY,EACjB,KAAK,gBAAgB,EACrB,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EACtB,MAAM,UAAU,CAAC;AAIlB,MAAM,MAAM,mBAAmB,GAAG;IAChC,gBAAgB,EAAE,OAAO,CAAC;IAC1B,cAAc,EAAE,cAAc,CAAC;IAC/B,gBAAgB,EAAE,MAAM,CAAC;IACzB,OAAO,EAAE,cAAc,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,eAAe,CAAC,EAAE,UAAU,CAAC;IAC7B,gBAAgB,EAAE,gBAAgB,CAAC;IACnC,KAAK,EAAE,KAAK,CAAC;IACb,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,iBAAiB,CAAC,EAAE,iBAAiB,CAAC;IACtC,eAAe,CAAC,EAAE,CAAC,GAAG,EAAE,UAAU,GAAG,UAAU,KAAK,IAAI,CAAC;IACzD,YAAY,EAAE,MAAM,SAAS,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,MAAM,EAAE,IAAI,CAAC,gBAAgB,EAAE,QAAQ,GAAG,IAAI,GAAG,MAAM,CAAC,GAAG,IAAI,CAAC;IAChE,cAAc,EAAE,cAAc,CAAC;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,QAAQ,EAAE,UAAU,CAAC;IACrB,iBAAiB,CAAC,EAAE,iBAAiB,CAAC;IACtC,GAAG,EAAE,QAAQ,GAAG,UAAU,CAAC;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,aAAa,EAAE,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU,EAAE,MAAM,EAAE,mBAAmB,KAAK,IAAI,CAAC;IACrF,OAAO,EAAE,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU,EAAE,MAAM,EAAE,aAAa,KAAK,MAAM,CAAC;CAC5E,CAAC;AAEF,KAAK,MAAM,GAAG;IACZ,aAAa,EAAE,OAAO,GAAG,IAAI,CAAC;IAC9B,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC;IAC9B,SAAS,EAAE,gBAAgB,GAAG,IAAI,CAAC;CACpC,CAAC;AAiQF,eAAO,MAAM,QAAQ,EAAE,gBAGtB,CAAC"}
|
package/dist/umd/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).XYFlowSystem={})}(this,(function(t){"use strict";const e={error001:()=>"[React Flow]: Seems like you have not used zustand provider as an ancestor. Help: https://reactflow.dev/error#001",error002:()=>"It looks like you've created a new nodeTypes or edgeTypes object. If this wasn't on purpose please define the nodeTypes/edgeTypes outside of the component or memoize them.",error003:t=>`Node type "${t}" not found. Using fallback type "default".`,error004:()=>"The React Flow parent container needs a width and a height to render the graph.",error005:()=>"Only child nodes can use a parent extent.",error006:()=>"Can't create edge. An edge needs a source and a target.",error007:t=>`The old edge with id=${t} does not exist.`,error009:t=>`Marker type "${t}" doesn't exist.`,error008:(t,{id:e,sourceHandle:n,targetHandle:o})=>`Couldn't create edge for ${t} handle id: "${n?o:n}", edge id: ${e}.`,error010:()=>"Handle: No node id found. Make sure to only use a Handle inside a custom Node.",error011:t=>`Edge type "${t}" not found. Using fallback type "default".`,error012:t=>`Node with id "${t}" does not exist, it may have been removed. This can happen when a node is deleted before the "onNodeClick" handler is called.`},n=Symbol.for("internals"),o=[[Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY],[Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY]];var r,i,a,s,u,c;t.ConnectionMode=void 0,(r=t.ConnectionMode||(t.ConnectionMode={})).Strict="strict",r.Loose="loose",t.PanOnScrollMode=void 0,(i=t.PanOnScrollMode||(t.PanOnScrollMode={})).Free="free",i.Vertical="vertical",i.Horizontal="horizontal",t.SelectionMode=void 0,(a=t.SelectionMode||(t.SelectionMode={})).Partial="partial",a.Full="full",t.ConnectionLineType=void 0,(s=t.ConnectionLineType||(t.ConnectionLineType={})).Bezier="default",s.Straight="straight",s.Step="step",s.SmoothStep="smoothstep",s.SimpleBezier="simplebezier",t.MarkerType=void 0,(u=t.MarkerType||(t.MarkerType={})).Arrow="arrow",u.ArrowClosed="arrowclosed",t.Position=void 0,(c=t.Position||(t.Position={})).Left="left",c.Top="top",c.Right="right",c.Bottom="bottom";const l=t=>"id"in t&&"source"in t&&"target"in t,h=(t,e=[0,0])=>{if(!t)return{x:0,y:0,positionAbsolute:{x:0,y:0}};const n=(t.computed?.width??t.width??0)*e[0],o=(t.computed?.height??t.height??0)*e[1],r={x:t.position.x-n,y:t.position.y-o};return{...r,positionAbsolute:t.computed?.positionAbsolute?{x:t.computed.positionAbsolute.x-n,y:t.computed.positionAbsolute.y-o}:r}},d=(t,e=[0,0])=>{if(0===t.length)return{x:0,y:0,width:0,height:0};const n=t.reduce(((t,n)=>{const{x:o,y:r}=h(n,n.origin||e);return x(t,w({x:o,y:r,width:n.computed?.width??n.width??0,height:n.computed?.height??n.height??0}))}),{x:1/0,y:1/0,x2:-1/0,y2:-1/0});return _(n)},f=(t,e)=>{const n=new Set;return t.forEach((t=>{n.add(t.id)})),e.filter((t=>n.has(t.source)||n.has(t.target)))};function p(t,n,o,r,i=[0,0],a){const s=function(t,e){return e&&"parent"!==e?[e[0],[e[1][0]-(t.computed?.width??0),e[1][1]-(t.computed?.height??0)]]:e}(t,t.extent||r);let u=s,c=null,l={x:0,y:0};if(t.parentNode&&(c=o.find((e=>e.id===t.parentNode))||null,l=c?h(c,c.origin||i).positionAbsolute:l),"parent"!==t.extent||t.expandParent)t.extent&&t.parentNode&&"parent"!==t.extent&&(u=[[t.extent[0][0]+l.x,t.extent[0][1]+l.y],[t.extent[1][0]+l.x,t.extent[1][1]+l.y]]);else{const n=t.computed?.width,o=t.computed?.height;if(t.parentNode&&n&&o){const e=t.origin||i;u=c&&M(c.computed?.width)&&M(c.computed?.height)?[[l.x+n*e[0],l.y+o*e[1]],[l.x+(c.computed?.width??0)-n+n*e[0],l.y+(c.computed?.height??0)-o+o*e[1]]]:u}else a?.("005",e.error005()),u=s}const d=u&&"parent"!==u?m(n,u):n;return{position:{x:d.x-l.x,y:d.y-l.y},positionAbsolute:d}}const g=(t,e=0,n=1)=>Math.min(Math.max(t,e),n),m=(t={x:0,y:0},e)=>({x:g(t.x,e[0][0],e[1][0]),y:g(t.y,e[0][1],e[1][1])}),y=(t,e,n)=>t<e?g(Math.abs(t-e),1,50)/50:t>n?-g(Math.abs(t-n),1,50)/50:0,v=(t,e)=>[20*y(t.x,35,e.width-35),20*y(t.y,35,e.height-35)],x=(t,e)=>({x:Math.min(t.x,e.x),y:Math.min(t.y,e.y),x2:Math.max(t.x2,e.x2),y2:Math.max(t.y2,e.y2)}),w=({x:t,y:e,width:n,height:o})=>({x:t,y:e,x2:t+n,y2:e+o}),_=({x:t,y:e,x2:n,y2:o})=>({x:t,y:e,width:n-t,height:o-e}),b=(t,e=[0,0])=>{const{positionAbsolute:n}=h(t,t.origin||e);return{...n,width:t.computed?.width??t.width??0,height:t.computed?.height??t.height??0}},P=(t,e=[0,0])=>{const{positionAbsolute:n}=h(t,t.origin||e);return{...n,x2:n.x+(t.computed?.width??t.width??0),y2:n.y+(t.computed?.height??t.height??0)}},E=(t,e)=>{const n=Math.max(0,Math.min(t.x+t.width,e.x+e.width)-Math.max(t.x,e.x)),o=Math.max(0,Math.min(t.y+t.height,e.y+e.height)-Math.max(t.y,e.y));return Math.ceil(n*o)},M=t=>!isNaN(t)&&isFinite(t),S=(t,e)=>{},N=(t,e=[1,1])=>({x:e[0]*Math.round(t.x/e[0]),y:e[1]*Math.round(t.y/e[1])}),z=({x:t,y:e},[n,o,r],i=!1,a=[1,1])=>{const s={x:(t-n)/r,y:(e-o)/r};return i?N(s,a):s},A=({x:t,y:e},[n,o,r])=>({x:t*r+n,y:e*r+o}),T=(t,e,n,o,r,i)=>{const a=e/(t.width*(1+i)),s=n/(t.height*(1+i)),u=Math.min(a,s),c=g(u,o,r);return{x:e/2-(t.x+t.width/2)*c,y:n/2-(t.y+t.height/2)*c,zoom:c}},$=()=>"undefined"!=typeof navigator&&navigator?.userAgent?.indexOf("Mac")>=0;function k(t,{snapGrid:e=[0,0],snapToGrid:n=!1,transform:o}){const{x:r,y:i}=H(t),a=z({x:r,y:i},o),{x:s,y:u}=n?N(a,e):a;return{xSnapped:s,ySnapped:u,...a}}const C=t=>({width:t.offsetWidth,height:t.offsetHeight}),I=t=>t.getRootNode?.()||window?.document,O=["INPUT","SELECT","TEXTAREA"];const X=t=>"clientX"in t,H=(t,e)=>{const n=X(t),o=n?t.clientX:t.touches?.[0].clientX,r=n?t.clientY:t.touches?.[0].clientY;return{x:o-(e?.left??0),y:r-(e?.top??0)}},Y=(t,e,n,o=[0,0])=>{const r=e.querySelectorAll(t);if(!r||!r.length)return null;const i=Array.from(r),a=e.getBoundingClientRect(),s=a.width*o[0],u=a.height*o[1];return i.map((t=>{const e=t.getBoundingClientRect();return{id:t.getAttribute("data-handleid"),position:t.getAttribute("data-handlepos"),x:(e.left-a.left-s)/n,y:(e.top-a.top-u)/n,...C(t)}}))};function R({sourceX:t,sourceY:e,targetX:n,targetY:o,sourceControlX:r,sourceControlY:i,targetControlX:a,targetControlY:s}){const u=.125*t+.375*r+.375*a+.125*n,c=.125*e+.375*i+.375*s+.125*o;return[u,c,Math.abs(u-t),Math.abs(c-e)]}function B(t,e){return t>=0?.5*t:25*e*Math.sqrt(-t)}function D({pos:e,x1:n,y1:o,x2:r,y2:i,c:a}){switch(e){case t.Position.Left:return[n-B(n-r,a),o];case t.Position.Right:return[n+B(r-n,a),o];case t.Position.Top:return[n,o-B(o-i,a)];case t.Position.Bottom:return[n,o+B(i-o,a)]}}function L({sourceX:t,sourceY:e,targetX:n,targetY:o}){const r=Math.abs(n-t)/2,i=n<t?n+r:n-r,a=Math.abs(o-e)/2;return[i,o<e?o+a:o-a,r,a]}const V=({source:t,sourceHandle:e,target:n,targetHandle:o})=>`xy-edge__${t}${e||""}-${n}${o||""}`;const q={[t.Position.Left]:{x:-1,y:0},[t.Position.Right]:{x:1,y:0},[t.Position.Top]:{x:0,y:-1},[t.Position.Bottom]:{x:0,y:1}},Z=({source:e,sourcePosition:n=t.Position.Bottom,target:o})=>n===t.Position.Left||n===t.Position.Right?e.x<o.x?{x:1,y:0}:{x:-1,y:0}:e.y<o.y?{x:0,y:1}:{x:0,y:-1},G=(t,e)=>Math.sqrt(Math.pow(e.x-t.x,2)+Math.pow(e.y-t.y,2));function j(t){return!(!t?.[n]?.handleBounds&&!t?.handles?.length||!t?.computed?.width&&!t?.width)}function F(t){if(!t)return null;const e=[],n=[];for(const o of t)o.width=o.width||1,o.height=o.height||1,"source"===o.type?e.push(o):"target"===o.type&&n.push(o);return{source:e,target:n}}function W(e,n,o=null){const r=(o?.x??0)+(n.computed?.positionAbsolute?.x??0),i=(o?.y??0)+(n.computed?.positionAbsolute?.y??0),a=o?.width||(n?.computed?.width??n?.width??0),s=o?.height||(n?.computed?.height??n?.height??0);switch(e){case t.Position.Top:return[r+a/2,i];case t.Position.Right:return[r+a,i+s/2];case t.Position.Bottom:return[r+a/2,i+s];case t.Position.Left:return[r,i+s/2]}}function K(t,e){return t?1!==t.length&&e?e&&t.find((t=>t.id===e))||null:t[0]:null}function U(t,e){if(!t)return"";if("string"==typeof t)return t;return`${e?`${e}__`:""}${Object.keys(t).sort().map((e=>`${e}=${t[e]}`)).join("&")}`}function Q(t,e,o=[0,0],r){return t.map((i=>{if(i.parentNode&&!e.has(i.parentNode))throw new Error(`Parent node ${i.parentNode} not found`);if(i.parentNode||r?.[i.id]){const a=i.parentNode?e.get(i.parentNode):null,{x:s,y:u,z:c}=J(i,t,e,{...i.position,z:i[n]?.z??0},a?.origin||o),l=s!==i.computed?.positionAbsolute?.x||u!==i.computed?.positionAbsolute?.y;i.computed.positionAbsolute=l?{x:s,y:u}:i.computed?.positionAbsolute,i[n].z=c,r?.[i.id]&&(i[n].isParent=!0)}return i}))}function J(t,e,o,r,i){if(!t.parentNode)return r;const a=o.get(t.parentNode),s=h(a,a?.origin||i);return J(a,e,o,{x:(r.x??0)+s.x,y:(r.y??0)+s.y,z:(a[n]?.z??0)>(r.z??0)?a[n]?.z??0:r.z??0},a.origin||i)}var tt={value:()=>{}};function et(){for(var t,e=0,n=arguments.length,o={};e<n;++e){if(!(t=arguments[e]+"")||t in o||/[\s.]/.test(t))throw new Error("illegal type: "+t);o[t]=[]}return new nt(o)}function nt(t){this._=t}function ot(t,e){for(var n,o=0,r=t.length;o<r;++o)if((n=t[o]).name===e)return n.value}function rt(t,e,n){for(var o=0,r=t.length;o<r;++o)if(t[o].name===e){t[o]=tt,t=t.slice(0,o).concat(t.slice(o+1));break}return null!=n&&t.push({name:e,value:n}),t}nt.prototype=et.prototype={constructor:nt,on:function(t,e){var n,o,r=this._,i=(o=r,(t+"").trim().split(/^|\s+/).map((function(t){var e="",n=t.indexOf(".");if(n>=0&&(e=t.slice(n+1),t=t.slice(0,n)),t&&!o.hasOwnProperty(t))throw new Error("unknown type: "+t);return{type:t,name:e}}))),a=-1,s=i.length;if(!(arguments.length<2)){if(null!=e&&"function"!=typeof e)throw new Error("invalid callback: "+e);for(;++a<s;)if(n=(t=i[a]).type)r[n]=rt(r[n],t.name,e);else if(null==e)for(n in r)r[n]=rt(r[n],t.name,null);return this}for(;++a<s;)if((n=(t=i[a]).type)&&(n=ot(r[n],t.name)))return n},copy:function(){var t={},e=this._;for(var n in e)t[n]=e[n].slice();return new nt(t)},call:function(t,e){if((n=arguments.length-2)>0)for(var n,o,r=new Array(n),i=0;i<n;++i)r[i]=arguments[i+2];if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(i=0,n=(o=this._[t]).length;i<n;++i)o[i].value.apply(e,r)},apply:function(t,e,n){if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(var o=this._[t],r=0,i=o.length;r<i;++r)o[r].value.apply(e,n)}};var it="http://www.w3.org/1999/xhtml",at={svg:"http://www.w3.org/2000/svg",xhtml:it,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function st(t){var e=t+="",n=e.indexOf(":");return n>=0&&"xmlns"!==(e=t.slice(0,n))&&(t=t.slice(n+1)),at.hasOwnProperty(e)?{space:at[e],local:t}:t}function ut(t){return function(){var e=this.ownerDocument,n=this.namespaceURI;return n===it&&e.documentElement.namespaceURI===it?e.createElement(t):e.createElementNS(n,t)}}function ct(t){return function(){return this.ownerDocument.createElementNS(t.space,t.local)}}function lt(t){var e=st(t);return(e.local?ct:ut)(e)}function ht(){}function dt(t){return null==t?ht:function(){return this.querySelector(t)}}function ft(){return[]}function pt(t){return null==t?ft:function(){return this.querySelectorAll(t)}}function gt(t){return function(){return null==(e=t.apply(this,arguments))?[]:Array.isArray(e)?e:Array.from(e);var e}}function mt(t){return function(){return this.matches(t)}}function yt(t){return function(e){return e.matches(t)}}var vt=Array.prototype.find;function xt(){return this.firstElementChild}var wt=Array.prototype.filter;function _t(){return Array.from(this.children)}function bt(t){return new Array(t.length)}function Pt(t,e){this.ownerDocument=t.ownerDocument,this.namespaceURI=t.namespaceURI,this._next=null,this._parent=t,this.__data__=e}function Et(t,e,n,o,r,i){for(var a,s=0,u=e.length,c=i.length;s<c;++s)(a=e[s])?(a.__data__=i[s],o[s]=a):n[s]=new Pt(t,i[s]);for(;s<u;++s)(a=e[s])&&(r[s]=a)}function Mt(t,e,n,o,r,i,a){var s,u,c,l=new Map,h=e.length,d=i.length,f=new Array(h);for(s=0;s<h;++s)(u=e[s])&&(f[s]=c=a.call(u,u.__data__,s,e)+"",l.has(c)?r[s]=u:l.set(c,u));for(s=0;s<d;++s)c=a.call(t,i[s],s,i)+"",(u=l.get(c))?(o[s]=u,u.__data__=i[s],l.delete(c)):n[s]=new Pt(t,i[s]);for(s=0;s<h;++s)(u=e[s])&&l.get(f[s])===u&&(r[s]=u)}function St(t){return t.__data__}function Nt(t){return"object"==typeof t&&"length"in t?t:Array.from(t)}function zt(t,e){return t<e?-1:t>e?1:t>=e?0:NaN}function At(t){return function(){this.removeAttribute(t)}}function Tt(t){return function(){this.removeAttributeNS(t.space,t.local)}}function $t(t,e){return function(){this.setAttribute(t,e)}}function kt(t,e){return function(){this.setAttributeNS(t.space,t.local,e)}}function Ct(t,e){return function(){var n=e.apply(this,arguments);null==n?this.removeAttribute(t):this.setAttribute(t,n)}}function It(t,e){return function(){var n=e.apply(this,arguments);null==n?this.removeAttributeNS(t.space,t.local):this.setAttributeNS(t.space,t.local,n)}}function Ot(t){return t.ownerDocument&&t.ownerDocument.defaultView||t.document&&t||t.defaultView}function Xt(t){return function(){this.style.removeProperty(t)}}function Ht(t,e,n){return function(){this.style.setProperty(t,e,n)}}function Yt(t,e,n){return function(){var o=e.apply(this,arguments);null==o?this.style.removeProperty(t):this.style.setProperty(t,o,n)}}function Rt(t,e){return t.style.getPropertyValue(e)||Ot(t).getComputedStyle(t,null).getPropertyValue(e)}function Bt(t){return function(){delete this[t]}}function Dt(t,e){return function(){this[t]=e}}function Lt(t,e){return function(){var n=e.apply(this,arguments);null==n?delete this[t]:this[t]=n}}function Vt(t){return t.trim().split(/^|\s+/)}function qt(t){return t.classList||new Zt(t)}function Zt(t){this._node=t,this._names=Vt(t.getAttribute("class")||"")}function Gt(t,e){for(var n=qt(t),o=-1,r=e.length;++o<r;)n.add(e[o])}function jt(t,e){for(var n=qt(t),o=-1,r=e.length;++o<r;)n.remove(e[o])}function Ft(t){return function(){Gt(this,t)}}function Wt(t){return function(){jt(this,t)}}function Kt(t,e){return function(){(e.apply(this,arguments)?Gt:jt)(this,t)}}function Ut(){this.textContent=""}function Qt(t){return function(){this.textContent=t}}function Jt(t){return function(){var e=t.apply(this,arguments);this.textContent=null==e?"":e}}function te(){this.innerHTML=""}function ee(t){return function(){this.innerHTML=t}}function ne(t){return function(){var e=t.apply(this,arguments);this.innerHTML=null==e?"":e}}function oe(){this.nextSibling&&this.parentNode.appendChild(this)}function re(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function ie(){return null}function ae(){var t=this.parentNode;t&&t.removeChild(this)}function se(){var t=this.cloneNode(!1),e=this.parentNode;return e?e.insertBefore(t,this.nextSibling):t}function ue(){var t=this.cloneNode(!0),e=this.parentNode;return e?e.insertBefore(t,this.nextSibling):t}function ce(t){return function(){var e=this.__on;if(e){for(var n,o=0,r=-1,i=e.length;o<i;++o)n=e[o],t.type&&n.type!==t.type||n.name!==t.name?e[++r]=n:this.removeEventListener(n.type,n.listener,n.options);++r?e.length=r:delete this.__on}}}function le(t,e,n){return function(){var o,r=this.__on,i=function(t){return function(e){t.call(this,e,this.__data__)}}(e);if(r)for(var a=0,s=r.length;a<s;++a)if((o=r[a]).type===t.type&&o.name===t.name)return this.removeEventListener(o.type,o.listener,o.options),this.addEventListener(o.type,o.listener=i,o.options=n),void(o.value=e);this.addEventListener(t.type,i,n),o={type:t.type,name:t.name,value:e,listener:i,options:n},r?r.push(o):this.__on=[o]}}function he(t,e,n){var o=Ot(t),r=o.CustomEvent;"function"==typeof r?r=new r(e,n):(r=o.document.createEvent("Event"),n?(r.initEvent(e,n.bubbles,n.cancelable),r.detail=n.detail):r.initEvent(e,!1,!1)),t.dispatchEvent(r)}function de(t,e){return function(){return he(this,t,e)}}function fe(t,e){return function(){return he(this,t,e.apply(this,arguments))}}Pt.prototype={constructor:Pt,appendChild:function(t){return this._parent.insertBefore(t,this._next)},insertBefore:function(t,e){return this._parent.insertBefore(t,e)},querySelector:function(t){return this._parent.querySelector(t)},querySelectorAll:function(t){return this._parent.querySelectorAll(t)}},Zt.prototype={add:function(t){this._names.indexOf(t)<0&&(this._names.push(t),this._node.setAttribute("class",this._names.join(" ")))},remove:function(t){var e=this._names.indexOf(t);e>=0&&(this._names.splice(e,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(t){return this._names.indexOf(t)>=0}};var pe=[null];function ge(t,e){this._groups=t,this._parents=e}function me(){return new ge([[document.documentElement]],pe)}function ye(t){return"string"==typeof t?new ge([[document.querySelector(t)]],[document.documentElement]):new ge([[t]],pe)}function ve(t,e){if(t=function(t){let e;for(;e=t.sourceEvent;)t=e;return t}(t),void 0===e&&(e=t.currentTarget),e){var n=e.ownerSVGElement||e;if(n.createSVGPoint){var o=n.createSVGPoint();return o.x=t.clientX,o.y=t.clientY,[(o=o.matrixTransform(e.getScreenCTM().inverse())).x,o.y]}if(e.getBoundingClientRect){var r=e.getBoundingClientRect();return[t.clientX-r.left-e.clientLeft,t.clientY-r.top-e.clientTop]}}return[t.pageX,t.pageY]}ge.prototype=me.prototype={constructor:ge,select:function(t){"function"!=typeof t&&(t=dt(t));for(var e=this._groups,n=e.length,o=new Array(n),r=0;r<n;++r)for(var i,a,s=e[r],u=s.length,c=o[r]=new Array(u),l=0;l<u;++l)(i=s[l])&&(a=t.call(i,i.__data__,l,s))&&("__data__"in i&&(a.__data__=i.__data__),c[l]=a);return new ge(o,this._parents)},selectAll:function(t){t="function"==typeof t?gt(t):pt(t);for(var e=this._groups,n=e.length,o=[],r=[],i=0;i<n;++i)for(var a,s=e[i],u=s.length,c=0;c<u;++c)(a=s[c])&&(o.push(t.call(a,a.__data__,c,s)),r.push(a));return new ge(o,r)},selectChild:function(t){return this.select(null==t?xt:function(t){return function(){return vt.call(this.children,t)}}("function"==typeof t?t:yt(t)))},selectChildren:function(t){return this.selectAll(null==t?_t:function(t){return function(){return wt.call(this.children,t)}}("function"==typeof t?t:yt(t)))},filter:function(t){"function"!=typeof t&&(t=mt(t));for(var e=this._groups,n=e.length,o=new Array(n),r=0;r<n;++r)for(var i,a=e[r],s=a.length,u=o[r]=[],c=0;c<s;++c)(i=a[c])&&t.call(i,i.__data__,c,a)&&u.push(i);return new ge(o,this._parents)},data:function(t,e){if(!arguments.length)return Array.from(this,St);var n,o=e?Mt:Et,r=this._parents,i=this._groups;"function"!=typeof t&&(n=t,t=function(){return n});for(var a=i.length,s=new Array(a),u=new Array(a),c=new Array(a),l=0;l<a;++l){var h=r[l],d=i[l],f=d.length,p=Nt(t.call(h,h&&h.__data__,l,r)),g=p.length,m=u[l]=new Array(g),y=s[l]=new Array(g);o(h,d,m,y,c[l]=new Array(f),p,e);for(var v,x,w=0,_=0;w<g;++w)if(v=m[w]){for(w>=_&&(_=w+1);!(x=y[_])&&++_<g;);v._next=x||null}}return(s=new ge(s,r))._enter=u,s._exit=c,s},enter:function(){return new ge(this._enter||this._groups.map(bt),this._parents)},exit:function(){return new ge(this._exit||this._groups.map(bt),this._parents)},join:function(t,e,n){var o=this.enter(),r=this,i=this.exit();return"function"==typeof t?(o=t(o))&&(o=o.selection()):o=o.append(t+""),null!=e&&(r=e(r))&&(r=r.selection()),null==n?i.remove():n(i),o&&r?o.merge(r).order():r},merge:function(t){for(var e=t.selection?t.selection():t,n=this._groups,o=e._groups,r=n.length,i=o.length,a=Math.min(r,i),s=new Array(r),u=0;u<a;++u)for(var c,l=n[u],h=o[u],d=l.length,f=s[u]=new Array(d),p=0;p<d;++p)(c=l[p]||h[p])&&(f[p]=c);for(;u<r;++u)s[u]=n[u];return new ge(s,this._parents)},selection:function(){return this},order:function(){for(var t=this._groups,e=-1,n=t.length;++e<n;)for(var o,r=t[e],i=r.length-1,a=r[i];--i>=0;)(o=r[i])&&(a&&4^o.compareDocumentPosition(a)&&a.parentNode.insertBefore(o,a),a=o);return this},sort:function(t){function e(e,n){return e&&n?t(e.__data__,n.__data__):!e-!n}t||(t=zt);for(var n=this._groups,o=n.length,r=new Array(o),i=0;i<o;++i){for(var a,s=n[i],u=s.length,c=r[i]=new Array(u),l=0;l<u;++l)(a=s[l])&&(c[l]=a);c.sort(e)}return new ge(r,this._parents).order()},call:function(){var t=arguments[0];return arguments[0]=this,t.apply(null,arguments),this},nodes:function(){return Array.from(this)},node:function(){for(var t=this._groups,e=0,n=t.length;e<n;++e)for(var o=t[e],r=0,i=o.length;r<i;++r){var a=o[r];if(a)return a}return null},size:function(){let t=0;for(const e of this)++t;return t},empty:function(){return!this.node()},each:function(t){for(var e=this._groups,n=0,o=e.length;n<o;++n)for(var r,i=e[n],a=0,s=i.length;a<s;++a)(r=i[a])&&t.call(r,r.__data__,a,i);return this},attr:function(t,e){var n=st(t);if(arguments.length<2){var o=this.node();return n.local?o.getAttributeNS(n.space,n.local):o.getAttribute(n)}return this.each((null==e?n.local?Tt:At:"function"==typeof e?n.local?It:Ct:n.local?kt:$t)(n,e))},style:function(t,e,n){return arguments.length>1?this.each((null==e?Xt:"function"==typeof e?Yt:Ht)(t,e,null==n?"":n)):Rt(this.node(),t)},property:function(t,e){return arguments.length>1?this.each((null==e?Bt:"function"==typeof e?Lt:Dt)(t,e)):this.node()[t]},classed:function(t,e){var n=Vt(t+"");if(arguments.length<2){for(var o=qt(this.node()),r=-1,i=n.length;++r<i;)if(!o.contains(n[r]))return!1;return!0}return this.each(("function"==typeof e?Kt:e?Ft:Wt)(n,e))},text:function(t){return arguments.length?this.each(null==t?Ut:("function"==typeof t?Jt:Qt)(t)):this.node().textContent},html:function(t){return arguments.length?this.each(null==t?te:("function"==typeof t?ne:ee)(t)):this.node().innerHTML},raise:function(){return this.each(oe)},lower:function(){return this.each(re)},append:function(t){var e="function"==typeof t?t:lt(t);return this.select((function(){return this.appendChild(e.apply(this,arguments))}))},insert:function(t,e){var n="function"==typeof t?t:lt(t),o=null==e?ie:"function"==typeof e?e:dt(e);return this.select((function(){return this.insertBefore(n.apply(this,arguments),o.apply(this,arguments)||null)}))},remove:function(){return this.each(ae)},clone:function(t){return this.select(t?ue:se)},datum:function(t){return arguments.length?this.property("__data__",t):this.node().__data__},on:function(t,e,n){var o,r,i=function(t){return t.trim().split(/^|\s+/).map((function(t){var e="",n=t.indexOf(".");return n>=0&&(e=t.slice(n+1),t=t.slice(0,n)),{type:t,name:e}}))}(t+""),a=i.length;if(!(arguments.length<2)){for(s=e?le:ce,o=0;o<a;++o)this.each(s(i[o],e,n));return this}var s=this.node().__on;if(s)for(var u,c=0,l=s.length;c<l;++c)for(o=0,u=s[c];o<a;++o)if((r=i[o]).type===u.type&&r.name===u.name)return u.value},dispatch:function(t,e){return this.each(("function"==typeof e?fe:de)(t,e))},[Symbol.iterator]:function*(){for(var t=this._groups,e=0,n=t.length;e<n;++e)for(var o,r=t[e],i=0,a=r.length;i<a;++i)(o=r[i])&&(yield o)}};const xe={passive:!1},we={capture:!0,passive:!1};function _e(t){t.stopImmediatePropagation()}function be(t){t.preventDefault(),t.stopImmediatePropagation()}function Pe(t){var e=t.document.documentElement,n=ye(t).on("dragstart.drag",be,we);"onselectstart"in e?n.on("selectstart.drag",be,we):(e.__noselect=e.style.MozUserSelect,e.style.MozUserSelect="none")}function Ee(t,e){var n=t.document.documentElement,o=ye(t).on("dragstart.drag",null);e&&(o.on("click.drag",be,we),setTimeout((function(){o.on("click.drag",null)}),0)),"onselectstart"in n?o.on("selectstart.drag",null):(n.style.MozUserSelect=n.__noselect,delete n.__noselect)}var Me=t=>()=>t;function Se(t,{sourceEvent:e,subject:n,target:o,identifier:r,active:i,x:a,y:s,dx:u,dy:c,dispatch:l}){Object.defineProperties(this,{type:{value:t,enumerable:!0,configurable:!0},sourceEvent:{value:e,enumerable:!0,configurable:!0},subject:{value:n,enumerable:!0,configurable:!0},target:{value:o,enumerable:!0,configurable:!0},identifier:{value:r,enumerable:!0,configurable:!0},active:{value:i,enumerable:!0,configurable:!0},x:{value:a,enumerable:!0,configurable:!0},y:{value:s,enumerable:!0,configurable:!0},dx:{value:u,enumerable:!0,configurable:!0},dy:{value:c,enumerable:!0,configurable:!0},_:{value:l}})}function Ne(t){return!t.ctrlKey&&!t.button}function ze(){return this.parentNode}function Ae(t,e){return null==e?{x:t.x,y:t.y}:e}function Te(){return navigator.maxTouchPoints||"ontouchstart"in this}function $e(){var t,e,n,o,r=Ne,i=ze,a=Ae,s=Te,u={},c=et("start","drag","end"),l=0,h=0;function d(t){t.on("mousedown.drag",f).filter(s).on("touchstart.drag",m).on("touchmove.drag",y,xe).on("touchend.drag touchcancel.drag",v).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function f(a,s){if(!o&&r.call(this,a,s)){var u=x(this,i.call(this,a,s),a,s,"mouse");u&&(ye(a.view).on("mousemove.drag",p,we).on("mouseup.drag",g,we),Pe(a.view),_e(a),n=!1,t=a.clientX,e=a.clientY,u("start",a))}}function p(o){if(be(o),!n){var r=o.clientX-t,i=o.clientY-e;n=r*r+i*i>h}u.mouse("drag",o)}function g(t){ye(t.view).on("mousemove.drag mouseup.drag",null),Ee(t.view,n),be(t),u.mouse("end",t)}function m(t,e){if(r.call(this,t,e)){var n,o,a=t.changedTouches,s=i.call(this,t,e),u=a.length;for(n=0;n<u;++n)(o=x(this,s,t,e,a[n].identifier,a[n]))&&(_e(t),o("start",t,a[n]))}}function y(t){var e,n,o=t.changedTouches,r=o.length;for(e=0;e<r;++e)(n=u[o[e].identifier])&&(be(t),n("drag",t,o[e]))}function v(t){var e,n,r=t.changedTouches,i=r.length;for(o&&clearTimeout(o),o=setTimeout((function(){o=null}),500),e=0;e<i;++e)(n=u[r[e].identifier])&&(_e(t),n("end",t,r[e]))}function x(t,e,n,o,r,i){var s,h,f,p=c.copy(),g=ve(i||n,e);if(null!=(f=a.call(t,new Se("beforestart",{sourceEvent:n,target:d,identifier:r,active:l,x:g[0],y:g[1],dx:0,dy:0,dispatch:p}),o)))return s=f.x-g[0]||0,h=f.y-g[1]||0,function n(i,a,c){var m,y=g;switch(i){case"start":u[r]=n,m=l++;break;case"end":delete u[r],--l;case"drag":g=ve(c||a,e),m=l}p.call(i,t,new Se(i,{sourceEvent:a,subject:f,target:d,identifier:r,active:m,x:g[0]+s,y:g[1]+h,dx:g[0]-y[0],dy:g[1]-y[1],dispatch:p}),o)}}return d.filter=function(t){return arguments.length?(r="function"==typeof t?t:Me(!!t),d):r},d.container=function(t){return arguments.length?(i="function"==typeof t?t:Me(t),d):i},d.subject=function(t){return arguments.length?(a="function"==typeof t?t:Me(t),d):a},d.touchable=function(t){return arguments.length?(s="function"==typeof t?t:Me(!!t),d):s},d.on=function(){var t=c.on.apply(c,arguments);return t===c?d:t},d.clickDistance=function(t){return arguments.length?(h=(t=+t)*t,d):Math.sqrt(h)},d}function ke(t){return(e,n,o)=>t?.(e,o)}function Ce(t,e){if(!t.parentNode)return!1;const n=e.find((t=>t.id===t.parentNode));return!!n&&(!!n.selected||Ce(n,e))}function Ie(t,e,n){let o=t;do{if(o?.matches(e))return!0;if(o===n)return!1;o=o.parentElement}while(o);return!1}function Oe(t,e,n,o){return t.filter((n=>(n.selected||n.id===o)&&(!n.parentNode||!Ce(n,t))&&(n.draggable||e&&void 0===n.draggable))).map((t=>({id:t.id,position:t.position||{x:0,y:0},distance:{x:n.x-(t.computed?.positionAbsolute?.x??0),y:n.y-(t.computed?.positionAbsolute?.y??0)},delta:{x:0,y:0},extent:t.extent,parentNode:t.parentNode,origin:t.origin,expandParent:t.expandParent,computed:{positionAbsolute:t.computed?.positionAbsolute||{x:0,y:0},width:t.computed?.width||0,height:t.computed?.height||0}})))}function Xe({nodeId:t,dragItems:e,nodeLookup:n}){const o=e.map((t=>({...n.get(t.id),position:t.position,computed:{...t.computed,positionAbsolute:t.computed.positionAbsolute}})));return[t?o.find((e=>e.id===t)):o[0],o]}function He(t,e,n,o){return(e[n]||[]).reduce(((e,r)=>(`${t.id}-${r.id}-${n}`!==o&&e.push({id:r.id||null,type:n,nodeId:t.id,x:(t.computed?.positionAbsolute?.x??0)+r.x+r.width/2,y:(t.computed?.positionAbsolute?.y??0)+r.y+r.height/2}),e)),[])}function Ye(t,e){return t||(e?.classList.contains("target")?"target":e?.classList.contains("source")?"source":null)}function Re(t,e){t?.classList.remove("valid","connecting",`${e}-flow__handle-valid`,`${e}-flow__handle-connecting`)}function Be(t,e){let n=null;return e?n="valid":t&&!e&&(n="invalid"),n}Se.prototype.on=function(){var t=this._.on.apply(this._,arguments);return t===this._?this:t};const De=()=>!0;let Le=null;function Ve(e,{handle:n,connectionMode:o,fromNodeId:r,fromHandleId:i,fromType:a,doc:s,lib:u,flowId:c,isValidConnection:l=De}){const h="target"===a,d=s.querySelector(`.${u}-flow__handle[data-id="${c}-${n?.nodeId}-${n?.id}-${n?.type}"]`),{x:f,y:p}=H(e),g=s.elementFromPoint(f,p),m=g?.classList.contains(`${u}-flow__handle`)?g:d,y={handleDomNode:m,isValid:!1,connection:null,endHandle:null};if(m){const e=Ye(void 0,m),n=m.getAttribute("data-nodeid"),a=m.getAttribute("data-handleid"),s=m.classList.contains("connectable"),u=m.classList.contains("connectableend");if(!n)return y;const c={source:h?n:r,sourceHandle:h?a:i,target:h?r:n,targetHandle:h?i:a};y.connection=c;s&&u&&(o===t.ConnectionMode.Strict?h&&"source"===e||!h&&"target"===e:n!==r||a!==i)&&(y.endHandle={nodeId:n,handleId:a,type:e},y.isValid=l(c))}return y}const qe={onPointerDown:function(t,{connectionMode:e,connectionRadius:o,handleId:r,nodeId:i,edgeUpdaterType:a,isTarget:s,domNode:u,nodes:c,lib:l,autoPanOnConnect:h,flowId:d,panBy:f,cancelConnection:p,onConnectStart:g,onConnect:m,onConnectEnd:y,isValidConnection:x=De,onEdgeUpdateEnd:w,updateConnection:_,getTransform:b}){const P=I(t.target);let E,M=0;const{x:S,y:N}=H(t),T=P?.elementFromPoint(S,N),$=Ye(a,T),k=u?.getBoundingClientRect();if(!k||!$)return;let C,O=H(t,k),X=!1,Y=null,R=!1,B=null;const D=function({nodes:t,nodeId:e,handleId:o,handleType:r}){return t.reduce(((t,i)=>{if(i[n]){const{handleBounds:a}=i[n];let s=[],u=[];a&&(s=He(i,a,"source",`${e}-${o}-${r}`),u=He(i,a,"target",`${e}-${o}-${r}`)),t.push(...s,...u)}return t}),[])}({nodes:c,nodeId:i,handleId:r,handleType:$});function L(){if(!h||!k)return;const[t,e]=v(O,k);f({x:t,y:e}),M=requestAnimationFrame(L)}function V(t){const n=b();O=H(t,k),E=function(t,e,n){let o=[],r=1/0;return n.forEach((n=>{const i=Math.sqrt(Math.pow(n.x-t.x,2)+Math.pow(n.y-t.y,2));i<=e&&(i<r?o=[n]:i===r&&o.push(n),r=i)})),o.length?1===o.length?o[0]:o.find((t=>"target"===t.type))||o[0]:null}(z(O,n,!1,[1,1]),o,D),X||(L(),X=!0);const a=Ve(t,{handle:E,connectionMode:e,fromNodeId:i,fromHandleId:r,fromType:s?"target":"source",isValidConnection:x,doc:P,lib:l,flowId:d});if(B=a.handleDomNode,Y=a.connection,R=a.isValid,_({connectionStartHandle:Le,connectionPosition:E&&R?A({x:E.x,y:E.y},n):O,connectionStatus:Be(!!E,R),connectionEndHandle:a.endHandle}),!E&&!R&&!B)return Re(C,l);Y?.source!==Y?.target&&B&&(Re(C,l),C=B,B.classList.add("connecting",`${l}-flow__handle-connecting`),B.classList.toggle("valid",R),B.classList.toggle(`${l}-flow__handle-valid`,R))}function q(t){(E||B)&&Y&&R&&m?.(Y),y?.(t),a&&w?.(t),Re(C,l),p(),cancelAnimationFrame(M),X=!1,R=!1,Y=null,B=null,Le=null,P.removeEventListener("mousemove",V),P.removeEventListener("mouseup",q),P.removeEventListener("touchmove",V),P.removeEventListener("touchend",q)}Le={nodeId:i,handleId:r,type:$},_({connectionPosition:O,connectionStatus:null,connectionStartHandle:Le,connectionEndHandle:null}),g?.(t,{nodeId:i,handleId:r,handleType:$}),P.addEventListener("mousemove",V),P.addEventListener("mouseup",q),P.addEventListener("touchmove",V),P.addEventListener("touchend",q)},isValid:Ve};function Ze(t,e,n){t.prototype=e.prototype=n,n.constructor=t}function Ge(t,e){var n=Object.create(t.prototype);for(var o in e)n[o]=e[o];return n}function je(){}var Fe=.7,We=1/Fe,Ke="\\s*([+-]?\\d+)\\s*",Ue="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",Qe="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",Je=/^#([0-9a-f]{3,8})$/,tn=new RegExp(`^rgb\\(${Ke},${Ke},${Ke}\\)$`),en=new RegExp(`^rgb\\(${Qe},${Qe},${Qe}\\)$`),nn=new RegExp(`^rgba\\(${Ke},${Ke},${Ke},${Ue}\\)$`),on=new RegExp(`^rgba\\(${Qe},${Qe},${Qe},${Ue}\\)$`),rn=new RegExp(`^hsl\\(${Ue},${Qe},${Qe}\\)$`),an=new RegExp(`^hsla\\(${Ue},${Qe},${Qe},${Ue}\\)$`),sn={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};function un(){return this.rgb().formatHex()}function cn(){return this.rgb().formatRgb()}function ln(t){var e,n;return t=(t+"").trim().toLowerCase(),(e=Je.exec(t))?(n=e[1].length,e=parseInt(e[1],16),6===n?hn(e):3===n?new pn(e>>8&15|e>>4&240,e>>4&15|240&e,(15&e)<<4|15&e,1):8===n?dn(e>>24&255,e>>16&255,e>>8&255,(255&e)/255):4===n?dn(e>>12&15|e>>8&240,e>>8&15|e>>4&240,e>>4&15|240&e,((15&e)<<4|15&e)/255):null):(e=tn.exec(t))?new pn(e[1],e[2],e[3],1):(e=en.exec(t))?new pn(255*e[1]/100,255*e[2]/100,255*e[3]/100,1):(e=nn.exec(t))?dn(e[1],e[2],e[3],e[4]):(e=on.exec(t))?dn(255*e[1]/100,255*e[2]/100,255*e[3]/100,e[4]):(e=rn.exec(t))?wn(e[1],e[2]/100,e[3]/100,1):(e=an.exec(t))?wn(e[1],e[2]/100,e[3]/100,e[4]):sn.hasOwnProperty(t)?hn(sn[t]):"transparent"===t?new pn(NaN,NaN,NaN,0):null}function hn(t){return new pn(t>>16&255,t>>8&255,255&t,1)}function dn(t,e,n,o){return o<=0&&(t=e=n=NaN),new pn(t,e,n,o)}function fn(t,e,n,o){return 1===arguments.length?((r=t)instanceof je||(r=ln(r)),r?new pn((r=r.rgb()).r,r.g,r.b,r.opacity):new pn):new pn(t,e,n,null==o?1:o);var r}function pn(t,e,n,o){this.r=+t,this.g=+e,this.b=+n,this.opacity=+o}function gn(){return`#${xn(this.r)}${xn(this.g)}${xn(this.b)}`}function mn(){const t=yn(this.opacity);return`${1===t?"rgb(":"rgba("}${vn(this.r)}, ${vn(this.g)}, ${vn(this.b)}${1===t?")":`, ${t})`}`}function yn(t){return isNaN(t)?1:Math.max(0,Math.min(1,t))}function vn(t){return Math.max(0,Math.min(255,Math.round(t)||0))}function xn(t){return((t=vn(t))<16?"0":"")+t.toString(16)}function wn(t,e,n,o){return o<=0?t=e=n=NaN:n<=0||n>=1?t=e=NaN:e<=0&&(t=NaN),new bn(t,e,n,o)}function _n(t){if(t instanceof bn)return new bn(t.h,t.s,t.l,t.opacity);if(t instanceof je||(t=ln(t)),!t)return new bn;if(t instanceof bn)return t;var e=(t=t.rgb()).r/255,n=t.g/255,o=t.b/255,r=Math.min(e,n,o),i=Math.max(e,n,o),a=NaN,s=i-r,u=(i+r)/2;return s?(a=e===i?(n-o)/s+6*(n<o):n===i?(o-e)/s+2:(e-n)/s+4,s/=u<.5?i+r:2-i-r,a*=60):s=u>0&&u<1?0:a,new bn(a,s,u,t.opacity)}function bn(t,e,n,o){this.h=+t,this.s=+e,this.l=+n,this.opacity=+o}function Pn(t){return(t=(t||0)%360)<0?t+360:t}function En(t){return Math.max(0,Math.min(1,t||0))}function Mn(t,e,n){return 255*(t<60?e+(n-e)*t/60:t<180?n:t<240?e+(n-e)*(240-t)/60:e)}Ze(je,ln,{copy(t){return Object.assign(new this.constructor,this,t)},displayable(){return this.rgb().displayable()},hex:un,formatHex:un,formatHex8:function(){return this.rgb().formatHex8()},formatHsl:function(){return _n(this).formatHsl()},formatRgb:cn,toString:cn}),Ze(pn,fn,Ge(je,{brighter(t){return t=null==t?We:Math.pow(We,t),new pn(this.r*t,this.g*t,this.b*t,this.opacity)},darker(t){return t=null==t?Fe:Math.pow(Fe,t),new pn(this.r*t,this.g*t,this.b*t,this.opacity)},rgb(){return this},clamp(){return new pn(vn(this.r),vn(this.g),vn(this.b),yn(this.opacity))},displayable(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:gn,formatHex:gn,formatHex8:function(){return`#${xn(this.r)}${xn(this.g)}${xn(this.b)}${xn(255*(isNaN(this.opacity)?1:this.opacity))}`},formatRgb:mn,toString:mn})),Ze(bn,(function(t,e,n,o){return 1===arguments.length?_n(t):new bn(t,e,n,null==o?1:o)}),Ge(je,{brighter(t){return t=null==t?We:Math.pow(We,t),new bn(this.h,this.s,this.l*t,this.opacity)},darker(t){return t=null==t?Fe:Math.pow(Fe,t),new bn(this.h,this.s,this.l*t,this.opacity)},rgb(){var t=this.h%360+360*(this.h<0),e=isNaN(t)||isNaN(this.s)?0:this.s,n=this.l,o=n+(n<.5?n:1-n)*e,r=2*n-o;return new pn(Mn(t>=240?t-240:t+120,r,o),Mn(t,r,o),Mn(t<120?t+240:t-120,r,o),this.opacity)},clamp(){return new bn(Pn(this.h),En(this.s),En(this.l),yn(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){const t=yn(this.opacity);return`${1===t?"hsl(":"hsla("}${Pn(this.h)}, ${100*En(this.s)}%, ${100*En(this.l)}%${1===t?")":`, ${t})`}`}}));var Sn=t=>()=>t;function Nn(t){return 1==(t=+t)?zn:function(e,n){return n-e?function(t,e,n){return t=Math.pow(t,n),e=Math.pow(e,n)-t,n=1/n,function(o){return Math.pow(t+o*e,n)}}(e,n,t):Sn(isNaN(e)?n:e)}}function zn(t,e){var n=e-t;return n?function(t,e){return function(n){return t+n*e}}(t,n):Sn(isNaN(t)?e:t)}var An=function t(e){var n=Nn(e);function o(t,e){var o=n((t=fn(t)).r,(e=fn(e)).r),r=n(t.g,e.g),i=n(t.b,e.b),a=zn(t.opacity,e.opacity);return function(e){return t.r=o(e),t.g=r(e),t.b=i(e),t.opacity=a(e),t+""}}return o.gamma=t,o}(1);function Tn(t,e){return t=+t,e=+e,function(n){return t*(1-n)+e*n}}var $n=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,kn=new RegExp($n.source,"g");function Cn(t,e){var n,o,r,i=$n.lastIndex=kn.lastIndex=0,a=-1,s=[],u=[];for(t+="",e+="";(n=$n.exec(t))&&(o=kn.exec(e));)(r=o.index)>i&&(r=e.slice(i,r),s[a]?s[a]+=r:s[++a]=r),(n=n[0])===(o=o[0])?s[a]?s[a]+=o:s[++a]=o:(s[++a]=null,u.push({i:a,x:Tn(n,o)})),i=kn.lastIndex;return i<e.length&&(r=e.slice(i),s[a]?s[a]+=r:s[++a]=r),s.length<2?u[0]?function(t){return function(e){return t(e)+""}}(u[0].x):function(t){return function(){return t}}(e):(e=u.length,function(t){for(var n,o=0;o<e;++o)s[(n=u[o]).i]=n.x(t);return s.join("")})}var In,On=180/Math.PI,Xn={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function Hn(t,e,n,o,r,i){var a,s,u;return(a=Math.sqrt(t*t+e*e))&&(t/=a,e/=a),(u=t*n+e*o)&&(n-=t*u,o-=e*u),(s=Math.sqrt(n*n+o*o))&&(n/=s,o/=s,u/=s),t*o<e*n&&(t=-t,e=-e,u=-u,a=-a),{translateX:r,translateY:i,rotate:Math.atan2(e,t)*On,skewX:Math.atan(u)*On,scaleX:a,scaleY:s}}function Yn(t,e,n,o){function r(t){return t.length?t.pop()+" ":""}return function(i,a){var s=[],u=[];return i=t(i),a=t(a),function(t,o,r,i,a,s){if(t!==r||o!==i){var u=a.push("translate(",null,e,null,n);s.push({i:u-4,x:Tn(t,r)},{i:u-2,x:Tn(o,i)})}else(r||i)&&a.push("translate("+r+e+i+n)}(i.translateX,i.translateY,a.translateX,a.translateY,s,u),function(t,e,n,i){t!==e?(t-e>180?e+=360:e-t>180&&(t+=360),i.push({i:n.push(r(n)+"rotate(",null,o)-2,x:Tn(t,e)})):e&&n.push(r(n)+"rotate("+e+o)}(i.rotate,a.rotate,s,u),function(t,e,n,i){t!==e?i.push({i:n.push(r(n)+"skewX(",null,o)-2,x:Tn(t,e)}):e&&n.push(r(n)+"skewX("+e+o)}(i.skewX,a.skewX,s,u),function(t,e,n,o,i,a){if(t!==n||e!==o){var s=i.push(r(i)+"scale(",null,",",null,")");a.push({i:s-4,x:Tn(t,n)},{i:s-2,x:Tn(e,o)})}else 1===n&&1===o||i.push(r(i)+"scale("+n+","+o+")")}(i.scaleX,i.scaleY,a.scaleX,a.scaleY,s,u),i=a=null,function(t){for(var e,n=-1,o=u.length;++n<o;)s[(e=u[n]).i]=e.x(t);return s.join("")}}}var Rn=Yn((function(t){const e=new("function"==typeof DOMMatrix?DOMMatrix:WebKitCSSMatrix)(t+"");return e.isIdentity?Xn:Hn(e.a,e.b,e.c,e.d,e.e,e.f)}),"px, ","px)","deg)"),Bn=Yn((function(t){return null==t?Xn:(In||(In=document.createElementNS("http://www.w3.org/2000/svg","g")),In.setAttribute("transform",t),(t=In.transform.baseVal.consolidate())?Hn((t=t.matrix).a,t.b,t.c,t.d,t.e,t.f):Xn)}),", ",")",")");function Dn(t){return((t=Math.exp(t))+1/t)/2}var Ln,Vn,qn=function t(e,n,o){function r(t,r){var i,a,s=t[0],u=t[1],c=t[2],l=r[0],h=r[1],d=r[2],f=l-s,p=h-u,g=f*f+p*p;if(g<1e-12)a=Math.log(d/c)/e,i=function(t){return[s+t*f,u+t*p,c*Math.exp(e*t*a)]};else{var m=Math.sqrt(g),y=(d*d-c*c+o*g)/(2*c*n*m),v=(d*d-c*c-o*g)/(2*d*n*m),x=Math.log(Math.sqrt(y*y+1)-y),w=Math.log(Math.sqrt(v*v+1)-v);a=(w-x)/e,i=function(t){var o,r=t*a,i=Dn(x),l=c/(n*m)*(i*(o=e*r+x,((o=Math.exp(2*o))-1)/(o+1))-function(t){return((t=Math.exp(t))-1/t)/2}(x));return[s+l*f,u+l*p,c*i/Dn(e*r+x)]}}return i.duration=1e3*a*e/Math.SQRT2,i}return r.rho=function(e){var n=Math.max(.001,+e),o=n*n;return t(n,o,o*o)},r}(Math.SQRT2,2,4),Zn=0,Gn=0,jn=0,Fn=1e3,Wn=0,Kn=0,Un=0,Qn="object"==typeof performance&&performance.now?performance:Date,Jn="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(t){setTimeout(t,17)};function to(){return Kn||(Jn(eo),Kn=Qn.now()+Un)}function eo(){Kn=0}function no(){this._call=this._time=this._next=null}function oo(t,e,n){var o=new no;return o.restart(t,e,n),o}function ro(){Kn=(Wn=Qn.now())+Un,Zn=Gn=0;try{!function(){to(),++Zn;for(var t,e=Ln;e;)(t=Kn-e._time)>=0&&e._call.call(void 0,t),e=e._next;--Zn}()}finally{Zn=0,function(){var t,e,n=Ln,o=1/0;for(;n;)n._call?(o>n._time&&(o=n._time),t=n,n=n._next):(e=n._next,n._next=null,n=t?t._next=e:Ln=e);Vn=t,ao(o)}(),Kn=0}}function io(){var t=Qn.now(),e=t-Wn;e>Fn&&(Un-=e,Wn=t)}function ao(t){Zn||(Gn&&(Gn=clearTimeout(Gn)),t-Kn>24?(t<1/0&&(Gn=setTimeout(ro,t-Qn.now()-Un)),jn&&(jn=clearInterval(jn))):(jn||(Wn=Qn.now(),jn=setInterval(io,Fn)),Zn=1,Jn(ro)))}function so(t,e,n){var o=new no;return e=null==e?0:+e,o.restart((n=>{o.stop(),t(n+e)}),e,n),o}no.prototype=oo.prototype={constructor:no,restart:function(t,e,n){if("function"!=typeof t)throw new TypeError("callback is not a function");n=(null==n?to():+n)+(null==e?0:+e),this._next||Vn===this||(Vn?Vn._next=this:Ln=this,Vn=this),this._call=t,this._time=n,ao()},stop:function(){this._call&&(this._call=null,this._time=1/0,ao())}};var uo=et("start","end","cancel","interrupt"),co=[],lo=0,ho=1,fo=2,po=3,go=4,mo=5,yo=6;function vo(t,e,n,o,r,i){var a=t.__transition;if(a){if(n in a)return}else t.__transition={};!function(t,e,n){var o,r=t.__transition;function i(t){n.state=ho,n.timer.restart(a,n.delay,n.time),n.delay<=t&&a(t-n.delay)}function a(i){var c,l,h,d;if(n.state!==ho)return u();for(c in r)if((d=r[c]).name===n.name){if(d.state===po)return so(a);d.state===go?(d.state=yo,d.timer.stop(),d.on.call("interrupt",t,t.__data__,d.index,d.group),delete r[c]):+c<e&&(d.state=yo,d.timer.stop(),d.on.call("cancel",t,t.__data__,d.index,d.group),delete r[c])}if(so((function(){n.state===po&&(n.state=go,n.timer.restart(s,n.delay,n.time),s(i))})),n.state=fo,n.on.call("start",t,t.__data__,n.index,n.group),n.state===fo){for(n.state=po,o=new Array(h=n.tween.length),c=0,l=-1;c<h;++c)(d=n.tween[c].value.call(t,t.__data__,n.index,n.group))&&(o[++l]=d);o.length=l+1}}function s(e){for(var r=e<n.duration?n.ease.call(null,e/n.duration):(n.timer.restart(u),n.state=mo,1),i=-1,a=o.length;++i<a;)o[i].call(t,r);n.state===mo&&(n.on.call("end",t,t.__data__,n.index,n.group),u())}function u(){for(var o in n.state=yo,n.timer.stop(),delete r[e],r)return;delete t.__transition}r[e]=n,n.timer=oo(i,0,n.time)}(t,n,{name:e,index:o,group:r,on:uo,tween:co,time:i.time,delay:i.delay,duration:i.duration,ease:i.ease,timer:null,state:lo})}function xo(t,e){var n=_o(t,e);if(n.state>lo)throw new Error("too late; already scheduled");return n}function wo(t,e){var n=_o(t,e);if(n.state>po)throw new Error("too late; already running");return n}function _o(t,e){var n=t.__transition;if(!n||!(n=n[e]))throw new Error("transition not found");return n}function bo(t,e){var n,o,r,i=t.__transition,a=!0;if(i){for(r in e=null==e?null:e+"",i)(n=i[r]).name===e?(o=n.state>fo&&n.state<mo,n.state=yo,n.timer.stop(),n.on.call(o?"interrupt":"cancel",t,t.__data__,n.index,n.group),delete i[r]):a=!1;a&&delete t.__transition}}function Po(t,e){var n,o;return function(){var r=wo(this,t),i=r.tween;if(i!==n)for(var a=0,s=(o=n=i).length;a<s;++a)if(o[a].name===e){(o=o.slice()).splice(a,1);break}r.tween=o}}function Eo(t,e,n){var o,r;if("function"!=typeof n)throw new Error;return function(){var i=wo(this,t),a=i.tween;if(a!==o){r=(o=a).slice();for(var s={name:e,value:n},u=0,c=r.length;u<c;++u)if(r[u].name===e){r[u]=s;break}u===c&&r.push(s)}i.tween=r}}function Mo(t,e,n){var o=t._id;return t.each((function(){var t=wo(this,o);(t.value||(t.value={}))[e]=n.apply(this,arguments)})),function(t){return _o(t,o).value[e]}}function So(t,e){var n;return("number"==typeof e?Tn:e instanceof ln?An:(n=ln(e))?(e=n,An):Cn)(t,e)}function No(t){return function(){this.removeAttribute(t)}}function zo(t){return function(){this.removeAttributeNS(t.space,t.local)}}function Ao(t,e,n){var o,r,i=n+"";return function(){var a=this.getAttribute(t);return a===i?null:a===o?r:r=e(o=a,n)}}function To(t,e,n){var o,r,i=n+"";return function(){var a=this.getAttributeNS(t.space,t.local);return a===i?null:a===o?r:r=e(o=a,n)}}function $o(t,e,n){var o,r,i;return function(){var a,s,u=n(this);if(null!=u)return(a=this.getAttribute(t))===(s=u+"")?null:a===o&&s===r?i:(r=s,i=e(o=a,u));this.removeAttribute(t)}}function ko(t,e,n){var o,r,i;return function(){var a,s,u=n(this);if(null!=u)return(a=this.getAttributeNS(t.space,t.local))===(s=u+"")?null:a===o&&s===r?i:(r=s,i=e(o=a,u));this.removeAttributeNS(t.space,t.local)}}function Co(t,e){var n,o;function r(){var r=e.apply(this,arguments);return r!==o&&(n=(o=r)&&function(t,e){return function(n){this.setAttributeNS(t.space,t.local,e.call(this,n))}}(t,r)),n}return r._value=e,r}function Io(t,e){var n,o;function r(){var r=e.apply(this,arguments);return r!==o&&(n=(o=r)&&function(t,e){return function(n){this.setAttribute(t,e.call(this,n))}}(t,r)),n}return r._value=e,r}function Oo(t,e){return function(){xo(this,t).delay=+e.apply(this,arguments)}}function Xo(t,e){return e=+e,function(){xo(this,t).delay=e}}function Ho(t,e){return function(){wo(this,t).duration=+e.apply(this,arguments)}}function Yo(t,e){return e=+e,function(){wo(this,t).duration=e}}var Ro=me.prototype.constructor;function Bo(t){return function(){this.style.removeProperty(t)}}var Do=0;function Lo(t,e,n,o){this._groups=t,this._parents=e,this._name=n,this._id=o}function Vo(){return++Do}var qo=me.prototype;Lo.prototype={constructor:Lo,select:function(t){var e=this._name,n=this._id;"function"!=typeof t&&(t=dt(t));for(var o=this._groups,r=o.length,i=new Array(r),a=0;a<r;++a)for(var s,u,c=o[a],l=c.length,h=i[a]=new Array(l),d=0;d<l;++d)(s=c[d])&&(u=t.call(s,s.__data__,d,c))&&("__data__"in s&&(u.__data__=s.__data__),h[d]=u,vo(h[d],e,n,d,h,_o(s,n)));return new Lo(i,this._parents,e,n)},selectAll:function(t){var e=this._name,n=this._id;"function"!=typeof t&&(t=pt(t));for(var o=this._groups,r=o.length,i=[],a=[],s=0;s<r;++s)for(var u,c=o[s],l=c.length,h=0;h<l;++h)if(u=c[h]){for(var d,f=t.call(u,u.__data__,h,c),p=_o(u,n),g=0,m=f.length;g<m;++g)(d=f[g])&&vo(d,e,n,g,f,p);i.push(f),a.push(u)}return new Lo(i,a,e,n)},selectChild:qo.selectChild,selectChildren:qo.selectChildren,filter:function(t){"function"!=typeof t&&(t=mt(t));for(var e=this._groups,n=e.length,o=new Array(n),r=0;r<n;++r)for(var i,a=e[r],s=a.length,u=o[r]=[],c=0;c<s;++c)(i=a[c])&&t.call(i,i.__data__,c,a)&&u.push(i);return new Lo(o,this._parents,this._name,this._id)},merge:function(t){if(t._id!==this._id)throw new Error;for(var e=this._groups,n=t._groups,o=e.length,r=n.length,i=Math.min(o,r),a=new Array(o),s=0;s<i;++s)for(var u,c=e[s],l=n[s],h=c.length,d=a[s]=new Array(h),f=0;f<h;++f)(u=c[f]||l[f])&&(d[f]=u);for(;s<o;++s)a[s]=e[s];return new Lo(a,this._parents,this._name,this._id)},selection:function(){return new Ro(this._groups,this._parents)},transition:function(){for(var t=this._name,e=this._id,n=Vo(),o=this._groups,r=o.length,i=0;i<r;++i)for(var a,s=o[i],u=s.length,c=0;c<u;++c)if(a=s[c]){var l=_o(a,e);vo(a,t,n,c,s,{time:l.time+l.delay+l.duration,delay:0,duration:l.duration,ease:l.ease})}return new Lo(o,this._parents,t,n)},call:qo.call,nodes:qo.nodes,node:qo.node,size:qo.size,empty:qo.empty,each:qo.each,on:function(t,e){var n=this._id;return arguments.length<2?_o(this.node(),n).on.on(t):this.each(function(t,e,n){var o,r,i=function(t){return(t+"").trim().split(/^|\s+/).every((function(t){var e=t.indexOf(".");return e>=0&&(t=t.slice(0,e)),!t||"start"===t}))}(e)?xo:wo;return function(){var a=i(this,t),s=a.on;s!==o&&(r=(o=s).copy()).on(e,n),a.on=r}}(n,t,e))},attr:function(t,e){var n=st(t),o="transform"===n?Bn:So;return this.attrTween(t,"function"==typeof e?(n.local?ko:$o)(n,o,Mo(this,"attr."+t,e)):null==e?(n.local?zo:No)(n):(n.local?To:Ao)(n,o,e))},attrTween:function(t,e){var n="attr."+t;if(arguments.length<2)return(n=this.tween(n))&&n._value;if(null==e)return this.tween(n,null);if("function"!=typeof e)throw new Error;var o=st(t);return this.tween(n,(o.local?Co:Io)(o,e))},style:function(t,e,n){var o="transform"==(t+="")?Rn:So;return null==e?this.styleTween(t,function(t,e){var n,o,r;return function(){var i=Rt(this,t),a=(this.style.removeProperty(t),Rt(this,t));return i===a?null:i===n&&a===o?r:r=e(n=i,o=a)}}(t,o)).on("end.style."+t,Bo(t)):"function"==typeof e?this.styleTween(t,function(t,e,n){var o,r,i;return function(){var a=Rt(this,t),s=n(this),u=s+"";return null==s&&(this.style.removeProperty(t),u=s=Rt(this,t)),a===u?null:a===o&&u===r?i:(r=u,i=e(o=a,s))}}(t,o,Mo(this,"style."+t,e))).each(function(t,e){var n,o,r,i,a="style."+e,s="end."+a;return function(){var u=wo(this,t),c=u.on,l=null==u.value[a]?i||(i=Bo(e)):void 0;c===n&&r===l||(o=(n=c).copy()).on(s,r=l),u.on=o}}(this._id,t)):this.styleTween(t,function(t,e,n){var o,r,i=n+"";return function(){var a=Rt(this,t);return a===i?null:a===o?r:r=e(o=a,n)}}(t,o,e),n).on("end.style."+t,null)},styleTween:function(t,e,n){var o="style."+(t+="");if(arguments.length<2)return(o=this.tween(o))&&o._value;if(null==e)return this.tween(o,null);if("function"!=typeof e)throw new Error;return this.tween(o,function(t,e,n){var o,r;function i(){var i=e.apply(this,arguments);return i!==r&&(o=(r=i)&&function(t,e,n){return function(o){this.style.setProperty(t,e.call(this,o),n)}}(t,i,n)),o}return i._value=e,i}(t,e,null==n?"":n))},text:function(t){return this.tween("text","function"==typeof t?function(t){return function(){var e=t(this);this.textContent=null==e?"":e}}(Mo(this,"text",t)):function(t){return function(){this.textContent=t}}(null==t?"":t+""))},textTween:function(t){var e="text";if(arguments.length<1)return(e=this.tween(e))&&e._value;if(null==t)return this.tween(e,null);if("function"!=typeof t)throw new Error;return this.tween(e,function(t){var e,n;function o(){var o=t.apply(this,arguments);return o!==n&&(e=(n=o)&&function(t){return function(e){this.textContent=t.call(this,e)}}(o)),e}return o._value=t,o}(t))},remove:function(){return this.on("end.remove",function(t){return function(){var e=this.parentNode;for(var n in this.__transition)if(+n!==t)return;e&&e.removeChild(this)}}(this._id))},tween:function(t,e){var n=this._id;if(t+="",arguments.length<2){for(var o,r=_o(this.node(),n).tween,i=0,a=r.length;i<a;++i)if((o=r[i]).name===t)return o.value;return null}return this.each((null==e?Po:Eo)(n,t,e))},delay:function(t){var e=this._id;return arguments.length?this.each(("function"==typeof t?Oo:Xo)(e,t)):_o(this.node(),e).delay},duration:function(t){var e=this._id;return arguments.length?this.each(("function"==typeof t?Ho:Yo)(e,t)):_o(this.node(),e).duration},ease:function(t){var e=this._id;return arguments.length?this.each(function(t,e){if("function"!=typeof e)throw new Error;return function(){wo(this,t).ease=e}}(e,t)):_o(this.node(),e).ease},easeVarying:function(t){if("function"!=typeof t)throw new Error;return this.each(function(t,e){return function(){var n=e.apply(this,arguments);if("function"!=typeof n)throw new Error;wo(this,t).ease=n}}(this._id,t))},end:function(){var t,e,n=this,o=n._id,r=n.size();return new Promise((function(i,a){var s={value:a},u={value:function(){0==--r&&i()}};n.each((function(){var n=wo(this,o),r=n.on;r!==t&&((e=(t=r).copy())._.cancel.push(s),e._.interrupt.push(s),e._.end.push(u)),n.on=e})),0===r&&i()}))},[Symbol.iterator]:qo[Symbol.iterator]};var Zo={time:null,delay:0,duration:250,ease:function(t){return((t*=2)<=1?t*t*t:(t-=2)*t*t+2)/2}};function Go(t,e){for(var n;!(n=t.__transition)||!(n=n[e]);)if(!(t=t.parentNode))throw new Error(`transition ${e} not found`);return n}me.prototype.interrupt=function(t){return this.each((function(){bo(this,t)}))},me.prototype.transition=function(t){var e,n;t instanceof Lo?(e=t._id,t=t._name):(e=Vo(),(n=Zo).time=to(),t=null==t?null:t+"");for(var o=this._groups,r=o.length,i=0;i<r;++i)for(var a,s=o[i],u=s.length,c=0;c<u;++c)(a=s[c])&&vo(a,t,e,c,s,n||Go(a,e));return new Lo(o,this._parents,t,e)};var jo=t=>()=>t;function Fo(t,{sourceEvent:e,target:n,transform:o,dispatch:r}){Object.defineProperties(this,{type:{value:t,enumerable:!0,configurable:!0},sourceEvent:{value:e,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},transform:{value:o,enumerable:!0,configurable:!0},_:{value:r}})}function Wo(t,e,n){this.k=t,this.x=e,this.y=n}Wo.prototype={constructor:Wo,scale:function(t){return 1===t?this:new Wo(this.k*t,this.x,this.y)},translate:function(t,e){return 0===t&0===e?this:new Wo(this.k,this.x+this.k*t,this.y+this.k*e)},apply:function(t){return[t[0]*this.k+this.x,t[1]*this.k+this.y]},applyX:function(t){return t*this.k+this.x},applyY:function(t){return t*this.k+this.y},invert:function(t){return[(t[0]-this.x)/this.k,(t[1]-this.y)/this.k]},invertX:function(t){return(t-this.x)/this.k},invertY:function(t){return(t-this.y)/this.k},rescaleX:function(t){return t.copy().domain(t.range().map(this.invertX,this).map(t.invert,t))},rescaleY:function(t){return t.copy().domain(t.range().map(this.invertY,this).map(t.invert,t))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var Ko=new Wo(1,0,0);function Uo(t){for(;!t.__zoom;)if(!(t=t.parentNode))return Ko;return t.__zoom}function Qo(t){t.stopImmediatePropagation()}function Jo(t){t.preventDefault(),t.stopImmediatePropagation()}function tr(t){return!(t.ctrlKey&&"wheel"!==t.type||t.button)}function er(){var t=this;return t instanceof SVGElement?(t=t.ownerSVGElement||t).hasAttribute("viewBox")?[[(t=t.viewBox.baseVal).x,t.y],[t.x+t.width,t.y+t.height]]:[[0,0],[t.width.baseVal.value,t.height.baseVal.value]]:[[0,0],[t.clientWidth,t.clientHeight]]}function nr(){return this.__zoom||Ko}function or(t){return-t.deltaY*(1===t.deltaMode?.05:t.deltaMode?1:.002)*(t.ctrlKey?10:1)}function rr(){return navigator.maxTouchPoints||"ontouchstart"in this}function ir(t,e,n){var o=t.invertX(e[0][0])-n[0][0],r=t.invertX(e[1][0])-n[1][0],i=t.invertY(e[0][1])-n[0][1],a=t.invertY(e[1][1])-n[1][1];return t.translate(r>o?(o+r)/2:Math.min(0,o)||Math.max(0,r),a>i?(i+a)/2:Math.min(0,i)||Math.max(0,a))}function ar(){var t,e,n,o=tr,r=er,i=ir,a=or,s=rr,u=[0,1/0],c=[[-1/0,-1/0],[1/0,1/0]],l=250,h=qn,d=et("start","zoom","end"),f=500,p=150,g=0,m=10;function y(t){t.property("__zoom",nr).on("wheel.zoom",E,{passive:!1}).on("mousedown.zoom",M).on("dblclick.zoom",S).filter(s).on("touchstart.zoom",N).on("touchmove.zoom",z).on("touchend.zoom touchcancel.zoom",A).style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function v(t,e){return(e=Math.max(u[0],Math.min(u[1],e)))===t.k?t:new Wo(e,t.x,t.y)}function x(t,e,n){var o=e[0]-n[0]*t.k,r=e[1]-n[1]*t.k;return o===t.x&&r===t.y?t:new Wo(t.k,o,r)}function w(t){return[(+t[0][0]+ +t[1][0])/2,(+t[0][1]+ +t[1][1])/2]}function _(t,e,n,o){t.on("start.zoom",(function(){b(this,arguments).event(o).start()})).on("interrupt.zoom end.zoom",(function(){b(this,arguments).event(o).end()})).tween("zoom",(function(){var t=this,i=arguments,a=b(t,i).event(o),s=r.apply(t,i),u=null==n?w(s):"function"==typeof n?n.apply(t,i):n,c=Math.max(s[1][0]-s[0][0],s[1][1]-s[0][1]),l=t.__zoom,d="function"==typeof e?e.apply(t,i):e,f=h(l.invert(u).concat(c/l.k),d.invert(u).concat(c/d.k));return function(t){if(1===t)t=d;else{var e=f(t),n=c/e[2];t=new Wo(n,u[0]-e[0]*n,u[1]-e[1]*n)}a.zoom(null,t)}}))}function b(t,e,n){return!n&&t.__zooming||new P(t,e)}function P(t,e){this.that=t,this.args=e,this.active=0,this.sourceEvent=null,this.extent=r.apply(t,e),this.taps=0}function E(t,...e){if(o.apply(this,arguments)){var n=b(this,e).event(t),r=this.__zoom,s=Math.max(u[0],Math.min(u[1],r.k*Math.pow(2,a.apply(this,arguments)))),l=ve(t);if(n.wheel)n.mouse[0][0]===l[0]&&n.mouse[0][1]===l[1]||(n.mouse[1]=r.invert(n.mouse[0]=l)),clearTimeout(n.wheel);else{if(r.k===s)return;n.mouse=[l,r.invert(l)],bo(this),n.start()}Jo(t),n.wheel=setTimeout((function(){n.wheel=null,n.end()}),p),n.zoom("mouse",i(x(v(r,s),n.mouse[0],n.mouse[1]),n.extent,c))}}function M(t,...e){if(!n&&o.apply(this,arguments)){var r=t.currentTarget,a=b(this,e,!0).event(t),s=ye(t.view).on("mousemove.zoom",(function(t){if(Jo(t),!a.moved){var e=t.clientX-l,n=t.clientY-h;a.moved=e*e+n*n>g}a.event(t).zoom("mouse",i(x(a.that.__zoom,a.mouse[0]=ve(t,r),a.mouse[1]),a.extent,c))}),!0).on("mouseup.zoom",(function(t){s.on("mousemove.zoom mouseup.zoom",null),Ee(t.view,a.moved),Jo(t),a.event(t).end()}),!0),u=ve(t,r),l=t.clientX,h=t.clientY;Pe(t.view),Qo(t),a.mouse=[u,this.__zoom.invert(u)],bo(this),a.start()}}function S(t,...e){if(o.apply(this,arguments)){var n=this.__zoom,a=ve(t.changedTouches?t.changedTouches[0]:t,this),s=n.invert(a),u=n.k*(t.shiftKey?.5:2),h=i(x(v(n,u),a,s),r.apply(this,e),c);Jo(t),l>0?ye(this).transition().duration(l).call(_,h,a,t):ye(this).call(y.transform,h,a,t)}}function N(n,...r){if(o.apply(this,arguments)){var i,a,s,u,c=n.touches,l=c.length,h=b(this,r,n.changedTouches.length===l).event(n);for(Qo(n),a=0;a<l;++a)u=[u=ve(s=c[a],this),this.__zoom.invert(u),s.identifier],h.touch0?h.touch1||h.touch0[2]===u[2]||(h.touch1=u,h.taps=0):(h.touch0=u,i=!0,h.taps=1+!!t);t&&(t=clearTimeout(t)),i&&(h.taps<2&&(e=u[0],t=setTimeout((function(){t=null}),f)),bo(this),h.start())}}function z(t,...e){if(this.__zooming){var n,o,r,a,s=b(this,e).event(t),u=t.changedTouches,l=u.length;for(Jo(t),n=0;n<l;++n)r=ve(o=u[n],this),s.touch0&&s.touch0[2]===o.identifier?s.touch0[0]=r:s.touch1&&s.touch1[2]===o.identifier&&(s.touch1[0]=r);if(o=s.that.__zoom,s.touch1){var h=s.touch0[0],d=s.touch0[1],f=s.touch1[0],p=s.touch1[1],g=(g=f[0]-h[0])*g+(g=f[1]-h[1])*g,m=(m=p[0]-d[0])*m+(m=p[1]-d[1])*m;o=v(o,Math.sqrt(g/m)),r=[(h[0]+f[0])/2,(h[1]+f[1])/2],a=[(d[0]+p[0])/2,(d[1]+p[1])/2]}else{if(!s.touch0)return;r=s.touch0[0],a=s.touch0[1]}s.zoom("touch",i(x(o,r,a),s.extent,c))}}function A(t,...o){if(this.__zooming){var r,i,a=b(this,o).event(t),s=t.changedTouches,u=s.length;for(Qo(t),n&&clearTimeout(n),n=setTimeout((function(){n=null}),f),r=0;r<u;++r)i=s[r],a.touch0&&a.touch0[2]===i.identifier?delete a.touch0:a.touch1&&a.touch1[2]===i.identifier&&delete a.touch1;if(a.touch1&&!a.touch0&&(a.touch0=a.touch1,delete a.touch1),a.touch0)a.touch0[1]=this.__zoom.invert(a.touch0[0]);else if(a.end(),2===a.taps&&(i=ve(i,this),Math.hypot(e[0]-i[0],e[1]-i[1])<m)){var c=ye(this).on("dblclick.zoom");c&&c.apply(this,arguments)}}}return y.transform=function(t,e,n,o){var r=t.selection?t.selection():t;r.property("__zoom",nr),t!==r?_(t,e,n,o):r.interrupt().each((function(){b(this,arguments).event(o).start().zoom(null,"function"==typeof e?e.apply(this,arguments):e).end()}))},y.scaleBy=function(t,e,n,o){y.scaleTo(t,(function(){return this.__zoom.k*("function"==typeof e?e.apply(this,arguments):e)}),n,o)},y.scaleTo=function(t,e,n,o){y.transform(t,(function(){var t=r.apply(this,arguments),o=this.__zoom,a=null==n?w(t):"function"==typeof n?n.apply(this,arguments):n,s=o.invert(a),u="function"==typeof e?e.apply(this,arguments):e;return i(x(v(o,u),a,s),t,c)}),n,o)},y.translateBy=function(t,e,n,o){y.transform(t,(function(){return i(this.__zoom.translate("function"==typeof e?e.apply(this,arguments):e,"function"==typeof n?n.apply(this,arguments):n),r.apply(this,arguments),c)}),null,o)},y.translateTo=function(t,e,n,o,a){y.transform(t,(function(){var t=r.apply(this,arguments),a=this.__zoom,s=null==o?w(t):"function"==typeof o?o.apply(this,arguments):o;return i(Ko.translate(s[0],s[1]).scale(a.k).translate("function"==typeof e?-e.apply(this,arguments):-e,"function"==typeof n?-n.apply(this,arguments):-n),t,c)}),o,a)},P.prototype={event:function(t){return t&&(this.sourceEvent=t),this},start:function(){return 1==++this.active&&(this.that.__zooming=this,this.emit("start")),this},zoom:function(t,e){return this.mouse&&"mouse"!==t&&(this.mouse[1]=e.invert(this.mouse[0])),this.touch0&&"touch"!==t&&(this.touch0[1]=e.invert(this.touch0[0])),this.touch1&&"touch"!==t&&(this.touch1[1]=e.invert(this.touch1[0])),this.that.__zoom=e,this.emit("zoom"),this},end:function(){return 0==--this.active&&(delete this.that.__zooming,this.emit("end")),this},emit:function(t){var e=ye(this.that).datum();d.call(t,this.that,new Fo(t,{sourceEvent:this.sourceEvent,target:y,type:t,transform:this.that.__zoom,dispatch:d}),e)}},y.wheelDelta=function(t){return arguments.length?(a="function"==typeof t?t:jo(+t),y):a},y.filter=function(t){return arguments.length?(o="function"==typeof t?t:jo(!!t),y):o},y.touchable=function(t){return arguments.length?(s="function"==typeof t?t:jo(!!t),y):s},y.extent=function(t){return arguments.length?(r="function"==typeof t?t:jo([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),y):r},y.scaleExtent=function(t){return arguments.length?(u[0]=+t[0],u[1]=+t[1],y):[u[0],u[1]]},y.translateExtent=function(t){return arguments.length?(c[0][0]=+t[0][0],c[1][0]=+t[1][0],c[0][1]=+t[0][1],c[1][1]=+t[1][1],y):[[c[0][0],c[0][1]],[c[1][0],c[1][1]]]},y.constrain=function(t){return arguments.length?(i=t,y):i},y.duration=function(t){return arguments.length?(l=+t,y):l},y.interpolate=function(t){return arguments.length?(h=t,y):h},y.on=function(){var t=d.on.apply(d,arguments);return t===d?y:t},y.clickDistance=function(t){return arguments.length?(g=(t=+t)*t,y):Math.sqrt(g)},y.tapDistance=function(t){return arguments.length?(m=+t,y):m},y}Uo.prototype=Wo.prototype;const sr=(t,e)=>t.x!==e.x||t.y!==e.y||t.zoom!==e.k,ur=t=>({x:t.x,y:t.y,zoom:t.k}),cr=({x:t,y:e,zoom:n})=>Ko.translate(t,e).scale(n),lr=(t,e)=>t.target.closest(`.${e}`),hr=(t,e)=>2===e&&Array.isArray(t)&&t.includes(2),dr=(t,e=0)=>"number"==typeof e&&e>0?t.transition().duration(e):t,fr=t=>{const e=t.ctrlKey&&$()?10:1;return-t.deltaY*(1===t.deltaMode?.05:t.deltaMode?1:.002)*e};var pr;t.ResizeControlVariant=void 0,(pr=t.ResizeControlVariant||(t.ResizeControlVariant={})).Line="line",pr.Handle="handle";const gr={width:0,height:0,x:0,y:0},mr={...gr,pointerX:0,pointerY:0,aspectRatio:1},yr={x:0,y:0,width:0,height:0,isXPosChange:!1,isYPosChange:!1,isWidthChange:!1,isHeightChange:!1};t.XYDrag=function({domNode:t,onNodeMouseDown:e,getStoreItems:n,onDragStart:o,onDrag:r,onDragStop:i}){let a={x:null,y:null},s=0,u=[],c=!1,l={x:0,y:0},h=null,f=null,g=!1;const m=ye(t);return{update:function({noDragClassName:t,handleSelector:y,domNode:x,isSelectable:_,nodeId:b}){function P({x:t,y:e}){const{nodes:o,nodeLookup:i,nodeExtent:s,snapGrid:c,snapToGrid:l,nodeOrigin:f,onNodeDrag:g,onSelectionDrag:m,onError:y,updateNodePositions:v}=n();a={x:t,y:e};let x=!1,_={x:0,y:0,x2:0,y2:0};if(u.length>1&&s){const t=d(u,f);_=w(t)}if(u=u.map((n=>{let r={x:t-n.distance.x,y:e-n.distance.y};l&&(r=N(r,c));const i=[[s[0][0],s[0][1]],[s[1][0],s[1][1]]];u.length>1&&s&&!n.extent&&(i[0][0]=n.computed.positionAbsolute.x-_.x+s[0][0],i[1][0]=n.computed.positionAbsolute.x+(n.computed?.width??0)-_.x2+s[1][0],i[0][1]=n.computed.positionAbsolute.y-_.y+s[0][1],i[1][1]=n.computed.positionAbsolute.y+(n.computed?.height??0)-_.y2+s[1][1]);const a=p(n,r,o,i,f,y);return x=x||n.position.x!==a.position.x||n.position.y!==a.position.y,n.position=a.position,n.computed.positionAbsolute=a.positionAbsolute,n})),!x)return;v(u,!0,!0);const P=b?g:ke(m);if(h&&(r||P)){const[t,e]=Xe({nodeId:b,dragItems:u,nodeLookup:i});r?.(h,u,t,e),P?.(h,t,e)}}function E(){if(!f)return;const[t,e]=v(l,f);if(0!==t||0!==e){const{transform:o,panBy:r}=n();a.x=(a.x??0)-t/o[2],a.y=(a.y??0)-e/o[2],r({x:t,y:e})&&P(a)}s=requestAnimationFrame(E)}function M(t){const{nodes:r,nodeLookup:i,multiSelectionActive:s,nodesDraggable:c,transform:l,snapGrid:h,snapToGrid:d,selectNodesOnDrag:f,onNodeDragStart:p,onSelectionDragStart:m,unselectNodesAndEdges:y}=n();g=!0,f&&_||s||!b||i.get(b)?.selected||y(),_&&f&&b&&e?.(b);const v=k(t.sourceEvent,{transform:l,snapGrid:h,snapToGrid:d});a=v,u=Oe(r,c,v,b);const x=b?p:ke(m);if(u&&(o||x)){const[e,n]=Xe({nodeId:b,dragItems:u,nodeLookup:i});o?.(t.sourceEvent,u,e,n),x?.(t.sourceEvent,e,n)}}const S=$e().on("start",(t=>{const{domNode:e,nodeDragThreshold:o,transform:r,snapGrid:i,snapToGrid:s}=n();0===o&&M(t);const u=k(t.sourceEvent,{transform:r,snapGrid:i,snapToGrid:s});a=u,f=e?.getBoundingClientRect()||null,l=H(t.sourceEvent,f)})).on("drag",(t=>{const{autoPanOnNodeDrag:e,transform:o,snapGrid:r,snapToGrid:i,nodeDragThreshold:s}=n(),d=k(t.sourceEvent,{transform:o,snapGrid:r,snapToGrid:i});if(!c&&e&&g&&(c=!0,E()),!g){const e=d.xSnapped-(a.x??0),n=d.ySnapped-(a.y??0);Math.sqrt(e*e+n*n)>s&&M(t)}(a.x!==d.xSnapped||a.y!==d.ySnapped)&&u&&g&&(h=t.sourceEvent,l=H(t.sourceEvent,f),P(d))})).on("end",(t=>{if(g&&(c=!1,g=!1,cancelAnimationFrame(s),u)){const{nodeLookup:e,updateNodePositions:o,onNodeDragStop:r,onSelectionDragStop:a}=n(),s=b?r:ke(a);if(o(u,!1,!1),i||s){const[n,o]=Xe({nodeId:b,dragItems:u,nodeLookup:e});i?.(t.sourceEvent,u,n,o),s?.(t.sourceEvent,n,o)}}})).filter((e=>{const n=e.target;return!e.button&&(!t||!Ie(n,`.${t}`,x))&&(!y||Ie(n,y,x))}));m.call(S)},destroy:function(){m.on(".drag",null)}}},t.XYHandle=qe,t.XYMinimap=function({domNode:t,panZoom:e,getTransform:n,getViewScale:o}){const r=ye(t);return{update:function({translateExtent:t,width:i,height:a,zoomStep:s=10,pannable:u=!0,zoomable:c=!0,inversePan:l=!1}){const h=ar().on("zoom",u?r=>{const s=n();if("mousemove"!==r.sourceEvent.type||!e)return;const u=o()*Math.max(s[2],Math.log(s[2]))*(l?-1:1),c={x:s[0]-r.sourceEvent.movementX*u,y:s[1]-r.sourceEvent.movementY*u},h=[[0,0],[i,a]];e.setViewportConstrained({x:c.x,y:c.y,zoom:s[2]},h,t)}:null).on("zoom.wheel",c?t=>{const o=n();if("wheel"!==t.sourceEvent.type||!e)return;const r=-t.sourceEvent.deltaY*(1===t.sourceEvent.deltaMode?.05:t.sourceEvent.deltaMode?1:.002)*s,i=o[2]*Math.pow(2,r);e.scaleTo(i)}:null);r.call(h,{})},destroy:function(){r.on("zoom",null)},pointer:ve}},t.XYPanZoom=function({domNode:e,minZoom:n,maxZoom:o,translateExtent:r,viewport:i,onPanZoom:a,onPanZoomStart:s,onPanZoomEnd:u,onTransformChange:c,onDraggingChange:l}){const h={isZoomingOrPanning:!1,usedRightMouseButton:!1,prevViewport:{x:0,y:0,zoom:0},mouseButton:0,timerId:void 0,panScrollTimeout:void 0,isPanScrolling:!1},d=e.getBoundingClientRect(),f=ar().scaleExtent([n,o]).translateExtent(r),p=ye(e).call(f);x({x:i.x,y:i.y,zoom:g(i.zoom,n,o)},[[0,0],[d.width,d.height]],r);const m=p.on("wheel.zoom");function y(t,e){p&&f?.transform(dr(p,e?.duration),t)}function v(){f.on("zoom",null)}function x(t,e,n){const o=cr(t),r=f?.constrain()(o,e,n);return r&&y(r),r}return f.wheelDelta(fr),{update:function({noWheelClassName:e,noPanClassName:n,onPaneContextMenu:o,userSelectionActive:r,panOnScroll:i,panOnDrag:d,panOnScrollMode:g,panOnScrollSpeed:y,preventScrolling:x,zoomOnPinch:w,zoomOnScroll:_,zoomOnDoubleClick:b,zoomActivationKeyPressed:P,lib:E}){r&&!h.isZoomingOrPanning&&v();const M=i&&!P&&!r?function({zoomPanValues:e,noWheelClassName:n,d3Selection:o,d3Zoom:r,panOnScrollMode:i,panOnScrollSpeed:a,zoomOnPinch:s,onPanZoomStart:u,onPanZoom:c,onPanZoomEnd:l}){return h=>{if(lr(h,n))return!1;h.preventDefault(),h.stopImmediatePropagation();const d=o.property("__zoom").k||1,f=$();if(h.ctrlKey&&s&&f){const t=ve(h),e=fr(h),n=d*Math.pow(2,e);return void r.scaleTo(o,n,t,h)}const p=1===h.deltaMode?20:1;let g=i===t.PanOnScrollMode.Vertical?0:h.deltaX*p,m=i===t.PanOnScrollMode.Horizontal?0:h.deltaY*p;!f&&h.shiftKey&&i!==t.PanOnScrollMode.Vertical&&(g=h.deltaY*p,m=0),r.translateBy(o,-g/d*a,-m/d*a,{internal:!0});const y=ur(o.property("__zoom"));clearTimeout(e.panScrollTimeout),e.isPanScrolling||(e.isPanScrolling=!0,u?.(h,y)),e.isPanScrolling&&(c?.(h,y),e.panScrollTimeout=setTimeout((()=>{l?.(h,y),e.isPanScrolling=!1}),150))}}({zoomPanValues:h,noWheelClassName:e,d3Selection:p,d3Zoom:f,panOnScrollMode:g,panOnScrollSpeed:y,zoomOnPinch:w,onPanZoomStart:s,onPanZoom:a,onPanZoomEnd:u}):function({noWheelClassName:t,preventScrolling:e,d3ZoomHandler:n}){return function(o,r){if(!e||lr(o,t))return null;o.preventDefault(),n.call(this,o,r)}}({noWheelClassName:e,preventScrolling:x,d3ZoomHandler:m});if(p.on("wheel.zoom",M,{passive:!1}),!r){const t=function({zoomPanValues:t,onDraggingChange:e,onPanZoomStart:n}){return o=>{if(o.sourceEvent?.internal)return;const r=ur(o.transform);t.mouseButton=o.sourceEvent?.button||0,t.isZoomingOrPanning=!0,t.prevViewport=r,"mousedown"===o.sourceEvent?.type&&e(!0),n&&n?.(o.sourceEvent,r)}}({zoomPanValues:h,onDraggingChange:l,onPanZoomStart:s});f.on("start",t);const e=function({zoomPanValues:t,panOnDrag:e,onPaneContextMenu:n,onTransformChange:o,onPanZoom:r}){return i=>{t.usedRightMouseButton=!(!n||!hr(e,t.mouseButton??0)),i.sourceEvent?.sync||o([i.transform.x,i.transform.y,i.transform.k]),r&&!i.sourceEvent?.internal&&r?.(i.sourceEvent,ur(i.transform))}}({zoomPanValues:h,panOnDrag:d,onPaneContextMenu:!!o,onPanZoom:a,onTransformChange:c});f.on("zoom",e);const n=function({zoomPanValues:t,panOnDrag:e,panOnScroll:n,onDraggingChange:o,onPanZoomEnd:r,onPaneContextMenu:i}){return a=>{if(!a.sourceEvent?.internal&&(t.isZoomingOrPanning=!1,i&&hr(e,t.mouseButton??0)&&!t.usedRightMouseButton&&a.sourceEvent&&i(a.sourceEvent),t.usedRightMouseButton=!1,o(!1),r&&sr(t.prevViewport,a.transform))){const e=ur(a.transform);t.prevViewport=e,clearTimeout(t.timerId),t.timerId=setTimeout((()=>{r?.(a.sourceEvent,e)}),n?150:0)}}}({zoomPanValues:h,panOnDrag:d,panOnScroll:i,onPaneContextMenu:o,onPanZoomEnd:u,onDraggingChange:l});f.on("end",n)}const S=function({zoomActivationKeyPressed:t,zoomOnScroll:e,zoomOnPinch:n,panOnDrag:o,panOnScroll:r,zoomOnDoubleClick:i,userSelectionActive:a,noWheelClassName:s,noPanClassName:u,lib:c}){return l=>{const h=t||e,d=n&&l.ctrlKey;if(1===l.button&&"mousedown"===l.type&&(lr(l,`${c}-flow__node`)||lr(l,`${c}-flow__edge`)))return!0;if(!(o||h||r||i||n))return!1;if(a)return!1;if(!i&&"dblclick"===l.type)return!1;if(lr(l,s)&&"wheel"===l.type)return!1;if(lr(l,u)&&("wheel"!==l.type||r&&"wheel"===l.type&&!t))return!1;if(!n&&l.ctrlKey&&"wheel"===l.type)return!1;if(!h&&!r&&!d&&"wheel"===l.type)return!1;if(!o&&("mousedown"===l.type||"touchstart"===l.type))return!1;if(Array.isArray(o)&&!o.includes(l.button)&&("mousedown"===l.type||"touchstart"===l.type))return!1;const f=Array.isArray(o)&&o.includes(l.button)||!l.button||l.button<=1;return(!l.ctrlKey||"wheel"===l.type)&&f}}({zoomActivationKeyPressed:P,panOnDrag:d,zoomOnScroll:_,panOnScroll:i,zoomOnDoubleClick:b,zoomOnPinch:w,userSelectionActive:r,noPanClassName:n,noWheelClassName:e,lib:E});f.filter(S)},destroy:v,setViewport:function(t,e){const n=cr(t);return y(n,e),n},setViewportConstrained:x,getViewport:function(){const t=p?Uo(p.node()):{x:0,y:0,k:1};return{x:t.x,y:t.y,zoom:t.k}},scaleTo:function(t,e){p&&f?.scaleTo(dr(p,e?.duration),t)},scaleBy:function(t,e){p&&f?.scaleBy(dr(p,e?.duration),t)},setScaleExtent:function(t){f?.scaleExtent(t)},setTranslateExtent:function(t){f?.translateExtent(t)},syncViewport:function(t){if(p){const e=cr(t),n=p.property("__zoom");n.k===t.zoom&&n.x===t.x&&n.y===t.y||f?.transform(p,e,null,{sync:!0})}}}},t.XYResizer=function({domNode:t,nodeId:e,getStoreItems:n,onChange:o}){const r=ye(t);return{update:function({controlPosition:t,boundaries:i,keepAspectRatio:a,onResizeStart:s,onResize:u,onResizeEnd:c,shouldResize:l}){let h={...gr},d={...mr};const f=function(t){return{isHorizontal:t.includes("right")||t.includes("left"),isVertical:t.includes("bottom")||t.includes("top"),affectsX:t.includes("left"),affectsY:t.includes("top")}}(t),p=$e().on("start",(t=>{const{nodeLookup:o,transform:r,snapGrid:i,snapToGrid:a}=n(),u=o.get(e),{xSnapped:c,ySnapped:l}=k(t.sourceEvent,{transform:r,snapGrid:i,snapToGrid:a});h={width:u?.computed?.width??0,height:u?.computed?.height??0,x:u?.position.x??0,y:u?.position.y??0},d={...h,pointerX:c,pointerY:l,aspectRatio:h.width/h.height},s?.(t,{...h})})).on("drag",(t=>{const{nodeLookup:r,transform:s,snapGrid:c,snapToGrid:p}=n(),m=k(t.sourceEvent,{transform:s,snapGrid:c,snapToGrid:p});if(r.get(e)){const e={...yr},{x:n,y:r,width:s,height:c}=h,{width:p,height:y}=function(t,e,n,o,r){const{isHorizontal:i,isVertical:a,affectsX:s,affectsY:u}=e,{xSnapped:c,ySnapped:l}=n,{minWidth:h,maxWidth:d,minHeight:f,maxHeight:p}=o,{pointerX:m,pointerY:y,width:v,height:x,aspectRatio:w}=t,_=Math.floor(i?c-m:0),b=Math.floor(a?l-y:0);let P=g(v+(s?-_:_),h,d),E=g(x+(u?-b:b),f,p);if(r){const t=P/E,e=i&&a;P=t<=w&&e||a&&!i?E*w:P,E=t>w&&e||i&&!a?P/w:E,P>=d?(P=d,E=d/w):P<=h&&(P=h,E=h/w),E>=p?(E=p,P=p*w):E<=f&&(E=f,P=f*w)}return{width:P,height:E}}(d,f,m,i,a),v=p!==s,x=y!==c;if(f.affectsX||f.affectsY){const{x:t,y:o}=function(t,e,n,o){return{x:e.affectsX?t.x-(n-t.width):t.x,y:e.affectsY?t.y-(o-t.height):t.y}}(d,f,p,y),i=t!==n&&v,a=o!==r&&x;(i||a)&&(e.isXPosChange=i,e.isYPosChange=a,e.x=i?t:n,e.y=a?o:r,h.x=e.x,h.y=e.y)}if((v||x)&&(e.isWidthChange=v,e.isHeightChange=x,e.width=p,e.height=y,h.width=p,h.height=y),!(e.isXPosChange||e.isYPosChange||v||x))return;const w=function({width:t,prevWidth:e,height:n,prevHeight:o,affectsX:r,affectsY:i}){const a=t-e,s=n-o,u=[a>0?1:a<0?-1:0,s>0?1:s<0?-1:0];return a&&r&&(u[0]=-1*u[0]),s&&i&&(u[1]=-1*u[1]),u}({width:h.width,prevWidth:s,height:h.height,prevHeight:c,affectsX:f.affectsX,affectsY:f.affectsY}),_={...h,direction:w},b=l?.(t,_);if(!1===b)return;u?.(t,_),o(e)}})).on("end",(t=>{c?.(t,{...h})}));r.call(p)},destroy:function(){r.on(".drag",null)}}},t.XY_RESIZER_HANDLE_POSITIONS=["top-left","top-right","bottom-left","bottom-right"],t.XY_RESIZER_LINE_POSITIONS=["top","right","bottom","left"],t.addEdge=(t,n)=>{if(!t.source||!t.target)return e.error006(),n;let o;return o=l(t)?{...t}:{...t,id:V(t)},((t,e)=>e.some((e=>!(e.source!==t.source||e.target!==t.target||e.sourceHandle!==t.sourceHandle&&(e.sourceHandle||t.sourceHandle)||e.targetHandle!==t.targetHandle&&(e.targetHandle||t.targetHandle)))))(o,n)?n:(null===o.sourceHandle&&delete o.sourceHandle,null===o.targetHandle&&delete o.targetHandle,n.concat(o))},t.adoptUserProvidedNodes=function(t,e,o={nodeOrigin:[0,0],elevateNodesOnSelect:!0,defaults:{}}){const r=new Map(e);e.clear();const i={},a=o?.elevateNodesOnSelect?1e3:0;return Q(t.map((t=>{const s=r.get(t.id);if(t===s?.[n]?.userProvidedNode)return e.set(t.id,s),s;const u={...o.defaults,...t,computed:{positionAbsolute:t.position,width:t.computed?.width||s?.computed?.width,height:t.computed?.height||s?.computed?.height}},c=(M(t.zIndex)?t.zIndex:0)+(t.selected?a:0),l=t?.[n]||s?.[n];return u.parentNode&&(i[u.parentNode]=!0),Object.defineProperty(u,n,{enumerable:!1,value:{handleBounds:l?.handleBounds,z:c,userProvidedNode:t}}),e.set(u.id,u),u})),e,o.nodeOrigin,i)},t.areConnectionMapsEqual=function(t,e){if(!t&&!e)return!0;if(!t||!e||t.size!==e.size)return!1;if(!t.size&&!e.size)return!0;for(const n of t.keys())if(!e.has(n))return!1;return!0},t.boxToRect=_,t.calcAutoPan=v,t.calcNextPosition=p,t.clamp=g,t.clampPosition=m,t.createMarkerIds=function(t,{id:e,defaultColor:n}){const o=[];return t.reduce(((t,r)=>([r.markerStart,r.markerEnd].forEach((r=>{if(r&&"object"==typeof r){const i=U(r,e);o.includes(i)||(t.push({id:i,color:r.color||n,...r}),o.push(i))}})),t)),[]).sort(((t,e)=>t.id.localeCompare(e.id)))},t.devWarn=S,t.elementSelectionKeys=["Enter"," ","Escape"],t.errorMessages=e,t.fitView=function({nodes:t,width:e,height:n,panZoom:o,minZoom:r,maxZoom:i,nodeOrigin:a=[0,0]},s){const u=t.filter((t=>{const e=t.computed?.width&&t.computed?.height&&(s?.includeHiddenNodes||!t.hidden);return s?.nodes?.length?e&&s?.nodes.some((e=>e.id===t.id)):e}));if(u.length>0){const t=d(u,a),c=T(t,e,n,s?.minZoom??r,s?.maxZoom??i,s?.padding??.1);return o.setViewport(c,{duration:s?.duration}),!0}return!1},t.getBezierEdgeCenter=R,t.getBezierPath=function({sourceX:e,sourceY:n,sourcePosition:o=t.Position.Bottom,targetX:r,targetY:i,targetPosition:a=t.Position.Top,curvature:s=.25}){const[u,c]=D({pos:o,x1:e,y1:n,x2:r,y2:i,c:s}),[l,h]=D({pos:a,x1:r,y1:i,x2:e,y2:n,c:s}),[d,f,p,g]=R({sourceX:e,sourceY:n,targetX:r,targetY:i,sourceControlX:u,sourceControlY:c,targetControlX:l,targetControlY:h});return[`M${e},${n} C${u},${c} ${l},${h} ${r},${i}`,d,f,p,g]},t.getBoundsOfBoxes=x,t.getBoundsOfRects=(t,e)=>_(x(w(t),w(e))),t.getConnectedEdges=f,t.getDimensions=C,t.getEdgeCenter=L,t.getEdgePosition=function(o){const{sourceNode:r,targetNode:i}=o;if(!j(r)||!j(i))return null;const a=r[n]?.handleBounds||F(r.handles),s=i[n]?.handleBounds||F(i.handles),u=K(a?.source??[],o.sourceHandle),c=K(o.connectionMode===t.ConnectionMode.Strict?s?.target??[]:(s?.target??[]).concat(s?.source??[]),o.targetHandle),l=u?.position||t.Position.Bottom,h=c?.position||t.Position.Top;if(!u||!c)return o.onError?.("008",e.error008(u?"target":"source",{id:o.id,sourceHandle:o.sourceHandle,targetHandle:o.targetHandle})),null;const[d,f]=W(l,r,u),[p,g]=W(h,i,c);return{sourceX:d,sourceY:f,targetX:p,targetY:g,sourcePosition:l,targetPosition:h}},t.getElementsToRemove=async function({nodesToRemove:t=[],edgesToRemove:e=[],nodes:n,edges:o,onBeforeDelete:r}){const i=t.map((t=>t.id)),a=[];for(const t of n){if(!1===t.deletable)continue;const e=i.includes(t.id),n=!e&&t.parentNode&&a.find((e=>e.id===t.parentNode));(e||n)&&a.push(t)}const s=e.map((t=>t.id)),u=o.filter((t=>!1!==t.deletable)),c=f(a,u);for(const t of u){s.includes(t.id)&&!c.find((e=>e.id===t.id))&&c.push(t)}if(!r)return{edges:c,nodes:a};const l=await r({nodes:a,edges:c});return"boolean"==typeof l?l?{edges:c,nodes:a}:{edges:[],nodes:[]}:l},t.getElevatedEdgeZIndex=function({sourceNode:t,targetNode:e,selected:o=!1,zIndex:r=0,elevateOnSelect:i=!1}){if(!i)return r;const a=o||e.selected||t.selected,s=Math.max(t[n]?.z||0,e[n]?.z||0,1e3);return r+(a?s:0)},t.getEventPosition=H,t.getHandleBounds=Y,t.getHostForElement=I,t.getIncomers=(t,e,n)=>{if(!t.id)return[];const o=new Set;return n.forEach((e=>{e.target===t.id&&o.add(e.source)})),e.filter((t=>o.has(t.id)))},t.getMarkerId=U,t.getNodePositionWithOrigin=h,t.getNodeToolbarTransform=function(e,n,o,r,i){let a=.5;"start"===i?a=0:"end"===i&&(a=1);let s=[(e.x+e.width*a)*n.zoom+n.x,e.y*n.zoom+n.y-r],u=[-100*a,-100];switch(o){case t.Position.Right:s=[(e.x+e.width)*n.zoom+n.x+r,(e.y+e.height*a)*n.zoom+n.y],u=[0,-100*a];break;case t.Position.Bottom:s[1]=(e.y+e.height)*n.zoom+n.y+r,u[1]=0;break;case t.Position.Left:s=[e.x*n.zoom+n.x-r,(e.y+e.height*a)*n.zoom+n.y],u=[-100,-100*a]}return`translate(${s[0]}px, ${s[1]}px) translate(${u[0]}%, ${u[1]}%)`},t.getNodesBounds=d,t.getNodesInside=(t,e,[n,o,r]=[0,0,1],i=!1,a=!1,s=[0,0])=>{const u={...z(e,[n,o,r]),width:e.width/r,height:e.height/r};return t.reduce(((t,e)=>{const{computed:n,selectable:o=!0,hidden:r=!1}=e,c=n?.width??e.width??null,l=n?.height??e.height??null;if(a&&!o||r)return t;const h=E(u,b(e,s));return(null===c||null===l||i&&h>0||h>=(c??0)*(l??0)||e.dragging)&&t.push(e),t}),[])},t.getOutgoers=(t,e,n)=>{if(!t.id)return[];const o=new Set;return n.forEach((e=>{e.source===t.id&&o.add(e.target)})),e.filter((t=>o.has(t.id)))},t.getOverlappingArea=E,t.getPointerPosition=k,t.getPositionWithOrigin=({x:t,y:e,width:n,height:o,origin:r=[0,0]})=>!n||!o||r[0]<0||r[1]<0||r[0]>1||r[1]>1?{x:t,y:e}:{x:t-n*r[0],y:e-o*r[1]},t.getSmoothStepPath=function({sourceX:e,sourceY:n,sourcePosition:o=t.Position.Bottom,targetX:r,targetY:i,targetPosition:a=t.Position.Top,borderRadius:s=5,centerX:u,centerY:c,offset:l=20}){const[h,d,f,p,g]=function({source:e,sourcePosition:n=t.Position.Bottom,target:o,targetPosition:r=t.Position.Top,center:i,offset:a}){const s=q[n],u=q[r],c={x:e.x+s.x*a,y:e.y+s.y*a},l={x:o.x+u.x*a,y:o.y+u.y*a},h=Z({source:c,sourcePosition:n,target:l}),d=0!==h.x?"x":"y",f=h[d];let p,g,m=[];const y={x:0,y:0},v={x:0,y:0},[x,w,_,b]=L({sourceX:e.x,sourceY:e.y,targetX:o.x,targetY:o.y});if(s[d]*u[d]==-1){p=i.x||x,g=i.y||w;const t=[{x:p,y:c.y},{x:p,y:l.y}],e=[{x:c.x,y:g},{x:l.x,y:g}];m=s[d]===f?"x"===d?t:e:"x"===d?e:t}else{const t=[{x:c.x,y:l.y}],i=[{x:l.x,y:c.y}];if(m="x"===d?s.x===f?i:t:s.y===f?t:i,n===r){const t=Math.abs(e[d]-o[d]);if(t<=a){const n=Math.min(a-1,a-t);s[d]===f?y[d]=(c[d]>e[d]?-1:1)*n:v[d]=(l[d]>o[d]?-1:1)*n}}if(n!==r){const e="x"===d?"y":"x",n=s[d]===u[e],o=c[e]>l[e],r=c[e]<l[e];(1===s[d]&&(!n&&o||n&&r)||1!==s[d]&&(!n&&r||n&&o))&&(m="x"===d?t:i)}const h={x:c.x+y.x,y:c.y+y.y},x={x:l.x+v.x,y:l.y+v.y};Math.max(Math.abs(h.x-m[0].x),Math.abs(x.x-m[0].x))>=Math.max(Math.abs(h.y-m[0].y),Math.abs(x.y-m[0].y))?(p=(h.x+x.x)/2,g=m[0].y):(p=m[0].x,g=(h.y+x.y)/2)}return[[e,{x:c.x+y.x,y:c.y+y.y},...m,{x:l.x+v.x,y:l.y+v.y},o],p,g,_,b]}({source:{x:e,y:n},sourcePosition:o,target:{x:r,y:i},targetPosition:a,center:{x:u,y:c},offset:l});return[h.reduce(((t,e,n)=>{let o="";return o=n>0&&n<h.length-1?function(t,e,n,o){const r=Math.min(G(t,e)/2,G(e,n)/2,o),{x:i,y:a}=e;if(t.x===i&&i===n.x||t.y===a&&a===n.y)return`L${i} ${a}`;if(t.y===a)return`L ${i+r*(t.x<n.x?-1:1)},${a}Q ${i},${a} ${i},${a+r*(t.y<n.y?1:-1)}`;const s=t.x<n.x?1:-1;return`L ${i},${a+r*(t.y<n.y?-1:1)}Q ${i},${a} ${i+r*s},${a}`}(h[n-1],e,h[n+1],s):`${0===n?"M":"L"}${e.x} ${e.y}`,t+=o}),""),d,f,p,g]},t.getStraightPath=function({sourceX:t,sourceY:e,targetX:n,targetY:o}){const[r,i,a,s]=L({sourceX:t,sourceY:e,targetX:n,targetY:o});return[`M ${t},${e}L ${n},${o}`,r,i,a,s]},t.getViewportForBounds=T,t.handleConnectionChange=function(t,e,n){if(!n)return;const o=[];t.forEach(((t,n)=>{e?.has(n)||o.push(t)})),o.length&&n(o)},t.infiniteExtent=o,t.internalsSymbol=n,t.isEdgeBase=l,t.isEdgeVisible=function({sourceNode:t,targetNode:e,width:n,height:o,transform:r}){const i=x(P(t),P(e));i.x===i.x2&&(i.x2+=1),i.y===i.y2&&(i.y2+=1);const a={x:-r[0]/r[2],y:-r[1]/r[2],width:n/r[2],height:o/r[2]};return E(a,_(i))>0},t.isInputDOMNode=function(t){const e=t.composedPath?.()?.[0]||t.target,n=O.includes(e?.nodeName)||e?.hasAttribute("contenteditable"),o=t.ctrlKey||t.metaKey||t.shiftKey;return n&&!o||!!e?.closest(".nokey")},t.isMacOs=$,t.isMouseEvent=X,t.isNodeBase=t=>"id"in t&&!("source"in t)&&!("target"in t),t.isNumeric=M,t.isRectObject=t=>M(t.width)&&M(t.height)&&M(t.x)&&M(t.y),t.nodeToBox=P,t.nodeToRect=b,t.panBy=function({delta:t,panZoom:e,transform:n,translateExtent:o,width:r,height:i}){if(!e||!t.x&&!t.y)return!1;const a=e.setViewportConstrained({x:n[0]+t.x,y:n[1]+t.y,zoom:n[2]},[[0,0],[r,i]],o);return!!a&&(a.x!==n[0]||a.y!==n[1]||a.k!==n[2])},t.pointToRendererPoint=z,t.rectToBox=w,t.rendererPointToPoint=A,t.snapPosition=N,t.updateAbsolutePositions=Q,t.updateConnectionLookup=function(t,e,n){t.clear(),e.clear();for(const o of n){const{source:n,target:r,sourceHandle:i=null,targetHandle:a=null}=o,s=`${n}-source-${i}`,u=`${r}-target-${a}`,c=t.get(s)||new Map,l=t.get(u)||new Map,h={source:n,target:r,sourceHandle:i,targetHandle:a};e.set(o.id,o),t.set(s,c.set(`${r}-${a}`,h)),t.set(u,l.set(`${n}-${i}`,h))}},t.updateEdge=(t,n,o,r={shouldReplaceId:!0})=>{const{id:i,...a}=t;if(!n.source||!n.target)return e.error006(),o;if(!o.find((e=>e.id===t.id)))return e.error007(i),o;const s={...a,id:r.shouldReplaceId?V(n):i,source:n.source,target:n.target,sourceHandle:n.sourceHandle,targetHandle:n.targetHandle};return o.filter((t=>t.id!==i)).concat(s)},t.updateNodeDimensions=function(t,e,o,r,i,a){const s=r?.querySelector(".xyflow__viewport");if(!s)return null;const u=window.getComputedStyle(s),{m22:c}=new window.DOMMatrixReadOnly(u.transform);return e.map((e=>{const r=t.get(e.id);if(r){const t=C(r.nodeElement);if(!(!t.width||!t.height||e.computed?.width===t.width&&e.computed?.height===t.height&&!r.forceUpdate)){a?.(e.id,t);const s={...e,computed:{...e.computed,...t},[n]:{...e[n],handleBounds:{source:Y(".source",r.nodeElement,c,e.origin||i),target:Y(".target",r.nodeElement,c,e.origin||i)}}};return o.set(e.id,s),s}}return e}))}}));
|
|
1
|
+
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).XYFlowSystem={})}(this,(function(t){"use strict";const e={error001:()=>"[React Flow]: Seems like you have not used zustand provider as an ancestor. Help: https://reactflow.dev/error#001",error002:()=>"It looks like you've created a new nodeTypes or edgeTypes object. If this wasn't on purpose please define the nodeTypes/edgeTypes outside of the component or memoize them.",error003:t=>`Node type "${t}" not found. Using fallback type "default".`,error004:()=>"The React Flow parent container needs a width and a height to render the graph.",error005:()=>"Only child nodes can use a parent extent.",error006:()=>"Can't create edge. An edge needs a source and a target.",error007:t=>`The old edge with id=${t} does not exist.`,error009:t=>`Marker type "${t}" doesn't exist.`,error008:(t,{id:e,sourceHandle:n,targetHandle:o})=>`Couldn't create edge for ${t} handle id: "${n?o:n}", edge id: ${e}.`,error010:()=>"Handle: No node id found. Make sure to only use a Handle inside a custom Node.",error011:t=>`Edge type "${t}" not found. Using fallback type "default".`,error012:t=>`Node with id "${t}" does not exist, it may have been removed. This can happen when a node is deleted before the "onNodeClick" handler is called.`},n=Symbol.for("internals"),o=[[Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY],[Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY]];var r,i,a,s,u,c;t.ConnectionMode=void 0,(r=t.ConnectionMode||(t.ConnectionMode={})).Strict="strict",r.Loose="loose",t.PanOnScrollMode=void 0,(i=t.PanOnScrollMode||(t.PanOnScrollMode={})).Free="free",i.Vertical="vertical",i.Horizontal="horizontal",t.SelectionMode=void 0,(a=t.SelectionMode||(t.SelectionMode={})).Partial="partial",a.Full="full",t.ConnectionLineType=void 0,(s=t.ConnectionLineType||(t.ConnectionLineType={})).Bezier="default",s.Straight="straight",s.Step="step",s.SmoothStep="smoothstep",s.SimpleBezier="simplebezier",t.MarkerType=void 0,(u=t.MarkerType||(t.MarkerType={})).Arrow="arrow",u.ArrowClosed="arrowclosed",t.Position=void 0,(c=t.Position||(t.Position={})).Left="left",c.Top="top",c.Right="right",c.Bottom="bottom";const l=t=>"id"in t&&"source"in t&&"target"in t,h=(t,e=[0,0])=>{if(!t)return{position:{x:0,y:0},positionAbsolute:{x:0,y:0}};const n=(t.computed?.width??t.width??0)*e[0],o=(t.computed?.height??t.height??0)*e[1],r={x:t.position.x-n,y:t.position.y-o};return{position:r,positionAbsolute:t.computed?.positionAbsolute?{x:t.computed.positionAbsolute.x-n,y:t.computed.positionAbsolute.y-o}:r}},d=(t,e={nodeOrigin:[0,0],useRelativePosition:!1})=>{if(0===t.length)return{x:0,y:0,width:0,height:0};const n=t.reduce(((t,n)=>{const o=h(n,n.origin||e.nodeOrigin);return x(t,w({...o[e.useRelativePosition?"position":"positionAbsolute"],width:n.computed?.width??n.width??0,height:n.computed?.height??n.height??0}))}),{x:1/0,y:1/0,x2:-1/0,y2:-1/0});return _(n)},f=(t,e)=>{const n=new Set;return t.forEach((t=>{n.add(t.id)})),e.filter((t=>n.has(t.source)||n.has(t.target)))};function p({nodeId:t,nextPosition:n,nodeLookup:o,nodeOrigin:r=[0,0],nodeExtent:i,onError:a}){const s=o.get(t),u=s.parentNode?o.get(s.parentNode):void 0,{x:c,y:l}=u?h(u,u.origin||r).positionAbsolute:{x:0,y:0};let d=function(t,e){return e&&"parent"!==e?[e[0],[e[1][0]-(t.computed?.width??0),e[1][1]-(t.computed?.height??0)]]:e}(s,s.extent||i);if("parent"!==s.extent||s.expandParent)u&&$(s.extent)&&(d=[[s.extent[0][0]+c,s.extent[0][1]+l],[s.extent[1][0]+c,s.extent[1][1]+l]]);else if(u){const t=s.computed?.width,e=s.computed?.height,n=u?.computed?.width,o=u?.computed?.height;if(t&&e&&n&&o){const i=s.origin||r,a=c+t*i[0],u=l+e*i[1];d=[[a,u],[a+n-t,u+o-e]]}}else a?.("005",e.error005());const f=$(d)?m(n,d):n;return{position:{x:f.x-c,y:f.y-l},positionAbsolute:f}}const g=(t,e=0,n=1)=>Math.min(Math.max(t,e),n),m=(t={x:0,y:0},e)=>({x:g(t.x,e[0][0],e[1][0]),y:g(t.y,e[0][1],e[1][1])}),y=(t,e,n)=>t<e?g(Math.abs(t-e),1,50)/50:t>n?-g(Math.abs(t-n),1,50)/50:0,v=(t,e)=>[20*y(t.x,35,e.width-35),20*y(t.y,35,e.height-35)],x=(t,e)=>({x:Math.min(t.x,e.x),y:Math.min(t.y,e.y),x2:Math.max(t.x2,e.x2),y2:Math.max(t.y2,e.y2)}),w=({x:t,y:e,width:n,height:o})=>({x:t,y:e,x2:t+n,y2:e+o}),_=({x:t,y:e,x2:n,y2:o})=>({x:t,y:e,width:n-t,height:o-e}),b=(t,e=[0,0])=>{const{positionAbsolute:n}=h(t,t.origin||e);return{...n,width:t.computed?.width??t.width??0,height:t.computed?.height??t.height??0}},E=(t,e=[0,0])=>{const{positionAbsolute:n}=h(t,t.origin||e);return{...n,x2:n.x+(t.computed?.width??t.width??0),y2:n.y+(t.computed?.height??t.height??0)}},P=(t,e)=>{const n=Math.max(0,Math.min(t.x+t.width,e.x+e.width)-Math.max(t.x,e.x)),o=Math.max(0,Math.min(t.y+t.height,e.y+e.height)-Math.max(t.y,e.y));return Math.ceil(n*o)},M=t=>!isNaN(t)&&isFinite(t),S=(t,e)=>{},N=(t,e=[1,1])=>({x:e[0]*Math.round(t.x/e[0]),y:e[1]*Math.round(t.y/e[1])}),z=({x:t,y:e},[n,o,r],i=!1,a=[1,1])=>{const s={x:(t-n)/r,y:(e-o)/r};return i?N(s,a):s},k=({x:t,y:e},[n,o,r])=>({x:t*r+n,y:e*r+o}),A=(t,e,n,o,r,i)=>{const a=e/(t.width*(1+i)),s=n/(t.height*(1+i)),u=Math.min(a,s),c=g(u,o,r);return{x:e/2-(t.x+t.width/2)*c,y:n/2-(t.y+t.height/2)*c,zoom:c}},T=()=>"undefined"!=typeof navigator&&navigator?.userAgent?.indexOf("Mac")>=0;function $(t){return void 0!==t&&"parent"!==t}function C(t,{snapGrid:e=[0,0],snapToGrid:n=!1,transform:o}){const{x:r,y:i}=Y(t),a=z({x:r,y:i},o),{x:s,y:u}=n?N(a,e):a;return{xSnapped:s,ySnapped:u,...a}}const I=t=>({width:t.offsetWidth,height:t.offsetHeight}),O=t=>t.getRootNode?.()||window?.document,X=["INPUT","SELECT","TEXTAREA"];const H=t=>"clientX"in t,Y=(t,e)=>{const n=H(t),o=n?t.clientX:t.touches?.[0].clientX,r=n?t.clientY:t.touches?.[0].clientY;return{x:o-(e?.left??0),y:r-(e?.top??0)}},R=(t,e,n,o=[0,0])=>{const r=e.querySelectorAll(t);if(!r||!r.length)return null;const i=Array.from(r),a=e.getBoundingClientRect(),s=a.width*o[0],u=a.height*o[1];return i.map((t=>{const e=t.getBoundingClientRect();return{id:t.getAttribute("data-handleid"),position:t.getAttribute("data-handlepos"),x:(e.left-a.left-s)/n,y:(e.top-a.top-u)/n,...I(t)}}))};function B({sourceX:t,sourceY:e,targetX:n,targetY:o,sourceControlX:r,sourceControlY:i,targetControlX:a,targetControlY:s}){const u=.125*t+.375*r+.375*a+.125*n,c=.125*e+.375*i+.375*s+.125*o;return[u,c,Math.abs(u-t),Math.abs(c-e)]}function D(t,e){return t>=0?.5*t:25*e*Math.sqrt(-t)}function L({pos:e,x1:n,y1:o,x2:r,y2:i,c:a}){switch(e){case t.Position.Left:return[n-D(n-r,a),o];case t.Position.Right:return[n+D(r-n,a),o];case t.Position.Top:return[n,o-D(o-i,a)];case t.Position.Bottom:return[n,o+D(i-o,a)]}}function V({sourceX:t,sourceY:e,targetX:n,targetY:o}){const r=Math.abs(n-t)/2,i=n<t?n+r:n-r,a=Math.abs(o-e)/2;return[i,o<e?o+a:o-a,r,a]}const q=({source:t,sourceHandle:e,target:n,targetHandle:o})=>`xy-edge__${t}${e||""}-${n}${o||""}`;const Z={[t.Position.Left]:{x:-1,y:0},[t.Position.Right]:{x:1,y:0},[t.Position.Top]:{x:0,y:-1},[t.Position.Bottom]:{x:0,y:1}},G=({source:e,sourcePosition:n=t.Position.Bottom,target:o})=>n===t.Position.Left||n===t.Position.Right?e.x<o.x?{x:1,y:0}:{x:-1,y:0}:e.y<o.y?{x:0,y:1}:{x:0,y:-1},j=(t,e)=>Math.sqrt(Math.pow(e.x-t.x,2)+Math.pow(e.y-t.y,2));function F(t){return!(!t?.[n]?.handleBounds&&!t?.handles?.length||!t?.computed?.width&&!t?.width)}function W(t){if(!t)return null;const e=[],n=[];for(const o of t)o.width=o.width||1,o.height=o.height||1,"source"===o.type?e.push(o):"target"===o.type&&n.push(o);return{source:e,target:n}}function K(e,n,o=null){const r=(o?.x??0)+(n.computed?.positionAbsolute?.x??0),i=(o?.y??0)+(n.computed?.positionAbsolute?.y??0),a=o?.width||(n?.computed?.width??n?.width??0),s=o?.height||(n?.computed?.height??n?.height??0);switch(e){case t.Position.Top:return[r+a/2,i];case t.Position.Right:return[r+a,i+s/2];case t.Position.Bottom:return[r+a/2,i+s];case t.Position.Left:return[r,i+s/2]}}function U(t,e){return t&&(e?t.find((t=>t.id===e)):t[0])||null}function Q(t,e){if(!t)return"";if("string"==typeof t)return t;return`${e?`${e}__`:""}${Object.keys(t).sort().map((e=>`${e}=${t[e]}`)).join("&")}`}function J(t,e,o=[0,0],r){return t.map((i=>{if(i.parentNode&&!e.has(i.parentNode))throw new Error(`Parent node ${i.parentNode} not found`);if(i.parentNode||r?.[i.id]){const a=i.parentNode?e.get(i.parentNode):null,{x:s,y:u,z:c}=tt(i,t,e,{...i.position,z:i[n]?.z??0},a?.origin||o),l=s!==i.computed?.positionAbsolute?.x||u!==i.computed?.positionAbsolute?.y;i.computed.positionAbsolute=l?{x:s,y:u}:i.computed?.positionAbsolute,i[n].z=c,r?.[i.id]&&(i[n].isParent=!0)}return i}))}function tt(t,e,o,r,i){if(!t.parentNode)return r;const a=o.get(t.parentNode),{position:s}=h(a,a?.origin||i);return tt(a,e,o,{x:(r.x??0)+s.x,y:(r.y??0)+s.y,z:(a[n]?.z??0)>(r.z??0)?a[n]?.z??0:r.z??0},a.origin||i)}var et={value:()=>{}};function nt(){for(var t,e=0,n=arguments.length,o={};e<n;++e){if(!(t=arguments[e]+"")||t in o||/[\s.]/.test(t))throw new Error("illegal type: "+t);o[t]=[]}return new ot(o)}function ot(t){this._=t}function rt(t,e){for(var n,o=0,r=t.length;o<r;++o)if((n=t[o]).name===e)return n.value}function it(t,e,n){for(var o=0,r=t.length;o<r;++o)if(t[o].name===e){t[o]=et,t=t.slice(0,o).concat(t.slice(o+1));break}return null!=n&&t.push({name:e,value:n}),t}ot.prototype=nt.prototype={constructor:ot,on:function(t,e){var n,o,r=this._,i=(o=r,(t+"").trim().split(/^|\s+/).map((function(t){var e="",n=t.indexOf(".");if(n>=0&&(e=t.slice(n+1),t=t.slice(0,n)),t&&!o.hasOwnProperty(t))throw new Error("unknown type: "+t);return{type:t,name:e}}))),a=-1,s=i.length;if(!(arguments.length<2)){if(null!=e&&"function"!=typeof e)throw new Error("invalid callback: "+e);for(;++a<s;)if(n=(t=i[a]).type)r[n]=it(r[n],t.name,e);else if(null==e)for(n in r)r[n]=it(r[n],t.name,null);return this}for(;++a<s;)if((n=(t=i[a]).type)&&(n=rt(r[n],t.name)))return n},copy:function(){var t={},e=this._;for(var n in e)t[n]=e[n].slice();return new ot(t)},call:function(t,e){if((n=arguments.length-2)>0)for(var n,o,r=new Array(n),i=0;i<n;++i)r[i]=arguments[i+2];if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(i=0,n=(o=this._[t]).length;i<n;++i)o[i].value.apply(e,r)},apply:function(t,e,n){if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(var o=this._[t],r=0,i=o.length;r<i;++r)o[r].value.apply(e,n)}};var at="http://www.w3.org/1999/xhtml",st={svg:"http://www.w3.org/2000/svg",xhtml:at,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function ut(t){var e=t+="",n=e.indexOf(":");return n>=0&&"xmlns"!==(e=t.slice(0,n))&&(t=t.slice(n+1)),st.hasOwnProperty(e)?{space:st[e],local:t}:t}function ct(t){return function(){var e=this.ownerDocument,n=this.namespaceURI;return n===at&&e.documentElement.namespaceURI===at?e.createElement(t):e.createElementNS(n,t)}}function lt(t){return function(){return this.ownerDocument.createElementNS(t.space,t.local)}}function ht(t){var e=ut(t);return(e.local?lt:ct)(e)}function dt(){}function ft(t){return null==t?dt:function(){return this.querySelector(t)}}function pt(){return[]}function gt(t){return null==t?pt:function(){return this.querySelectorAll(t)}}function mt(t){return function(){return null==(e=t.apply(this,arguments))?[]:Array.isArray(e)?e:Array.from(e);var e}}function yt(t){return function(){return this.matches(t)}}function vt(t){return function(e){return e.matches(t)}}var xt=Array.prototype.find;function wt(){return this.firstElementChild}var _t=Array.prototype.filter;function bt(){return Array.from(this.children)}function Et(t){return new Array(t.length)}function Pt(t,e){this.ownerDocument=t.ownerDocument,this.namespaceURI=t.namespaceURI,this._next=null,this._parent=t,this.__data__=e}function Mt(t,e,n,o,r,i){for(var a,s=0,u=e.length,c=i.length;s<c;++s)(a=e[s])?(a.__data__=i[s],o[s]=a):n[s]=new Pt(t,i[s]);for(;s<u;++s)(a=e[s])&&(r[s]=a)}function St(t,e,n,o,r,i,a){var s,u,c,l=new Map,h=e.length,d=i.length,f=new Array(h);for(s=0;s<h;++s)(u=e[s])&&(f[s]=c=a.call(u,u.__data__,s,e)+"",l.has(c)?r[s]=u:l.set(c,u));for(s=0;s<d;++s)c=a.call(t,i[s],s,i)+"",(u=l.get(c))?(o[s]=u,u.__data__=i[s],l.delete(c)):n[s]=new Pt(t,i[s]);for(s=0;s<h;++s)(u=e[s])&&l.get(f[s])===u&&(r[s]=u)}function Nt(t){return t.__data__}function zt(t){return"object"==typeof t&&"length"in t?t:Array.from(t)}function kt(t,e){return t<e?-1:t>e?1:t>=e?0:NaN}function At(t){return function(){this.removeAttribute(t)}}function Tt(t){return function(){this.removeAttributeNS(t.space,t.local)}}function $t(t,e){return function(){this.setAttribute(t,e)}}function Ct(t,e){return function(){this.setAttributeNS(t.space,t.local,e)}}function It(t,e){return function(){var n=e.apply(this,arguments);null==n?this.removeAttribute(t):this.setAttribute(t,n)}}function Ot(t,e){return function(){var n=e.apply(this,arguments);null==n?this.removeAttributeNS(t.space,t.local):this.setAttributeNS(t.space,t.local,n)}}function Xt(t){return t.ownerDocument&&t.ownerDocument.defaultView||t.document&&t||t.defaultView}function Ht(t){return function(){this.style.removeProperty(t)}}function Yt(t,e,n){return function(){this.style.setProperty(t,e,n)}}function Rt(t,e,n){return function(){var o=e.apply(this,arguments);null==o?this.style.removeProperty(t):this.style.setProperty(t,o,n)}}function Bt(t,e){return t.style.getPropertyValue(e)||Xt(t).getComputedStyle(t,null).getPropertyValue(e)}function Dt(t){return function(){delete this[t]}}function Lt(t,e){return function(){this[t]=e}}function Vt(t,e){return function(){var n=e.apply(this,arguments);null==n?delete this[t]:this[t]=n}}function qt(t){return t.trim().split(/^|\s+/)}function Zt(t){return t.classList||new Gt(t)}function Gt(t){this._node=t,this._names=qt(t.getAttribute("class")||"")}function jt(t,e){for(var n=Zt(t),o=-1,r=e.length;++o<r;)n.add(e[o])}function Ft(t,e){for(var n=Zt(t),o=-1,r=e.length;++o<r;)n.remove(e[o])}function Wt(t){return function(){jt(this,t)}}function Kt(t){return function(){Ft(this,t)}}function Ut(t,e){return function(){(e.apply(this,arguments)?jt:Ft)(this,t)}}function Qt(){this.textContent=""}function Jt(t){return function(){this.textContent=t}}function te(t){return function(){var e=t.apply(this,arguments);this.textContent=null==e?"":e}}function ee(){this.innerHTML=""}function ne(t){return function(){this.innerHTML=t}}function oe(t){return function(){var e=t.apply(this,arguments);this.innerHTML=null==e?"":e}}function re(){this.nextSibling&&this.parentNode.appendChild(this)}function ie(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function ae(){return null}function se(){var t=this.parentNode;t&&t.removeChild(this)}function ue(){var t=this.cloneNode(!1),e=this.parentNode;return e?e.insertBefore(t,this.nextSibling):t}function ce(){var t=this.cloneNode(!0),e=this.parentNode;return e?e.insertBefore(t,this.nextSibling):t}function le(t){return function(){var e=this.__on;if(e){for(var n,o=0,r=-1,i=e.length;o<i;++o)n=e[o],t.type&&n.type!==t.type||n.name!==t.name?e[++r]=n:this.removeEventListener(n.type,n.listener,n.options);++r?e.length=r:delete this.__on}}}function he(t,e,n){return function(){var o,r=this.__on,i=function(t){return function(e){t.call(this,e,this.__data__)}}(e);if(r)for(var a=0,s=r.length;a<s;++a)if((o=r[a]).type===t.type&&o.name===t.name)return this.removeEventListener(o.type,o.listener,o.options),this.addEventListener(o.type,o.listener=i,o.options=n),void(o.value=e);this.addEventListener(t.type,i,n),o={type:t.type,name:t.name,value:e,listener:i,options:n},r?r.push(o):this.__on=[o]}}function de(t,e,n){var o=Xt(t),r=o.CustomEvent;"function"==typeof r?r=new r(e,n):(r=o.document.createEvent("Event"),n?(r.initEvent(e,n.bubbles,n.cancelable),r.detail=n.detail):r.initEvent(e,!1,!1)),t.dispatchEvent(r)}function fe(t,e){return function(){return de(this,t,e)}}function pe(t,e){return function(){return de(this,t,e.apply(this,arguments))}}Pt.prototype={constructor:Pt,appendChild:function(t){return this._parent.insertBefore(t,this._next)},insertBefore:function(t,e){return this._parent.insertBefore(t,e)},querySelector:function(t){return this._parent.querySelector(t)},querySelectorAll:function(t){return this._parent.querySelectorAll(t)}},Gt.prototype={add:function(t){this._names.indexOf(t)<0&&(this._names.push(t),this._node.setAttribute("class",this._names.join(" ")))},remove:function(t){var e=this._names.indexOf(t);e>=0&&(this._names.splice(e,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(t){return this._names.indexOf(t)>=0}};var ge=[null];function me(t,e){this._groups=t,this._parents=e}function ye(){return new me([[document.documentElement]],ge)}function ve(t){return"string"==typeof t?new me([[document.querySelector(t)]],[document.documentElement]):new me([[t]],ge)}function xe(t,e){if(t=function(t){let e;for(;e=t.sourceEvent;)t=e;return t}(t),void 0===e&&(e=t.currentTarget),e){var n=e.ownerSVGElement||e;if(n.createSVGPoint){var o=n.createSVGPoint();return o.x=t.clientX,o.y=t.clientY,[(o=o.matrixTransform(e.getScreenCTM().inverse())).x,o.y]}if(e.getBoundingClientRect){var r=e.getBoundingClientRect();return[t.clientX-r.left-e.clientLeft,t.clientY-r.top-e.clientTop]}}return[t.pageX,t.pageY]}me.prototype=ye.prototype={constructor:me,select:function(t){"function"!=typeof t&&(t=ft(t));for(var e=this._groups,n=e.length,o=new Array(n),r=0;r<n;++r)for(var i,a,s=e[r],u=s.length,c=o[r]=new Array(u),l=0;l<u;++l)(i=s[l])&&(a=t.call(i,i.__data__,l,s))&&("__data__"in i&&(a.__data__=i.__data__),c[l]=a);return new me(o,this._parents)},selectAll:function(t){t="function"==typeof t?mt(t):gt(t);for(var e=this._groups,n=e.length,o=[],r=[],i=0;i<n;++i)for(var a,s=e[i],u=s.length,c=0;c<u;++c)(a=s[c])&&(o.push(t.call(a,a.__data__,c,s)),r.push(a));return new me(o,r)},selectChild:function(t){return this.select(null==t?wt:function(t){return function(){return xt.call(this.children,t)}}("function"==typeof t?t:vt(t)))},selectChildren:function(t){return this.selectAll(null==t?bt:function(t){return function(){return _t.call(this.children,t)}}("function"==typeof t?t:vt(t)))},filter:function(t){"function"!=typeof t&&(t=yt(t));for(var e=this._groups,n=e.length,o=new Array(n),r=0;r<n;++r)for(var i,a=e[r],s=a.length,u=o[r]=[],c=0;c<s;++c)(i=a[c])&&t.call(i,i.__data__,c,a)&&u.push(i);return new me(o,this._parents)},data:function(t,e){if(!arguments.length)return Array.from(this,Nt);var n,o=e?St:Mt,r=this._parents,i=this._groups;"function"!=typeof t&&(n=t,t=function(){return n});for(var a=i.length,s=new Array(a),u=new Array(a),c=new Array(a),l=0;l<a;++l){var h=r[l],d=i[l],f=d.length,p=zt(t.call(h,h&&h.__data__,l,r)),g=p.length,m=u[l]=new Array(g),y=s[l]=new Array(g);o(h,d,m,y,c[l]=new Array(f),p,e);for(var v,x,w=0,_=0;w<g;++w)if(v=m[w]){for(w>=_&&(_=w+1);!(x=y[_])&&++_<g;);v._next=x||null}}return(s=new me(s,r))._enter=u,s._exit=c,s},enter:function(){return new me(this._enter||this._groups.map(Et),this._parents)},exit:function(){return new me(this._exit||this._groups.map(Et),this._parents)},join:function(t,e,n){var o=this.enter(),r=this,i=this.exit();return"function"==typeof t?(o=t(o))&&(o=o.selection()):o=o.append(t+""),null!=e&&(r=e(r))&&(r=r.selection()),null==n?i.remove():n(i),o&&r?o.merge(r).order():r},merge:function(t){for(var e=t.selection?t.selection():t,n=this._groups,o=e._groups,r=n.length,i=o.length,a=Math.min(r,i),s=new Array(r),u=0;u<a;++u)for(var c,l=n[u],h=o[u],d=l.length,f=s[u]=new Array(d),p=0;p<d;++p)(c=l[p]||h[p])&&(f[p]=c);for(;u<r;++u)s[u]=n[u];return new me(s,this._parents)},selection:function(){return this},order:function(){for(var t=this._groups,e=-1,n=t.length;++e<n;)for(var o,r=t[e],i=r.length-1,a=r[i];--i>=0;)(o=r[i])&&(a&&4^o.compareDocumentPosition(a)&&a.parentNode.insertBefore(o,a),a=o);return this},sort:function(t){function e(e,n){return e&&n?t(e.__data__,n.__data__):!e-!n}t||(t=kt);for(var n=this._groups,o=n.length,r=new Array(o),i=0;i<o;++i){for(var a,s=n[i],u=s.length,c=r[i]=new Array(u),l=0;l<u;++l)(a=s[l])&&(c[l]=a);c.sort(e)}return new me(r,this._parents).order()},call:function(){var t=arguments[0];return arguments[0]=this,t.apply(null,arguments),this},nodes:function(){return Array.from(this)},node:function(){for(var t=this._groups,e=0,n=t.length;e<n;++e)for(var o=t[e],r=0,i=o.length;r<i;++r){var a=o[r];if(a)return a}return null},size:function(){let t=0;for(const e of this)++t;return t},empty:function(){return!this.node()},each:function(t){for(var e=this._groups,n=0,o=e.length;n<o;++n)for(var r,i=e[n],a=0,s=i.length;a<s;++a)(r=i[a])&&t.call(r,r.__data__,a,i);return this},attr:function(t,e){var n=ut(t);if(arguments.length<2){var o=this.node();return n.local?o.getAttributeNS(n.space,n.local):o.getAttribute(n)}return this.each((null==e?n.local?Tt:At:"function"==typeof e?n.local?Ot:It:n.local?Ct:$t)(n,e))},style:function(t,e,n){return arguments.length>1?this.each((null==e?Ht:"function"==typeof e?Rt:Yt)(t,e,null==n?"":n)):Bt(this.node(),t)},property:function(t,e){return arguments.length>1?this.each((null==e?Dt:"function"==typeof e?Vt:Lt)(t,e)):this.node()[t]},classed:function(t,e){var n=qt(t+"");if(arguments.length<2){for(var o=Zt(this.node()),r=-1,i=n.length;++r<i;)if(!o.contains(n[r]))return!1;return!0}return this.each(("function"==typeof e?Ut:e?Wt:Kt)(n,e))},text:function(t){return arguments.length?this.each(null==t?Qt:("function"==typeof t?te:Jt)(t)):this.node().textContent},html:function(t){return arguments.length?this.each(null==t?ee:("function"==typeof t?oe:ne)(t)):this.node().innerHTML},raise:function(){return this.each(re)},lower:function(){return this.each(ie)},append:function(t){var e="function"==typeof t?t:ht(t);return this.select((function(){return this.appendChild(e.apply(this,arguments))}))},insert:function(t,e){var n="function"==typeof t?t:ht(t),o=null==e?ae:"function"==typeof e?e:ft(e);return this.select((function(){return this.insertBefore(n.apply(this,arguments),o.apply(this,arguments)||null)}))},remove:function(){return this.each(se)},clone:function(t){return this.select(t?ce:ue)},datum:function(t){return arguments.length?this.property("__data__",t):this.node().__data__},on:function(t,e,n){var o,r,i=function(t){return t.trim().split(/^|\s+/).map((function(t){var e="",n=t.indexOf(".");return n>=0&&(e=t.slice(n+1),t=t.slice(0,n)),{type:t,name:e}}))}(t+""),a=i.length;if(!(arguments.length<2)){for(s=e?he:le,o=0;o<a;++o)this.each(s(i[o],e,n));return this}var s=this.node().__on;if(s)for(var u,c=0,l=s.length;c<l;++c)for(o=0,u=s[c];o<a;++o)if((r=i[o]).type===u.type&&r.name===u.name)return u.value},dispatch:function(t,e){return this.each(("function"==typeof e?pe:fe)(t,e))},[Symbol.iterator]:function*(){for(var t=this._groups,e=0,n=t.length;e<n;++e)for(var o,r=t[e],i=0,a=r.length;i<a;++i)(o=r[i])&&(yield o)}};const we={passive:!1},_e={capture:!0,passive:!1};function be(t){t.stopImmediatePropagation()}function Ee(t){t.preventDefault(),t.stopImmediatePropagation()}function Pe(t){var e=t.document.documentElement,n=ve(t).on("dragstart.drag",Ee,_e);"onselectstart"in e?n.on("selectstart.drag",Ee,_e):(e.__noselect=e.style.MozUserSelect,e.style.MozUserSelect="none")}function Me(t,e){var n=t.document.documentElement,o=ve(t).on("dragstart.drag",null);e&&(o.on("click.drag",Ee,_e),setTimeout((function(){o.on("click.drag",null)}),0)),"onselectstart"in n?o.on("selectstart.drag",null):(n.style.MozUserSelect=n.__noselect,delete n.__noselect)}var Se=t=>()=>t;function Ne(t,{sourceEvent:e,subject:n,target:o,identifier:r,active:i,x:a,y:s,dx:u,dy:c,dispatch:l}){Object.defineProperties(this,{type:{value:t,enumerable:!0,configurable:!0},sourceEvent:{value:e,enumerable:!0,configurable:!0},subject:{value:n,enumerable:!0,configurable:!0},target:{value:o,enumerable:!0,configurable:!0},identifier:{value:r,enumerable:!0,configurable:!0},active:{value:i,enumerable:!0,configurable:!0},x:{value:a,enumerable:!0,configurable:!0},y:{value:s,enumerable:!0,configurable:!0},dx:{value:u,enumerable:!0,configurable:!0},dy:{value:c,enumerable:!0,configurable:!0},_:{value:l}})}function ze(t){return!t.ctrlKey&&!t.button}function ke(){return this.parentNode}function Ae(t,e){return null==e?{x:t.x,y:t.y}:e}function Te(){return navigator.maxTouchPoints||"ontouchstart"in this}function $e(){var t,e,n,o,r=ze,i=ke,a=Ae,s=Te,u={},c=nt("start","drag","end"),l=0,h=0;function d(t){t.on("mousedown.drag",f).filter(s).on("touchstart.drag",m).on("touchmove.drag",y,we).on("touchend.drag touchcancel.drag",v).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function f(a,s){if(!o&&r.call(this,a,s)){var u=x(this,i.call(this,a,s),a,s,"mouse");u&&(ve(a.view).on("mousemove.drag",p,_e).on("mouseup.drag",g,_e),Pe(a.view),be(a),n=!1,t=a.clientX,e=a.clientY,u("start",a))}}function p(o){if(Ee(o),!n){var r=o.clientX-t,i=o.clientY-e;n=r*r+i*i>h}u.mouse("drag",o)}function g(t){ve(t.view).on("mousemove.drag mouseup.drag",null),Me(t.view,n),Ee(t),u.mouse("end",t)}function m(t,e){if(r.call(this,t,e)){var n,o,a=t.changedTouches,s=i.call(this,t,e),u=a.length;for(n=0;n<u;++n)(o=x(this,s,t,e,a[n].identifier,a[n]))&&(be(t),o("start",t,a[n]))}}function y(t){var e,n,o=t.changedTouches,r=o.length;for(e=0;e<r;++e)(n=u[o[e].identifier])&&(Ee(t),n("drag",t,o[e]))}function v(t){var e,n,r=t.changedTouches,i=r.length;for(o&&clearTimeout(o),o=setTimeout((function(){o=null}),500),e=0;e<i;++e)(n=u[r[e].identifier])&&(be(t),n("end",t,r[e]))}function x(t,e,n,o,r,i){var s,h,f,p=c.copy(),g=xe(i||n,e);if(null!=(f=a.call(t,new Ne("beforestart",{sourceEvent:n,target:d,identifier:r,active:l,x:g[0],y:g[1],dx:0,dy:0,dispatch:p}),o)))return s=f.x-g[0]||0,h=f.y-g[1]||0,function n(i,a,c){var m,y=g;switch(i){case"start":u[r]=n,m=l++;break;case"end":delete u[r],--l;case"drag":g=xe(c||a,e),m=l}p.call(i,t,new Ne(i,{sourceEvent:a,subject:f,target:d,identifier:r,active:m,x:g[0]+s,y:g[1]+h,dx:g[0]-y[0],dy:g[1]-y[1],dispatch:p}),o)}}return d.filter=function(t){return arguments.length?(r="function"==typeof t?t:Se(!!t),d):r},d.container=function(t){return arguments.length?(i="function"==typeof t?t:Se(t),d):i},d.subject=function(t){return arguments.length?(a="function"==typeof t?t:Se(t),d):a},d.touchable=function(t){return arguments.length?(s="function"==typeof t?t:Se(!!t),d):s},d.on=function(){var t=c.on.apply(c,arguments);return t===c?d:t},d.clickDistance=function(t){return arguments.length?(h=(t=+t)*t,d):Math.sqrt(h)},d}function Ce(t){return(e,n,o)=>t?.(e,o)}function Ie(t,e){if(!t.parentNode)return!1;const n=e.find((t=>t.id===t.parentNode));return!!n&&(!!n.selected||Ie(n,e))}function Oe(t,e,n){let o=t;do{if(o?.matches(e))return!0;if(o===n)return!1;o=o.parentElement}while(o);return!1}function Xe(t,e,n,o){return t.filter((n=>(n.selected||n.id===o)&&(!n.parentNode||!Ie(n,t))&&(n.draggable||e&&void 0===n.draggable))).map((t=>({id:t.id,position:t.position||{x:0,y:0},distance:{x:n.x-(t.computed?.positionAbsolute?.x??0),y:n.y-(t.computed?.positionAbsolute?.y??0)},delta:{x:0,y:0},extent:t.extent,parentNode:t.parentNode,origin:t.origin,expandParent:t.expandParent,computed:{positionAbsolute:t.computed?.positionAbsolute||{x:0,y:0},width:t.computed?.width||0,height:t.computed?.height||0}})))}function He({nodeId:t,dragItems:e,nodeLookup:n}){const o=e.map((t=>({...n.get(t.id),position:t.position,computed:{...t.computed,positionAbsolute:t.computed.positionAbsolute}})));return[t?o.find((e=>e.id===t)):o[0],o]}function Ye(t,e,n,o){return(e[n]||[]).reduce(((e,r)=>(`${t.id}-${r.id}-${n}`!==o&&e.push({id:r.id||null,type:n,nodeId:t.id,x:(t.computed?.positionAbsolute?.x??0)+r.x+r.width/2,y:(t.computed?.positionAbsolute?.y??0)+r.y+r.height/2}),e)),[])}function Re(t,e){return t||(e?.classList.contains("target")?"target":e?.classList.contains("source")?"source":null)}function Be(t,e){t?.classList.remove("valid","connecting",`${e}-flow__handle-valid`,`${e}-flow__handle-connecting`)}function De(t,e){let n=null;return e?n="valid":t&&!e&&(n="invalid"),n}Ne.prototype.on=function(){var t=this._.on.apply(this._,arguments);return t===this._?this:t};const Le=()=>!0;let Ve=null;function qe(e,{handle:n,connectionMode:o,fromNodeId:r,fromHandleId:i,fromType:a,doc:s,lib:u,flowId:c,isValidConnection:l=Le}){const h="target"===a,d=n?s.querySelector(`.${u}-flow__handle[data-id="${c}-${n?.nodeId}-${n?.id}-${n?.type}"]`):null,{x:f,y:p}=Y(e),g=s.elementFromPoint(f,p),m=g?.classList.contains(`${u}-flow__handle`)?g:d,y={handleDomNode:m,isValid:!1,connection:null,endHandle:null};if(m){const e=Re(void 0,m),n=m.getAttribute("data-nodeid"),a=m.getAttribute("data-handleid"),s=m.classList.contains("connectable"),u=m.classList.contains("connectableend");if(!n)return y;const c={source:h?n:r,sourceHandle:h?a:i,target:h?r:n,targetHandle:h?i:a};y.connection=c;s&&u&&(o===t.ConnectionMode.Strict?h&&"source"===e||!h&&"target"===e:n!==r||a!==i)&&(y.endHandle={nodeId:n,handleId:a,type:e},y.isValid=l(c))}return y}const Ze={onPointerDown:function(t,{connectionMode:e,connectionRadius:o,handleId:r,nodeId:i,edgeUpdaterType:a,isTarget:s,domNode:u,nodes:c,lib:l,autoPanOnConnect:h,flowId:d,panBy:f,cancelConnection:p,onConnectStart:g,onConnect:m,onConnectEnd:y,isValidConnection:x=Le,onEdgeUpdateEnd:w,updateConnection:_,getTransform:b}){const E=O(t.target);let P,M=0;const{x:S,y:N}=Y(t),A=E?.elementFromPoint(S,N),T=Re(a,A),$=u?.getBoundingClientRect();if(!$||!T)return;let C,I=Y(t,$),X=!1,H=null,R=!1,B=null;const D=function({nodes:t,nodeId:e,handleId:o,handleType:r}){return t.reduce(((t,i)=>{if(i[n]){const{handleBounds:a}=i[n];let s=[],u=[];a&&(s=Ye(i,a,"source",`${e}-${o}-${r}`),u=Ye(i,a,"target",`${e}-${o}-${r}`)),t.push(...s,...u)}return t}),[])}({nodes:c,nodeId:i,handleId:r,handleType:T});function L(){if(!h||!$)return;const[t,e]=v(I,$);f({x:t,y:e}),M=requestAnimationFrame(L)}function V(t){const n=b();I=Y(t,$),P=function(t,e,n){let o=[],r=1/0;return n.forEach((n=>{const i=Math.sqrt(Math.pow(n.x-t.x,2)+Math.pow(n.y-t.y,2));i<=e&&(i<r?o=[n]:i===r&&o.push(n),r=i)})),o.length?1===o.length?o[0]:o.find((t=>"target"===t.type))||o[0]:null}(z(I,n,!1,[1,1]),o,D),X||(L(),X=!0);const a=qe(t,{handle:P,connectionMode:e,fromNodeId:i,fromHandleId:r,fromType:s?"target":"source",isValidConnection:x,doc:E,lib:l,flowId:d});if(B=a.handleDomNode,H=a.connection,R=a.isValid,_({connectionStartHandle:Ve,connectionPosition:P&&R?k({x:P.x,y:P.y},n):I,connectionStatus:De(!!P,R),connectionEndHandle:a.endHandle}),!P&&!R&&!B)return Be(C,l);H?.source!==H?.target&&B&&(Be(C,l),C=B,B.classList.add("connecting",`${l}-flow__handle-connecting`),B.classList.toggle("valid",R),B.classList.toggle(`${l}-flow__handle-valid`,R))}function q(t){(P||B)&&H&&R&&m?.(H),y?.(t),a&&w?.(t),Be(C,l),p(),cancelAnimationFrame(M),X=!1,R=!1,H=null,B=null,Ve=null,E.removeEventListener("mousemove",V),E.removeEventListener("mouseup",q),E.removeEventListener("touchmove",V),E.removeEventListener("touchend",q)}Ve={nodeId:i,handleId:r,type:T},_({connectionPosition:I,connectionStatus:null,connectionStartHandle:Ve,connectionEndHandle:null}),g?.(t,{nodeId:i,handleId:r,handleType:T}),E.addEventListener("mousemove",V),E.addEventListener("mouseup",q),E.addEventListener("touchmove",V),E.addEventListener("touchend",q)},isValid:qe};function Ge(t,e,n){t.prototype=e.prototype=n,n.constructor=t}function je(t,e){var n=Object.create(t.prototype);for(var o in e)n[o]=e[o];return n}function Fe(){}var We=.7,Ke=1/We,Ue="\\s*([+-]?\\d+)\\s*",Qe="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",Je="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",tn=/^#([0-9a-f]{3,8})$/,en=new RegExp(`^rgb\\(${Ue},${Ue},${Ue}\\)$`),nn=new RegExp(`^rgb\\(${Je},${Je},${Je}\\)$`),on=new RegExp(`^rgba\\(${Ue},${Ue},${Ue},${Qe}\\)$`),rn=new RegExp(`^rgba\\(${Je},${Je},${Je},${Qe}\\)$`),an=new RegExp(`^hsl\\(${Qe},${Je},${Je}\\)$`),sn=new RegExp(`^hsla\\(${Qe},${Je},${Je},${Qe}\\)$`),un={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};function cn(){return this.rgb().formatHex()}function ln(){return this.rgb().formatRgb()}function hn(t){var e,n;return t=(t+"").trim().toLowerCase(),(e=tn.exec(t))?(n=e[1].length,e=parseInt(e[1],16),6===n?dn(e):3===n?new gn(e>>8&15|e>>4&240,e>>4&15|240&e,(15&e)<<4|15&e,1):8===n?fn(e>>24&255,e>>16&255,e>>8&255,(255&e)/255):4===n?fn(e>>12&15|e>>8&240,e>>8&15|e>>4&240,e>>4&15|240&e,((15&e)<<4|15&e)/255):null):(e=en.exec(t))?new gn(e[1],e[2],e[3],1):(e=nn.exec(t))?new gn(255*e[1]/100,255*e[2]/100,255*e[3]/100,1):(e=on.exec(t))?fn(e[1],e[2],e[3],e[4]):(e=rn.exec(t))?fn(255*e[1]/100,255*e[2]/100,255*e[3]/100,e[4]):(e=an.exec(t))?_n(e[1],e[2]/100,e[3]/100,1):(e=sn.exec(t))?_n(e[1],e[2]/100,e[3]/100,e[4]):un.hasOwnProperty(t)?dn(un[t]):"transparent"===t?new gn(NaN,NaN,NaN,0):null}function dn(t){return new gn(t>>16&255,t>>8&255,255&t,1)}function fn(t,e,n,o){return o<=0&&(t=e=n=NaN),new gn(t,e,n,o)}function pn(t,e,n,o){return 1===arguments.length?((r=t)instanceof Fe||(r=hn(r)),r?new gn((r=r.rgb()).r,r.g,r.b,r.opacity):new gn):new gn(t,e,n,null==o?1:o);var r}function gn(t,e,n,o){this.r=+t,this.g=+e,this.b=+n,this.opacity=+o}function mn(){return`#${wn(this.r)}${wn(this.g)}${wn(this.b)}`}function yn(){const t=vn(this.opacity);return`${1===t?"rgb(":"rgba("}${xn(this.r)}, ${xn(this.g)}, ${xn(this.b)}${1===t?")":`, ${t})`}`}function vn(t){return isNaN(t)?1:Math.max(0,Math.min(1,t))}function xn(t){return Math.max(0,Math.min(255,Math.round(t)||0))}function wn(t){return((t=xn(t))<16?"0":"")+t.toString(16)}function _n(t,e,n,o){return o<=0?t=e=n=NaN:n<=0||n>=1?t=e=NaN:e<=0&&(t=NaN),new En(t,e,n,o)}function bn(t){if(t instanceof En)return new En(t.h,t.s,t.l,t.opacity);if(t instanceof Fe||(t=hn(t)),!t)return new En;if(t instanceof En)return t;var e=(t=t.rgb()).r/255,n=t.g/255,o=t.b/255,r=Math.min(e,n,o),i=Math.max(e,n,o),a=NaN,s=i-r,u=(i+r)/2;return s?(a=e===i?(n-o)/s+6*(n<o):n===i?(o-e)/s+2:(e-n)/s+4,s/=u<.5?i+r:2-i-r,a*=60):s=u>0&&u<1?0:a,new En(a,s,u,t.opacity)}function En(t,e,n,o){this.h=+t,this.s=+e,this.l=+n,this.opacity=+o}function Pn(t){return(t=(t||0)%360)<0?t+360:t}function Mn(t){return Math.max(0,Math.min(1,t||0))}function Sn(t,e,n){return 255*(t<60?e+(n-e)*t/60:t<180?n:t<240?e+(n-e)*(240-t)/60:e)}Ge(Fe,hn,{copy(t){return Object.assign(new this.constructor,this,t)},displayable(){return this.rgb().displayable()},hex:cn,formatHex:cn,formatHex8:function(){return this.rgb().formatHex8()},formatHsl:function(){return bn(this).formatHsl()},formatRgb:ln,toString:ln}),Ge(gn,pn,je(Fe,{brighter(t){return t=null==t?Ke:Math.pow(Ke,t),new gn(this.r*t,this.g*t,this.b*t,this.opacity)},darker(t){return t=null==t?We:Math.pow(We,t),new gn(this.r*t,this.g*t,this.b*t,this.opacity)},rgb(){return this},clamp(){return new gn(xn(this.r),xn(this.g),xn(this.b),vn(this.opacity))},displayable(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:mn,formatHex:mn,formatHex8:function(){return`#${wn(this.r)}${wn(this.g)}${wn(this.b)}${wn(255*(isNaN(this.opacity)?1:this.opacity))}`},formatRgb:yn,toString:yn})),Ge(En,(function(t,e,n,o){return 1===arguments.length?bn(t):new En(t,e,n,null==o?1:o)}),je(Fe,{brighter(t){return t=null==t?Ke:Math.pow(Ke,t),new En(this.h,this.s,this.l*t,this.opacity)},darker(t){return t=null==t?We:Math.pow(We,t),new En(this.h,this.s,this.l*t,this.opacity)},rgb(){var t=this.h%360+360*(this.h<0),e=isNaN(t)||isNaN(this.s)?0:this.s,n=this.l,o=n+(n<.5?n:1-n)*e,r=2*n-o;return new gn(Sn(t>=240?t-240:t+120,r,o),Sn(t,r,o),Sn(t<120?t+240:t-120,r,o),this.opacity)},clamp(){return new En(Pn(this.h),Mn(this.s),Mn(this.l),vn(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){const t=vn(this.opacity);return`${1===t?"hsl(":"hsla("}${Pn(this.h)}, ${100*Mn(this.s)}%, ${100*Mn(this.l)}%${1===t?")":`, ${t})`}`}}));var Nn=t=>()=>t;function zn(t){return 1==(t=+t)?kn:function(e,n){return n-e?function(t,e,n){return t=Math.pow(t,n),e=Math.pow(e,n)-t,n=1/n,function(o){return Math.pow(t+o*e,n)}}(e,n,t):Nn(isNaN(e)?n:e)}}function kn(t,e){var n=e-t;return n?function(t,e){return function(n){return t+n*e}}(t,n):Nn(isNaN(t)?e:t)}var An=function t(e){var n=zn(e);function o(t,e){var o=n((t=pn(t)).r,(e=pn(e)).r),r=n(t.g,e.g),i=n(t.b,e.b),a=kn(t.opacity,e.opacity);return function(e){return t.r=o(e),t.g=r(e),t.b=i(e),t.opacity=a(e),t+""}}return o.gamma=t,o}(1);function Tn(t,e){return t=+t,e=+e,function(n){return t*(1-n)+e*n}}var $n=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,Cn=new RegExp($n.source,"g");function In(t,e){var n,o,r,i=$n.lastIndex=Cn.lastIndex=0,a=-1,s=[],u=[];for(t+="",e+="";(n=$n.exec(t))&&(o=Cn.exec(e));)(r=o.index)>i&&(r=e.slice(i,r),s[a]?s[a]+=r:s[++a]=r),(n=n[0])===(o=o[0])?s[a]?s[a]+=o:s[++a]=o:(s[++a]=null,u.push({i:a,x:Tn(n,o)})),i=Cn.lastIndex;return i<e.length&&(r=e.slice(i),s[a]?s[a]+=r:s[++a]=r),s.length<2?u[0]?function(t){return function(e){return t(e)+""}}(u[0].x):function(t){return function(){return t}}(e):(e=u.length,function(t){for(var n,o=0;o<e;++o)s[(n=u[o]).i]=n.x(t);return s.join("")})}var On,Xn=180/Math.PI,Hn={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function Yn(t,e,n,o,r,i){var a,s,u;return(a=Math.sqrt(t*t+e*e))&&(t/=a,e/=a),(u=t*n+e*o)&&(n-=t*u,o-=e*u),(s=Math.sqrt(n*n+o*o))&&(n/=s,o/=s,u/=s),t*o<e*n&&(t=-t,e=-e,u=-u,a=-a),{translateX:r,translateY:i,rotate:Math.atan2(e,t)*Xn,skewX:Math.atan(u)*Xn,scaleX:a,scaleY:s}}function Rn(t,e,n,o){function r(t){return t.length?t.pop()+" ":""}return function(i,a){var s=[],u=[];return i=t(i),a=t(a),function(t,o,r,i,a,s){if(t!==r||o!==i){var u=a.push("translate(",null,e,null,n);s.push({i:u-4,x:Tn(t,r)},{i:u-2,x:Tn(o,i)})}else(r||i)&&a.push("translate("+r+e+i+n)}(i.translateX,i.translateY,a.translateX,a.translateY,s,u),function(t,e,n,i){t!==e?(t-e>180?e+=360:e-t>180&&(t+=360),i.push({i:n.push(r(n)+"rotate(",null,o)-2,x:Tn(t,e)})):e&&n.push(r(n)+"rotate("+e+o)}(i.rotate,a.rotate,s,u),function(t,e,n,i){t!==e?i.push({i:n.push(r(n)+"skewX(",null,o)-2,x:Tn(t,e)}):e&&n.push(r(n)+"skewX("+e+o)}(i.skewX,a.skewX,s,u),function(t,e,n,o,i,a){if(t!==n||e!==o){var s=i.push(r(i)+"scale(",null,",",null,")");a.push({i:s-4,x:Tn(t,n)},{i:s-2,x:Tn(e,o)})}else 1===n&&1===o||i.push(r(i)+"scale("+n+","+o+")")}(i.scaleX,i.scaleY,a.scaleX,a.scaleY,s,u),i=a=null,function(t){for(var e,n=-1,o=u.length;++n<o;)s[(e=u[n]).i]=e.x(t);return s.join("")}}}var Bn=Rn((function(t){const e=new("function"==typeof DOMMatrix?DOMMatrix:WebKitCSSMatrix)(t+"");return e.isIdentity?Hn:Yn(e.a,e.b,e.c,e.d,e.e,e.f)}),"px, ","px)","deg)"),Dn=Rn((function(t){return null==t?Hn:(On||(On=document.createElementNS("http://www.w3.org/2000/svg","g")),On.setAttribute("transform",t),(t=On.transform.baseVal.consolidate())?Yn((t=t.matrix).a,t.b,t.c,t.d,t.e,t.f):Hn)}),", ",")",")");function Ln(t){return((t=Math.exp(t))+1/t)/2}var Vn,qn,Zn=function t(e,n,o){function r(t,r){var i,a,s=t[0],u=t[1],c=t[2],l=r[0],h=r[1],d=r[2],f=l-s,p=h-u,g=f*f+p*p;if(g<1e-12)a=Math.log(d/c)/e,i=function(t){return[s+t*f,u+t*p,c*Math.exp(e*t*a)]};else{var m=Math.sqrt(g),y=(d*d-c*c+o*g)/(2*c*n*m),v=(d*d-c*c-o*g)/(2*d*n*m),x=Math.log(Math.sqrt(y*y+1)-y),w=Math.log(Math.sqrt(v*v+1)-v);a=(w-x)/e,i=function(t){var o,r=t*a,i=Ln(x),l=c/(n*m)*(i*(o=e*r+x,((o=Math.exp(2*o))-1)/(o+1))-function(t){return((t=Math.exp(t))-1/t)/2}(x));return[s+l*f,u+l*p,c*i/Ln(e*r+x)]}}return i.duration=1e3*a*e/Math.SQRT2,i}return r.rho=function(e){var n=Math.max(.001,+e),o=n*n;return t(n,o,o*o)},r}(Math.SQRT2,2,4),Gn=0,jn=0,Fn=0,Wn=1e3,Kn=0,Un=0,Qn=0,Jn="object"==typeof performance&&performance.now?performance:Date,to="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(t){setTimeout(t,17)};function eo(){return Un||(to(no),Un=Jn.now()+Qn)}function no(){Un=0}function oo(){this._call=this._time=this._next=null}function ro(t,e,n){var o=new oo;return o.restart(t,e,n),o}function io(){Un=(Kn=Jn.now())+Qn,Gn=jn=0;try{!function(){eo(),++Gn;for(var t,e=Vn;e;)(t=Un-e._time)>=0&&e._call.call(void 0,t),e=e._next;--Gn}()}finally{Gn=0,function(){var t,e,n=Vn,o=1/0;for(;n;)n._call?(o>n._time&&(o=n._time),t=n,n=n._next):(e=n._next,n._next=null,n=t?t._next=e:Vn=e);qn=t,so(o)}(),Un=0}}function ao(){var t=Jn.now(),e=t-Kn;e>Wn&&(Qn-=e,Kn=t)}function so(t){Gn||(jn&&(jn=clearTimeout(jn)),t-Un>24?(t<1/0&&(jn=setTimeout(io,t-Jn.now()-Qn)),Fn&&(Fn=clearInterval(Fn))):(Fn||(Kn=Jn.now(),Fn=setInterval(ao,Wn)),Gn=1,to(io)))}function uo(t,e,n){var o=new oo;return e=null==e?0:+e,o.restart((n=>{o.stop(),t(n+e)}),e,n),o}oo.prototype=ro.prototype={constructor:oo,restart:function(t,e,n){if("function"!=typeof t)throw new TypeError("callback is not a function");n=(null==n?eo():+n)+(null==e?0:+e),this._next||qn===this||(qn?qn._next=this:Vn=this,qn=this),this._call=t,this._time=n,so()},stop:function(){this._call&&(this._call=null,this._time=1/0,so())}};var co=nt("start","end","cancel","interrupt"),lo=[],ho=0,fo=1,po=2,go=3,mo=4,yo=5,vo=6;function xo(t,e,n,o,r,i){var a=t.__transition;if(a){if(n in a)return}else t.__transition={};!function(t,e,n){var o,r=t.__transition;function i(t){n.state=fo,n.timer.restart(a,n.delay,n.time),n.delay<=t&&a(t-n.delay)}function a(i){var c,l,h,d;if(n.state!==fo)return u();for(c in r)if((d=r[c]).name===n.name){if(d.state===go)return uo(a);d.state===mo?(d.state=vo,d.timer.stop(),d.on.call("interrupt",t,t.__data__,d.index,d.group),delete r[c]):+c<e&&(d.state=vo,d.timer.stop(),d.on.call("cancel",t,t.__data__,d.index,d.group),delete r[c])}if(uo((function(){n.state===go&&(n.state=mo,n.timer.restart(s,n.delay,n.time),s(i))})),n.state=po,n.on.call("start",t,t.__data__,n.index,n.group),n.state===po){for(n.state=go,o=new Array(h=n.tween.length),c=0,l=-1;c<h;++c)(d=n.tween[c].value.call(t,t.__data__,n.index,n.group))&&(o[++l]=d);o.length=l+1}}function s(e){for(var r=e<n.duration?n.ease.call(null,e/n.duration):(n.timer.restart(u),n.state=yo,1),i=-1,a=o.length;++i<a;)o[i].call(t,r);n.state===yo&&(n.on.call("end",t,t.__data__,n.index,n.group),u())}function u(){for(var o in n.state=vo,n.timer.stop(),delete r[e],r)return;delete t.__transition}r[e]=n,n.timer=ro(i,0,n.time)}(t,n,{name:e,index:o,group:r,on:co,tween:lo,time:i.time,delay:i.delay,duration:i.duration,ease:i.ease,timer:null,state:ho})}function wo(t,e){var n=bo(t,e);if(n.state>ho)throw new Error("too late; already scheduled");return n}function _o(t,e){var n=bo(t,e);if(n.state>go)throw new Error("too late; already running");return n}function bo(t,e){var n=t.__transition;if(!n||!(n=n[e]))throw new Error("transition not found");return n}function Eo(t,e){var n,o,r,i=t.__transition,a=!0;if(i){for(r in e=null==e?null:e+"",i)(n=i[r]).name===e?(o=n.state>po&&n.state<yo,n.state=vo,n.timer.stop(),n.on.call(o?"interrupt":"cancel",t,t.__data__,n.index,n.group),delete i[r]):a=!1;a&&delete t.__transition}}function Po(t,e){var n,o;return function(){var r=_o(this,t),i=r.tween;if(i!==n)for(var a=0,s=(o=n=i).length;a<s;++a)if(o[a].name===e){(o=o.slice()).splice(a,1);break}r.tween=o}}function Mo(t,e,n){var o,r;if("function"!=typeof n)throw new Error;return function(){var i=_o(this,t),a=i.tween;if(a!==o){r=(o=a).slice();for(var s={name:e,value:n},u=0,c=r.length;u<c;++u)if(r[u].name===e){r[u]=s;break}u===c&&r.push(s)}i.tween=r}}function So(t,e,n){var o=t._id;return t.each((function(){var t=_o(this,o);(t.value||(t.value={}))[e]=n.apply(this,arguments)})),function(t){return bo(t,o).value[e]}}function No(t,e){var n;return("number"==typeof e?Tn:e instanceof hn?An:(n=hn(e))?(e=n,An):In)(t,e)}function zo(t){return function(){this.removeAttribute(t)}}function ko(t){return function(){this.removeAttributeNS(t.space,t.local)}}function Ao(t,e,n){var o,r,i=n+"";return function(){var a=this.getAttribute(t);return a===i?null:a===o?r:r=e(o=a,n)}}function To(t,e,n){var o,r,i=n+"";return function(){var a=this.getAttributeNS(t.space,t.local);return a===i?null:a===o?r:r=e(o=a,n)}}function $o(t,e,n){var o,r,i;return function(){var a,s,u=n(this);if(null!=u)return(a=this.getAttribute(t))===(s=u+"")?null:a===o&&s===r?i:(r=s,i=e(o=a,u));this.removeAttribute(t)}}function Co(t,e,n){var o,r,i;return function(){var a,s,u=n(this);if(null!=u)return(a=this.getAttributeNS(t.space,t.local))===(s=u+"")?null:a===o&&s===r?i:(r=s,i=e(o=a,u));this.removeAttributeNS(t.space,t.local)}}function Io(t,e){var n,o;function r(){var r=e.apply(this,arguments);return r!==o&&(n=(o=r)&&function(t,e){return function(n){this.setAttributeNS(t.space,t.local,e.call(this,n))}}(t,r)),n}return r._value=e,r}function Oo(t,e){var n,o;function r(){var r=e.apply(this,arguments);return r!==o&&(n=(o=r)&&function(t,e){return function(n){this.setAttribute(t,e.call(this,n))}}(t,r)),n}return r._value=e,r}function Xo(t,e){return function(){wo(this,t).delay=+e.apply(this,arguments)}}function Ho(t,e){return e=+e,function(){wo(this,t).delay=e}}function Yo(t,e){return function(){_o(this,t).duration=+e.apply(this,arguments)}}function Ro(t,e){return e=+e,function(){_o(this,t).duration=e}}var Bo=ye.prototype.constructor;function Do(t){return function(){this.style.removeProperty(t)}}var Lo=0;function Vo(t,e,n,o){this._groups=t,this._parents=e,this._name=n,this._id=o}function qo(){return++Lo}var Zo=ye.prototype;Vo.prototype={constructor:Vo,select:function(t){var e=this._name,n=this._id;"function"!=typeof t&&(t=ft(t));for(var o=this._groups,r=o.length,i=new Array(r),a=0;a<r;++a)for(var s,u,c=o[a],l=c.length,h=i[a]=new Array(l),d=0;d<l;++d)(s=c[d])&&(u=t.call(s,s.__data__,d,c))&&("__data__"in s&&(u.__data__=s.__data__),h[d]=u,xo(h[d],e,n,d,h,bo(s,n)));return new Vo(i,this._parents,e,n)},selectAll:function(t){var e=this._name,n=this._id;"function"!=typeof t&&(t=gt(t));for(var o=this._groups,r=o.length,i=[],a=[],s=0;s<r;++s)for(var u,c=o[s],l=c.length,h=0;h<l;++h)if(u=c[h]){for(var d,f=t.call(u,u.__data__,h,c),p=bo(u,n),g=0,m=f.length;g<m;++g)(d=f[g])&&xo(d,e,n,g,f,p);i.push(f),a.push(u)}return new Vo(i,a,e,n)},selectChild:Zo.selectChild,selectChildren:Zo.selectChildren,filter:function(t){"function"!=typeof t&&(t=yt(t));for(var e=this._groups,n=e.length,o=new Array(n),r=0;r<n;++r)for(var i,a=e[r],s=a.length,u=o[r]=[],c=0;c<s;++c)(i=a[c])&&t.call(i,i.__data__,c,a)&&u.push(i);return new Vo(o,this._parents,this._name,this._id)},merge:function(t){if(t._id!==this._id)throw new Error;for(var e=this._groups,n=t._groups,o=e.length,r=n.length,i=Math.min(o,r),a=new Array(o),s=0;s<i;++s)for(var u,c=e[s],l=n[s],h=c.length,d=a[s]=new Array(h),f=0;f<h;++f)(u=c[f]||l[f])&&(d[f]=u);for(;s<o;++s)a[s]=e[s];return new Vo(a,this._parents,this._name,this._id)},selection:function(){return new Bo(this._groups,this._parents)},transition:function(){for(var t=this._name,e=this._id,n=qo(),o=this._groups,r=o.length,i=0;i<r;++i)for(var a,s=o[i],u=s.length,c=0;c<u;++c)if(a=s[c]){var l=bo(a,e);xo(a,t,n,c,s,{time:l.time+l.delay+l.duration,delay:0,duration:l.duration,ease:l.ease})}return new Vo(o,this._parents,t,n)},call:Zo.call,nodes:Zo.nodes,node:Zo.node,size:Zo.size,empty:Zo.empty,each:Zo.each,on:function(t,e){var n=this._id;return arguments.length<2?bo(this.node(),n).on.on(t):this.each(function(t,e,n){var o,r,i=function(t){return(t+"").trim().split(/^|\s+/).every((function(t){var e=t.indexOf(".");return e>=0&&(t=t.slice(0,e)),!t||"start"===t}))}(e)?wo:_o;return function(){var a=i(this,t),s=a.on;s!==o&&(r=(o=s).copy()).on(e,n),a.on=r}}(n,t,e))},attr:function(t,e){var n=ut(t),o="transform"===n?Dn:No;return this.attrTween(t,"function"==typeof e?(n.local?Co:$o)(n,o,So(this,"attr."+t,e)):null==e?(n.local?ko:zo)(n):(n.local?To:Ao)(n,o,e))},attrTween:function(t,e){var n="attr."+t;if(arguments.length<2)return(n=this.tween(n))&&n._value;if(null==e)return this.tween(n,null);if("function"!=typeof e)throw new Error;var o=ut(t);return this.tween(n,(o.local?Io:Oo)(o,e))},style:function(t,e,n){var o="transform"==(t+="")?Bn:No;return null==e?this.styleTween(t,function(t,e){var n,o,r;return function(){var i=Bt(this,t),a=(this.style.removeProperty(t),Bt(this,t));return i===a?null:i===n&&a===o?r:r=e(n=i,o=a)}}(t,o)).on("end.style."+t,Do(t)):"function"==typeof e?this.styleTween(t,function(t,e,n){var o,r,i;return function(){var a=Bt(this,t),s=n(this),u=s+"";return null==s&&(this.style.removeProperty(t),u=s=Bt(this,t)),a===u?null:a===o&&u===r?i:(r=u,i=e(o=a,s))}}(t,o,So(this,"style."+t,e))).each(function(t,e){var n,o,r,i,a="style."+e,s="end."+a;return function(){var u=_o(this,t),c=u.on,l=null==u.value[a]?i||(i=Do(e)):void 0;c===n&&r===l||(o=(n=c).copy()).on(s,r=l),u.on=o}}(this._id,t)):this.styleTween(t,function(t,e,n){var o,r,i=n+"";return function(){var a=Bt(this,t);return a===i?null:a===o?r:r=e(o=a,n)}}(t,o,e),n).on("end.style."+t,null)},styleTween:function(t,e,n){var o="style."+(t+="");if(arguments.length<2)return(o=this.tween(o))&&o._value;if(null==e)return this.tween(o,null);if("function"!=typeof e)throw new Error;return this.tween(o,function(t,e,n){var o,r;function i(){var i=e.apply(this,arguments);return i!==r&&(o=(r=i)&&function(t,e,n){return function(o){this.style.setProperty(t,e.call(this,o),n)}}(t,i,n)),o}return i._value=e,i}(t,e,null==n?"":n))},text:function(t){return this.tween("text","function"==typeof t?function(t){return function(){var e=t(this);this.textContent=null==e?"":e}}(So(this,"text",t)):function(t){return function(){this.textContent=t}}(null==t?"":t+""))},textTween:function(t){var e="text";if(arguments.length<1)return(e=this.tween(e))&&e._value;if(null==t)return this.tween(e,null);if("function"!=typeof t)throw new Error;return this.tween(e,function(t){var e,n;function o(){var o=t.apply(this,arguments);return o!==n&&(e=(n=o)&&function(t){return function(e){this.textContent=t.call(this,e)}}(o)),e}return o._value=t,o}(t))},remove:function(){return this.on("end.remove",function(t){return function(){var e=this.parentNode;for(var n in this.__transition)if(+n!==t)return;e&&e.removeChild(this)}}(this._id))},tween:function(t,e){var n=this._id;if(t+="",arguments.length<2){for(var o,r=bo(this.node(),n).tween,i=0,a=r.length;i<a;++i)if((o=r[i]).name===t)return o.value;return null}return this.each((null==e?Po:Mo)(n,t,e))},delay:function(t){var e=this._id;return arguments.length?this.each(("function"==typeof t?Xo:Ho)(e,t)):bo(this.node(),e).delay},duration:function(t){var e=this._id;return arguments.length?this.each(("function"==typeof t?Yo:Ro)(e,t)):bo(this.node(),e).duration},ease:function(t){var e=this._id;return arguments.length?this.each(function(t,e){if("function"!=typeof e)throw new Error;return function(){_o(this,t).ease=e}}(e,t)):bo(this.node(),e).ease},easeVarying:function(t){if("function"!=typeof t)throw new Error;return this.each(function(t,e){return function(){var n=e.apply(this,arguments);if("function"!=typeof n)throw new Error;_o(this,t).ease=n}}(this._id,t))},end:function(){var t,e,n=this,o=n._id,r=n.size();return new Promise((function(i,a){var s={value:a},u={value:function(){0==--r&&i()}};n.each((function(){var n=_o(this,o),r=n.on;r!==t&&((e=(t=r).copy())._.cancel.push(s),e._.interrupt.push(s),e._.end.push(u)),n.on=e})),0===r&&i()}))},[Symbol.iterator]:Zo[Symbol.iterator]};var Go={time:null,delay:0,duration:250,ease:function(t){return((t*=2)<=1?t*t*t:(t-=2)*t*t+2)/2}};function jo(t,e){for(var n;!(n=t.__transition)||!(n=n[e]);)if(!(t=t.parentNode))throw new Error(`transition ${e} not found`);return n}ye.prototype.interrupt=function(t){return this.each((function(){Eo(this,t)}))},ye.prototype.transition=function(t){var e,n;t instanceof Vo?(e=t._id,t=t._name):(e=qo(),(n=Go).time=eo(),t=null==t?null:t+"");for(var o=this._groups,r=o.length,i=0;i<r;++i)for(var a,s=o[i],u=s.length,c=0;c<u;++c)(a=s[c])&&xo(a,t,e,c,s,n||jo(a,e));return new Vo(o,this._parents,t,e)};var Fo=t=>()=>t;function Wo(t,{sourceEvent:e,target:n,transform:o,dispatch:r}){Object.defineProperties(this,{type:{value:t,enumerable:!0,configurable:!0},sourceEvent:{value:e,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},transform:{value:o,enumerable:!0,configurable:!0},_:{value:r}})}function Ko(t,e,n){this.k=t,this.x=e,this.y=n}Ko.prototype={constructor:Ko,scale:function(t){return 1===t?this:new Ko(this.k*t,this.x,this.y)},translate:function(t,e){return 0===t&0===e?this:new Ko(this.k,this.x+this.k*t,this.y+this.k*e)},apply:function(t){return[t[0]*this.k+this.x,t[1]*this.k+this.y]},applyX:function(t){return t*this.k+this.x},applyY:function(t){return t*this.k+this.y},invert:function(t){return[(t[0]-this.x)/this.k,(t[1]-this.y)/this.k]},invertX:function(t){return(t-this.x)/this.k},invertY:function(t){return(t-this.y)/this.k},rescaleX:function(t){return t.copy().domain(t.range().map(this.invertX,this).map(t.invert,t))},rescaleY:function(t){return t.copy().domain(t.range().map(this.invertY,this).map(t.invert,t))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var Uo=new Ko(1,0,0);function Qo(t){for(;!t.__zoom;)if(!(t=t.parentNode))return Uo;return t.__zoom}function Jo(t){t.stopImmediatePropagation()}function tr(t){t.preventDefault(),t.stopImmediatePropagation()}function er(t){return!(t.ctrlKey&&"wheel"!==t.type||t.button)}function nr(){var t=this;return t instanceof SVGElement?(t=t.ownerSVGElement||t).hasAttribute("viewBox")?[[(t=t.viewBox.baseVal).x,t.y],[t.x+t.width,t.y+t.height]]:[[0,0],[t.width.baseVal.value,t.height.baseVal.value]]:[[0,0],[t.clientWidth,t.clientHeight]]}function or(){return this.__zoom||Uo}function rr(t){return-t.deltaY*(1===t.deltaMode?.05:t.deltaMode?1:.002)*(t.ctrlKey?10:1)}function ir(){return navigator.maxTouchPoints||"ontouchstart"in this}function ar(t,e,n){var o=t.invertX(e[0][0])-n[0][0],r=t.invertX(e[1][0])-n[1][0],i=t.invertY(e[0][1])-n[0][1],a=t.invertY(e[1][1])-n[1][1];return t.translate(r>o?(o+r)/2:Math.min(0,o)||Math.max(0,r),a>i?(i+a)/2:Math.min(0,i)||Math.max(0,a))}function sr(){var t,e,n,o=er,r=nr,i=ar,a=rr,s=ir,u=[0,1/0],c=[[-1/0,-1/0],[1/0,1/0]],l=250,h=Zn,d=nt("start","zoom","end"),f=500,p=150,g=0,m=10;function y(t){t.property("__zoom",or).on("wheel.zoom",P,{passive:!1}).on("mousedown.zoom",M).on("dblclick.zoom",S).filter(s).on("touchstart.zoom",N).on("touchmove.zoom",z).on("touchend.zoom touchcancel.zoom",k).style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function v(t,e){return(e=Math.max(u[0],Math.min(u[1],e)))===t.k?t:new Ko(e,t.x,t.y)}function x(t,e,n){var o=e[0]-n[0]*t.k,r=e[1]-n[1]*t.k;return o===t.x&&r===t.y?t:new Ko(t.k,o,r)}function w(t){return[(+t[0][0]+ +t[1][0])/2,(+t[0][1]+ +t[1][1])/2]}function _(t,e,n,o){t.on("start.zoom",(function(){b(this,arguments).event(o).start()})).on("interrupt.zoom end.zoom",(function(){b(this,arguments).event(o).end()})).tween("zoom",(function(){var t=this,i=arguments,a=b(t,i).event(o),s=r.apply(t,i),u=null==n?w(s):"function"==typeof n?n.apply(t,i):n,c=Math.max(s[1][0]-s[0][0],s[1][1]-s[0][1]),l=t.__zoom,d="function"==typeof e?e.apply(t,i):e,f=h(l.invert(u).concat(c/l.k),d.invert(u).concat(c/d.k));return function(t){if(1===t)t=d;else{var e=f(t),n=c/e[2];t=new Ko(n,u[0]-e[0]*n,u[1]-e[1]*n)}a.zoom(null,t)}}))}function b(t,e,n){return!n&&t.__zooming||new E(t,e)}function E(t,e){this.that=t,this.args=e,this.active=0,this.sourceEvent=null,this.extent=r.apply(t,e),this.taps=0}function P(t,...e){if(o.apply(this,arguments)){var n=b(this,e).event(t),r=this.__zoom,s=Math.max(u[0],Math.min(u[1],r.k*Math.pow(2,a.apply(this,arguments)))),l=xe(t);if(n.wheel)n.mouse[0][0]===l[0]&&n.mouse[0][1]===l[1]||(n.mouse[1]=r.invert(n.mouse[0]=l)),clearTimeout(n.wheel);else{if(r.k===s)return;n.mouse=[l,r.invert(l)],Eo(this),n.start()}tr(t),n.wheel=setTimeout((function(){n.wheel=null,n.end()}),p),n.zoom("mouse",i(x(v(r,s),n.mouse[0],n.mouse[1]),n.extent,c))}}function M(t,...e){if(!n&&o.apply(this,arguments)){var r=t.currentTarget,a=b(this,e,!0).event(t),s=ve(t.view).on("mousemove.zoom",(function(t){if(tr(t),!a.moved){var e=t.clientX-l,n=t.clientY-h;a.moved=e*e+n*n>g}a.event(t).zoom("mouse",i(x(a.that.__zoom,a.mouse[0]=xe(t,r),a.mouse[1]),a.extent,c))}),!0).on("mouseup.zoom",(function(t){s.on("mousemove.zoom mouseup.zoom",null),Me(t.view,a.moved),tr(t),a.event(t).end()}),!0),u=xe(t,r),l=t.clientX,h=t.clientY;Pe(t.view),Jo(t),a.mouse=[u,this.__zoom.invert(u)],Eo(this),a.start()}}function S(t,...e){if(o.apply(this,arguments)){var n=this.__zoom,a=xe(t.changedTouches?t.changedTouches[0]:t,this),s=n.invert(a),u=n.k*(t.shiftKey?.5:2),h=i(x(v(n,u),a,s),r.apply(this,e),c);tr(t),l>0?ve(this).transition().duration(l).call(_,h,a,t):ve(this).call(y.transform,h,a,t)}}function N(n,...r){if(o.apply(this,arguments)){var i,a,s,u,c=n.touches,l=c.length,h=b(this,r,n.changedTouches.length===l).event(n);for(Jo(n),a=0;a<l;++a)u=[u=xe(s=c[a],this),this.__zoom.invert(u),s.identifier],h.touch0?h.touch1||h.touch0[2]===u[2]||(h.touch1=u,h.taps=0):(h.touch0=u,i=!0,h.taps=1+!!t);t&&(t=clearTimeout(t)),i&&(h.taps<2&&(e=u[0],t=setTimeout((function(){t=null}),f)),Eo(this),h.start())}}function z(t,...e){if(this.__zooming){var n,o,r,a,s=b(this,e).event(t),u=t.changedTouches,l=u.length;for(tr(t),n=0;n<l;++n)r=xe(o=u[n],this),s.touch0&&s.touch0[2]===o.identifier?s.touch0[0]=r:s.touch1&&s.touch1[2]===o.identifier&&(s.touch1[0]=r);if(o=s.that.__zoom,s.touch1){var h=s.touch0[0],d=s.touch0[1],f=s.touch1[0],p=s.touch1[1],g=(g=f[0]-h[0])*g+(g=f[1]-h[1])*g,m=(m=p[0]-d[0])*m+(m=p[1]-d[1])*m;o=v(o,Math.sqrt(g/m)),r=[(h[0]+f[0])/2,(h[1]+f[1])/2],a=[(d[0]+p[0])/2,(d[1]+p[1])/2]}else{if(!s.touch0)return;r=s.touch0[0],a=s.touch0[1]}s.zoom("touch",i(x(o,r,a),s.extent,c))}}function k(t,...o){if(this.__zooming){var r,i,a=b(this,o).event(t),s=t.changedTouches,u=s.length;for(Jo(t),n&&clearTimeout(n),n=setTimeout((function(){n=null}),f),r=0;r<u;++r)i=s[r],a.touch0&&a.touch0[2]===i.identifier?delete a.touch0:a.touch1&&a.touch1[2]===i.identifier&&delete a.touch1;if(a.touch1&&!a.touch0&&(a.touch0=a.touch1,delete a.touch1),a.touch0)a.touch0[1]=this.__zoom.invert(a.touch0[0]);else if(a.end(),2===a.taps&&(i=xe(i,this),Math.hypot(e[0]-i[0],e[1]-i[1])<m)){var c=ve(this).on("dblclick.zoom");c&&c.apply(this,arguments)}}}return y.transform=function(t,e,n,o){var r=t.selection?t.selection():t;r.property("__zoom",or),t!==r?_(t,e,n,o):r.interrupt().each((function(){b(this,arguments).event(o).start().zoom(null,"function"==typeof e?e.apply(this,arguments):e).end()}))},y.scaleBy=function(t,e,n,o){y.scaleTo(t,(function(){return this.__zoom.k*("function"==typeof e?e.apply(this,arguments):e)}),n,o)},y.scaleTo=function(t,e,n,o){y.transform(t,(function(){var t=r.apply(this,arguments),o=this.__zoom,a=null==n?w(t):"function"==typeof n?n.apply(this,arguments):n,s=o.invert(a),u="function"==typeof e?e.apply(this,arguments):e;return i(x(v(o,u),a,s),t,c)}),n,o)},y.translateBy=function(t,e,n,o){y.transform(t,(function(){return i(this.__zoom.translate("function"==typeof e?e.apply(this,arguments):e,"function"==typeof n?n.apply(this,arguments):n),r.apply(this,arguments),c)}),null,o)},y.translateTo=function(t,e,n,o,a){y.transform(t,(function(){var t=r.apply(this,arguments),a=this.__zoom,s=null==o?w(t):"function"==typeof o?o.apply(this,arguments):o;return i(Uo.translate(s[0],s[1]).scale(a.k).translate("function"==typeof e?-e.apply(this,arguments):-e,"function"==typeof n?-n.apply(this,arguments):-n),t,c)}),o,a)},E.prototype={event:function(t){return t&&(this.sourceEvent=t),this},start:function(){return 1==++this.active&&(this.that.__zooming=this,this.emit("start")),this},zoom:function(t,e){return this.mouse&&"mouse"!==t&&(this.mouse[1]=e.invert(this.mouse[0])),this.touch0&&"touch"!==t&&(this.touch0[1]=e.invert(this.touch0[0])),this.touch1&&"touch"!==t&&(this.touch1[1]=e.invert(this.touch1[0])),this.that.__zoom=e,this.emit("zoom"),this},end:function(){return 0==--this.active&&(delete this.that.__zooming,this.emit("end")),this},emit:function(t){var e=ve(this.that).datum();d.call(t,this.that,new Wo(t,{sourceEvent:this.sourceEvent,target:y,type:t,transform:this.that.__zoom,dispatch:d}),e)}},y.wheelDelta=function(t){return arguments.length?(a="function"==typeof t?t:Fo(+t),y):a},y.filter=function(t){return arguments.length?(o="function"==typeof t?t:Fo(!!t),y):o},y.touchable=function(t){return arguments.length?(s="function"==typeof t?t:Fo(!!t),y):s},y.extent=function(t){return arguments.length?(r="function"==typeof t?t:Fo([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),y):r},y.scaleExtent=function(t){return arguments.length?(u[0]=+t[0],u[1]=+t[1],y):[u[0],u[1]]},y.translateExtent=function(t){return arguments.length?(c[0][0]=+t[0][0],c[1][0]=+t[1][0],c[0][1]=+t[0][1],c[1][1]=+t[1][1],y):[[c[0][0],c[0][1]],[c[1][0],c[1][1]]]},y.constrain=function(t){return arguments.length?(i=t,y):i},y.duration=function(t){return arguments.length?(l=+t,y):l},y.interpolate=function(t){return arguments.length?(h=t,y):h},y.on=function(){var t=d.on.apply(d,arguments);return t===d?y:t},y.clickDistance=function(t){return arguments.length?(g=(t=+t)*t,y):Math.sqrt(g)},y.tapDistance=function(t){return arguments.length?(m=+t,y):m},y}Qo.prototype=Ko.prototype;const ur=(t,e)=>t.x!==e.x||t.y!==e.y||t.zoom!==e.k,cr=t=>({x:t.x,y:t.y,zoom:t.k}),lr=({x:t,y:e,zoom:n})=>Uo.translate(t,e).scale(n),hr=(t,e)=>t.target.closest(`.${e}`),dr=(t,e)=>2===e&&Array.isArray(t)&&t.includes(2),fr=(t,e=0)=>"number"==typeof e&&e>0?t.transition().duration(e):t,pr=t=>{const e=t.ctrlKey&&T()?10:1;return-t.deltaY*(1===t.deltaMode?.05:t.deltaMode?1:.002)*e};var gr;t.ResizeControlVariant=void 0,(gr=t.ResizeControlVariant||(t.ResizeControlVariant={})).Line="line",gr.Handle="handle";const mr={width:0,height:0,x:0,y:0},yr={...mr,pointerX:0,pointerY:0,aspectRatio:1},vr={x:0,y:0,width:0,height:0,isXPosChange:!1,isYPosChange:!1,isWidthChange:!1,isHeightChange:!1};t.XYDrag=function({domNode:t,onNodeMouseDown:e,getStoreItems:n,onDragStart:o,onDrag:r,onDragStop:i}){let a={x:null,y:null},s=0,u=[],c=!1,l={x:0,y:0},h=null,f=null,g=!1;const m=ve(t);return{update:function({noDragClassName:t,handleSelector:y,domNode:x,isSelectable:_,nodeId:b}){function E({x:t,y:e}){const{nodeLookup:o,nodeExtent:i,snapGrid:s,snapToGrid:c,nodeOrigin:l,onNodeDrag:f,onSelectionDrag:g,onError:m,updateNodePositions:y}=n();a={x:t,y:e};let v=!1,x={x:0,y:0,x2:0,y2:0};if(u.length>1&&i){const t=d(u,{nodeOrigin:l});x=w(t)}if(u=u.map((n=>{let r={x:t-n.distance.x,y:e-n.distance.y};c&&(r=N(r,s));const a=[[i[0][0],i[0][1]],[i[1][0],i[1][1]]];u.length>1&&i&&!n.extent&&(a[0][0]=n.computed.positionAbsolute.x-x.x+i[0][0],a[1][0]=n.computed.positionAbsolute.x+(n.computed?.width??0)-x.x2+i[1][0],a[0][1]=n.computed.positionAbsolute.y-x.y+i[0][1],a[1][1]=n.computed.positionAbsolute.y+(n.computed?.height??0)-x.y2+i[1][1]);const{position:h,positionAbsolute:d}=p({nodeId:n.id,nextPosition:r,nodeLookup:o,nodeExtent:a,nodeOrigin:l,onError:m});return v=v||n.position.x!==h.x||n.position.y!==h.y,n.position=h,n.computed.positionAbsolute=d,n})),!v)return;y(u,!0,!0);const _=b?f:Ce(g);if(h&&(r||_)){const[t,e]=He({nodeId:b,dragItems:u,nodeLookup:o});r?.(h,u,t,e),_?.(h,t,e)}}function P(){if(!f)return;const[t,e]=v(l,f);if(0!==t||0!==e){const{transform:o,panBy:r}=n();a.x=(a.x??0)-t/o[2],a.y=(a.y??0)-e/o[2],r({x:t,y:e})&&E(a)}s=requestAnimationFrame(P)}function M(t){const{nodes:r,nodeLookup:i,multiSelectionActive:s,nodesDraggable:c,transform:l,snapGrid:h,snapToGrid:d,selectNodesOnDrag:f,onNodeDragStart:p,onSelectionDragStart:m,unselectNodesAndEdges:y}=n();g=!0,f&&_||s||!b||i.get(b)?.selected||y(),_&&f&&b&&e?.(b);const v=C(t.sourceEvent,{transform:l,snapGrid:h,snapToGrid:d});a=v,u=Xe(r,c,v,b);const x=b?p:Ce(m);if(u&&(o||x)){const[e,n]=He({nodeId:b,dragItems:u,nodeLookup:i});o?.(t.sourceEvent,u,e,n),x?.(t.sourceEvent,e,n)}}const S=$e().on("start",(t=>{const{domNode:e,nodeDragThreshold:o,transform:r,snapGrid:i,snapToGrid:s}=n();0===o&&M(t);const u=C(t.sourceEvent,{transform:r,snapGrid:i,snapToGrid:s});a=u,f=e?.getBoundingClientRect()||null,l=Y(t.sourceEvent,f)})).on("drag",(t=>{const{autoPanOnNodeDrag:e,transform:o,snapGrid:r,snapToGrid:i,nodeDragThreshold:s}=n(),d=C(t.sourceEvent,{transform:o,snapGrid:r,snapToGrid:i});if(!c&&e&&g&&(c=!0,P()),!g){const e=d.xSnapped-(a.x??0),n=d.ySnapped-(a.y??0);Math.sqrt(e*e+n*n)>s&&M(t)}(a.x!==d.xSnapped||a.y!==d.ySnapped)&&u&&g&&(h=t.sourceEvent,l=Y(t.sourceEvent,f),E(d))})).on("end",(t=>{if(g&&(c=!1,g=!1,cancelAnimationFrame(s),u)){const{nodeLookup:e,updateNodePositions:o,onNodeDragStop:r,onSelectionDragStop:a}=n(),s=b?r:Ce(a);if(o(u,!1,!1),i||s){const[n,o]=He({nodeId:b,dragItems:u,nodeLookup:e});i?.(t.sourceEvent,u,n,o),s?.(t.sourceEvent,n,o)}}})).filter((e=>{const n=e.target;return!e.button&&(!t||!Oe(n,`.${t}`,x))&&(!y||Oe(n,y,x))}));m.call(S)},destroy:function(){m.on(".drag",null)}}},t.XYHandle=Ze,t.XYMinimap=function({domNode:t,panZoom:e,getTransform:n,getViewScale:o}){const r=ve(t);return{update:function({translateExtent:t,width:i,height:a,zoomStep:s=10,pannable:u=!0,zoomable:c=!0,inversePan:l=!1}){const h=sr().on("zoom",u?r=>{const s=n();if("mousemove"!==r.sourceEvent.type||!e)return;const u=o()*Math.max(s[2],Math.log(s[2]))*(l?-1:1),c={x:s[0]-r.sourceEvent.movementX*u,y:s[1]-r.sourceEvent.movementY*u},h=[[0,0],[i,a]];e.setViewportConstrained({x:c.x,y:c.y,zoom:s[2]},h,t)}:null).on("zoom.wheel",c?t=>{const o=n();if("wheel"!==t.sourceEvent.type||!e)return;const r=-t.sourceEvent.deltaY*(1===t.sourceEvent.deltaMode?.05:t.sourceEvent.deltaMode?1:.002)*s,i=o[2]*Math.pow(2,r);e.scaleTo(i)}:null);r.call(h,{})},destroy:function(){r.on("zoom",null)},pointer:xe}},t.XYPanZoom=function({domNode:e,minZoom:n,maxZoom:o,translateExtent:r,viewport:i,onPanZoom:a,onPanZoomStart:s,onPanZoomEnd:u,onTransformChange:c,onDraggingChange:l}){const h={isZoomingOrPanning:!1,usedRightMouseButton:!1,prevViewport:{x:0,y:0,zoom:0},mouseButton:0,timerId:void 0,panScrollTimeout:void 0,isPanScrolling:!1},d=e.getBoundingClientRect(),f=sr().scaleExtent([n,o]).translateExtent(r),p=ve(e).call(f);x({x:i.x,y:i.y,zoom:g(i.zoom,n,o)},[[0,0],[d.width,d.height]],r);const m=p.on("wheel.zoom");function y(t,e){p&&f?.transform(fr(p,e?.duration),t)}function v(){f.on("zoom",null)}function x(t,e,n){const o=lr(t),r=f?.constrain()(o,e,n);return r&&y(r),r}return f.wheelDelta(pr),{update:function({noWheelClassName:e,noPanClassName:n,onPaneContextMenu:o,userSelectionActive:r,panOnScroll:i,panOnDrag:d,panOnScrollMode:g,panOnScrollSpeed:y,preventScrolling:x,zoomOnPinch:w,zoomOnScroll:_,zoomOnDoubleClick:b,zoomActivationKeyPressed:E,lib:P}){r&&!h.isZoomingOrPanning&&v();const M=i&&!E&&!r?function({zoomPanValues:e,noWheelClassName:n,d3Selection:o,d3Zoom:r,panOnScrollMode:i,panOnScrollSpeed:a,zoomOnPinch:s,onPanZoomStart:u,onPanZoom:c,onPanZoomEnd:l}){return h=>{if(hr(h,n))return!1;h.preventDefault(),h.stopImmediatePropagation();const d=o.property("__zoom").k||1,f=T();if(h.ctrlKey&&s&&f){const t=xe(h),e=pr(h),n=d*Math.pow(2,e);return void r.scaleTo(o,n,t,h)}const p=1===h.deltaMode?20:1;let g=i===t.PanOnScrollMode.Vertical?0:h.deltaX*p,m=i===t.PanOnScrollMode.Horizontal?0:h.deltaY*p;!f&&h.shiftKey&&i!==t.PanOnScrollMode.Vertical&&(g=h.deltaY*p,m=0),r.translateBy(o,-g/d*a,-m/d*a,{internal:!0});const y=cr(o.property("__zoom"));clearTimeout(e.panScrollTimeout),e.isPanScrolling||(e.isPanScrolling=!0,u?.(h,y)),e.isPanScrolling&&(c?.(h,y),e.panScrollTimeout=setTimeout((()=>{l?.(h,y),e.isPanScrolling=!1}),150))}}({zoomPanValues:h,noWheelClassName:e,d3Selection:p,d3Zoom:f,panOnScrollMode:g,panOnScrollSpeed:y,zoomOnPinch:w,onPanZoomStart:s,onPanZoom:a,onPanZoomEnd:u}):function({noWheelClassName:t,preventScrolling:e,d3ZoomHandler:n}){return function(o,r){if(!e||hr(o,t))return null;o.preventDefault(),n.call(this,o,r)}}({noWheelClassName:e,preventScrolling:x,d3ZoomHandler:m});if(p.on("wheel.zoom",M,{passive:!1}),!r){const t=function({zoomPanValues:t,onDraggingChange:e,onPanZoomStart:n}){return o=>{if(o.sourceEvent?.internal)return;const r=cr(o.transform);t.mouseButton=o.sourceEvent?.button||0,t.isZoomingOrPanning=!0,t.prevViewport=r,"mousedown"===o.sourceEvent?.type&&e(!0),n&&n?.(o.sourceEvent,r)}}({zoomPanValues:h,onDraggingChange:l,onPanZoomStart:s});f.on("start",t);const e=function({zoomPanValues:t,panOnDrag:e,onPaneContextMenu:n,onTransformChange:o,onPanZoom:r}){return i=>{t.usedRightMouseButton=!(!n||!dr(e,t.mouseButton??0)),i.sourceEvent?.sync||o([i.transform.x,i.transform.y,i.transform.k]),r&&!i.sourceEvent?.internal&&r?.(i.sourceEvent,cr(i.transform))}}({zoomPanValues:h,panOnDrag:d,onPaneContextMenu:!!o,onPanZoom:a,onTransformChange:c});f.on("zoom",e);const n=function({zoomPanValues:t,panOnDrag:e,panOnScroll:n,onDraggingChange:o,onPanZoomEnd:r,onPaneContextMenu:i}){return a=>{if(!a.sourceEvent?.internal&&(t.isZoomingOrPanning=!1,i&&dr(e,t.mouseButton??0)&&!t.usedRightMouseButton&&a.sourceEvent&&i(a.sourceEvent),t.usedRightMouseButton=!1,o(!1),r&&ur(t.prevViewport,a.transform))){const e=cr(a.transform);t.prevViewport=e,clearTimeout(t.timerId),t.timerId=setTimeout((()=>{r?.(a.sourceEvent,e)}),n?150:0)}}}({zoomPanValues:h,panOnDrag:d,panOnScroll:i,onPaneContextMenu:o,onPanZoomEnd:u,onDraggingChange:l});f.on("end",n)}const S=function({zoomActivationKeyPressed:t,zoomOnScroll:e,zoomOnPinch:n,panOnDrag:o,panOnScroll:r,zoomOnDoubleClick:i,userSelectionActive:a,noWheelClassName:s,noPanClassName:u,lib:c}){return l=>{const h=t||e,d=n&&l.ctrlKey;if(1===l.button&&"mousedown"===l.type&&(hr(l,`${c}-flow__node`)||hr(l,`${c}-flow__edge`)))return!0;if(!(o||h||r||i||n))return!1;if(a)return!1;if(!i&&"dblclick"===l.type)return!1;if(hr(l,s)&&"wheel"===l.type)return!1;if(hr(l,u)&&("wheel"!==l.type||r&&"wheel"===l.type&&!t))return!1;if(!n&&l.ctrlKey&&"wheel"===l.type)return!1;if(!h&&!r&&!d&&"wheel"===l.type)return!1;if(!o&&("mousedown"===l.type||"touchstart"===l.type))return!1;if(Array.isArray(o)&&!o.includes(l.button)&&("mousedown"===l.type||"touchstart"===l.type))return!1;const f=Array.isArray(o)&&o.includes(l.button)||!l.button||l.button<=1;return(!l.ctrlKey||"wheel"===l.type)&&f}}({zoomActivationKeyPressed:E,panOnDrag:d,zoomOnScroll:_,panOnScroll:i,zoomOnDoubleClick:b,zoomOnPinch:w,userSelectionActive:r,noPanClassName:n,noWheelClassName:e,lib:P});f.filter(S)},destroy:v,setViewport:function(t,e){const n=lr(t);return y(n,e),n},setViewportConstrained:x,getViewport:function(){const t=p?Qo(p.node()):{x:0,y:0,k:1};return{x:t.x,y:t.y,zoom:t.k}},scaleTo:function(t,e){p&&f?.scaleTo(fr(p,e?.duration),t)},scaleBy:function(t,e){p&&f?.scaleBy(fr(p,e?.duration),t)},setScaleExtent:function(t){f?.scaleExtent(t)},setTranslateExtent:function(t){f?.translateExtent(t)},syncViewport:function(t){if(p){const e=lr(t),n=p.property("__zoom");n.k===t.zoom&&n.x===t.x&&n.y===t.y||f?.transform(p,e,null,{sync:!0})}}}},t.XYResizer=function({domNode:t,nodeId:e,getStoreItems:n,onChange:o}){const r=ve(t);return{update:function({controlPosition:t,boundaries:i,keepAspectRatio:a,onResizeStart:s,onResize:u,onResizeEnd:c,shouldResize:l}){let h={...mr},d={...yr};const f=function(t){return{isHorizontal:t.includes("right")||t.includes("left"),isVertical:t.includes("bottom")||t.includes("top"),affectsX:t.includes("left"),affectsY:t.includes("top")}}(t),p=$e().on("start",(t=>{const{nodeLookup:o,transform:r,snapGrid:i,snapToGrid:a}=n(),u=o.get(e),{xSnapped:c,ySnapped:l}=C(t.sourceEvent,{transform:r,snapGrid:i,snapToGrid:a});h={width:u?.computed?.width??0,height:u?.computed?.height??0,x:u?.position.x??0,y:u?.position.y??0},d={...h,pointerX:c,pointerY:l,aspectRatio:h.width/h.height},s?.(t,{...h})})).on("drag",(t=>{const{nodeLookup:r,transform:s,snapGrid:c,snapToGrid:p}=n(),m=C(t.sourceEvent,{transform:s,snapGrid:c,snapToGrid:p});if(r.get(e)){const e={...vr},{x:n,y:r,width:s,height:c}=h,{width:p,height:y}=function(t,e,n,o,r){const{isHorizontal:i,isVertical:a,affectsX:s,affectsY:u}=e,{xSnapped:c,ySnapped:l}=n,{minWidth:h,maxWidth:d,minHeight:f,maxHeight:p}=o,{pointerX:m,pointerY:y,width:v,height:x,aspectRatio:w}=t,_=Math.floor(i?c-m:0),b=Math.floor(a?l-y:0);let E=g(v+(s?-_:_),h,d),P=g(x+(u?-b:b),f,p);if(r){const t=E/P,e=i&&a;E=t<=w&&e||a&&!i?P*w:E,P=t>w&&e||i&&!a?E/w:P,E>=d?(E=d,P=d/w):E<=h&&(E=h,P=h/w),P>=p?(P=p,E=p*w):P<=f&&(P=f,E=f*w)}return{width:E,height:P}}(d,f,m,i,a),v=p!==s,x=y!==c;if(f.affectsX||f.affectsY){const{x:t,y:o}=function(t,e,n,o){return{x:e.affectsX?t.x-(n-t.width):t.x,y:e.affectsY?t.y-(o-t.height):t.y}}(d,f,p,y),i=t!==n&&v,a=o!==r&&x;(i||a)&&(e.isXPosChange=i,e.isYPosChange=a,e.x=i?t:n,e.y=a?o:r,h.x=e.x,h.y=e.y)}if((v||x)&&(e.isWidthChange=v,e.isHeightChange=x,e.width=p,e.height=y,h.width=p,h.height=y),!(e.isXPosChange||e.isYPosChange||v||x))return;const w=function({width:t,prevWidth:e,height:n,prevHeight:o,affectsX:r,affectsY:i}){const a=t-e,s=n-o,u=[a>0?1:a<0?-1:0,s>0?1:s<0?-1:0];return a&&r&&(u[0]=-1*u[0]),s&&i&&(u[1]=-1*u[1]),u}({width:h.width,prevWidth:s,height:h.height,prevHeight:c,affectsX:f.affectsX,affectsY:f.affectsY}),_={...h,direction:w},b=l?.(t,_);if(!1===b)return;u?.(t,_),o(e)}})).on("end",(t=>{c?.(t,{...h})}));r.call(p)},destroy:function(){r.on(".drag",null)}}},t.XY_RESIZER_HANDLE_POSITIONS=["top-left","top-right","bottom-left","bottom-right"],t.XY_RESIZER_LINE_POSITIONS=["top","right","bottom","left"],t.addEdge=(t,n)=>{if(!t.source||!t.target)return e.error006(),n;let o;return o=l(t)?{...t}:{...t,id:q(t)},((t,e)=>e.some((e=>!(e.source!==t.source||e.target!==t.target||e.sourceHandle!==t.sourceHandle&&(e.sourceHandle||t.sourceHandle)||e.targetHandle!==t.targetHandle&&(e.targetHandle||t.targetHandle)))))(o,n)?n:(null===o.sourceHandle&&delete o.sourceHandle,null===o.targetHandle&&delete o.targetHandle,n.concat(o))},t.adoptUserProvidedNodes=function(t,e,o={nodeOrigin:[0,0],elevateNodesOnSelect:!0,defaults:{}}){const r=new Map(e);e.clear();const i={},a=o?.elevateNodesOnSelect?1e3:0;return J(t.map((t=>{const s=r.get(t.id);if(t===s?.[n]?.userProvidedNode)return e.set(t.id,s),s;const u={...o.defaults,...t,computed:{positionAbsolute:t.position,width:t.computed?.width||s?.computed?.width,height:t.computed?.height||s?.computed?.height}},c=(M(t.zIndex)?t.zIndex:0)+(t.selected?a:0),l=t?.[n]||s?.[n];return u.parentNode&&(i[u.parentNode]=!0),Object.defineProperty(u,n,{enumerable:!1,value:{handleBounds:l?.handleBounds,z:c,userProvidedNode:t}}),e.set(u.id,u),u})),e,o.nodeOrigin,i)},t.areConnectionMapsEqual=function(t,e){if(!t&&!e)return!0;if(!t||!e||t.size!==e.size)return!1;if(!t.size&&!e.size)return!0;for(const n of t.keys())if(!e.has(n))return!1;return!0},t.boxToRect=_,t.calcAutoPan=v,t.calculateNodePosition=p,t.clamp=g,t.clampPosition=m,t.createMarkerIds=function(t,{id:e,defaultColor:n,defaultMarkerStart:o,defaultMarkerEnd:r}){const i=new Set;return t.reduce(((t,a)=>([a.markerStart||o,a.markerEnd||r].forEach((o=>{if(o&&"object"==typeof o){const r=Q(o,e);i.has(r)||(t.push({id:r,color:o.color||n,...o}),i.add(r))}})),t)),[]).sort(((t,e)=>t.id.localeCompare(e.id)))},t.devWarn=S,t.elementSelectionKeys=["Enter"," ","Escape"],t.errorMessages=e,t.fitView=function({nodes:t,width:e,height:n,panZoom:o,minZoom:r,maxZoom:i,nodeOrigin:a=[0,0]},s){const u=t.filter((t=>{const e=t.computed?.width&&t.computed?.height&&(s?.includeHiddenNodes||!t.hidden);return s?.nodes?.length?e&&s?.nodes.some((e=>e.id===t.id)):e}));if(u.length>0){const t=d(u,{nodeOrigin:a}),c=A(t,e,n,s?.minZoom??r,s?.maxZoom??i,s?.padding??.1);return o.setViewport(c,{duration:s?.duration}),!0}return!1},t.getBezierEdgeCenter=B,t.getBezierPath=function({sourceX:e,sourceY:n,sourcePosition:o=t.Position.Bottom,targetX:r,targetY:i,targetPosition:a=t.Position.Top,curvature:s=.25}){const[u,c]=L({pos:o,x1:e,y1:n,x2:r,y2:i,c:s}),[l,h]=L({pos:a,x1:r,y1:i,x2:e,y2:n,c:s}),[d,f,p,g]=B({sourceX:e,sourceY:n,targetX:r,targetY:i,sourceControlX:u,sourceControlY:c,targetControlX:l,targetControlY:h});return[`M${e},${n} C${u},${c} ${l},${h} ${r},${i}`,d,f,p,g]},t.getBoundsOfBoxes=x,t.getBoundsOfRects=(t,e)=>_(x(w(t),w(e))),t.getConnectedEdges=f,t.getDimensions=I,t.getEdgeCenter=V,t.getEdgePosition=function(o){const{sourceNode:r,targetNode:i}=o;if(!F(r)||!F(i))return null;const a=r[n]?.handleBounds||W(r.handles),s=i[n]?.handleBounds||W(i.handles),u=U(a?.source??[],o.sourceHandle),c=U(o.connectionMode===t.ConnectionMode.Strict?s?.target??[]:(s?.target??[]).concat(s?.source??[]),o.targetHandle),l=u?.position||t.Position.Bottom,h=c?.position||t.Position.Top;if(!u||!c)return o.onError?.("008",e.error008(u?"target":"source",{id:o.id,sourceHandle:o.sourceHandle,targetHandle:o.targetHandle})),null;const[d,f]=K(l,r,u),[p,g]=K(h,i,c);return{sourceX:d,sourceY:f,targetX:p,targetY:g,sourcePosition:l,targetPosition:h}},t.getElementsToRemove=async function({nodesToRemove:t=[],edgesToRemove:e=[],nodes:n,edges:o,onBeforeDelete:r}){const i=t.map((t=>t.id)),a=[];for(const t of n){if(!1===t.deletable)continue;const e=i.includes(t.id),n=!e&&t.parentNode&&a.find((e=>e.id===t.parentNode));(e||n)&&a.push(t)}const s=e.map((t=>t.id)),u=o.filter((t=>!1!==t.deletable)),c=f(a,u);for(const t of u){s.includes(t.id)&&!c.find((e=>e.id===t.id))&&c.push(t)}if(!r)return{edges:c,nodes:a};const l=await r({nodes:a,edges:c});return"boolean"==typeof l?l?{edges:c,nodes:a}:{edges:[],nodes:[]}:l},t.getElevatedEdgeZIndex=function({sourceNode:t,targetNode:e,selected:o=!1,zIndex:r=0,elevateOnSelect:i=!1}){if(!i)return r;const a=o||e.selected||t.selected,s=Math.max(t[n]?.z||0,e[n]?.z||0,1e3);return r+(a?s:0)},t.getEventPosition=Y,t.getHandleBounds=R,t.getHostForElement=O,t.getIncomers=(t,e,n)=>{if(!t.id)return[];const o=new Set;return n.forEach((e=>{e.target===t.id&&o.add(e.source)})),e.filter((t=>o.has(t.id)))},t.getMarkerId=Q,t.getNodePositionWithOrigin=h,t.getNodeToolbarTransform=function(e,n,o,r,i){let a=.5;"start"===i?a=0:"end"===i&&(a=1);let s=[(e.x+e.width*a)*n.zoom+n.x,e.y*n.zoom+n.y-r],u=[-100*a,-100];switch(o){case t.Position.Right:s=[(e.x+e.width)*n.zoom+n.x+r,(e.y+e.height*a)*n.zoom+n.y],u=[0,-100*a];break;case t.Position.Bottom:s[1]=(e.y+e.height)*n.zoom+n.y+r,u[1]=0;break;case t.Position.Left:s=[e.x*n.zoom+n.x-r,(e.y+e.height*a)*n.zoom+n.y],u=[-100,-100*a]}return`translate(${s[0]}px, ${s[1]}px) translate(${u[0]}%, ${u[1]}%)`},t.getNodesBounds=d,t.getNodesInside=(t,e,[n,o,r]=[0,0,1],i=!1,a=!1,s=[0,0])=>{const u={...z(e,[n,o,r]),width:e.width/r,height:e.height/r};return t.reduce(((t,e)=>{const{computed:n,selectable:o=!0,hidden:r=!1}=e,c=n?.width??e.width??null,l=n?.height??e.height??null;if(a&&!o||r)return t;const h=P(u,b(e,s));return(null===c||null===l||i&&h>0||h>=(c??0)*(l??0)||e.dragging)&&t.push(e),t}),[])},t.getOutgoers=(t,e,n)=>{if(!t.id)return[];const o=new Set;return n.forEach((e=>{e.source===t.id&&o.add(e.target)})),e.filter((t=>o.has(t.id)))},t.getOverlappingArea=P,t.getPointerPosition=C,t.getPositionWithOrigin=({x:t,y:e,width:n,height:o,origin:r=[0,0]})=>!n||!o||r[0]<0||r[1]<0||r[0]>1||r[1]>1?{x:t,y:e}:{x:t-n*r[0],y:e-o*r[1]},t.getSmoothStepPath=function({sourceX:e,sourceY:n,sourcePosition:o=t.Position.Bottom,targetX:r,targetY:i,targetPosition:a=t.Position.Top,borderRadius:s=5,centerX:u,centerY:c,offset:l=20}){const[h,d,f,p,g]=function({source:e,sourcePosition:n=t.Position.Bottom,target:o,targetPosition:r=t.Position.Top,center:i,offset:a}){const s=Z[n],u=Z[r],c={x:e.x+s.x*a,y:e.y+s.y*a},l={x:o.x+u.x*a,y:o.y+u.y*a},h=G({source:c,sourcePosition:n,target:l}),d=0!==h.x?"x":"y",f=h[d];let p,g,m=[];const y={x:0,y:0},v={x:0,y:0},[x,w,_,b]=V({sourceX:e.x,sourceY:e.y,targetX:o.x,targetY:o.y});if(s[d]*u[d]==-1){p=i.x||x,g=i.y||w;const t=[{x:p,y:c.y},{x:p,y:l.y}],e=[{x:c.x,y:g},{x:l.x,y:g}];m=s[d]===f?"x"===d?t:e:"x"===d?e:t}else{const t=[{x:c.x,y:l.y}],i=[{x:l.x,y:c.y}];if(m="x"===d?s.x===f?i:t:s.y===f?t:i,n===r){const t=Math.abs(e[d]-o[d]);if(t<=a){const n=Math.min(a-1,a-t);s[d]===f?y[d]=(c[d]>e[d]?-1:1)*n:v[d]=(l[d]>o[d]?-1:1)*n}}if(n!==r){const e="x"===d?"y":"x",n=s[d]===u[e],o=c[e]>l[e],r=c[e]<l[e];(1===s[d]&&(!n&&o||n&&r)||1!==s[d]&&(!n&&r||n&&o))&&(m="x"===d?t:i)}const h={x:c.x+y.x,y:c.y+y.y},x={x:l.x+v.x,y:l.y+v.y};Math.max(Math.abs(h.x-m[0].x),Math.abs(x.x-m[0].x))>=Math.max(Math.abs(h.y-m[0].y),Math.abs(x.y-m[0].y))?(p=(h.x+x.x)/2,g=m[0].y):(p=m[0].x,g=(h.y+x.y)/2)}return[[e,{x:c.x+y.x,y:c.y+y.y},...m,{x:l.x+v.x,y:l.y+v.y},o],p,g,_,b]}({source:{x:e,y:n},sourcePosition:o,target:{x:r,y:i},targetPosition:a,center:{x:u,y:c},offset:l});return[h.reduce(((t,e,n)=>{let o="";return o=n>0&&n<h.length-1?function(t,e,n,o){const r=Math.min(j(t,e)/2,j(e,n)/2,o),{x:i,y:a}=e;if(t.x===i&&i===n.x||t.y===a&&a===n.y)return`L${i} ${a}`;if(t.y===a)return`L ${i+r*(t.x<n.x?-1:1)},${a}Q ${i},${a} ${i},${a+r*(t.y<n.y?1:-1)}`;const s=t.x<n.x?1:-1;return`L ${i},${a+r*(t.y<n.y?-1:1)}Q ${i},${a} ${i+r*s},${a}`}(h[n-1],e,h[n+1],s):`${0===n?"M":"L"}${e.x} ${e.y}`,t+=o}),""),d,f,p,g]},t.getStraightPath=function({sourceX:t,sourceY:e,targetX:n,targetY:o}){const[r,i,a,s]=V({sourceX:t,sourceY:e,targetX:n,targetY:o});return[`M ${t},${e}L ${n},${o}`,r,i,a,s]},t.getViewportForBounds=A,t.handleConnectionChange=function(t,e,n){if(!n)return;const o=[];t.forEach(((t,n)=>{e?.has(n)||o.push(t)})),o.length&&n(o)},t.infiniteExtent=o,t.internalsSymbol=n,t.isCoordinateExtent=$,t.isEdgeBase=l,t.isEdgeVisible=function({sourceNode:t,targetNode:e,width:n,height:o,transform:r}){const i=x(E(t),E(e));i.x===i.x2&&(i.x2+=1),i.y===i.y2&&(i.y2+=1);const a={x:-r[0]/r[2],y:-r[1]/r[2],width:n/r[2],height:o/r[2]};return P(a,_(i))>0},t.isInputDOMNode=function(t){const e=t.composedPath?.()?.[0]||t.target,n=X.includes(e?.nodeName)||e?.hasAttribute("contenteditable"),o=t.ctrlKey||t.metaKey||t.shiftKey;return n&&!o||!!e?.closest(".nokey")},t.isMacOs=T,t.isMouseEvent=H,t.isNodeBase=t=>"id"in t&&!("source"in t)&&!("target"in t),t.isNumeric=M,t.isRectObject=t=>M(t.width)&&M(t.height)&&M(t.x)&&M(t.y),t.nodeToBox=E,t.nodeToRect=b,t.panBy=function({delta:t,panZoom:e,transform:n,translateExtent:o,width:r,height:i}){if(!e||!t.x&&!t.y)return!1;const a=e.setViewportConstrained({x:n[0]+t.x,y:n[1]+t.y,zoom:n[2]},[[0,0],[r,i]],o);return!!a&&(a.x!==n[0]||a.y!==n[1]||a.k!==n[2])},t.pointToRendererPoint=z,t.rectToBox=w,t.rendererPointToPoint=k,t.snapPosition=N,t.updateAbsolutePositions=J,t.updateConnectionLookup=function(t,e,n){t.clear(),e.clear();for(const o of n){const{source:n,target:r,sourceHandle:i=null,targetHandle:a=null}=o,s=`${n}-source-${i}`,u=`${r}-target-${a}`,c=t.get(s)||new Map,l=t.get(u)||new Map,h={source:n,target:r,sourceHandle:i,targetHandle:a};e.set(o.id,o),t.set(s,c.set(`${r}-${a}`,h)),t.set(u,l.set(`${n}-${i}`,h))}},t.updateEdge=(t,n,o,r={shouldReplaceId:!0})=>{const{id:i,...a}=t;if(!n.source||!n.target)return e.error006(),o;if(!o.find((e=>e.id===t.id)))return e.error007(i),o;const s={...a,id:r.shouldReplaceId?q(n):i,source:n.source,target:n.target,sourceHandle:n.sourceHandle,targetHandle:n.targetHandle};return o.filter((t=>t.id!==i)).concat(s)},t.updateNodeDimensions=function(t,e,o,r,i,a){const s=r?.querySelector(".xyflow__viewport");if(!s)return null;const u=window.getComputedStyle(s),{m22:c}=new window.DOMMatrixReadOnly(u.transform);return e.map((e=>{const r=t.get(e.id);if(r){const t=I(r.nodeElement);if(!(!t.width||!t.height||e.computed?.width===t.width&&e.computed?.height===t.height&&!r.forceUpdate)){a?.(e.id,t);const s={...e,computed:{...e.computed,...t},[n]:{...e[n],handleBounds:{source:R(".source",r.nodeElement,c,e.origin||i),target:R(".target",r.nodeElement,c,e.origin||i)}}};return o.set(e.id,s),s}}return e}))}}));
|
|
@@ -106,7 +106,7 @@ export type UpdateConnection = (params: {
|
|
|
106
106
|
export type ColorModeClass = 'light' | 'dark';
|
|
107
107
|
export type ColorMode = ColorModeClass | 'system';
|
|
108
108
|
export type ConnectionLookup = Map<string, Map<string, Connection>>;
|
|
109
|
-
export type
|
|
109
|
+
export type OnBeforeDeleteBase<NodeType extends NodeBase = NodeBase, EdgeType extends EdgeBase = EdgeBase> = ({ nodes, edges, }: {
|
|
110
110
|
nodes: NodeType[];
|
|
111
111
|
edges: EdgeType[];
|
|
112
112
|
}) => Promise<boolean | {
|