@next-bricks/diagram 0.32.1 → 0.32.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/dist/bricks.json +3 -3
  2. package/dist/chunks/{1728.457b3de4.js → 1728.838032d1.js} +2 -2
  3. package/dist/chunks/{1728.457b3de4.js.map → 1728.838032d1.js.map} +1 -1
  4. package/dist/chunks/1860.08a89fdc.js +2 -0
  5. package/dist/chunks/1860.08a89fdc.js.map +1 -0
  6. package/dist/chunks/{1972.d6fea46c.js → 1972.2904ef68.js} +2 -2
  7. package/dist/chunks/{1972.d6fea46c.js.map → 1972.2904ef68.js.map} +1 -1
  8. package/dist/chunks/{5481.d6977dfc.js → 5481.96ff558b.js} +3 -3
  9. package/dist/chunks/{5481.d6977dfc.js.map → 5481.96ff558b.js.map} +1 -1
  10. package/dist/chunks/{7034.286dd8ae.js → 7034.2b76ed5d.js} +3 -3
  11. package/dist/chunks/{7034.286dd8ae.js.map → 7034.2b76ed5d.js.map} +1 -1
  12. package/dist/chunks/709.5f97613d.js +2 -0
  13. package/dist/chunks/709.5f97613d.js.map +1 -0
  14. package/dist/chunks/{9591.c5101110.js → 9591.50cab9c8.js} +2 -2
  15. package/dist/chunks/{9591.c5101110.js.map → 9591.50cab9c8.js.map} +1 -1
  16. package/dist/chunks/{editable-label.8e6f528c.js → editable-label.27f45f0e.js} +3 -3
  17. package/dist/chunks/{editable-label.8e6f528c.js.map → editable-label.27f45f0e.js.map} +1 -1
  18. package/dist/chunks/{eo-diagram.78ef4cc9.js → eo-diagram.d23e4cc3.js} +2 -2
  19. package/dist/chunks/{eo-diagram.78ef4cc9.js.map → eo-diagram.d23e4cc3.js.map} +1 -1
  20. package/dist/chunks/{eo-display-canvas.d128a126.js → eo-display-canvas.8d78dc6f.js} +2 -2
  21. package/dist/chunks/{eo-display-canvas.d128a126.js.map → eo-display-canvas.8d78dc6f.js.map} +1 -1
  22. package/dist/chunks/{eo-draw-canvas.dc2cf3e4.js → eo-draw-canvas.3e6c3ab0.js} +2 -2
  23. package/dist/chunks/{eo-draw-canvas.dc2cf3e4.js.map → eo-draw-canvas.3e6c3ab0.js.map} +1 -1
  24. package/dist/chunks/{experimental-node.4545beba.js → experimental-node.e8c45637.js} +2 -2
  25. package/dist/chunks/{experimental-node.4545beba.js.map → experimental-node.e8c45637.js.map} +1 -1
  26. package/dist/chunks/{main.865d31e9.js → main.4738e9f4.js} +2 -2
  27. package/dist/chunks/{main.865d31e9.js.map → main.4738e9f4.js.map} +1 -1
  28. package/dist/{index.931e68b8.js → index.9011afb3.js} +2 -2
  29. package/dist/{index.931e68b8.js.map → index.9011afb3.js.map} +1 -1
  30. package/dist/manifest.json +41 -41
  31. package/dist/types.json +67 -67
  32. package/package.json +2 -2
  33. package/dist/chunks/1860.4fd60630.js +0 -2
  34. package/dist/chunks/1860.4fd60630.js.map +0 -1
  35. package/dist/chunks/709.29f69a6d.js +0 -2
  36. package/dist/chunks/709.29f69a6d.js.map +0 -1
  37. /package/dist/chunks/{5481.d6977dfc.js.LICENSE.txt → 5481.96ff558b.js.LICENSE.txt} +0 -0
  38. /package/dist/chunks/{7034.286dd8ae.js.LICENSE.txt → 7034.2b76ed5d.js.LICENSE.txt} +0 -0
  39. /package/dist/chunks/{editable-label.8e6f528c.js.LICENSE.txt → editable-label.27f45f0e.js.LICENSE.txt} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"chunks/eo-display-canvas.d128a126.js","mappings":"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","sources":["webpack:///./src/display-canvas/index.tsx"],"sourcesContent":["import React, {\n useCallback,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { RangeTuple, SizeTuple } from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n InitialCell,\n NodeBrickConf,\n CellContextMenuDetail,\n EdgeLineConf,\n Cell,\n LayoutType,\n LayoutOptions,\n} from \"../draw-canvas/interfaces\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport { sameTarget } from \"../draw-canvas/processors/sameTarget\";\nimport { CellComponent } from \"../draw-canvas/CellComponent\";\nimport { initializeCells } from \"../draw-canvas/processors/initializeCells\";\nimport {\n DEFAULT_DEGRADED_THRESHOLD,\n DEFAULT_NODE_SIZE,\n} from \"../draw-canvas/constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\nimport { rootReducer } from \"../draw-canvas/reducers\";\nimport { getUnrelatedCells } from \"../draw-canvas/processors/getUnrelatedCells\";\nimport { isEdgeCell, isNodeCell } from \"../draw-canvas/processors/asserts\";\nimport { ZoomBarComponent } from \"../shared/canvas/ZoomBarComponent\";\nimport { useLayout } from \"../shared/canvas/useLayout\";\nimport { useReady } from \"../shared/canvas/useReady\";\nimport { useLineMarkers } from \"../shared/canvas/useLineMarkers\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface EoDisplayCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\n/**\n * 用于展示查看的画布。\n */\nexport\n@defineElement(\"eo-display-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDisplayCanvas extends ReactNextElement implements EoDisplayCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当鼠标悬浮到某节点上时,隐藏其他跟该节点无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n render() {\n return (\n <EoDisplayCanvasComponent\n shadowRoot={this.shadowRoot!}\n cells={this.cells}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellContextMenu={this.#handleCellContextMenu}\n />\n );\n }\n}\n\nexport interface EoDisplayCanvasComponentProps extends EoDisplayCanvasProps {\n shadowRoot: ShadowRoot;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n}\n\nfunction EoDisplayCanvasComponent({\n shadowRoot,\n cells: initialCells,\n layout,\n layoutOptions,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellContextMenu,\n}: EoDisplayCanvasComponentProps) {\n const [{ cells }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n const { centered, setCentered } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n dispatch,\n });\n\n const activeTarget = useActiveTarget({\n cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({ type: \"update-node-size\", payload: { id, size } });\n },\n []\n );\n\n const [hoverCell, setHoverCell] = useState<Cell | null>(null);\n const handleCellMouseEnter = useCallback((cell: Cell) => {\n setHoverCell(cell);\n }, []);\n const handleCellMouseLeave = useCallback((cell: Cell) => {\n setHoverCell((prev) => (prev === cell ? null : prev));\n }, []);\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, null, hoverCell)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [cells, fadeUnrelatedCells, hoverCell]);\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\" ref={cellsRef}>\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={undefined}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n lineConfMap={lineConfMap}\n transform={transform}\n active={sameTarget(activeTarget, cell)}\n readOnly\n unrelatedCells={unrelatedCells}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseEnter\n : undefined\n }\n onCellMouseLeave={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseLeave\n : undefined\n }\n />\n ))}\n </g>\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={shadowRoot}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n"],"names":["_EoDisplayCanvas","defineElement","property","event","createDecorators","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_EoDisplayCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_P","_handleCellContextMenu","EoDisplayCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","render","React","EoDisplayCanvasComponent","shadowRoot","onActiveTargetChange","onSwitchActiveTarget","onCellContextMenu","_ref","initialCells","_activeTarget","_scaleRange","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","length","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","grabbing","transform","zoomer","useZoom","centered","setCentered","useLayout","useActiveTarget","defPrefix","concat","uniqueId","markerPrefix","handleNodeBrickResize","useCallback","id","size","type","payload","hoverCell","setHoverCell","useState","handleCellMouseEnter","cell","handleCellMouseLeave","prev","unrelatedCells","setUnrelatedCells","useEffect","nextUnrelated","getUnrelatedCells","handleZoomSlide","value","scaleTo","select","current","reCenter","lineConfMap","markers","useLineMarkers","ready","useReady","width","height","ref","className","classNames","tabIndex","map","marker","index","MarkerComponent","key","strokeColor","x","y","k","CellComponent","isEdgeCell","source","undefined","active","readOnly","onNodeBrickResize","onCellMouseEnter","onCellMouseLeave","ZoomBarComponent","scale","onZoomChange","onReCenter","_EoDisplayCanvas2","e","_set_activeTargetChangeEvent","_set_cellContextMenu","c","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS"],"sourceRoot":""}
1
+ {"version":3,"file":"chunks/eo-display-canvas.8d78dc6f.js","mappings":"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","sources":["webpack:///./src/display-canvas/index.tsx"],"sourcesContent":["import React, {\n useCallback,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { RangeTuple, SizeTuple } from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n InitialCell,\n NodeBrickConf,\n CellContextMenuDetail,\n EdgeLineConf,\n Cell,\n LayoutType,\n LayoutOptions,\n} from \"../draw-canvas/interfaces\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport { sameTarget } from \"../draw-canvas/processors/sameTarget\";\nimport { CellComponent } from \"../draw-canvas/CellComponent\";\nimport { initializeCells } from \"../draw-canvas/processors/initializeCells\";\nimport {\n DEFAULT_DEGRADED_THRESHOLD,\n DEFAULT_NODE_SIZE,\n} from \"../draw-canvas/constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\nimport { rootReducer } from \"../draw-canvas/reducers\";\nimport { getUnrelatedCells } from \"../draw-canvas/processors/getUnrelatedCells\";\nimport { isEdgeCell, isNodeCell } from \"../draw-canvas/processors/asserts\";\nimport { ZoomBarComponent } from \"../shared/canvas/ZoomBarComponent\";\nimport { useLayout } from \"../shared/canvas/useLayout\";\nimport { useReady } from \"../shared/canvas/useReady\";\nimport { useLineMarkers } from \"../shared/canvas/useLineMarkers\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface EoDisplayCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\n/**\n * 用于展示查看的画布。\n */\nexport\n@defineElement(\"eo-display-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDisplayCanvas extends ReactNextElement implements EoDisplayCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当鼠标悬浮到某节点上时,隐藏其他跟该节点无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n render() {\n return (\n <EoDisplayCanvasComponent\n shadowRoot={this.shadowRoot!}\n cells={this.cells}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellContextMenu={this.#handleCellContextMenu}\n />\n );\n }\n}\n\nexport interface EoDisplayCanvasComponentProps extends EoDisplayCanvasProps {\n shadowRoot: ShadowRoot;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n}\n\nfunction EoDisplayCanvasComponent({\n shadowRoot,\n cells: initialCells,\n layout,\n layoutOptions,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellContextMenu,\n}: EoDisplayCanvasComponentProps) {\n const [{ cells }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n const { centered, setCentered } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n dispatch,\n });\n\n const activeTarget = useActiveTarget({\n cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({ type: \"update-node-size\", payload: { id, size } });\n },\n []\n );\n\n const [hoverCell, setHoverCell] = useState<Cell | null>(null);\n const handleCellMouseEnter = useCallback((cell: Cell) => {\n setHoverCell(cell);\n }, []);\n const handleCellMouseLeave = useCallback((cell: Cell) => {\n setHoverCell((prev) => (prev === cell ? null : prev));\n }, []);\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, null, hoverCell)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [cells, fadeUnrelatedCells, hoverCell]);\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\" ref={cellsRef}>\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${isEdgeCell(cell) ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={undefined}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n lineConfMap={lineConfMap}\n transform={transform}\n active={sameTarget(activeTarget, cell)}\n readOnly\n unrelatedCells={unrelatedCells}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onNodeBrickResize={handleNodeBrickResize}\n onCellMouseEnter={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseEnter\n : undefined\n }\n onCellMouseLeave={\n fadeUnrelatedCells && isNodeCell(cell)\n ? handleCellMouseLeave\n : undefined\n }\n />\n ))}\n </g>\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={shadowRoot}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n"],"names":["_EoDisplayCanvas","defineElement","property","event","createDecorators","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_EoDisplayCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_P","_handleCellContextMenu","EoDisplayCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","render","React","EoDisplayCanvasComponent","shadowRoot","onActiveTargetChange","onSwitchActiveTarget","onCellContextMenu","_ref","initialCells","_activeTarget","_scaleRange","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","length","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","grabbing","transform","zoomer","useZoom","centered","setCentered","useLayout","useActiveTarget","defPrefix","concat","uniqueId","markerPrefix","handleNodeBrickResize","useCallback","id","size","type","payload","hoverCell","setHoverCell","useState","handleCellMouseEnter","cell","handleCellMouseLeave","prev","unrelatedCells","setUnrelatedCells","useEffect","nextUnrelated","getUnrelatedCells","handleZoomSlide","value","scaleTo","select","current","reCenter","lineConfMap","markers","useLineMarkers","ready","useReady","width","height","ref","className","classNames","tabIndex","map","marker","index","MarkerComponent","key","strokeColor","x","y","k","CellComponent","isEdgeCell","source","undefined","active","readOnly","onNodeBrickResize","onCellMouseEnter","onCellMouseLeave","ZoomBarComponent","scale","onZoomChange","onReCenter","_EoDisplayCanvas2","e","_set_activeTargetChangeEvent","_set_cellContextMenu","c","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS"],"sourceRoot":""}
@@ -1,2 +1,2 @@
1
- "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[8939],{3639:(e,t,a)=>{a.d(t,{w:()=>l});var n=a(8769),r=a.n(n),i=a(3373),o=a.n(i);function l(e){var{connectLineState:t,transform:a,markerEnd:i,onConnect:l}=e,[s,d]=(0,n.useState)(null);return(0,n.useEffect)((()=>{t&&d(t.from)}),[t]),(0,n.useEffect)((()=>{if(t){var e=e=>{d([(e.clientX-a.x-t.offset[0])/a.k,(e.clientY-a.y-t.offset[1])/a.k])},n=e=>{e.stopPropagation()},r=e=>{e.stopPropagation(),i(),l(t,[(e.clientX-a.x-t.offset[0])/a.k,(e.clientY-a.y-t.offset[1])/a.k])},i=()=>{document.removeEventListener("mousemove",e),document.removeEventListener("mousedown",n,{capture:!0}),document.removeEventListener("click",r,{capture:!0}),d(null)};return document.addEventListener("mousemove",e),document.addEventListener("mousedown",n,{capture:!0}),document.addEventListener("click",r,{capture:!0}),i}}),[t,l,a]),r().createElement("path",{className:o()("connect-line",{connecting:!!t&&s&&(s[0]-t.from[0])**2+(s[1]-t.from[1])**2>25}),d:t&&s?"M".concat(t.from.join(" "),"L").concat(s.join(" ")):"",fill:"none",stroke:"gray",strokeWidth:1,markerEnd:"url(#".concat(i,")")})}},9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>nt,EoDrawCanvasComponent:()=>dt});var n,r,i,o,l,s,d,c,u,h,v,f,g,p,w,m,y,k,C,b,x,A,N,E,z,M,W,R,T,S,L,B,D,P,H,j,O,I,U,_,V,Y,F,X,q,J,Z,G,K,Q,$,ee,te,ae,ne,re,ie,oe,le,se,de,ce,ue,he,ve,fe,ge,pe=a(4223),we=a(9740),me=a(6330),ye=a(4635),ke=a(918),Ce=a(1369),be=a(8449),xe=a(6902),Ae=a(8769),Ne=a.n(Ae),Ee=a(9929),ze=a(9938),Me=a(8438),We=(a(330),a(1030)),Re=a(3373),Te=a.n(Re),Se=a(7566),Le=a(1083),Be=a(3739),De=a(531),Pe=a(8185),He=a(5114),je=a(2830),Oe=a(3639),Ie=a(3783),Ue=a(2098),_e=a(227),Ve=a(3033),Ye=a(8091),Fe=a(1819),Xe=a(7099),qe=a(2361),Je=a(8197),Ze=a(7531),Ge=a(3012),Ke=a(8618),Qe=["shouldReCenter"];function $e(e,t,a){return a(at(e,t))}function et(e,t,a){return e.set(at(e,t),a),a}function tt(e,t){return e.get(at(e,t))}function at(e,t,a){if("function"==typeof e?e===t:e.has(t))return arguments.length<3?t:a;throw new TypeError("Private element is not present on this object")}var nt,rt=(0,Me.unwrapProvider)("basic.lock-body-scroll"),{defineElement:it,property:ot,method:lt,event:st}=(0,Ee.createDecorators)(),dt=Ne().forwardRef(Ft),ct=new WeakMap,ut=new WeakMap,ht=new WeakMap,vt=new WeakMap,ft=new WeakMap,gt=new WeakMap,pt=new WeakMap,wt=new WeakMap,mt=new WeakMap,yt=new WeakMap,kt=new WeakMap,Ct=new WeakMap,bt=new WeakMap,xt=new WeakMap,At=new WeakMap,Nt=new WeakSet,Et=new WeakMap,zt=new WeakMap,Mt=new WeakMap,Wt=new WeakMap,Rt=new WeakMap,Tt=new WeakMap,St=new WeakMap,Lt=new WeakMap,Bt=new WeakMap,Dt=new WeakMap,Pt=new WeakMap,Ht=new WeakMap,jt=new WeakMap,Ot=new WeakMap,It=new WeakMap,Ut=new WeakMap,_t=new WeakMap;class Vt extends ze.ReactNextElement{constructor(){super(...arguments),(0,ye.A)(this,Nt),(0,ke.A)(this,ct,(n(this),i(this))),(0,ke.A)(this,ut,(o(this),l(this))),(0,ke.A)(this,ht,(s(this),d(this))),(0,ke.A)(this,vt,(c(this),u(this,[Ve.HP,Ve.HP]))),(0,ke.A)(this,ft,(h(this),v(this))),(0,ke.A)(this,gt,(f(this),g(this))),(0,ke.A)(this,pt,(p(this),w(this))),(0,ke.A)(this,wt,(m(this),y(this))),(0,ke.A)(this,mt,(k(this),C(this))),(0,ke.A)(this,yt,(b(this),x(this))),(0,ke.A)(this,kt,(A(this),N(this,!0))),(0,ke.A)(this,Ct,(E(this),z(this,!0))),(0,ke.A)(this,bt,(M(this),W(this,!0))),(0,ke.A)(this,xt,(R(this),T(this))),(0,ke.A)(this,At,(S(this),L(this))),(0,ke.A)(this,Et,(P(this),e=>{$e(Nt,this,B).emit(e)})),(0,ke.A)(this,zt,(e=>{(0,Pe.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,ke.A)(this,Mt,H(this)),(0,ke.A)(this,Wt,(I(this),U(this))),(0,ke.A)(this,Rt,(Y(this),e=>{$e(Nt,this,_).emit(e),"node"===e.type&&$e(Nt,this,j).emit(e)})),(0,ke.A)(this,Tt,F(this)),(0,ke.A)(this,St,(J(this),e=>{$e(Nt,this,X).emit(e)})),(0,ke.A)(this,Lt,Z(this)),(0,ke.A)(this,Bt,(Q(this),$(this))),(0,ke.A)(this,Dt,(ae(this),e=>{$e(Nt,this,ee).emit(e),"node"===e.type&&$e(Nt,this,G).emit(e)})),(0,ke.A)(this,Pt,ne(this)),(0,ke.A)(this,Ht,(oe(this),e=>{$e(Nt,this,re).emit(e)})),(0,ke.A)(this,jt,le(this)),(0,ke.A)(this,Ot,(ce(this),e=>{$e(Nt,this,se).emit(e)})),(0,ke.A)(this,It,ue(this)),(0,ke.A)(this,Ut,(fe(this),e=>{$e(Nt,this,he).emit(e)})),(0,ke.A)(this,_t,(0,Ae.createRef)())}get cells(){return tt(ct,this)}set cells(e){et(ct,this,e)}get layout(){return tt(ut,this)}set layout(e){et(ut,this,e)}get layoutOptions(){return tt(ht,this)}set layoutOptions(e){et(ht,this,e)}get defaultNodeSize(){return tt(vt,this)}set defaultNodeSize(e){et(vt,this,e)}get defaultNodeBricks(){return tt(ft,this)}set defaultNodeBricks(e){et(ft,this,e)}get degradedThreshold(){return tt(gt,this)}set degradedThreshold(e){et(gt,this,e)}get degradedNodeLabel(){return tt(pt,this)}set degradedNodeLabel(e){et(pt,this,e)}get defaultEdgeLines(){return tt(wt,this)}set defaultEdgeLines(e){et(wt,this,e)}get activeTarget(){return tt(mt,this)}set activeTarget(e){et(mt,this,e)}get fadeUnrelatedCells(){return tt(yt,this)}set fadeUnrelatedCells(e){et(yt,this,e)}get zoomable(){return tt(kt,this)}set zoomable(e){et(kt,this,e)}get scrollable(){return tt(Ct,this)}set scrollable(e){et(Ct,this,e)}get pannable(){return tt(bt,this)}set pannable(e){et(bt,this,e)}get scaleRange(){return tt(xt,this)}set scaleRange(e){et(xt,this,e)}dropNode(e){var t=this;return(0,me.A)((function*(){var a,n,{id:r,position:i,size:o,data:l,useBrick:s}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,i[0],i[1]))||void 0===a?void 0:a.includes(t)){var d,c,u,h=t.getBoundingClientRect(),v=tt(_t,t).current.getTransform(),f={type:"node",id:r,view:(0,we.A)((0,we.A)({},"force"===t.layout||"dagre"===t.layout?null:{x:(i[0]-h.left-v.x)/v.k,y:(i[1]-h.top-v.y)/v.k}),{},{width:null!==(d=null==o?void 0:o[0])&&void 0!==d?d:t.defaultNodeSize[0],height:null!==(c=null==o?void 0:o[1])&&void 0!==c?c:t.defaultNodeSize[0]}),data:l,useBrick:s};return null===(u=tt(_t,t).current)||void 0===u||u.dropNode(f),f}return null}))()}dropDecorator(e){var t=this;return(0,me.A)((function*(){var a,n,{position:r,decorator:i,text:o}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,r[0],r[1]))||void 0===a?void 0:a.includes(t)){var l,s=t.getBoundingClientRect(),d=tt(_t,t).current.getTransform(),c={type:"decorator",decorator:i,id:"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){var t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)})),view:{x:(r[0]-s.left-d.x)/d.k,y:(r[1]-s.top-d.y)/d.k,width:Ve.N8,height:Ve.w1,text:o}};return null===(l=tt(_t,t).current)||void 0===l||l.dropDecorator(c),c}return null}))()}addNodes(e){var t=this;return(0,me.A)((function*(){if(0===e.length)return[];var a=e.map((e=>{var a,n,{size:r,useBrick:i,id:o,data:l}=e;return{type:"node",id:o,data:l,view:{width:null!==(a=null==r?void 0:r[0])&&void 0!==a?a:t.defaultNodeSize[0],height:null!==(n=null==r?void 0:r[1])&&void 0!==n?n:t.defaultNodeSize[0]},useBrick:i}}));return tt(_t,t).current.addNodes(a,{defaultNodeSize:t.defaultNodeSize,canvasWidth:t.clientWidth,canvasHeight:t.clientHeight})}))()}addEdge(e){var t=this;return(0,me.A)((function*(){var a,{source:n,target:r,data:i}=e,o={type:"edge",source:n,target:r,data:i};return null===(a=tt(_t,t).current)||void 0===a||a.addEdge(o),o}))()}manuallyConnectNodes(e){return tt(_t,this).current.manuallyConnectNodes(e)}updateCells(e,t){var a=this;return(0,me.A)((function*(){yield at(Nt,a,Yt).call(a);var{updated:n}=tt(_t,a).current.updateCells(e,(0,we.A)((0,we.A)({},t),{},{defaultNodeSize:a.defaultNodeSize,canvasWidth:a.clientWidth,canvasHeight:a.clientHeight}));return{updated:n}}))()}disconnectedCallback(){super.disconnectedCallback(),rt(this,!1)}render(){return Ne().createElement(dt,{host:this,ref:tt(_t,this),layout:this.layout,layoutOptions:this.layoutOptions,cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:tt(Et,this),onSwitchActiveTarget:tt(zt,this),onCellMove:tt(Rt,this),onCellResize:tt(St,this),onCellDelete:tt(Dt,this),onCellContextMenu:tt(Ht,this),onDecoratorTextChange:tt(Ot,this),onScaleChange:tt(Ut,this)})}}function Yt(){return new Promise((e=>{var t=()=>{tt(_t,this).current?e():setTimeout(t,10)};t()}))}function Ft(e,t){var{host:a,layout:n,layoutOptions:r,cells:i,defaultNodeSize:o,defaultNodeBricks:l,defaultEdgeLines:s,degradedThreshold:d,degradedNodeLabel:c,activeTarget:u,fadeUnrelatedCells:h,zoomable:v,scrollable:f,pannable:g,scaleRange:p,onActiveTargetChange:w,onSwitchActiveTarget:m,onCellMove:y,onCellResize:k,onCellDelete:C,onCellContextMenu:b,onDecoratorTextChange:x,onScaleChange:A}=e,[{cells:N},E]=(0,Ae.useReducer)(Le.d,i,(e=>({cells:(0,Ie.C)(e,{defaultNodeSize:o})}))),z=(0,Ae.useMemo)((()=>N.filter(De.N).length>=(null!=d?d:Ve.pC)),[N,d]),M=(0,Ae.useRef)(null),W=(0,Ae.useRef)(null),R=(0,Ae.useRef)(null),[T,S]=(0,Ae.useState)([]),{grabbing:L,transform:B,zoomer:D,scaleRange:P}=(0,Ye.f)({rootRef:M,zoomable:v,scrollable:f,pannable:g,scaleRange:p,onSwitchActiveTarget:m});(0,Ae.useEffect)((()=>{A(B.k)}),[A,B.k]);var[H,j]=(0,Ae.useState)(null),{centered:O,setCentered:I}=(0,qe.g)({layout:n,layoutOptions:r,rootRef:M,cells:N,zoomable:v,zoomer:D,scaleRange:P,dispatch:E});(0,Ae.useImperativeHandle)(t,(()=>({dropNode(e){I(!0),E({type:"drop-node",payload:e})},dropDecorator(e){I(!0),E({type:"drop-decorator",payload:e})},addNodes(e,t){var{defaultNodeSize:a,canvasWidth:r,canvasHeight:i}=t,o=N.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,l=[...N.slice(0,o),...e,...N.slice(o)],{cells:s,updated:d,shouldReCenter:c}=(0,Ue.L)({cells:l,layout:n,previousCells:N,defaultNodeSize:a,canvasWidth:r,canvasHeight:i,scaleRange:P,transform:B});return c&&I(!1),E({type:"update-cells",payload:s}),d.filter((t=>e.includes(t)))},addEdge(e){E({type:"add-edge",payload:e})},updateCells(e,t){var a=(0,Ue.L)((0,we.A)((0,we.A)({},t),{},{layout:n,previousCells:N,cells:e,scaleRange:P,transform:B})),{shouldReCenter:r}=a,i=(0,pe.A)(a,Qe);return r&&I(!1),E({type:"update-cells",payload:i.cells}),i},getTransform:()=>B,manuallyConnectNodes(e){var t=N.find((t=>(0,De.N)(t)&&t.id===e));if(t){var a=M.current.getBoundingClientRect();return j({source:t,from:[t.view.x+t.view.width/2,t.view.y+t.view.height/2],offset:[a.left,a.top]}),new Promise(((e,t)=>{R.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[N,n,P,I,B]);var U=(0,Ae.useCallback)(((e,t)=>{for(var a,n=0;n<N.length;n++){var r=N[n];if((0,De.N)(r)&&r.id!==e.source.id&&r.view.x<t[0]&&r.view.x+r.view.width>t[0]&&r.view.y<t[1]&&r.view.y+r.view.height>t[1]){var i;null===(i=R.current)||void 0===i||i.resolve({source:e.source,target:r});break}}null===(a=R.current)||void 0===a||a.reject(null),j(null)}),[N]);(0,Ae.useEffect)((()=>{rt(a,!!H)}),[H,a]);var _=(0,Fe.J)({cellsRef:W,activeTarget:u,onActiveTargetChange:w}),[V,Y]=(0,Ae.useState)([]);(0,Ae.useEffect)((()=>{var e=h?(0,_e.Y)(N,H,_):[];Y((t=>0===t.length&&0===e.length?t:e))}),[_,N,H,h]),(0,Ae.useEffect)((()=>{var e=M.current;if(e&&!(T.length>0)){var t=e=>{var t=(0,He.a)(e,{cells:N,activeTarget:_});"delete-cell"===(null==t?void 0:t.action)&&C(t.cell)};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}}),[_,N,T.length,C]);var F=(0,Ae.useMemo)((()=>"".concat((0,We.uniqueId)("diagram-"),"-")),[]),X="".concat(F,"line-arrow-"),q=(0,Ae.useCallback)((e=>{E({type:"move-cell",payload:e})}),[]),J=(0,Ae.useCallback)((e=>{E({type:"move-cell",payload:e}),y(e)}),[y]),Z=(0,Ae.useCallback)((e=>{E({type:"resize-cell",payload:e})}),[]),G=(0,Ae.useCallback)((e=>{E({type:"resize-cell",payload:e}),k(e)}),[k]),K=(0,Ae.useCallback)((e=>{var{id:t,editing:a}=e;S(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Q=(0,Ae.useCallback)(((e,t)=>{E({type:"update-node-size",payload:{id:e,size:t}})}),[]),$=(0,Ae.useCallback)((e=>{D.scaleTo((0,Se.A)(M.current),e/100)}),[D]),ee=(0,Ae.useCallback)((()=>{I(!1)}),[I]),[te,ae]=(0,Ze.d)({cells:N,defaultEdgeLines:s,markerPrefix:X}),ne=(0,Je.H)({cells:N,layout:n,centered:O});return Ne().createElement(Ne().Fragment,null,Ne().createElement("svg",{width:"100%",height:"100%",ref:M,className:Te()("root",{grabbing:L,pannable:g,ready:ne}),tabIndex:-1},Ne().createElement("defs",null,ae.map(((e,t)=>Ne().createElement(Be.c,{key:t,id:"".concat(X).concat(t),type:"arrow",strokeColor:e.strokeColor})))),Ne().createElement("g",{transform:"translate(".concat(B.x," ").concat(B.y,") scale(").concat(B.k,")")},Ne().createElement("g",{className:"cells",ref:W},N.map((e=>Ne().createElement(je.m,{key:"".concat(e.type,":").concat("edge"===e.type?"".concat(e.source,"~").concat(e.target):e.id),layout:n,cell:e,cells:N,degraded:z,degradedNodeLabel:c,defaultNodeBricks:l,transform:B,lineConfMap:te,active:(0,Pe.c)(_,e),unrelatedCells:V,onCellMoving:q,onCellMoved:J,onCellResizing:Z,onCellResized:G,onSwitchActiveTarget:m,onCellContextMenu:b,onDecoratorTextChange:x,onDecoratorTextEditing:K,onNodeBrickResize:Q})))),Ne().createElement(Oe.w,{connectLineState:H,transform:B,markerEnd:"".concat(X,"0"),onConnect:U}))),Ne().createElement(Xe.Y,{shadowRoot:a.shadowRoot,scale:B.k,scaleRange:P,onZoomChange:$,onReCenter:ee}))}ge=Vt,({e:[i,o,l,s,d,c,u,h,v,f,g,p,w,m,y,k,C,b,x,A,N,E,z,M,W,R,T,S,L,B,D,P,H,j,O,I,U,_,V,Y,F,X,q,J,Z,G,K,Q,$,ee,te,ae,ne,re,ie,oe,le,se,de,ce,ue,he,ve,fe,n],c:[nt,r]}=function(e,t,a,n,r,i){var o,l,s,d,c,u,h,v=Symbol.metadata||Symbol.for("Symbol.metadata"),f=Object.defineProperty,g=Object.create,p=[g(null),g(null)],w=t.length;function m(t,a,n){return function(r,i){a&&(i=r,r=e);for(var o=0;o<t.length;o++)i=t[o].apply(r,n?[i]:[]);return n?i:r}}function y(e,t,a,n){if("function"!=typeof e&&(n||void 0!==e))throw new TypeError(t+" must "+(a||"be")+" a function"+(n?"":" or undefined"));return e}function k(e,t,a,n,r,i,s,d,c,u,h){function v(e){if(!h(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),w=t[3],k=!s,C=1===r,b=3===r,x=4===r,A=2===r;function N(t,a,n){return function(r,i){return a&&(i=r,r=e),n&&n(r),E[t].call(r,i)}}if(!k){var E={},z=[],M=b?"get":x||C?"set":"value";if(c?(u||C?E={get:(0,be.A)((function(){return w(this)}),n,"get"),set:function(e){t[4](this,e)}}:E[M]=w,u||(0,be.A)(E[M],n,A?"":M)):u||(E=Object.getOwnPropertyDescriptor(e,n)),!u&&!c){if((l=p[+d][n])&&7!=(l^r))throw new Error("Decorating two elements with the same name ("+E[M].name+") is not supported yet");p[+d][n]=r<3?1:r}}for(var W=e,R=g.length-1;R>=0;R-=a?2:1){var T=g[R],S=a?g[R-1]:void 0,L={},B={kind:["field","accessor","method","getter","setter","class"][r],name:n,metadata:o,addInitializer:function(e,t){if(e.v)throw new Error("attempted to call addInitializer after decoration was finished");y(t,"An initializer","be",!0),i.push(t)}.bind(null,L)};if(k)l=T.call(S,W,B),L.v=1,y(l,"class decorators","return")&&(W=l);else if(B.static=d,B.private=c,l=B.access={has:c?h.bind():function(e){return n in e}},x||(l.get=c?A?function(e){return v(e),E.value}:N("get",0,v):function(e){return e[n]}),A||b||(l.set=c?N("set",0,v):function(e,t){e[n]=t}),W=T.call(S,C?{get:E.get,set:E.set}:E[M],B),L.v=1,C){if("object"==typeof W&&W)(l=y(W.get,"accessor.get"))&&(E.get=l),(l=y(W.set,"accessor.set"))&&(E.set=l),(l=y(W.init,"accessor.init"))&&z.unshift(l);else if(void 0!==W)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else y(W,(u?"field":"method")+" decorators","return")&&(u?z.unshift(W):E[M]=W)}return r<2&&s.push(m(z,d,1),m(i,d,0)),u||k||(c?C?s.splice(-1,0,N("get",d),N("set",d)):s.push(A?E[M]:y.call.bind(E[M])):f(e,n,E)),W}function C(e){return f(e,v,{configurable:!0,enumerable:!0,value:o})}return void 0!==i&&(o=i[v]),o=g(null==o?null:o),c=[],u=function(e){e&&c.push(m(e))},(h=function(t,n){for(var i=0;i<a.length;i++){var o=a[i],l=o[1],u=7&l;if((8&l)==t&&!u==n){var h=o[2],v=!!o[3],f=16&l;k(t?e:e.prototype,o,f,v?"#"+h:(0,Ce.A)(h),u,u<2?[]:t?d=d||[]:s=s||[],c,!!t,v,n,t&&v?function(t){return(0,xe.A)(t)===e}:r)}}})(8,0),h(0,0),h(8,1),h(0,1),u(s),u(d),l=c,w||C(e),{e:l,get c(){var a=[];return w&&[C(e=k(e,[t],0,e.name,5,a)),m(a,1)]}}}(ge,[it("eo-draw-canvas",{styleTexts:[Ge.A,Ke.A]})],[[ot({attribute:!1}),1,"cells"],[ot({type:String}),1,"layout"],[ot({attribute:!1}),1,"layoutOptions"],[ot({attribute:!1}),1,"defaultNodeSize"],[ot({attribute:!1}),1,"defaultNodeBricks"],[ot({type:Number}),1,"degradedThreshold"],[ot({attribute:!1}),1,"degradedNodeLabel"],[ot({attribute:!1}),1,"defaultEdgeLines"],[ot({attribute:!1}),1,"activeTarget"],[ot({type:Boolean}),1,"fadeUnrelatedCells"],[ot({type:Boolean}),1,"zoomable"],[ot({type:Boolean}),1,"scrollable"],[ot({type:Boolean}),1,"pannable"],[ot({attribute:!1}),1,"scaleRange"],[st({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>tt(At,e),(e,t)=>et(At,e,t)],[st({type:"node.move"}),1,"nodeMoveEvent",e=>tt(Mt,e),(e,t)=>et(Mt,e,t)],[st({type:"cell.move"}),1,"cellMoveEvent",e=>tt(Wt,e),(e,t)=>et(Wt,e,t)],[st({type:"cell.resize"}),1,"cellResizeEvent",e=>tt(Tt,e),(e,t)=>et(Tt,e,t)],[st({type:"node.delete"}),1,"nodeDelete",e=>tt(Lt,e),(e,t)=>et(Lt,e,t)],[st({type:"cell.delete"}),1,"cellDelete",e=>tt(Bt,e),(e,t)=>et(Bt,e,t)],[st({type:"cell.contextmenu"}),1,"cellContextMenu",e=>tt(Pt,e),(e,t)=>et(Pt,e,t)],[st({type:"decorator.text.change"}),1,"decoratorTextChange",e=>tt(jt,e),(e,t)=>et(jt,e,t)],[st({type:"scale.change"}),1,"scaleChange",e=>tt(It,e),(e,t)=>et(It,e,t)],[lt(),2,"dropNode"],[lt(),2,"dropDecorator"],[lt(),2,"addNodes"],[lt(),2,"addEdge"],[lt(),2,"manuallyConnectNodes"],[lt(),2,"updateCells"]],0,(e=>_t.has((0,xe.A)(e))),ze.ReactNextElement)),r()},5114:(e,t,a)=>{a.d(t,{a:()=>r});var n=a(8185);function r(e,t){var{cells:a,activeTarget:r}=t,i=a.find((e=>(0,n.c)(e,r)));if(i)switch(e.key||e.keyCode||e.which){case"Backspace":case 8:case"Delete":case 46:return e.preventDefault(),e.stopPropagation(),{action:"delete-cell",cell:i}}}},2098:(e,t,a)=>{a.d(t,{L:()=>c});var n=a(1030),r=a(3033),i=a(531),o=a(3783),l=a(908),s=a(6170),d=a(9127);function c(e){var{cells:t,layout:a,previousCells:c,defaultNodeSize:u,canvasWidth:h,canvasHeight:v,scaleRange:f,transform:g,reason:p,parent:w}=e,m="force"!==a&&"dagre"!==a,y=(0,o.C)(t,{defaultNodeSize:u}),k=[],C=!1,b=new Map,x=!1;for(var A of c)(0,i.mH)(A)?x=!0:(0,i.N)(A)&&(x=!0,A[r.CV]&&b.set(A.id,A));var N=new Map;for(var E of y)if((0,i.N)(E)){N.set(E.id,E);var z=b.get(E.id);z&&(E.view.width=z.view.width,E.view.height=z.view.height,E[r.CV]=!0)}var M=!1;if("add-related-nodes"===p&&w){var W=new Set;for(var R of y)(0,i.WW)(R)&&R.source===w&&R.target!==w&&W.add(R.target);var T=N.get(w);if(void 0!==(null==T?void 0:T.view.x)&&void 0!==T.view.y){M=!0;var S=[...W].map((e=>N.get(e))).filter(Boolean),L=void 0;for(var B of S)void 0!==B.view.x&&void 0!==B.view.y?(!L||B.view.x>L.view.x)&&B.view.y>T.view.y&&(L=B):k.push(B);if(k.length>0&&m){var D,P;if(L)D=L.view.x+L.view.width+r.sz,P=L.view.y;else{var H=k.reduce(((e,t)=>e+t.view.width+r.sz),-r.sz);D=T.view.x-H/2+T.view.width/2,P=T.view.y+T.view.height+r.sz}for(var j of k)j.view.x=D,j.view.y=P,D+=j.view.width+r.sz}}}if(!M){var O,I=u[0],U=u[1],_=0,V=!1;for(var Y of y)(0,i.N)(Y)?(Y.view.width>I&&(I=Y.view.width),Y.view.height>U&&(U=Y.view.height),void 0===Y.view.x||void 0===Y.view.y?k.push(Y):_++):(0,i.mH)(Y)&&(V=!0);if(m)for(var F of(x||(g=(0,l.r)((0,n.without)(y,...k),{canvasWidth:h,canvasHeight:v,scaleRange:f})),0===_||1===_&&!V?(({getNodeView:O}=(0,d.C)({cells:y})),C=!0):({getNodeView:O}=(0,s.k)({cells:y,fixedPosition:!0,center:[(h/2-g.x)/g.k,(v/2-g.y)/g.k]})),y))if((0,i.N)(F)){var X=O(F.id);F.view.x=X.x,F.view.y=X.y}}return{cells:y,updated:k,shouldReCenter:C}}},6330:(e,t,a)=>{function n(e,t,a,n,r,i,o){try{var l=e[i](o),s=l.value}catch(e){return void a(e)}l.done?t(s):Promise.resolve(s).then(n,r)}function r(e){return function(){var t=this,a=arguments;return new Promise((function(r,i){var o=e.apply(t,a);function l(e){n(o,r,i,l,s,"next",e)}function s(e){n(o,r,i,l,s,"throw",e)}l(void 0)}))}}a.d(t,{A:()=>r})}}]);
2
- //# sourceMappingURL=eo-draw-canvas.dc2cf3e4.js.map
1
+ "use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[8939],{3639:(e,t,a)=>{a.d(t,{w:()=>l});var n=a(8769),r=a.n(n),i=a(3373),o=a.n(i);function l(e){var{connectLineState:t,transform:a,markerEnd:i,onConnect:l}=e,[s,d]=(0,n.useState)(null);return(0,n.useEffect)((()=>{t&&d(t.from)}),[t]),(0,n.useEffect)((()=>{if(t){var e=e=>{d([(e.clientX-a.x-t.offset[0])/a.k,(e.clientY-a.y-t.offset[1])/a.k])},n=e=>{e.stopPropagation()},r=e=>{e.stopPropagation(),i(),l(t,[(e.clientX-a.x-t.offset[0])/a.k,(e.clientY-a.y-t.offset[1])/a.k])},i=()=>{document.removeEventListener("mousemove",e),document.removeEventListener("mousedown",n,{capture:!0}),document.removeEventListener("click",r,{capture:!0}),d(null)};return document.addEventListener("mousemove",e),document.addEventListener("mousedown",n,{capture:!0}),document.addEventListener("click",r,{capture:!0}),i}}),[t,l,a]),r().createElement("path",{className:o()("connect-line",{connecting:!!t&&s&&(s[0]-t.from[0])**2+(s[1]-t.from[1])**2>25}),d:t&&s?"M".concat(t.from.join(" "),"L").concat(s.join(" ")):"",fill:"none",stroke:"gray",strokeWidth:1,markerEnd:"url(#".concat(i,")")})}},9068:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>nt,EoDrawCanvasComponent:()=>dt});var n,r,i,o,l,s,d,c,u,h,v,f,g,p,w,m,y,k,C,b,x,A,N,E,z,M,W,R,T,S,L,B,D,P,H,j,O,I,U,_,V,Y,F,X,q,J,Z,G,K,Q,$,ee,te,ae,ne,re,ie,oe,le,se,de,ce,ue,he,ve,fe,ge,pe=a(4223),we=a(9740),me=a(6330),ye=a(4635),ke=a(918),Ce=a(1369),be=a(8449),xe=a(4521),Ae=a(8769),Ne=a.n(Ae),Ee=a(9929),ze=a(9938),Me=a(8438),We=(a(330),a(1030)),Re=a(3373),Te=a.n(Re),Se=a(7566),Le=a(1083),Be=a(3739),De=a(531),Pe=a(8185),He=a(5114),je=a(2830),Oe=a(3639),Ie=a(3783),Ue=a(2098),_e=a(227),Ve=a(3033),Ye=a(8091),Fe=a(1819),Xe=a(7099),qe=a(2361),Je=a(8197),Ze=a(7531),Ge=a(3012),Ke=a(8618),Qe=["shouldReCenter"];function $e(e,t,a){return a(at(e,t))}function et(e,t,a){return e.set(at(e,t),a),a}function tt(e,t){return e.get(at(e,t))}function at(e,t,a){if("function"==typeof e?e===t:e.has(t))return arguments.length<3?t:a;throw new TypeError("Private element is not present on this object")}var nt,rt=(0,Me.unwrapProvider)("basic.lock-body-scroll"),{defineElement:it,property:ot,method:lt,event:st}=(0,Ee.createDecorators)(),dt=Ne().forwardRef(Ft),ct=new WeakMap,ut=new WeakMap,ht=new WeakMap,vt=new WeakMap,ft=new WeakMap,gt=new WeakMap,pt=new WeakMap,wt=new WeakMap,mt=new WeakMap,yt=new WeakMap,kt=new WeakMap,Ct=new WeakMap,bt=new WeakMap,xt=new WeakMap,At=new WeakMap,Nt=new WeakSet,Et=new WeakMap,zt=new WeakMap,Mt=new WeakMap,Wt=new WeakMap,Rt=new WeakMap,Tt=new WeakMap,St=new WeakMap,Lt=new WeakMap,Bt=new WeakMap,Dt=new WeakMap,Pt=new WeakMap,Ht=new WeakMap,jt=new WeakMap,Ot=new WeakMap,It=new WeakMap,Ut=new WeakMap,_t=new WeakMap;class Vt extends ze.ReactNextElement{constructor(){super(...arguments),(0,ye.A)(this,Nt),(0,ke.A)(this,ct,(n(this),i(this))),(0,ke.A)(this,ut,(o(this),l(this))),(0,ke.A)(this,ht,(s(this),d(this))),(0,ke.A)(this,vt,(c(this),u(this,[Ve.HP,Ve.HP]))),(0,ke.A)(this,ft,(h(this),v(this))),(0,ke.A)(this,gt,(f(this),g(this))),(0,ke.A)(this,pt,(p(this),w(this))),(0,ke.A)(this,wt,(m(this),y(this))),(0,ke.A)(this,mt,(k(this),C(this))),(0,ke.A)(this,yt,(b(this),x(this))),(0,ke.A)(this,kt,(A(this),N(this,!0))),(0,ke.A)(this,Ct,(E(this),z(this,!0))),(0,ke.A)(this,bt,(M(this),W(this,!0))),(0,ke.A)(this,xt,(R(this),T(this))),(0,ke.A)(this,At,(S(this),L(this))),(0,ke.A)(this,Et,(P(this),e=>{$e(Nt,this,B).emit(e)})),(0,ke.A)(this,zt,(e=>{(0,Pe.c)(e,this.activeTarget)||(this.activeTarget=e)})),(0,ke.A)(this,Mt,H(this)),(0,ke.A)(this,Wt,(I(this),U(this))),(0,ke.A)(this,Rt,(Y(this),e=>{$e(Nt,this,_).emit(e),"node"===e.type&&$e(Nt,this,j).emit(e)})),(0,ke.A)(this,Tt,F(this)),(0,ke.A)(this,St,(J(this),e=>{$e(Nt,this,X).emit(e)})),(0,ke.A)(this,Lt,Z(this)),(0,ke.A)(this,Bt,(Q(this),$(this))),(0,ke.A)(this,Dt,(ae(this),e=>{$e(Nt,this,ee).emit(e),"node"===e.type&&$e(Nt,this,G).emit(e)})),(0,ke.A)(this,Pt,ne(this)),(0,ke.A)(this,Ht,(oe(this),e=>{$e(Nt,this,re).emit(e)})),(0,ke.A)(this,jt,le(this)),(0,ke.A)(this,Ot,(ce(this),e=>{$e(Nt,this,se).emit(e)})),(0,ke.A)(this,It,ue(this)),(0,ke.A)(this,Ut,(fe(this),e=>{$e(Nt,this,he).emit(e)})),(0,ke.A)(this,_t,(0,Ae.createRef)())}get cells(){return tt(ct,this)}set cells(e){et(ct,this,e)}get layout(){return tt(ut,this)}set layout(e){et(ut,this,e)}get layoutOptions(){return tt(ht,this)}set layoutOptions(e){et(ht,this,e)}get defaultNodeSize(){return tt(vt,this)}set defaultNodeSize(e){et(vt,this,e)}get defaultNodeBricks(){return tt(ft,this)}set defaultNodeBricks(e){et(ft,this,e)}get degradedThreshold(){return tt(gt,this)}set degradedThreshold(e){et(gt,this,e)}get degradedNodeLabel(){return tt(pt,this)}set degradedNodeLabel(e){et(pt,this,e)}get defaultEdgeLines(){return tt(wt,this)}set defaultEdgeLines(e){et(wt,this,e)}get activeTarget(){return tt(mt,this)}set activeTarget(e){et(mt,this,e)}get fadeUnrelatedCells(){return tt(yt,this)}set fadeUnrelatedCells(e){et(yt,this,e)}get zoomable(){return tt(kt,this)}set zoomable(e){et(kt,this,e)}get scrollable(){return tt(Ct,this)}set scrollable(e){et(Ct,this,e)}get pannable(){return tt(bt,this)}set pannable(e){et(bt,this,e)}get scaleRange(){return tt(xt,this)}set scaleRange(e){et(xt,this,e)}dropNode(e){var t=this;return(0,me.A)((function*(){var a,n,{id:r,position:i,size:o,data:l,useBrick:s}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,i[0],i[1]))||void 0===a?void 0:a.includes(t)){var d,c,u,h=t.getBoundingClientRect(),v=tt(_t,t).current.getTransform(),f={type:"node",id:r,view:(0,we.A)((0,we.A)({},"force"===t.layout||"dagre"===t.layout?null:{x:(i[0]-h.left-v.x)/v.k,y:(i[1]-h.top-v.y)/v.k}),{},{width:null!==(d=null==o?void 0:o[0])&&void 0!==d?d:t.defaultNodeSize[0],height:null!==(c=null==o?void 0:o[1])&&void 0!==c?c:t.defaultNodeSize[0]}),data:l,useBrick:s};return null===(u=tt(_t,t).current)||void 0===u||u.dropNode(f),f}return null}))()}dropDecorator(e){var t=this;return(0,me.A)((function*(){var a,n,{position:r,decorator:i,text:o}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,r[0],r[1]))||void 0===a?void 0:a.includes(t)){var l,s=t.getBoundingClientRect(),d=tt(_t,t).current.getTransform(),c={type:"decorator",decorator:i,id:"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){var t=16*Math.random()|0;return("x"==e?t:3&t|8).toString(16)})),view:{x:(r[0]-s.left-d.x)/d.k,y:(r[1]-s.top-d.y)/d.k,width:Ve.N8,height:Ve.w1,text:o}};return null===(l=tt(_t,t).current)||void 0===l||l.dropDecorator(c),c}return null}))()}addNodes(e){var t=this;return(0,me.A)((function*(){if(0===e.length)return[];var a=e.map((e=>{var a,n,{size:r,useBrick:i,id:o,data:l}=e;return{type:"node",id:o,data:l,view:{width:null!==(a=null==r?void 0:r[0])&&void 0!==a?a:t.defaultNodeSize[0],height:null!==(n=null==r?void 0:r[1])&&void 0!==n?n:t.defaultNodeSize[0]},useBrick:i}}));return tt(_t,t).current.addNodes(a,{defaultNodeSize:t.defaultNodeSize,canvasWidth:t.clientWidth,canvasHeight:t.clientHeight})}))()}addEdge(e){var t=this;return(0,me.A)((function*(){var a,{source:n,target:r,data:i}=e,o={type:"edge",source:n,target:r,data:i};return null===(a=tt(_t,t).current)||void 0===a||a.addEdge(o),o}))()}manuallyConnectNodes(e){return tt(_t,this).current.manuallyConnectNodes(e)}updateCells(e,t){var a=this;return(0,me.A)((function*(){yield at(Nt,a,Yt).call(a);var{updated:n}=tt(_t,a).current.updateCells(e,(0,we.A)((0,we.A)({},t),{},{defaultNodeSize:a.defaultNodeSize,canvasWidth:a.clientWidth,canvasHeight:a.clientHeight}));return{updated:n}}))()}disconnectedCallback(){super.disconnectedCallback(),rt(this,!1)}render(){return Ne().createElement(dt,{host:this,ref:tt(_t,this),layout:this.layout,layoutOptions:this.layoutOptions,cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,degradedThreshold:this.degradedThreshold,degradedNodeLabel:this.degradedNodeLabel,activeTarget:this.activeTarget,fadeUnrelatedCells:this.fadeUnrelatedCells,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:tt(Et,this),onSwitchActiveTarget:tt(zt,this),onCellMove:tt(Rt,this),onCellResize:tt(St,this),onCellDelete:tt(Dt,this),onCellContextMenu:tt(Ht,this),onDecoratorTextChange:tt(Ot,this),onScaleChange:tt(Ut,this)})}}function Yt(){return new Promise((e=>{var t=()=>{tt(_t,this).current?e():setTimeout(t,10)};t()}))}function Ft(e,t){var{host:a,layout:n,layoutOptions:r,cells:i,defaultNodeSize:o,defaultNodeBricks:l,defaultEdgeLines:s,degradedThreshold:d,degradedNodeLabel:c,activeTarget:u,fadeUnrelatedCells:h,zoomable:v,scrollable:f,pannable:g,scaleRange:p,onActiveTargetChange:w,onSwitchActiveTarget:m,onCellMove:y,onCellResize:k,onCellDelete:C,onCellContextMenu:b,onDecoratorTextChange:x,onScaleChange:A}=e,[{cells:N},E]=(0,Ae.useReducer)(Le.d,i,(e=>({cells:(0,Ie.C)(e,{defaultNodeSize:o})}))),z=(0,Ae.useMemo)((()=>N.filter(De.N).length>=(null!=d?d:Ve.pC)),[N,d]),M=(0,Ae.useRef)(null),W=(0,Ae.useRef)(null),R=(0,Ae.useRef)(null),[T,S]=(0,Ae.useState)([]),{grabbing:L,transform:B,zoomer:D,scaleRange:P}=(0,Ye.f)({rootRef:M,zoomable:v,scrollable:f,pannable:g,scaleRange:p,onSwitchActiveTarget:m});(0,Ae.useEffect)((()=>{A(B.k)}),[A,B.k]);var[H,j]=(0,Ae.useState)(null),{centered:O,setCentered:I}=(0,qe.g)({layout:n,layoutOptions:r,rootRef:M,cells:N,zoomable:v,zoomer:D,scaleRange:P,dispatch:E});(0,Ae.useImperativeHandle)(t,(()=>({dropNode(e){I(!0),E({type:"drop-node",payload:e})},dropDecorator(e){I(!0),E({type:"drop-decorator",payload:e})},addNodes(e,t){var{defaultNodeSize:a,canvasWidth:r,canvasHeight:i}=t,o=N.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1,l=[...N.slice(0,o),...e,...N.slice(o)],{cells:s,updated:d,shouldReCenter:c}=(0,Ue.L)({cells:l,layout:n,previousCells:N,defaultNodeSize:a,canvasWidth:r,canvasHeight:i,scaleRange:P,transform:B});return c&&I(!1),E({type:"update-cells",payload:s}),d.filter((t=>e.includes(t)))},addEdge(e){E({type:"add-edge",payload:e})},updateCells(e,t){var a=(0,Ue.L)((0,we.A)((0,we.A)({},t),{},{layout:n,previousCells:N,cells:e,scaleRange:P,transform:B})),{shouldReCenter:r}=a,i=(0,pe.A)(a,Qe);return r&&I(!1),E({type:"update-cells",payload:i.cells}),i},getTransform:()=>B,manuallyConnectNodes(e){var t=N.find((t=>(0,De.N)(t)&&t.id===e));if(t){var a=M.current.getBoundingClientRect();return j({source:t,from:[t.view.x+t.view.width/2,t.view.y+t.view.height/2],offset:[a.left,a.top]}),new Promise(((e,t)=>{R.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[N,n,P,I,B]);var U=(0,Ae.useCallback)(((e,t)=>{for(var a,n=0;n<N.length;n++){var r=N[n];if((0,De.N)(r)&&r.id!==e.source.id&&r.view.x<t[0]&&r.view.x+r.view.width>t[0]&&r.view.y<t[1]&&r.view.y+r.view.height>t[1]){var i;null===(i=R.current)||void 0===i||i.resolve({source:e.source,target:r});break}}null===(a=R.current)||void 0===a||a.reject(null),j(null)}),[N]);(0,Ae.useEffect)((()=>{rt(a,!!H)}),[H,a]);var _=(0,Fe.J)({cellsRef:W,activeTarget:u,onActiveTargetChange:w}),[V,Y]=(0,Ae.useState)([]);(0,Ae.useEffect)((()=>{var e=h?(0,_e.Y)(N,H,_):[];Y((t=>0===t.length&&0===e.length?t:e))}),[_,N,H,h]),(0,Ae.useEffect)((()=>{var e=M.current;if(e&&!(T.length>0)){var t=e=>{var t=(0,He.a)(e,{cells:N,activeTarget:_});"delete-cell"===(null==t?void 0:t.action)&&C(t.cell)};return e.addEventListener("keydown",t),()=>{e.removeEventListener("keydown",t)}}}),[_,N,T.length,C]);var F=(0,Ae.useMemo)((()=>"".concat((0,We.uniqueId)("diagram-"),"-")),[]),X="".concat(F,"line-arrow-"),q=(0,Ae.useCallback)((e=>{E({type:"move-cell",payload:e})}),[]),J=(0,Ae.useCallback)((e=>{E({type:"move-cell",payload:e}),y(e)}),[y]),Z=(0,Ae.useCallback)((e=>{E({type:"resize-cell",payload:e})}),[]),G=(0,Ae.useCallback)((e=>{E({type:"resize-cell",payload:e}),k(e)}),[k]),K=(0,Ae.useCallback)((e=>{var{id:t,editing:a}=e;S(a?e=>e.includes(t)?e:[...e,t]:e=>e.filter((e=>e!==t)))}),[]),Q=(0,Ae.useCallback)(((e,t)=>{E({type:"update-node-size",payload:{id:e,size:t}})}),[]),$=(0,Ae.useCallback)((e=>{D.scaleTo((0,Se.A)(M.current),e/100)}),[D]),ee=(0,Ae.useCallback)((()=>{I(!1)}),[I]),[te,ae]=(0,Ze.d)({cells:N,defaultEdgeLines:s,markerPrefix:X}),ne=(0,Je.H)({cells:N,layout:n,centered:O});return Ne().createElement(Ne().Fragment,null,Ne().createElement("svg",{width:"100%",height:"100%",ref:M,className:Te()("root",{grabbing:L,pannable:g,ready:ne}),tabIndex:-1},Ne().createElement("defs",null,ae.map(((e,t)=>Ne().createElement(Be.c,{key:t,id:"".concat(X).concat(t),type:"arrow",strokeColor:e.strokeColor})))),Ne().createElement("g",{transform:"translate(".concat(B.x," ").concat(B.y,") scale(").concat(B.k,")")},Ne().createElement("g",{className:"cells",ref:W},N.map((e=>Ne().createElement(je.m,{key:"".concat(e.type,":").concat("edge"===e.type?"".concat(e.source,"~").concat(e.target):e.id),layout:n,cell:e,cells:N,degraded:z,degradedNodeLabel:c,defaultNodeBricks:l,transform:B,lineConfMap:te,active:(0,Pe.c)(_,e),unrelatedCells:V,onCellMoving:q,onCellMoved:J,onCellResizing:Z,onCellResized:G,onSwitchActiveTarget:m,onCellContextMenu:b,onDecoratorTextChange:x,onDecoratorTextEditing:K,onNodeBrickResize:Q})))),Ne().createElement(Oe.w,{connectLineState:H,transform:B,markerEnd:"".concat(X,"0"),onConnect:U}))),Ne().createElement(Xe.Y,{shadowRoot:a.shadowRoot,scale:B.k,scaleRange:P,onZoomChange:$,onReCenter:ee}))}ge=Vt,({e:[i,o,l,s,d,c,u,h,v,f,g,p,w,m,y,k,C,b,x,A,N,E,z,M,W,R,T,S,L,B,D,P,H,j,O,I,U,_,V,Y,F,X,q,J,Z,G,K,Q,$,ee,te,ae,ne,re,ie,oe,le,se,de,ce,ue,he,ve,fe,n],c:[nt,r]}=function(e,t,a,n,r,i){var o,l,s,d,c,u,h,v=Symbol.metadata||Symbol.for("Symbol.metadata"),f=Object.defineProperty,g=Object.create,p=[g(null),g(null)],w=t.length;function m(t,a,n){return function(r,i){a&&(i=r,r=e);for(var o=0;o<t.length;o++)i=t[o].apply(r,n?[i]:[]);return n?i:r}}function y(e,t,a,n){if("function"!=typeof e&&(n||void 0!==e))throw new TypeError(t+" must "+(a||"be")+" a function"+(n?"":" or undefined"));return e}function k(e,t,a,n,r,i,s,d,c,u,h){function v(e){if(!h(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),w=t[3],k=!s,C=1===r,b=3===r,x=4===r,A=2===r;function N(t,a,n){return function(r,i){return a&&(i=r,r=e),n&&n(r),E[t].call(r,i)}}if(!k){var E={},z=[],M=b?"get":x||C?"set":"value";if(c?(u||C?E={get:(0,be.A)((function(){return w(this)}),n,"get"),set:function(e){t[4](this,e)}}:E[M]=w,u||(0,be.A)(E[M],n,A?"":M)):u||(E=Object.getOwnPropertyDescriptor(e,n)),!u&&!c){if((l=p[+d][n])&&7!=(l^r))throw new Error("Decorating two elements with the same name ("+E[M].name+") is not supported yet");p[+d][n]=r<3?1:r}}for(var W=e,R=g.length-1;R>=0;R-=a?2:1){var T=g[R],S=a?g[R-1]:void 0,L={},B={kind:["field","accessor","method","getter","setter","class"][r],name:n,metadata:o,addInitializer:function(e,t){if(e.v)throw new Error("attempted to call addInitializer after decoration was finished");y(t,"An initializer","be",!0),i.push(t)}.bind(null,L)};if(k)l=T.call(S,W,B),L.v=1,y(l,"class decorators","return")&&(W=l);else if(B.static=d,B.private=c,l=B.access={has:c?h.bind():function(e){return n in e}},x||(l.get=c?A?function(e){return v(e),E.value}:N("get",0,v):function(e){return e[n]}),A||b||(l.set=c?N("set",0,v):function(e,t){e[n]=t}),W=T.call(S,C?{get:E.get,set:E.set}:E[M],B),L.v=1,C){if("object"==typeof W&&W)(l=y(W.get,"accessor.get"))&&(E.get=l),(l=y(W.set,"accessor.set"))&&(E.set=l),(l=y(W.init,"accessor.init"))&&z.unshift(l);else if(void 0!==W)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else y(W,(u?"field":"method")+" decorators","return")&&(u?z.unshift(W):E[M]=W)}return r<2&&s.push(m(z,d,1),m(i,d,0)),u||k||(c?C?s.splice(-1,0,N("get",d),N("set",d)):s.push(A?E[M]:y.call.bind(E[M])):f(e,n,E)),W}function C(e){return f(e,v,{configurable:!0,enumerable:!0,value:o})}return void 0!==i&&(o=i[v]),o=g(null==o?null:o),c=[],u=function(e){e&&c.push(m(e))},(h=function(t,n){for(var i=0;i<a.length;i++){var o=a[i],l=o[1],u=7&l;if((8&l)==t&&!u==n){var h=o[2],v=!!o[3],f=16&l;k(t?e:e.prototype,o,f,v?"#"+h:(0,Ce.A)(h),u,u<2?[]:t?d=d||[]:s=s||[],c,!!t,v,n,t&&v?function(t){return(0,xe.A)(t)===e}:r)}}})(8,0),h(0,0),h(8,1),h(0,1),u(s),u(d),l=c,w||C(e),{e:l,get c(){var a=[];return w&&[C(e=k(e,[t],0,e.name,5,a)),m(a,1)]}}}(ge,[it("eo-draw-canvas",{styleTexts:[Ge.A,Ke.A]})],[[ot({attribute:!1}),1,"cells"],[ot({type:String}),1,"layout"],[ot({attribute:!1}),1,"layoutOptions"],[ot({attribute:!1}),1,"defaultNodeSize"],[ot({attribute:!1}),1,"defaultNodeBricks"],[ot({type:Number}),1,"degradedThreshold"],[ot({attribute:!1}),1,"degradedNodeLabel"],[ot({attribute:!1}),1,"defaultEdgeLines"],[ot({attribute:!1}),1,"activeTarget"],[ot({type:Boolean}),1,"fadeUnrelatedCells"],[ot({type:Boolean}),1,"zoomable"],[ot({type:Boolean}),1,"scrollable"],[ot({type:Boolean}),1,"pannable"],[ot({attribute:!1}),1,"scaleRange"],[st({type:"activeTarget.change"}),1,"activeTargetChangeEvent",e=>tt(At,e),(e,t)=>et(At,e,t)],[st({type:"node.move"}),1,"nodeMoveEvent",e=>tt(Mt,e),(e,t)=>et(Mt,e,t)],[st({type:"cell.move"}),1,"cellMoveEvent",e=>tt(Wt,e),(e,t)=>et(Wt,e,t)],[st({type:"cell.resize"}),1,"cellResizeEvent",e=>tt(Tt,e),(e,t)=>et(Tt,e,t)],[st({type:"node.delete"}),1,"nodeDelete",e=>tt(Lt,e),(e,t)=>et(Lt,e,t)],[st({type:"cell.delete"}),1,"cellDelete",e=>tt(Bt,e),(e,t)=>et(Bt,e,t)],[st({type:"cell.contextmenu"}),1,"cellContextMenu",e=>tt(Pt,e),(e,t)=>et(Pt,e,t)],[st({type:"decorator.text.change"}),1,"decoratorTextChange",e=>tt(jt,e),(e,t)=>et(jt,e,t)],[st({type:"scale.change"}),1,"scaleChange",e=>tt(It,e),(e,t)=>et(It,e,t)],[lt(),2,"dropNode"],[lt(),2,"dropDecorator"],[lt(),2,"addNodes"],[lt(),2,"addEdge"],[lt(),2,"manuallyConnectNodes"],[lt(),2,"updateCells"]],0,(e=>_t.has((0,xe.A)(e))),ze.ReactNextElement)),r()},5114:(e,t,a)=>{a.d(t,{a:()=>r});var n=a(8185);function r(e,t){var{cells:a,activeTarget:r}=t,i=a.find((e=>(0,n.c)(e,r)));if(i)switch(e.key||e.keyCode||e.which){case"Backspace":case 8:case"Delete":case 46:return e.preventDefault(),e.stopPropagation(),{action:"delete-cell",cell:i}}}},2098:(e,t,a)=>{a.d(t,{L:()=>c});var n=a(1030),r=a(3033),i=a(531),o=a(3783),l=a(908),s=a(6170),d=a(9127);function c(e){var{cells:t,layout:a,previousCells:c,defaultNodeSize:u,canvasWidth:h,canvasHeight:v,scaleRange:f,transform:g,reason:p,parent:w}=e,m="force"!==a&&"dagre"!==a,y=(0,o.C)(t,{defaultNodeSize:u}),k=[],C=!1,b=new Map,x=!1;for(var A of c)(0,i.mH)(A)?x=!0:(0,i.N)(A)&&(x=!0,A[r.CV]&&b.set(A.id,A));var N=new Map;for(var E of y)if((0,i.N)(E)){N.set(E.id,E);var z=b.get(E.id);z&&(E.view.width=z.view.width,E.view.height=z.view.height,E[r.CV]=!0)}var M=!1;if("add-related-nodes"===p&&w){var W=new Set;for(var R of y)(0,i.WW)(R)&&R.source===w&&R.target!==w&&W.add(R.target);var T=N.get(w);if(void 0!==(null==T?void 0:T.view.x)&&void 0!==T.view.y){M=!0;var S=[...W].map((e=>N.get(e))).filter(Boolean),L=void 0;for(var B of S)void 0!==B.view.x&&void 0!==B.view.y?(!L||B.view.x>L.view.x)&&B.view.y>T.view.y&&(L=B):k.push(B);if(k.length>0&&m){var D,P;if(L)D=L.view.x+L.view.width+r.sz,P=L.view.y;else{var H=k.reduce(((e,t)=>e+t.view.width+r.sz),-r.sz);D=T.view.x-H/2+T.view.width/2,P=T.view.y+T.view.height+r.sz}for(var j of k)j.view.x=D,j.view.y=P,D+=j.view.width+r.sz}}}if(!M){var O,I=u[0],U=u[1],_=0,V=!1;for(var Y of y)(0,i.N)(Y)?(Y.view.width>I&&(I=Y.view.width),Y.view.height>U&&(U=Y.view.height),void 0===Y.view.x||void 0===Y.view.y?k.push(Y):_++):(0,i.mH)(Y)&&(V=!0);if(m)for(var F of(x||(g=(0,l.r)((0,n.without)(y,...k),{canvasWidth:h,canvasHeight:v,scaleRange:f})),0===_||1===_&&!V?(({getNodeView:O}=(0,d.C)({cells:y})),C=!0):({getNodeView:O}=(0,s.k)({cells:y,fixedPosition:!0,center:[(h/2-g.x)/g.k,(v/2-g.y)/g.k]})),y))if((0,i.N)(F)){var X=O(F.id);F.view.x=X.x,F.view.y=X.y}}return{cells:y,updated:k,shouldReCenter:C}}},6330:(e,t,a)=>{function n(e,t,a,n,r,i,o){try{var l=e[i](o),s=l.value}catch(e){return void a(e)}l.done?t(s):Promise.resolve(s).then(n,r)}function r(e){return function(){var t=this,a=arguments;return new Promise((function(r,i){var o=e.apply(t,a);function l(e){n(o,r,i,l,s,"next",e)}function s(e){n(o,r,i,l,s,"throw",e)}l(void 0)}))}}a.d(t,{A:()=>r})}}]);
2
+ //# sourceMappingURL=eo-draw-canvas.3e6c3ab0.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"chunks/eo-draw-canvas.dc2cf3e4.js","mappings":"uLAYO,SAASA,EAAoBC,GAKO,IALN,iBACnCC,EAAgB,UAChBC,EAAS,UACTC,EAAS,UACTC,GAC0BJ,GACnBK,EAAeC,IAAoBC,EAAAA,EAAAA,UACxC,MA8CF,OA3CAC,EAAAA,EAAAA,YAAU,KACJP,GACFK,EAAiBL,EAAiBQ,KACpC,GACC,CAACR,KAEJO,EAAAA,EAAAA,YAAU,KACR,GAAIP,EAAkB,CACpB,IAAMS,EAAeC,IAEnBL,EAAiB,EACdK,EAAEC,QAAUV,EAAUW,EAAIZ,EAAiBa,OAAO,IAAMZ,EAAUa,GAClEJ,EAAEK,QAAUd,EAAUe,EAAIhB,EAAiBa,OAAO,IAAMZ,EAAUa,GACnE,EAEEG,EAAeP,IACnBA,EAAEQ,iBAAiB,EAEfC,EAAWT,IACfA,EAAEQ,kBAEFE,IACAjB,EAAUH,EAAkB,EACzBU,EAAEC,QAAUV,EAAUW,EAAIZ,EAAiBa,OAAO,IAAMZ,EAAUa,GAClEJ,EAAEK,QAAUd,EAAUe,EAAIhB,EAAiBa,OAAO,IAAMZ,EAAUa,GACnE,EAEEM,EAAQA,KACZC,SAASC,oBAAoB,YAAab,GAC1CY,SAASC,oBAAoB,YAAaL,EAAa,CACrDM,SAAS,IAEXF,SAASC,oBAAoB,QAASH,EAAS,CAAEI,SAAS,IAC1DlB,EAAiB,KAAK,EAMxB,OAJAgB,SAASG,iBAAiB,YAAaf,GACvCY,SAASG,iBAAiB,YAAaP,EAAa,CAAEM,SAAS,IAC/DF,SAASG,iBAAiB,QAASL,EAAS,CAAEI,SAAS,IAEhDH,CACT,IACC,CAACpB,EAAkBG,EAAWF,IAG/BwB,IAAAA,cAAA,QACEC,UAAWC,IAAW,eAAgB,CACpCC,aACI5B,GACFI,IAECA,EAAc,GAAKJ,EAAiBQ,KAAK,KAAO,GAC9CJ,EAAc,GAAKJ,EAAiBQ,KAAK,KAAO,EACjD,KAENqB,EACE7B,GAAoBI,EAAa,IAAA0B,OACzB9B,EAAiBQ,KAAKuB,KAAK,KAAI,KAAAD,OAAI1B,EAAc2B,KAAK,MAC1D,GAENC,KAAK,OACLC,OAAO,OACPC,YAAa,EACbhC,UAAS,QAAA4B,OAAU5B,EAAS,MAGlC,C,06BChBA,IA+DAiC,GA/DMC,IAAiBC,EAAAA,GAAAA,gBACrB,2BAGI,cAAEC,GAAa,SAAEC,GAAQ,OAAEC,GAAM,MAAEC,KAAUC,EAAAA,GAAAA,oBAuDtCC,GAAwBlB,KAAAA,WACnCmB,IAGFC,GAAA,IAAAC,QAAAC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAc,GAAA,IAAAd,QAAAe,GAAA,IAAAC,QAAAC,GAAA,IAAAjB,QAAAkB,GAAA,IAAAlB,QAAAmB,GAAA,IAAAnB,QAAAoB,GAAA,IAAApB,QAAAqB,GAAA,IAAArB,QAAAsB,GAAA,IAAAtB,QAAAuB,GAAA,IAAAvB,QAAAwB,GAAA,IAAAxB,QAAAyB,GAAA,IAAAzB,QAAA0B,GAAA,IAAA1B,QAAA2B,GAAA,IAAA3B,QAAA4B,GAAA,IAAA5B,QAAA6B,GAAA,IAAA7B,QAAA8B,GAAA,IAAA9B,QAAA+B,GAAA,IAAA/B,QAAAgC,GAAA,IAAAhC,QAAAiC,GAAA,IAAAjC,QAMA,MAAAkC,WAG2BC,GAAAA,iBAA8CC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,GAAAA,GAAA,KAAAvB,KACvEwB,EAAAA,GAAAA,GAAA,KAAAxC,IAAAyC,EAAA,MAAAC,EAAA,SAAAF,EAAAA,GAAAA,GAAA,KAAAtC,IAAAyC,EAAA,MAAAC,EAAA,SAAAJ,EAAAA,GAAAA,GAAA,KAAArC,IAAA0C,EAAA,MAAAC,EAAA,SAAAN,EAAAA,GAAAA,GAAA,KAAApC,IAAA2C,EAAA,MAAAC,EAAA,KAasC,CAACC,GAAAA,GAAmBA,GAAAA,QAAkBT,EAAAA,GAAAA,GAAA,KAAAnC,IAAA6C,EAAA,MAAAC,EAAA,SAK5EX,EAAAA,GAAAA,GAAA,KAAAlC,IAAA8C,EAAA,MAAAC,EAAA,SAWAb,EAAAA,GAAAA,GAAA,KAAAjC,IAAA+C,EAAA,MAAAC,EAAA,SAQAf,EAAAA,GAAAA,GAAA,KAAAhC,IAAAgD,EAAA,MAAAC,EAAA,SAAAjB,EAAAA,GAAAA,GAAA,KAAA/B,IAAAiD,EAAA,MAAAC,EAAA,SAeAnB,EAAAA,GAAAA,GAAA,KAAA9B,IAAAkD,EAAA,MAAAC,EAAA,SAAArB,EAAAA,GAAAA,GAAA,KAAA7B,IAAAmD,EAAA,MAAAC,EAAA,MAOyC,MAAIvB,EAAAA,GAAAA,GAAA,KAAA5B,IAAAoD,EAAA,MAAAC,EAAA,MAGF,MAAIzB,EAAAA,GAAAA,GAAA,KAAA3B,IAAAqD,EAAA,MAAAC,EAAA,MAGN,MAAI3B,EAAAA,GAAAA,GAAA,KAAA1B,IAAAsD,EAAA,MAAAC,EAAA,SAAA7B,EAAAA,GAAAA,GAAA,KAAAzB,IAAAuD,EAAA,MAAAC,EAAA,SAAA/B,EAAAA,GAAAA,GAAA,KAAAtB,IAAAsD,EAAA,MAQhBC,IAC3BC,GAAA1D,GAAA2D,KAAIC,GAA0BC,KAAKJ,EAAO,KAC3CjC,EAAAA,GAAAA,GAAA,KAAArB,IAE4BsD,KACtBK,EAAAA,GAAAA,GAAWL,EAAQE,KAAKI,gBAC3BJ,KAAKI,aAAeN,EACtB,KAGFjC,EAAAA,GAAAA,GAAA,KAAApB,GAAA4D,EAAA,QAAAxC,EAAAA,GAAAA,GAAA,KAAAnB,IAAA4D,EAAA,MAAAC,EAAA,SAAA1C,EAAAA,GAAAA,GAAA,KAAAlB,IAAA6D,EAAA,MASmBC,IACjBV,GAAA1D,GAAA2D,KAAIU,GAAgBR,KAAKO,GACP,SAAdA,EAAKE,MACPZ,GAAA1D,GAAA2D,KAAIY,GAAgBV,KAAKO,EAC3B,KACD5C,EAAAA,GAAAA,GAAA,KAAAjB,GAAAiE,EAAA,QAAAhD,EAAAA,GAAAA,GAAA,KAAAhB,IAAAiE,EAAA,MAKoBL,IACnBV,GAAA1D,GAAA2D,KAAIe,GAAkBb,KAAKO,EAAK,KAGlC5C,EAAAA,GAAAA,GAAA,KAAAf,GAAAkE,EAAA,QAAAnD,EAAAA,GAAAA,GAAA,KAAAd,IAAAkE,EAAA,MAAAC,EAAA,SAAArD,EAAAA,GAAAA,GAAA,KAAAb,IAAAmE,GAAA,MASqBC,IACnBrB,GAAA1D,GAAA2D,KAAIqB,IAAanB,KAAKkB,GACJ,SAAdA,EAAKT,MACPZ,GAAA1D,GAAA2D,KAAIsB,GAAapB,KAAKkB,EACxB,KACDvD,EAAAA,GAAAA,GAAA,KAAAZ,GAAAsE,GAAA,QAAA1D,EAAAA,GAAAA,GAAA,KAAAX,IAAAsE,GAAA,MAKyBC,IACxB1B,GAAA1D,GAAA2D,KAAI0B,IAAkBxB,KAAKuB,EAAO,KACnC5D,EAAAA,GAAAA,GAAA,KAAAV,GAAAwE,GAAA,QAAA9D,EAAAA,GAAAA,GAAA,KAAAT,IAAAwE,GAAA,MAK6BH,IAC5B1B,GAAA1D,GAAA2D,KAAI6B,IAAsB3B,KAAKuB,EAAO,KAGxC5D,EAAAA,GAAAA,GAAA,KAAAR,GAAAyE,GAAA,QAAAjE,EAAAA,GAAAA,GAAA,KAAAP,IAAAyE,GAAA,MAMsBC,IACpBjC,GAAA1D,GAAA2D,KAAIiC,IAAc/B,KAAK8B,EAAM,KAC9BnE,EAAAA,GAAAA,GAAA,KAAAN,IA8IY2E,EAAAA,GAAAA,aAA0B,UA1R9BC,GAAK,OAAAC,GAAA/G,GAAA,eAAL8G,CAAKE,GAAAC,GAAAjH,GAAA,KAAAgH,EAAA,WAGLE,GAAM,OAAAH,GAAA7G,GAAA,gBAANgH,CAAMF,GAAAC,GAAA/G,GAAA,KAAA8G,EAAA,kBAGNG,GAAa,OAAAJ,GAAA5G,GAAA,uBAAbgH,CAAaH,GAAAC,GAAA9G,GAAA,KAAA6G,EAAA,oBAGbI,GAAe,OAAAL,GAAA3G,GAAA,yBAAfgH,CAAeJ,GAAAC,GAAA7G,GAAA,KAAA4G,EAAA,sBAGfK,GAAiB,OAAAN,GAAA1G,GAAA,2BAAjBgH,CAAiBL,GAAAC,GAAA5G,GAAA,KAAA2G,EAAA,sBAQjBM,GAAiB,OAAAP,GAAAzG,GAAA,2BAAjBgH,CAAiBN,GAAAC,GAAA3G,GAAA,KAAA0G,EAAA,sBAWjBO,GAAiB,OAAAR,GAAAxG,GAAA,2BAAjBgH,CAAiBP,GAAAC,GAAA1G,GAAA,KAAAyG,EAAA,qBAYjBQ,GAAgB,OAAAT,GAAAvG,GAAA,0BAAhBgH,CAAgBR,GAAAC,GAAAzG,GAAA,KAAAwG,EAAA,iBAGhBjC,GAAY,OAAAgC,GAAAtG,GAAA,sBAAZsE,CAAYiC,GAAAC,GAAAxG,GAAA,KAAAuG,EAAA,uBAMZS,GAAkB,OAAAV,GAAArG,GAAA,4BAAlB+G,CAAkBT,GAAAC,GAAAvG,GAAA,KAAAsG,EAAA,aAGlBU,GAAQ,OAAAX,GAAApG,GAAA,kBAAR+G,CAAQV,GAAAC,GAAAtG,GAAA,KAAAqG,EAAA,eAGRW,GAAU,OAAAZ,GAAAnG,GAAA,oBAAV+G,CAAUX,GAAAC,GAAArG,GAAA,KAAAoG,EAAA,aAGVY,GAAQ,OAAAb,GAAAlG,GAAA,kBAAR+G,CAAQZ,GAAAC,GAAApG,GAAA,KAAAmG,EAAA,eAGRa,GAAU,OAAAd,GAAAjG,GAAA,oBAAV+G,CAAUb,GAAAC,GAAAnG,GAAA,KAAAkG,EAAA,CA+Ebc,QAAAA,CAAQ5K,GAM6B,IAAA6K,EAAA,YAAAC,EAAAA,GAAAA,IAAA,gBAAAC,EAAAC,GAN5B,GACbC,EAAE,SACFC,EAAQ,KACRC,EAAI,KACJC,EAAI,SACJC,GACarL,EAKb,GAFoB,QADD+K,GAAGC,EAAA1J,UACnBgK,yBAAiB,IAAAP,GAA4B,QAA5BA,EADEA,EAAAQ,KAAAP,EACCE,EAAS,GAAIA,EAAS,WAAG,IAAAH,OAAA,EAD1BA,EAElBS,SAASX,GACM,KAAAY,EAAAC,EAAAC,EACXC,EAAqBf,EAAKgB,wBAC1B3L,EAAY2J,GAAA7E,GAAA6F,GAAgBiB,QAASC,eACrCC,EAAU,CACd5D,KAAM,OACN6C,KACAgB,MAAIC,EAAAA,GAAAA,IAAAA,EAAAA,GAAAA,GAAA,GACkB,UAAhBrB,EAAKb,QAAsC,UAAhBa,EAAKb,OAChC,KACA,CACEnJ,GACGqK,EAAS,GAAKU,EAAmBO,KAAOjM,EAAUW,GACnDX,EAAUa,EACZE,GACGiK,EAAS,GAAKU,EAAmBQ,IAAMlM,EAAUe,GAClDf,EAAUa,IACb,IACLsL,MAAgB,QAAXZ,EAAEN,aAAI,EAAJA,EAAO,UAAE,IAAAM,EAAAA,EAAIZ,EAAKX,gBAAgB,GACzCoC,OAAiB,QAAXZ,EAAEP,aAAI,EAAJA,EAAO,UAAE,IAAAO,EAAAA,EAAIb,EAAKX,gBAAgB,KAE5CkB,OACAC,YAGF,OADuB,QAAvBM,EAAA9B,GAAA7E,GAAA6F,GAAgBiB,eAAO,IAAAH,GAAvBA,EAAyBf,SAASoB,GAC3BA,CACT,CACA,OAAO,IAAK,GA/B6BlB,EAgC3C,CAGMyB,aAAAA,CAAaC,GAIkC,IAAAC,EAAA,YAAA3B,EAAAA,GAAAA,IAAA,gBAAA4B,EAAAC,GAJjC,SAClBzB,EAAQ,UACR0B,EAAS,KACTC,GACkBL,EAKlB,GAFoB,QADDE,GAAGC,EAAArL,UACnBgK,yBAAiB,IAAAoB,GAA4B,QAA5BA,EADEA,EAAAnB,KAAAoB,EACCzB,EAAS,GAAIA,EAAS,WAAG,IAAAwB,OAAA,EAD1BA,EAElBlB,SAASiB,GACM,KAAAK,EACXlB,EAAqBa,EAAKZ,wBAC1B3L,EAAY2J,GAAA7E,GAAAyH,GAAgBX,QAASC,eACrCgB,EAA8B,CAClC3E,KAAM,YACNwE,YACA3B,GAohBC,uCAAuC+B,QAAQ,SAAS,SAAUC,GACvE,IAAMC,EAAqB,GAAhBC,KAAKC,SAAiB,EAEjC,OADW,KAALH,EAAWC,EAAS,EAAJA,EAAW,GACxBG,SAAS,GACpB,IAvhBMpB,KAAM,CACJpL,GACGqK,EAAS,GAAKU,EAAmBO,KAAOjM,EAAUW,GAAKX,EAAUa,EACpEE,GAAIiK,EAAS,GAAKU,EAAmBQ,IAAMlM,EAAUe,GAAKf,EAAUa,EACpEsL,MAAOiB,GAAAA,GACPhB,OAAQiB,GAAAA,GACRV,SAIJ,OADuB,QAAvBC,EAAAjD,GAAA7E,GAAAyH,GAAgBX,eAAO,IAAAgB,GAAvBA,EAAyBP,cAAcQ,GAChCA,CACT,CACA,OAAO,IAAK,GAxBuCjC,EAyBrD,CAGM0C,QAAAA,CAASC,GAA2C,IAAAC,EAAA,YAAA5C,EAAAA,GAAAA,IAAA,YACxD,GAAqB,IAAjB2C,EAAME,OACR,MAAO,GAET,IAAMC,EAAWH,EAAMI,KAAcC,IAAA,IAAAC,EAAAC,GAAC,KAAE7C,EAAI,SAAEE,EAAQ,GAAEJ,EAAE,KAAEG,GAAM0C,EAAA,MAAM,CACtE1F,KAAM,OACN6C,KACAG,OACAa,KAAM,CACJI,MAAgB,QAAX0B,EAAE5C,aAAI,EAAJA,EAAO,UAAE,IAAA4C,EAAAA,EAAIL,EAAKxD,gBAAgB,GACzCoC,OAAiB,QAAX0B,EAAE7C,aAAI,EAAJA,EAAO,UAAE,IAAA6C,EAAAA,EAAIN,EAAKxD,gBAAgB,IAE5CmB,WACD,IACD,OAAOxB,GAAA7E,GAAA0I,GAAgB5B,QAAS0B,SAASI,EAAU,CACjD1D,gBAAiBwD,EAAKxD,gBACtB+D,YAAaP,EAAKQ,YAClBC,aAAcT,EAAKU,cAClB,GAlBqDtD,EAmB1D,CAGMuD,OAAAA,CAAOC,GAA2D,IAAAC,EAAA,YAAAzD,EAAAA,GAAAA,IAAA,gBAAA0D,GAA1D,OAAEC,EAAM,OAAElH,EAAM,KAAE6D,GAAmBkD,EAC3CI,EAAoB,CACxBtG,KAAM,OACNqG,SACAlH,SACA6D,QAGF,OADuB,QAAvBoD,EAAA3E,GAAA7E,GAAAuJ,GAAgBzC,eAAO,IAAA0C,GAAvBA,EAAyBH,QAAQK,GAC1BA,CAAQ,GARuD5D,EASxE,CAGA6D,oBAAAA,CAAqBF,GACnB,OAAO5E,GAAA7E,GAAAyC,MAAgBqE,QAAS6C,qBAAqBF,EACvD,CAGMG,WAAAA,CACJhF,EACAiF,GAC8B,IAAAC,EAAA,YAAAhE,EAAAA,GAAAA,IAAA,kBAC9BiE,GAAAjL,GAAMgL,EAAIE,IAAAzD,KAAJuD,GACN,IAAM,QAAEG,GAAYpF,GAAA7E,GAAA8J,GAAgBhD,QAAS8C,YAAYhF,GAAKsC,EAAAA,GAAAA,IAAAA,EAAAA,GAAAA,GAAA,GACzD2C,GAAG,IACN3E,gBAAiB4E,EAAK5E,gBACtB+D,YAAaa,EAAKZ,YAClBC,aAAcW,EAAKV,gBAErB,MAAO,CAAEa,UAAU,GARWnE,EAShC,CAiBAoE,oBAAAA,GACEC,MAAMD,uBACN7M,GAAeoF,MAAM,EACvB,CAEA2H,MAAAA,GACE,OACE1N,KAAAA,cAACkB,GAAqB,CACpByM,KAAM5H,KACN6H,IAAGzF,GAAA7E,GAAEyC,MACLuC,OAAQvC,KAAKuC,OACbC,cAAexC,KAAKwC,cACpBL,MAAOnC,KAAKmC,MACZM,gBAAiBzC,KAAKyC,gBACtBC,kBAAmB1C,KAAK0C,kBACxBG,iBAAkB7C,KAAK6C,iBACvBF,kBAAmB3C,KAAK2C,kBACxBC,kBAAmB5C,KAAK4C,kBACxBxC,aAAcJ,KAAKI,aACnB0C,mBAAoB9C,KAAK8C,mBACzBC,SAAU/C,KAAK+C,SACfC,WAAYhD,KAAKgD,WACjBC,SAAUjD,KAAKiD,SACfC,WAAYlD,KAAKkD,WACjB4E,qBAAoB1F,GAAA7F,GAAEyD,MACtB+H,qBAAoB3F,GAAA5F,GAAEwD,MACtBgI,WAAU5F,GAAAzF,GAAEqD,MACZiI,aAAY7F,GAAAvF,GAAEmD,MACdkI,aAAY9F,GAAApF,GAAEgD,MACdmI,kBAAiB/F,GAAAlF,GAAE8C,MACnBoI,sBAAqBhG,GAAAhF,GAAE4C,MACvBqI,cAAajG,GAAA9E,GAAE0C,OAGrB,EACD,SAAAuH,KAjDG,OAAO,IAAIe,SAAeC,IACxB,IAAMC,EAAQA,KACRpG,GAAA7E,GAAAyC,MAAgBqE,QAClBkE,IAEAE,WAAWD,EAAO,GACpB,EAEFA,GAAO,GAEX,CAyEF,SAASpN,GAA2BsN,EA0BlCb,GACA,IA1BA,KACED,EAAI,OACJrF,EAAM,cACNC,EACAL,MAAOwG,EAAY,gBACnBlG,EAAe,kBACfC,EAAiB,iBACjBG,EAAgB,kBAChBF,EAAiB,kBACjBC,EACAxC,aAAcwI,EAAa,mBAC3B9F,EAAkB,SAClBC,EAAQ,WACRC,EAAU,SACVC,EACAC,WAAY2F,EAAW,qBACvBf,EAAoB,qBACpBC,EAAoB,WACpBC,EAAU,aACVC,EAAY,aACZC,EAAY,kBACZC,EAAiB,sBACjBC,EAAqB,cACrBC,GAC2BK,IAGtB,MAAEvG,GAAS2G,IAAYC,EAAAA,GAAAA,YAC5BC,GAAAA,EACAL,GACCA,IAAY,CACXxG,OAAO8G,EAAAA,GAAAA,GAAgBN,EAAc,CAAElG,wBAMrCyG,GAAWC,EAAAA,GAAAA,UACf,IACEhH,EAAMiH,OAAOC,GAAAA,GAAYnD,SACxBvD,QAAAA,EAAqB2G,GAAAA,KACxB,CAACnH,EAAOQ,IAGJ4G,GAAUC,EAAAA,GAAAA,QAAsB,MAChCC,GAAWD,EAAAA,GAAAA,QAAoB,MAC/BE,GAA2BF,EAAAA,GAAAA,QAC/B,OAEKG,EAAcC,IAAmB9Q,EAAAA,GAAAA,UAAmB,KACrD,SAAE+Q,EAAQ,UAAEpR,EAAS,OAAEqR,EAAM,WAAE5G,IAAe6G,EAAAA,GAAAA,GAAQ,CAC1DR,UACAxG,WACAC,aACAC,WACAC,WAAY2F,EACZd,0BAGFhP,EAAAA,GAAAA,YAAU,KACRsP,EAAc5P,EAAUa,EAAE,GACzB,CAAC+O,EAAe5P,EAAUa,IAE7B,IAAOd,EAAkBwR,IACvBlR,EAAAA,GAAAA,UAAkC,OAE9B,SAAEmR,EAAQ,YAAEC,IAAgBC,EAAAA,GAAAA,GAAU,CAC1C5H,SACAC,gBACA+G,UACApH,QACAY,WACA+G,SACA5G,aACA4F,cAGFsB,EAAAA,GAAAA,qBACEvC,GACA,KAAM,CACJ1E,QAAAA,CAASkH,GAEPH,GAAY,GACZpB,EAAS,CAAEnI,KAAM,YAAa2J,QAASD,GACzC,EACAvF,aAAAA,CAAcK,GAEZ+E,GAAY,GACZpB,EAAS,CAAEnI,KAAM,iBAAkB2J,QAASnF,GAC9C,EACAY,QAAAA,CACEC,EAAKuE,GAEL,IADA,gBAAE9H,EAAe,YAAE+D,EAAW,aAAEE,GAA+B6D,EAEzDC,EACJrI,EAAMsI,eACHrJ,KAAyB,cAAdA,EAAKT,MAA2C,SAAnBS,EAAK+D,aAC5C,EACAuF,EAAW,IACZvI,EAAMwI,MAAM,EAAGH,MACfxE,KACA7D,EAAMwI,MAAMH,KAGfrI,MAAOyI,EAAQ,QACfpD,EAAO,eACPqD,IACE1D,EAAAA,GAAAA,GAAY,CACdhF,MAAOuI,EACPnI,SACAuI,cAAe3I,EACfM,kBACA+D,cACAE,eACAxD,aACAzK,cAMF,OAJIoS,GACFX,GAAY,GAEdpB,EAAS,CAAEnI,KAAM,eAAgB2J,QAASM,IACnCpD,EAAQ4B,QAAQiB,GACrBrE,EAAMjC,SAASsG,IAEnB,EACAzD,OAAAA,CAAQmE,GACNjC,EAAS,CAAEnI,KAAM,WAAY2J,QAASS,GACxC,EACA5D,WAAAA,CAAYuD,EAAUtD,GACpB,IAAA4D,GAAsC7D,EAAAA,GAAAA,IAAW1C,EAAAA,GAAAA,IAAAA,EAAAA,GAAAA,GAAC,CAAC,EAC9C2C,GAAG,IACN7E,SACAuI,cAAe3I,EACfA,MAAOuI,EACPxH,aACAzK,gBANI,eAAEoS,GAA2BG,EAARC,GAAMC,EAAAA,GAAAA,GAAAF,EAAAG,IAYjC,OAJIN,GACFX,GAAY,GAEdpB,EAAS,CAAEnI,KAAM,eAAgB2J,QAASW,EAAO9I,QAC1C8I,CACT,EACA3G,aAAYA,IACH7L,EAETyO,oBAAAA,CAAqBkE,GACnB,IAAMpE,EAAS7E,EAAMkJ,MAClBjK,IAASiI,EAAAA,GAAAA,GAAWjI,IAASA,EAAKoC,KAAO4H,IAE5C,GAAIpE,EAAQ,CACV,IAAMsE,EAAO/B,EAAQlF,QAASD,wBAY9B,OAXA4F,EAAoB,CAClBhD,SACAhO,KAAM,CACJgO,EAAOxC,KAAKpL,EAAI4N,EAAOxC,KAAKI,MAAQ,EACpCoC,EAAOxC,KAAKhL,EAAIwN,EAAOxC,KAAKK,OAAS,GAEvCxL,OAAQ,CAACiS,EAAK5G,KAAM4G,EAAK3G,OAEX,IAAI2D,SAA4B,CAACC,EAASgD,KACxD7B,EAAyBrF,QAAU,CAAEkE,UAASgD,SAAQ,GAG1D,CACA,OAAOjD,QAAQiD,OAAO,KACxB,KAEF,CAACpJ,EAAOI,EAAQW,EAAYgH,EAAazR,IAG3C,IAAM+S,GAAgBC,EAAAA,GAAAA,cACpB,CAACC,EAAyBC,KAGxB,IAH8C,IAAAC,EAGrCC,EAAI,EAAGA,EAAI1J,EAAM+D,OAAQ2F,IAAK,CACrC,IAAMzK,EAAOe,EAAM0J,GAEnB,IAAIxC,EAAAA,GAAAA,GAAWjI,IAASA,EAAKoC,KAAOkI,EAAM1E,OAAOxD,IAE7CpC,EAAKoD,KAAKpL,EAAIuS,EAAG,IACjBvK,EAAKoD,KAAKpL,EAAIgI,EAAKoD,KAAKI,MAAQ+G,EAAG,IACnCvK,EAAKoD,KAAKhL,EAAImS,EAAG,IACjBvK,EAAKoD,KAAKhL,EAAI4H,EAAKoD,KAAKK,OAAS8G,EAAG,GACpC,KAAAG,EACgC,QAAhCA,EAAApC,EAAyBrF,eAAO,IAAAyH,GAAhCA,EAAkCvD,QAAQ,CACxCvB,OAAQ0E,EAAM1E,OACdlH,OAAQsB,IAEV,KACF,CAEJ,CACgC,QAAhCwK,EAAAlC,EAAyBrF,eAAO,IAAAuH,GAAhCA,EAAkCL,OAAO,MACzCvB,EAAoB,KAAK,GAE3B,CAAC7H,KAGHpJ,EAAAA,GAAAA,YAAU,KACR6B,GAAegN,IAAQpP,EAAiB,GACvC,CAACA,EAAkBoP,IAEtB,IAAMxH,GAAe2L,EAAAA,GAAAA,GAAgB,CACnCtC,WACArJ,aAAcwI,EACdd,0BAGKkE,EAAgBC,IAAqBnT,EAAAA,GAAAA,UAAiB,KAC7DC,EAAAA,GAAAA,YAAU,KACR,IAAMmT,EAAgBpJ,GAClBqJ,EAAAA,GAAAA,GAAkBhK,EAAO3J,EAAkB4H,GAC3C,GAEJ6L,GAAmBG,GACD,IAAhBA,EAAKlG,QAAyC,IAAzBgG,EAAchG,OAAekG,EAAOF,GAC1D,GACA,CAAC9L,EAAc+B,EAAO3J,EAAkBsK,KAE3C/J,EAAAA,GAAAA,YAAU,KACR,IAAMsT,EAAO9C,EAAQlF,QACrB,GAAKgI,KAAQ1C,EAAazD,OAAS,GAAnC,CAGA,IAAMoG,EAAarR,IACjB,IAAMsR,GAASC,EAAAA,GAAAA,GAAevR,EAAO,CACnCkH,QACA/B,iBAGqB,iBAAnBmM,aAAM,EAANA,EAAQA,SACVrE,EAAaqE,EAAOnL,KACtB,EAGF,OADAiL,EAAKrS,iBAAiB,UAAWsS,GAC1B,KACLD,EAAKvS,oBAAoB,UAAWwS,EAAU,CAbhD,CAcC,GACA,CAAClM,EAAc+B,EAAOwH,EAAazD,OAAQgC,IAE9C,IAAMuE,GAAYtD,EAAAA,GAAAA,UAAQ,IAAM,GAAN7O,QAASoS,EAAAA,GAAAA,UAAS,YAAW,MAAK,IACtDC,EAAe,GAAHrS,OAAMmS,EAAS,eAE3BG,GAAmBnB,EAAAA,GAAAA,cAAahL,IACpCqI,EAAS,CAAEnI,KAAM,YAAa2J,QAAS7J,GAAO,GAC7C,IAEGoM,GAAkBpB,EAAAA,GAAAA,cACrBhL,IACCqI,EAAS,CAAEnI,KAAM,YAAa2J,QAAS7J,IACvCuH,EAAWvH,EAAK,GAElB,CAACuH,IAGG8E,GAAqBrB,EAAAA,GAAAA,cAAahL,IACtCqI,EAAS,CAAEnI,KAAM,cAAe2J,QAAS7J,GAAO,GAC/C,IAEGsM,GAAoBtB,EAAAA,GAAAA,cACvBhL,IACCqI,EAAS,CAAEnI,KAAM,cAAe2J,QAAS7J,IACzCwH,EAAaxH,EAAK,GAEpB,CAACwH,IAGG+E,GAA6BvB,EAAAA,GAAAA,cACjCwB,IAAuD,IAAtD,GAAEzJ,EAAE,QAAE0J,GAA2CD,EAE9CrD,EADEsD,EACeC,GACfA,EAAMpJ,SAASP,GAAM2J,EAAQ,IAAIA,EAAO3J,GAGzB2J,GAAUA,EAAM/D,QAAQhE,GAASA,IAAS5B,IAC7D,GAEF,IAGI4J,GAAwB3B,EAAAA,GAAAA,cAC5B,CAACjI,EAAYE,KACXoF,EAAS,CAAEnI,KAAM,mBAAoB2J,QAAS,CAAE9G,KAAIE,SAAS,GAE/D,IAGI2J,GAAkB5B,EAAAA,GAAAA,cACrB6B,IAGGxD,EAAOyD,SAAQC,EAAAA,GAAAA,GAAOjE,EAAQlF,SAAWiJ,EAAQ,IACnD,GAEF,CAACxD,IAGG2D,IAAWhC,EAAAA,GAAAA,cAAY,KAC3BvB,GAAY,EAAM,GACjB,CAACA,KACGwD,GAAaC,KAAWC,EAAAA,GAAAA,GAAe,CAC5CzL,QACAU,mBACA8J,iBAGIkB,IAAQC,EAAAA,GAAAA,GAAS,CAAE3L,QAAOI,SAAQ0H,aAExC,OACEhQ,KAAAA,cAAAA,KAAAA,SAAA,KACEA,KAAAA,cAAA,OACE2K,MAAM,OACNC,OAAO,OACPgD,IAAK0B,EACLrP,UAAWC,KAAW,OAAQ,CAAE0P,WAAU5G,WAAU4K,WACpDE,UAAW,GAEX9T,KAAAA,cAAA,YACG0T,GAAQvH,KAAI,CAAC4H,EAAQxD,IACpBvQ,KAAAA,cAACgU,GAAAA,EAAe,CACdC,IAAK1D,EACLhH,GAAE,GAAAlJ,OAAKqS,GAAYrS,OAAGkQ,GACtB7J,KAAK,QACLwN,YAAaH,EAAOG,iBAI1BlU,KAAAA,cAAA,KACExB,UAAS,aAAA6B,OAAe7B,EAAUW,EAAC,KAAAkB,OAAI7B,EAAUe,EAAC,YAAAc,OAAW7B,EAAUa,EAAC,MAExEW,KAAAA,cAAA,KAAGC,UAAU,QAAQ2N,IAAK4B,GACvBtH,EAAMiE,KAAKhF,GACVnH,KAAAA,cAACmU,GAAAA,EAAa,CACZF,IAAG,GAAA5T,OAAK8G,EAAKT,KAAI,KAAArG,OAAkB,SAAd8G,EAAKT,KAAkB,GAAHrG,OAAM8G,EAAK4F,OAAM,KAAA1M,OAAI8G,EAAKtB,QAAWsB,EAAKoC,IACnFjB,OAAQA,EACRnB,KAAMA,EACNe,MAAOA,EACP+G,SAAUA,EACVtG,kBAAmBA,EACnBF,kBAAmBA,EACnBjK,UAAWA,EACXiV,YAAaA,GACbW,QAAQlO,EAAAA,GAAAA,GAAWC,EAAcgB,GACjC4K,eAAgBA,EAChBsC,aAAc1B,EACd2B,YAAa1B,EACb2B,eAAgB1B,EAChB2B,cAAe1B,EACfhF,qBAAsBA,EACtBI,kBAAmBA,EACnBC,sBAAuBA,EACvBsG,uBAAwB1B,EACxB2B,kBAAmBvB,OAIzBnT,KAAAA,cAAC3B,GAAAA,EAAoB,CACnBE,iBAAkBA,EAClBC,UAAWA,EACXC,UAAS,GAAA4B,OAAKqS,EAAY,KAC1BhU,UAAW6S,MAIjBvR,KAAAA,cAAC2U,GAAAA,EAAgB,CACfC,WAAYjH,EAAKiH,WACjB7M,MAAOvJ,EAAUa,EACjB4J,WAAYA,EACZ4L,aAAczB,EACd0B,WAAYtB,KAIpB,CAzZCuB,GAAAxR,KAvCEtE,GAAA6E,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAE,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAK,EAAAgP,EAAApP,EAAAQ,EAAAO,EAAAsO,EAAA5O,EAAAC,EAAAG,EAAAyO,EAAA3O,EAAAK,EAAAE,EAAAqO,EAAAtO,EAAAE,EAAAM,EAAA+N,EAAApO,EAAAC,EAAAG,GAAAiO,GAAAnO,GAAAI,GAAAG,GAAA6N,GAAA/N,GAAAG,GAAAE,GAAA2N,GAAA5N,GAAAE,GAAAG,GAAAwN,GAAA1N,GAAAjE,GAAA0H,GAAA7K,GAAA+U,I,6qFA1BQ,E,uBA0BRC,CAAAX,GAAA,CAhSFlU,GAAc,iBAAkB,CAC/B8U,WAAY,CAACC,GAAAA,EAAWC,GAAAA,MACxB,EAKC/U,GAAS,CAAEgV,WAAW,IAAQ,YAG9BhV,GAAS,CAAE4F,KAAMqP,SAAS,aAG1BjV,GAAS,CAAEgV,WAAW,IAAQ,oBAG9BhV,GAAS,CAAEgV,WAAW,IAAQ,sBAG9BhV,GAAS,CAAEgV,WAAW,IAAQ,wBAQ9BhV,GAAS,CAAE4F,KAAMsP,SAAS,wBAW1BlV,GAAS,CAAEgV,WAAW,IAAQ,wBAY9BhV,GAAS,CAAEgV,WAAW,IAAQ,uBAG9BhV,GAAS,CAAEgV,WAAW,IAAQ,mBAM9BhV,GAAS,CAAE4F,KAAMuP,UAAU,yBAG3BnV,GAAS,CAAE4F,KAAMuP,UAAU,eAG3BnV,GAAS,CAAE4F,KAAMuP,UAAU,iBAG3BnV,GAAS,CAAE4F,KAAMuP,UAAU,eAG3BnV,GAAS,CAAEgV,WAAW,IAAQ,iBAG9B9U,GAAM,CAAE0F,KAAM,wBAAwB,4BAAAwP,GAAA/N,GAAAhG,GAAA+T,GAAA,CAAAA,EAAA9N,IAAAC,GAAAlG,GAAA+T,EAAA9N,IAAA,CAgBtCpH,GAAM,CAAE0F,KAAM,cAAc,kBAAAwP,GAAA/N,GAAA3F,GAAA0T,GAAA,CAAAA,EAAA9N,IAAAC,GAAA7F,GAAA0T,EAAA9N,IAAA,CAG5BpH,GAAM,CAAE0F,KAAM,cAAc,kBAAAwP,GAAA/N,GAAA1F,GAAAyT,GAAA,CAAAA,EAAA9N,IAAAC,GAAA5F,GAAAyT,EAAA9N,IAAA,CAU5BpH,GAAM,CAAE0F,KAAM,gBAAgB,oBAAAwP,GAAA/N,GAAAxF,GAAAuT,GAAA,CAAAA,EAAA9N,IAAAC,GAAA1F,GAAAuT,EAAA9N,IAAA,CAU9BpH,GAAM,CAAE0F,KAAM,gBAAgB,eAAAwP,GAAA/N,GAAAtF,GAAAqT,GAAA,CAAAA,EAAA9N,IAAAC,GAAAxF,GAAAqT,EAAA9N,IAAA,CAG9BpH,GAAM,CAAE0F,KAAM,gBAAgB,eAAAwP,GAAA/N,GAAArF,GAAAoT,GAAA,CAAAA,EAAA9N,IAAAC,GAAAvF,GAAAoT,EAAA9N,IAAA,CAU9BpH,GAAM,CAAE0F,KAAM,qBAAqB,oBAAAwP,GAAA/N,GAAAnF,GAAAkT,GAAA,CAAAA,EAAA9N,IAAAC,GAAArF,GAAAkT,EAAA9N,IAAA,CAOnCpH,GAAM,CAAE0F,KAAM,0BAA0B,wBAAAwP,GAAA/N,GAAAjF,GAAAgT,GAAA,CAAAA,EAAA9N,IAAAC,GAAAnF,GAAAgT,EAAA9N,IAAA,CAUxCpH,GAAM,CAAE0F,KAAM,iBAAiB,gBAAAwP,GAAA/N,GAAA/E,GAAA8S,GAAA,CAAAA,EAAA9N,IAAAC,GAAAjF,GAAA8S,EAAA9N,IAAA,CAO/BrH,KAAQ,eAyCRA,KAAQ,oBAgCRA,KAAQ,eAsBRA,KAAQ,cAYRA,KAAQ,2BAKRA,KAAQ,qBAAAoV,GAAA7S,GAAA8S,KAAAC,EAAAA,GAAAA,GAAAF,KAnQgB3S,GAAAA,mBAAgBiS,G,gDCrIpC,SAASlD,EACdvR,EAAoB1C,GAQQ,IAP5B,MACE4J,EAAK,aACL/B,GAID7H,EAEKgY,EAAapO,EAAMkJ,MAAMjK,IAASjB,EAAAA,EAAAA,GAAWiB,EAAMhB,KAEzD,GAAKmQ,EASL,OAJEtV,EAAMiT,KACoCjT,EAAMuV,SACNvV,EAAMwV,OAGhD,IAAK,YACL,KAAK,EACL,IAAK,SACL,KAAK,GAGH,OAFAxV,EAAMyV,iBACNzV,EAAMvB,kBACC,CACL6S,OAAQ,cACRnL,KAAMmP,GAId,C,0GCvBO,SAASpJ,EAAW5O,GA0BzB,IA1B0B,MAC1B4J,EAAK,OACLI,EAAM,cACNuI,EAAa,gBACbrI,EAAe,YACf+D,EAAW,aACXE,EAAY,WACZxD,EAAU,UACVzK,EAAS,OACTkY,EAAM,OACNC,GAYDrY,EAKOsY,EAA4B,UAAXtO,GAAiC,UAAXA,EACvCmI,GAAWzB,EAAAA,EAAAA,GAAgB9G,EAAO,CAAEM,oBACpCqO,EAA+B,GACjCjG,GAAiB,EAEfkG,EAA+B,IAAIC,IACrCC,GAAyB,EAC7B,IAAK,IAAM7P,KAAQ0J,GACboG,EAAAA,EAAAA,IAAgB9P,GAClB6P,GAAyB,GAChB5H,EAAAA,EAAAA,GAAWjI,KACpB6P,GAAyB,EACrB7P,EAAK+P,EAAAA,KACPJ,EAA6BK,IAAIhQ,EAAKoC,GAAIpC,IAKhD,IAAMiQ,EAAW,IAAIL,IACrB,IAAK,IAAM5P,KAAQsJ,EACjB,IAAIrB,EAAAA,EAAAA,GAAWjI,GAAO,CACpBiQ,EAASD,IAAIhQ,EAAKoC,GAAIpC,GACtB,IAAMkQ,EAAeP,EAA6BQ,IAAInQ,EAAKoC,IACvD8N,IACFlQ,EAAKoD,KAAKI,MAAQ0M,EAAa9M,KAAKI,MACpCxD,EAAKoD,KAAKK,OAASyM,EAAa9M,KAAKK,OACrCzD,EAAK+P,EAAAA,KAA+B,EAExC,CAGF,IAAIK,GAAU,EAEd,GAAe,sBAAXb,GAAkCC,EAAQ,CAG5C,IAAMa,EAAoB,IAAIC,IAC9B,IAAK,IAAMtQ,KAAQsJ,GAEfiH,EAAAA,EAAAA,IAAWvQ,IACXA,EAAK4F,SAAW4J,GAChBxP,EAAKtB,SAAW8Q,GAEhBa,EAAkBG,IAAIxQ,EAAKtB,QAG/B,IAAM+R,EAAaR,EAASE,IAAIX,GAChC,QAA2BkB,KAAvBD,aAAU,EAAVA,EAAYrN,KAAKpL,SAAyC0Y,IAAtBD,EAAWrN,KAAKhL,EAAiB,CACvEgY,GAAU,EACV,IAAMO,EAAkB,IAAIN,GACzBrL,KAAK5C,GAAO6N,EAASE,IAAI/N,KACzB4F,OAAO8G,SACN8B,OAAsCF,EAC1C,IAAK,IAAMzH,KAAQ0H,OACGD,IAAhBzH,EAAK7F,KAAKpL,QAAmC0Y,IAAhBzH,EAAK7F,KAAKhL,IAGrCwY,GAAiB3H,EAAK7F,KAAKpL,EAAI4Y,EAAcxN,KAAKpL,IACpDiR,EAAK7F,KAAKhL,EAAIqY,EAAWrN,KAAKhL,IAE9BwY,EAAgB3H,GAIlByG,EAAiBmB,KAAK5H,GAG1B,GAAIyG,EAAiB5K,OAAS,GAAK2K,EAAgB,CACjD,IAAIqB,EACAC,EACJ,GAAIH,EAEFE,EACEF,EAAcxN,KAAKpL,EAAI4Y,EAAcxN,KAAKI,MAAQwN,EAAAA,GACpDD,EAAQH,EAAcxN,KAAKhL,MACtB,CAEL,IAAM6Y,EAAavB,EAAiBwB,QAClC,CAACC,EAAKlI,IAASkI,EAAMlI,EAAK7F,KAAKI,MAAQwN,EAAAA,KACtCA,EAAAA,IAEHF,EACEL,EAAWrN,KAAKpL,EAAIiZ,EAAa,EAAIR,EAAWrN,KAAKI,MAAQ,EAC/DuN,EAAQN,EAAWrN,KAAKhL,EAAIqY,EAAWrN,KAAKK,OAASuN,EAAAA,EACvD,CACA,IAAK,IAAM/H,KAAQyG,EACjBzG,EAAK7F,KAAKpL,EAAI8Y,EACd7H,EAAK7F,KAAKhL,EAAI2Y,EACdD,GAAS7H,EAAK7F,KAAKI,MAAQwN,EAAAA,EAE/B,CACF,CACF,CAEA,IAAKZ,EAAS,CAEZ,IAgCMgB,EAhCFC,EAAWhQ,EAAgB,GAC3BiQ,EAAYjQ,EAAgB,GAC5BkQ,EAAuB,EACvBC,GAAgB,EACpB,IAAK,IAAMxR,KAAQsJ,GACbrB,EAAAA,EAAAA,GAAWjI,IACTA,EAAKoD,KAAKI,MAAQ6N,IACpBA,EAAWrR,EAAKoD,KAAKI,OAEnBxD,EAAKoD,KAAKK,OAAS6N,IACrBA,EAAYtR,EAAKoD,KAAKK,aAEJiN,IAAhB1Q,EAAKoD,KAAKpL,QAAmC0Y,IAAhB1Q,EAAKoD,KAAKhL,EACzCsX,EAAiBmB,KAAK7Q,GAEtBuR,MAEOzB,EAAAA,EAAAA,IAAgB9P,KACzBwR,GAAgB,GAIpB,GAAI/B,EAgCF,IAAK,IAAMzP,KA/BN6P,IAEHxY,GAAYoa,EAAAA,EAAAA,IAAkBC,EAAAA,EAAAA,SAAQpI,KAAaoG,GAAmB,CACpEtK,cACAE,eACAxD,gBAUuB,IAAzByP,GAC0B,IAAzBA,IAA+BC,KAE7BJ,gBAAgBO,EAAAA,EAAAA,GAAY,CAAE5Q,MAAOuI,KACxCG,GAAiB,KAEd2H,gBAAgBQ,EAAAA,EAAAA,GAAY,CAC7B7Q,MAAOuI,EACPuI,eAAe,EACfC,OAAQ,EACL1M,EAAc,EAAI/N,EAAUW,GAAKX,EAAUa,GAC3CoN,EAAe,EAAIjO,EAAUe,GAAKf,EAAUa,MAKhCoR,GACjB,IAAIrB,EAAAA,EAAAA,GAAWjI,GAAO,CACpB,IAAMoD,EAAOgO,EAAYpR,EAAKoC,IAC9BpC,EAAKoD,KAAKpL,EAAIoL,EAAKpL,EACnBgI,EAAKoD,KAAKhL,EAAIgL,EAAKhL,CACrB,CAGN,CAEA,MAAO,CAAE2I,MAAOuI,EAAUlD,QAASsJ,EAAkBjG,iBACvD,C,iBCjNA,SAASsI,EAAmBC,EAAK7K,EAASgD,EAAQ8H,EAAOC,EAAQpF,EAAKqF,GACpE,IACE,IAAI9S,EAAO2S,EAAIlF,GAAKqF,GAChBjG,EAAQ7M,EAAK6M,KACnB,CAAE,MAAOkG,GAEP,YADAjI,EAAOiI,EAET,CACI/S,EAAKgT,KACPlL,EAAQ+E,GAERhF,QAAQC,QAAQ+E,GAAOoG,KAAKL,EAAOC,EAEvC,CACe,SAASjQ,EAAkBsQ,GACxC,OAAO,WACL,IAAIC,EAAO5T,KACT6T,EAAOlW,UACT,OAAO,IAAI2K,SAAQ,SAAUC,EAASgD,GACpC,IAAI6H,EAAMO,EAAGG,MAAMF,EAAMC,GACzB,SAASR,EAAM/F,GACb6F,EAAmBC,EAAK7K,EAASgD,EAAQ8H,EAAOC,EAAQ,OAAQhG,EAClE,CACA,SAASgG,EAAOS,GACdZ,EAAmBC,EAAK7K,EAASgD,EAAQ8H,EAAOC,EAAQ,QAASS,EACnE,CACAV,OAAMvB,EACR,GACF,CACF,C","sources":["webpack:///./src/draw-canvas/ConnectLineComponent.tsx","webpack:///./src/draw-canvas/index.tsx","webpack:///./src/draw-canvas/processors/handleKeyboard.ts","webpack:///./src/draw-canvas/processors/updateCells.ts","webpack:///../../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js"],"sourcesContent":["import React, { useEffect, useState } from \"react\";\nimport classNames from \"classnames\";\nimport type { ConnectLineState } from \"./interfaces\";\nimport type { PositionTuple, TransformLiteral } from \"../diagram/interfaces\";\n\nexport interface ConnectLineComponentProps {\n connectLineState: ConnectLineState | null;\n transform: TransformLiteral;\n markerEnd: string;\n onConnect(state: ConnectLineState, to: PositionTuple): void;\n}\n\nexport function ConnectLineComponent({\n connectLineState,\n transform,\n markerEnd,\n onConnect,\n}: ConnectLineComponentProps): JSX.Element {\n const [connectLineTo, setConnectLineTo] = useState<PositionTuple | null>(\n null\n );\n\n useEffect(() => {\n if (connectLineState) {\n setConnectLineTo(connectLineState.from);\n }\n }, [connectLineState]);\n\n useEffect(() => {\n if (connectLineState) {\n const onMouseMove = (e: MouseEvent) => {\n // Set connect line to based on the mouse position and the transform\n setConnectLineTo([\n (e.clientX - transform.x - connectLineState.offset[0]) / transform.k,\n (e.clientY - transform.y - connectLineState.offset[1]) / transform.k,\n ]);\n };\n const onMouseDown = (e: MouseEvent) => {\n e.stopPropagation();\n };\n const onClick = (e: MouseEvent) => {\n e.stopPropagation();\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n reset();\n onConnect(connectLineState, [\n (e.clientX - transform.x - connectLineState.offset[0]) / transform.k,\n (e.clientY - transform.y - connectLineState.offset[1]) / transform.k,\n ]);\n };\n const reset = () => {\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mousedown\", onMouseDown, {\n capture: true,\n });\n document.removeEventListener(\"click\", onClick, { capture: true });\n setConnectLineTo(null);\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mousedown\", onMouseDown, { capture: true });\n document.addEventListener(\"click\", onClick, { capture: true });\n\n return reset;\n }\n }, [connectLineState, onConnect, transform]);\n\n return (\n <path\n className={classNames(\"connect-line\", {\n connecting:\n !!connectLineState &&\n connectLineTo &&\n // Do not show when the distance of mouse move is less than 5px\n (connectLineTo[0] - connectLineState.from[0]) ** 2 +\n (connectLineTo[1] - connectLineState.from[1]) ** 2 >\n 25,\n })}\n d={\n connectLineState && connectLineTo\n ? `M${connectLineState.from.join(\" \")}L${connectLineTo.join(\" \")}`\n : \"\"\n }\n fill=\"none\"\n stroke=\"gray\"\n strokeWidth={1}\n markerEnd={`url(#${markerEnd})`}\n />\n );\n}\n","import React, {\n createRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport type { UseSingleBrickConf } from \"@next-core/react-runtime\";\nimport { unwrapProvider } from \"@next-core/utils/general\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { lockBodyScroll as _lockBodyScroll } from \"@next-bricks/basic/data-providers/lock-body-scroll/lock-body-scroll\";\nimport type {\n PositionTuple,\n RangeTuple,\n SizeTuple,\n TransformLiteral,\n} from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n Cell,\n EdgeCell,\n InitialCell,\n NodeBrickConf,\n NodeCell,\n NodeId,\n DecoratorCell,\n DecoratorType,\n CellContextMenuDetail,\n ConnectLineState,\n Deferred,\n ConnectNodesDetail,\n EdgeLineConf,\n DecoratorTextChangeDetail,\n NodeView,\n LayoutType,\n LayoutOptions,\n} from \"./interfaces\";\nimport { rootReducer } from \"./reducers\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport { isNodeCell } from \"./processors/asserts\";\nimport type { MoveCellPayload, ResizeCellPayload } from \"./reducers/interfaces\";\nimport { sameTarget } from \"./processors/sameTarget\";\nimport { handleKeyboard } from \"./processors/handleKeyboard\";\nimport { CellComponent } from \"./CellComponent\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { initializeCells } from \"./processors/initializeCells\";\nimport { updateCells } from \"./processors/updateCells\";\nimport { getUnrelatedCells } from \"./processors/getUnrelatedCells\";\nimport {\n DEFAULT_NODE_SIZE,\n DEFAULT_AREA_WIDTH,\n DEFAULT_AREA_HEIGHT,\n DEFAULT_DEGRADED_THRESHOLD,\n} from \"./constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\nimport { ZoomBarComponent } from \"../shared/canvas/ZoomBarComponent\";\nimport { useLayout } from \"../shared/canvas/useLayout\";\nimport { useReady } from \"../shared/canvas/useReady\";\nimport { useLineMarkers } from \"../shared/canvas/useLineMarkers\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\n\nconst lockBodyScroll = unwrapProvider<typeof _lockBodyScroll>(\n \"basic.lock-body-scroll\"\n);\n\nconst { defineElement, property, method, event } = createDecorators();\n\nexport interface EoDrawCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\nexport interface DropNodeInfo extends AddNodeInfo {\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n}\n\nexport interface DropDecoratorInfo {\n decorator: DecoratorType;\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n text?: string;\n}\n\nexport interface AddNodeInfo {\n id: NodeId;\n useBrick?: UseSingleBrickConf;\n data?: unknown;\n size?: SizeTuple;\n}\n\nexport interface AddEdgeInfo {\n source: NodeId;\n target: NodeId;\n data?: unknown;\n}\n\nexport interface UpdateCellsContext {\n reason: \"add-related-nodes\";\n parent: NodeId;\n}\n\nexport interface AddNodesContext {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n}\n\nexport const EoDrawCanvasComponent = React.forwardRef(\n LegacyEoDrawCanvasComponent\n);\n\n/**\n * 用于手工绘图的画布。\n *\n * 注意:将配套另外一个用于展示的画布构件。\n */\nexport\n@defineElement(\"eo-draw-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当 `activeTarget` 不为 `null` 时,隐藏其他跟该 `activeTarget` 无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n /**\n * @deprecated Use `cell.move` instead.\n */\n @event({ type: \"node.move\" })\n accessor #nodeMoveEvent!: EventEmitter<MoveCellPayload>;\n\n @event({ type: \"cell.move\" })\n accessor #cellMoveEvent!: EventEmitter<MoveCellPayload>;\n\n #handleCellMove = (info: MoveCellPayload) => {\n this.#cellMoveEvent.emit(info);\n if (info.type === \"node\") {\n this.#nodeMoveEvent.emit(info);\n }\n };\n\n @event({ type: \"cell.resize\" })\n accessor #cellResizeEvent!: EventEmitter<ResizeCellPayload>;\n\n #handleCellResize = (info: ResizeCellPayload) => {\n this.#cellResizeEvent.emit(info);\n };\n\n /**\n * @deprecated Use `cell.delete` instead.\n */\n @event({ type: \"node.delete\" })\n accessor #nodeDelete!: EventEmitter<Cell>;\n\n @event({ type: \"cell.delete\" })\n accessor #cellDelete!: EventEmitter<Cell>;\n\n #handleCellDelete = (cell: Cell) => {\n this.#cellDelete.emit(cell);\n if (cell.type === \"node\") {\n this.#nodeDelete.emit(cell);\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n @event({ type: \"decorator.text.change\" })\n accessor #decoratorTextChange!: EventEmitter<DecoratorTextChangeDetail>;\n\n #handleDecoratorTextChange = (detail: DecoratorTextChangeDetail) => {\n this.#decoratorTextChange.emit(detail);\n };\n\n /**\n * 缩放变化后,从素材库拖拽元素进画布时,拖拽图像应设置对应的缩放比例。\n */\n @event({ type: \"scale.change\" })\n accessor #scaleChange!: EventEmitter<number>;\n\n #handleScaleChange = (scale: number) => {\n this.#scaleChange.emit(scale);\n };\n\n @method()\n async dropNode({\n id,\n position,\n size,\n data,\n useBrick,\n }: DropNodeInfo): Promise<NodeCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newNode = {\n type: \"node\",\n id,\n view: {\n ...(this.layout === \"force\" || this.layout === \"dagre\"\n ? null\n : {\n x:\n (position[0] - boundingClientRect.left - transform.x) /\n transform.k,\n y:\n (position[1] - boundingClientRect.top - transform.y) /\n transform.k,\n }),\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n },\n data,\n useBrick,\n } as NodeCell;\n this.#canvasRef.current?.dropNode(newNode);\n return newNode;\n }\n return null;\n }\n\n @method()\n async dropDecorator({\n position,\n decorator,\n text,\n }: DropDecoratorInfo): Promise<DecoratorCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newDecorator: DecoratorCell = {\n type: \"decorator\",\n decorator,\n id: uuidV4(),\n view: {\n x:\n (position[0] - boundingClientRect.left - transform.x) / transform.k,\n y: (position[1] - boundingClientRect.top - transform.y) / transform.k,\n width: DEFAULT_AREA_WIDTH,\n height: DEFAULT_AREA_HEIGHT,\n text,\n },\n };\n this.#canvasRef.current?.dropDecorator(newDecorator);\n return newDecorator;\n }\n return null;\n }\n\n @method()\n async addNodes(nodes: AddNodeInfo[]): Promise<NodeCell[]> {\n if (nodes.length === 0) {\n return [];\n }\n const newNodes = nodes.map<NodeCell>(({ size, useBrick, id, data }) => ({\n type: \"node\",\n id,\n data,\n view: {\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n } as NodeView,\n useBrick,\n }));\n return this.#canvasRef.current!.addNodes(newNodes, {\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n }\n\n @method()\n async addEdge({ source, target, data }: AddEdgeInfo): Promise<EdgeCell> {\n const newEdge: EdgeCell = {\n type: \"edge\",\n source,\n target,\n data,\n };\n this.#canvasRef.current?.addEdge(newEdge);\n return newEdge;\n }\n\n @method()\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail> {\n return this.#canvasRef.current!.manuallyConnectNodes(source);\n }\n\n @method()\n async updateCells(\n cells: InitialCell[],\n ctx?: UpdateCellsContext\n ): Promise<{ updated: Cell[] }> {\n await this.#waitForCanvasRef();\n const { updated } = this.#canvasRef.current!.updateCells(cells, {\n ...ctx,\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n return { updated };\n }\n\n #waitForCanvasRef() {\n return new Promise<void>((resolve) => {\n const check = () => {\n if (this.#canvasRef.current) {\n resolve();\n } else {\n setTimeout(check, 10);\n }\n };\n check();\n });\n }\n\n #canvasRef = createRef<DrawCanvasRef>();\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n lockBodyScroll(this, false);\n }\n\n render() {\n return (\n <EoDrawCanvasComponent\n host={this}\n ref={this.#canvasRef}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n cells={this.cells}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellMove={this.#handleCellMove}\n onCellResize={this.#handleCellResize}\n onCellDelete={this.#handleCellDelete}\n onCellContextMenu={this.#handleCellContextMenu}\n onDecoratorTextChange={this.#handleDecoratorTextChange}\n onScaleChange={this.#handleScaleChange}\n />\n );\n }\n}\n\nexport interface EoDrawCanvasComponentProps extends EoDrawCanvasProps {\n host: HTMLElement;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellMove(info: MoveCellPayload): void;\n onCellResize(cell: ResizeCellPayload): void;\n onCellDelete(cell: Cell): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onDecoratorTextChange(detail: DecoratorTextChangeDetail): void;\n onScaleChange(scale: number): void;\n}\n\nexport interface DrawCanvasRef {\n dropNode(node: NodeCell): void;\n dropDecorator(decorator: DecoratorCell): void;\n addNodes(nodes: NodeCell[], ctx: AddNodesContext): NodeCell[];\n addEdge(edge: EdgeCell): void;\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail>;\n updateCells(\n cells: InitialCell[],\n ctx: Partial<UpdateCellsContext> & {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n }\n ): {\n cells: Cell[];\n updated: Cell[];\n };\n getTransform(): TransformLiteral;\n}\n\nfunction LegacyEoDrawCanvasComponent(\n {\n host,\n layout,\n layoutOptions,\n cells: initialCells,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellMove,\n onCellResize,\n onCellDelete,\n onCellContextMenu,\n onDecoratorTextChange,\n onScaleChange,\n }: EoDrawCanvasComponentProps,\n ref: React.Ref<DrawCanvasRef>\n) {\n const [{ cells }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n const manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n const [editingTexts, setEditingTexts] = useState<string[]>([]);\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n useEffect(() => {\n onScaleChange(transform.k);\n }, [onScaleChange, transform.k]);\n\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n const { centered, setCentered } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n dispatch,\n });\n\n useImperativeHandle(\n ref,\n () => ({\n dropNode(node) {\n // Do not apply auto centering when dropping a node.\n setCentered(true);\n dispatch({ type: \"drop-node\", payload: node });\n },\n dropDecorator(decorator) {\n // Do not apply auto centering when dropping a decorator.\n setCentered(true);\n dispatch({ type: \"drop-decorator\", payload: decorator });\n },\n addNodes(\n nodes,\n { defaultNodeSize, canvasWidth, canvasHeight }: AddNodesContext\n ) {\n const index =\n cells.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n const newCells = [\n ...cells.slice(0, index),\n ...nodes,\n ...cells.slice(index),\n ];\n const {\n cells: allCells,\n updated,\n shouldReCenter,\n } = updateCells({\n cells: newCells,\n layout,\n previousCells: cells,\n defaultNodeSize,\n canvasWidth,\n canvasHeight,\n scaleRange,\n transform,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: allCells });\n return updated.filter((node) =>\n nodes.includes(node as NodeCell)\n ) as NodeCell[];\n },\n addEdge(edge) {\n dispatch({ type: \"add-edge\", payload: edge });\n },\n updateCells(newCells, ctx) {\n const { shouldReCenter, ...result } = updateCells({\n ...ctx,\n layout,\n previousCells: cells,\n cells: newCells,\n scaleRange,\n transform,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: result.cells });\n return result;\n },\n getTransform() {\n return transform;\n },\n manuallyConnectNodes(sourceId) {\n const source = cells.find(\n (cell) => isNodeCell(cell) && cell.id === sourceId\n ) as NodeCell | undefined;\n if (source) {\n const rect = rootRef.current!.getBoundingClientRect();\n setConnectLineState({\n source,\n from: [\n source.view.x + source.view.width / 2,\n source.view.y + source.view.height / 2,\n ],\n offset: [rect.left, rect.top],\n });\n const promise = new Promise<ConnectNodesDetail>((resolve, reject) => {\n manualConnectDeferredRef.current = { resolve, reject };\n });\n return promise;\n }\n return Promise.reject(null);\n },\n }),\n [cells, layout, scaleRange, setCentered, transform]\n );\n\n const handleConnect = useCallback(\n (state: ConnectLineState, to: PositionTuple) => {\n // Find the target node from top bo bottom,\n // detect whether the pointer is inside the target node.\n for (let i = 0; i < cells.length; i++) {\n const cell = cells[i];\n // Currently ignore connecting to self\n if (isNodeCell(cell) && cell.id !== state.source.id) {\n if (\n cell.view.x < to[0] &&\n cell.view.x + cell.view.width > to[0] &&\n cell.view.y < to[1] &&\n cell.view.y + cell.view.height > to[1]\n ) {\n manualConnectDeferredRef.current?.resolve({\n source: state.source,\n target: cell,\n });\n break;\n }\n }\n }\n manualConnectDeferredRef.current?.reject(null);\n setConnectLineState(null);\n },\n [cells]\n );\n\n useEffect(() => {\n lockBodyScroll(host, !!connectLineState);\n }, [connectLineState, host]);\n\n const activeTarget = useActiveTarget({\n cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, connectLineState, activeTarget)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [activeTarget, cells, connectLineState, fadeUnrelatedCells]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || editingTexts.length > 0) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n cells,\n activeTarget,\n });\n\n if (action?.action === \"delete-cell\") {\n onCellDelete(action.cell);\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [activeTarget, cells, editingTexts.length, onCellDelete]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleCellMoving = useCallback((info: MoveCellPayload) => {\n dispatch({ type: \"move-cell\", payload: info });\n }, []);\n\n const handleCellMoved = useCallback(\n (info: MoveCellPayload) => {\n dispatch({ type: \"move-cell\", payload: info });\n onCellMove(info);\n },\n [onCellMove]\n );\n\n const handleCellResizing = useCallback((info: ResizeCellPayload) => {\n dispatch({ type: \"resize-cell\", payload: info });\n }, []);\n\n const handleCellResized = useCallback(\n (info: ResizeCellPayload) => {\n dispatch({ type: \"resize-cell\", payload: info });\n onCellResize(info);\n },\n [onCellResize]\n );\n\n const handleDecoratorTextEditing = useCallback(\n ({ id, editing }: { id: string; editing: boolean }) => {\n if (editing) {\n setEditingTexts((texts) =>\n texts.includes(id) ? texts : [...texts, id]\n );\n } else {\n setEditingTexts((texts) => texts.filter((text) => text !== id));\n }\n },\n []\n );\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({ type: \"update-node-size\", payload: { id, size } });\n },\n []\n );\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\" ref={cellsRef}>\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${cell.type === \"edge\" ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n transform={transform}\n lineConfMap={lineConfMap}\n active={sameTarget(activeTarget, cell)}\n unrelatedCells={unrelatedCells}\n onCellMoving={handleCellMoving}\n onCellMoved={handleCellMoved}\n onCellResizing={handleCellResizing}\n onCellResized={handleCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onDecoratorTextChange={onDecoratorTextChange}\n onDecoratorTextEditing={handleDecoratorTextEditing}\n onNodeBrickResize={handleNodeBrickResize}\n />\n ))}\n </g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={`${markerPrefix}0`}\n onConnect={handleConnect}\n />\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={host.shadowRoot!}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n\nfunction uuidV4() {\n return \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\".replace(/[xy]/g, function (c) {\n const r = (Math.random() * 16) | 0,\n v = c == \"x\" ? r : (r & 0x3) | 0x8;\n return v.toString(16);\n });\n}\n","import type { ActiveTarget, Cell } from \"../interfaces\";\nimport { sameTarget } from \"./sameTarget\";\n\nexport type KeyboardAction = KeyboardActionDeleteCell;\n\nexport interface KeyboardActionDeleteCell {\n action: \"delete-cell\";\n cell: Cell;\n}\n\nexport function handleKeyboard(\n event: KeyboardEvent,\n {\n cells,\n activeTarget,\n }: {\n cells: Cell[];\n activeTarget: ActiveTarget | null | undefined;\n }\n): KeyboardAction | undefined {\n const activeCell = cells.find((cell) => sameTarget(cell, activeTarget));\n\n if (!activeCell) {\n return;\n }\n\n const key =\n event.key ||\n /* istanbul ignore next: compatibility */ event.keyCode ||\n /* istanbul ignore next: compatibility */ event.which;\n\n switch (key) {\n case \"Backspace\":\n case 8:\n case \"Delete\":\n case 46: {\n event.preventDefault();\n event.stopPropagation();\n return {\n action: \"delete-cell\",\n cell: activeCell,\n };\n }\n }\n}\n","import { without } from \"lodash\";\nimport type {\n RangeTuple,\n SizeTuple,\n TransformLiteral,\n} from \"../../diagram/interfaces\";\nimport { DEFAULT_NODE_GAP, SYMBOL_FOR_SIZE_INITIALIZED } from \"../constants\";\nimport type {\n Cell,\n InitialCell,\n LayoutType,\n NodeCell,\n NodeId,\n NodeView,\n} from \"../interfaces\";\nimport { isDecoratorCell, isEdgeCell, isNodeCell } from \"./asserts\";\nimport { initializeCells } from \"./initializeCells\";\nimport { transformToCenter } from \"./transformToCenter\";\nimport { forceLayout } from \"../../shared/canvas/forceLayout\";\nimport { dagreLayout } from \"../../shared/canvas/dagreLayout\";\n\nexport function updateCells({\n cells,\n layout,\n previousCells,\n defaultNodeSize,\n canvasWidth,\n canvasHeight,\n scaleRange,\n transform,\n reason,\n parent,\n}: {\n cells: InitialCell[];\n layout?: LayoutType;\n previousCells: Cell[];\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n scaleRange: RangeTuple;\n transform: TransformLiteral;\n reason?: \"add-related-nodes\";\n parent?: NodeId;\n}): {\n cells: Cell[];\n updated: Cell[];\n shouldReCenter: boolean;\n} {\n const isManualLayout = layout !== \"force\" && layout !== \"dagre\";\n const newCells = initializeCells(cells, { defaultNodeSize });\n const updateCandidates: NodeCell[] = [];\n let shouldReCenter = false;\n\n const previousSizeInitializedNodes = new Map<string, NodeCell>();\n let previousShouldCentered = false;\n for (const cell of previousCells) {\n if (isDecoratorCell(cell)) {\n previousShouldCentered = true;\n } else if (isNodeCell(cell)) {\n previousShouldCentered = true;\n if (cell[SYMBOL_FOR_SIZE_INITIALIZED]) {\n previousSizeInitializedNodes.set(cell.id, cell);\n }\n }\n }\n\n const nodesMap = new Map<string, NodeCell>();\n for (const cell of newCells) {\n if (isNodeCell(cell)) {\n nodesMap.set(cell.id, cell);\n const previousNode = previousSizeInitializedNodes.get(cell.id);\n if (previousNode) {\n cell.view.width = previousNode.view.width;\n cell.view.height = previousNode.view.height;\n cell[SYMBOL_FOR_SIZE_INITIALIZED] = true;\n }\n }\n }\n\n let handled = false;\n\n if (reason === \"add-related-nodes\" && parent) {\n // Place these unpositioned downstream nodes below the parent node, and\n // on the right side of the positioned siblings.\n const downstreamNodeIds = new Set<string>();\n for (const cell of newCells) {\n if (\n isEdgeCell(cell) &&\n cell.source === parent &&\n cell.target !== parent\n ) {\n downstreamNodeIds.add(cell.target);\n }\n }\n const parentNode = nodesMap.get(parent);\n if (parentNode?.view.x !== undefined && parentNode.view.y !== undefined) {\n handled = true;\n const downstreamNodes = [...downstreamNodeIds]\n .map((id) => nodesMap.get(id))\n .filter(Boolean) as NodeCell[];\n let rightMostNode: NodeCell | undefined = undefined;\n for (const node of downstreamNodes) {\n if (node.view.x !== undefined && node.view.y !== undefined) {\n // Find the rightmost node that is below the parent node.\n if (\n (!rightMostNode || node.view.x > rightMostNode.view.x) &&\n node.view.y > parentNode.view.y\n ) {\n rightMostNode = node;\n }\n } else {\n // Unpositioned nodes\n updateCandidates.push(node);\n }\n }\n if (updateCandidates.length > 0 && isManualLayout) {\n let nextX: number;\n let nextY: number;\n if (rightMostNode) {\n // Place unpositioned nodes on the right side of the rightmost positioned siblings.\n nextX =\n rightMostNode.view.x + rightMostNode.view.width + DEFAULT_NODE_GAP;\n nextY = rightMostNode.view.y;\n } else {\n // If there are no positioned siblings, just place them below the parent.\n const totalWidth = updateCandidates.reduce(\n (acc, node) => acc + node.view.width + DEFAULT_NODE_GAP,\n -DEFAULT_NODE_GAP\n );\n nextX =\n parentNode.view.x - totalWidth / 2 + parentNode.view.width / 2;\n nextY = parentNode.view.y + parentNode.view.height + DEFAULT_NODE_GAP;\n }\n for (const node of updateCandidates) {\n node.view.x = nextX;\n node.view.y = nextY;\n nextX += node.view.width + DEFAULT_NODE_GAP;\n }\n }\n }\n }\n\n if (!handled) {\n // By default, place unpositioned nodes in a grid.\n let maxWidth = defaultNodeSize[0];\n let maxHeight = defaultNodeSize[1];\n let positionedNodesCount = 0;\n let hasDecorators = false;\n for (const cell of newCells) {\n if (isNodeCell(cell)) {\n if (cell.view.width > maxWidth) {\n maxWidth = cell.view.width;\n }\n if (cell.view.height > maxHeight) {\n maxHeight = cell.view.height;\n }\n if (cell.view.x === undefined || cell.view.y === undefined) {\n updateCandidates.push(cell);\n } else {\n positionedNodesCount++;\n }\n } else if (isDecoratorCell(cell)) {\n hasDecorators = true;\n }\n }\n\n if (isManualLayout) {\n if (!previousShouldCentered) {\n // If the previous cells are not centered, use the centered transform instead.\n transform = transformToCenter(without(newCells, ...updateCandidates), {\n canvasWidth,\n canvasHeight,\n scaleRange,\n });\n }\n\n let getNodeView: (id: NodeId) => NodeView;\n\n // If there is no positioned nodes, or only one while without decorators,\n // then there is no relative positions, we can place the nodes with dagre layout.\n // Otherwise, use the force layout.\n if (\n positionedNodesCount === 0 ||\n (positionedNodesCount === 1 && !hasDecorators)\n ) {\n ({ getNodeView } = dagreLayout({ cells: newCells }));\n shouldReCenter = true;\n } else {\n ({ getNodeView } = forceLayout({\n cells: newCells,\n fixedPosition: true,\n center: [\n (canvasWidth / 2 - transform.x) / transform.k,\n (canvasHeight / 2 - transform.y) / transform.k,\n ],\n }));\n }\n\n for (const cell of newCells) {\n if (isNodeCell(cell)) {\n const view = getNodeView(cell.id);\n cell.view.x = view.x;\n cell.view.y = view.y;\n }\n }\n }\n }\n\n return { cells: newCells, updated: updateCandidates, shouldReCenter };\n}\n","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n _next(undefined);\n });\n };\n}"],"names":["ConnectLineComponent","_ref","connectLineState","transform","markerEnd","onConnect","connectLineTo","setConnectLineTo","useState","useEffect","from","onMouseMove","e","clientX","x","offset","k","clientY","y","onMouseDown","stopPropagation","onClick","reset","document","removeEventListener","capture","addEventListener","React","className","classNames","connecting","d","concat","join","fill","stroke","strokeWidth","_EoDrawCanvas","lockBodyScroll","unwrapProvider","defineElement","property","method","event","createDecorators","EoDrawCanvasComponent","LegacyEoDrawCanvasComponent","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_EoDrawCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_P","_Q","_handleCellMove","_R","_handleCellResize","_S","_T","_handleCellDelete","_U","_handleCellContextMenu","_V","_handleDecoratorTextChange","_W","_handleScaleChange","_canvasRef","EoDrawCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_initProto","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_nodeMoveEvent","_init_extra_nodeMoveEvent","_init_cellMoveEvent","_init_extra_cellMoveEvent","info","_get_cellMoveEvent","type","_get_nodeMoveEvent","_init_cellResizeEvent","_init_extra_cellResizeEvent","_get_cellResizeEvent","_init_nodeDelete","_init_extra_nodeDelete","_init_cellDelete","_init_extra_cellDelete","cell","_get_cellDelete","_get_nodeDelete","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_decoratorTextChange","_init_extra_decoratorTextChange","_get_decoratorTextChange","_init_scaleChange","_init_extra_scaleChange","scale","_get_scaleChange","createRef","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","dropNode","_this","_asyncToGenerator","_document$elementsFro","_document","id","position","size","data","useBrick","elementsFromPoint","call","includes","_size$","_size$2","_classPrivateFieldGet2","boundingClientRect","getBoundingClientRect","current","getTransform","newNode","view","_objectSpread","left","top","width","height","dropDecorator","_ref2","_this2","_document$elementsFro2","_document2","decorator","text","_classPrivateFieldGet3","newDecorator","replace","c","r","Math","random","toString","DEFAULT_AREA_WIDTH","DEFAULT_AREA_HEIGHT","addNodes","nodes","_this3","length","newNodes","map","_ref3","_size$3","_size$4","canvasWidth","clientWidth","canvasHeight","clientHeight","addEdge","_ref4","_this4","_classPrivateFieldGet4","source","newEdge","manuallyConnectNodes","updateCells","ctx","_this5","_assertClassBrand","_waitForCanvasRef","updated","disconnectedCallback","super","render","host","ref","onActiveTargetChange","onSwitchActiveTarget","onCellMove","onCellResize","onCellDelete","onCellContextMenu","onDecoratorTextChange","onScaleChange","Promise","resolve","check","setTimeout","_ref5","initialCells","_activeTarget","_scaleRange","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","manualConnectDeferredRef","editingTexts","setEditingTexts","grabbing","zoomer","useZoom","setConnectLineState","centered","setCentered","useLayout","useImperativeHandle","node","payload","_ref6","index","findLastIndex","newCells","slice","allCells","shouldReCenter","previousCells","edge","_updateCells","result","_objectWithoutProperties","_excluded","sourceId","find","rect","reject","handleConnect","useCallback","state","to","_manualConnectDeferre2","i","_manualConnectDeferre","useActiveTarget","unrelatedCells","setUnrelatedCells","nextUnrelated","getUnrelatedCells","prev","root","onKeydown","action","handleKeyboard","defPrefix","uniqueId","markerPrefix","handleCellMoving","handleCellMoved","handleCellResizing","handleCellResized","handleDecoratorTextEditing","_ref7","editing","texts","handleNodeBrickResize","handleZoomSlide","value","scaleTo","select","reCenter","lineConfMap","markers","useLineMarkers","ready","useReady","tabIndex","marker","MarkerComponent","key","strokeColor","CellComponent","active","onCellMoving","onCellMoved","onCellResizing","onCellResized","onDecoratorTextEditing","onNodeBrickResize","ZoomBarComponent","shadowRoot","onZoomChange","onReCenter","_EoDrawCanvas2","_set_activeTargetChangeEvent","_set_nodeMoveEvent","_set_cellMoveEvent","_set_cellResizeEvent","_set_nodeDelete","_set_cellDelete","_set_cellContextMenu","_set_decoratorTextChange","_set_scaleChange","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS","activeCell","keyCode","which","preventDefault","reason","parent","isManualLayout","updateCandidates","previousSizeInitializedNodes","Map","previousShouldCentered","isDecoratorCell","SYMBOL_FOR_SIZE_INITIALIZED","set","nodesMap","previousNode","get","handled","downstreamNodeIds","Set","isEdgeCell","add","parentNode","undefined","downstreamNodes","rightMostNode","push","nextX","nextY","DEFAULT_NODE_GAP","totalWidth","reduce","acc","getNodeView","maxWidth","maxHeight","positionedNodesCount","hasDecorators","transformToCenter","without","dagreLayout","forceLayout","fixedPosition","center","asyncGeneratorStep","gen","_next","_throw","arg","error","done","then","fn","self","args","apply","err"],"sourceRoot":""}
1
+ {"version":3,"file":"chunks/eo-draw-canvas.3e6c3ab0.js","mappings":"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","sources":["webpack:///./src/draw-canvas/ConnectLineComponent.tsx","webpack:///./src/draw-canvas/index.tsx","webpack:///./src/draw-canvas/processors/handleKeyboard.ts","webpack:///./src/draw-canvas/processors/updateCells.ts","webpack:///../../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js"],"sourcesContent":["import React, { useEffect, useState } from \"react\";\nimport classNames from \"classnames\";\nimport type { ConnectLineState } from \"./interfaces\";\nimport type { PositionTuple, TransformLiteral } from \"../diagram/interfaces\";\n\nexport interface ConnectLineComponentProps {\n connectLineState: ConnectLineState | null;\n transform: TransformLiteral;\n markerEnd: string;\n onConnect(state: ConnectLineState, to: PositionTuple): void;\n}\n\nexport function ConnectLineComponent({\n connectLineState,\n transform,\n markerEnd,\n onConnect,\n}: ConnectLineComponentProps): JSX.Element {\n const [connectLineTo, setConnectLineTo] = useState<PositionTuple | null>(\n null\n );\n\n useEffect(() => {\n if (connectLineState) {\n setConnectLineTo(connectLineState.from);\n }\n }, [connectLineState]);\n\n useEffect(() => {\n if (connectLineState) {\n const onMouseMove = (e: MouseEvent) => {\n // Set connect line to based on the mouse position and the transform\n setConnectLineTo([\n (e.clientX - transform.x - connectLineState.offset[0]) / transform.k,\n (e.clientY - transform.y - connectLineState.offset[1]) / transform.k,\n ]);\n };\n const onMouseDown = (e: MouseEvent) => {\n e.stopPropagation();\n };\n const onClick = (e: MouseEvent) => {\n e.stopPropagation();\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n reset();\n onConnect(connectLineState, [\n (e.clientX - transform.x - connectLineState.offset[0]) / transform.k,\n (e.clientY - transform.y - connectLineState.offset[1]) / transform.k,\n ]);\n };\n const reset = () => {\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mousedown\", onMouseDown, {\n capture: true,\n });\n document.removeEventListener(\"click\", onClick, { capture: true });\n setConnectLineTo(null);\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mousedown\", onMouseDown, { capture: true });\n document.addEventListener(\"click\", onClick, { capture: true });\n\n return reset;\n }\n }, [connectLineState, onConnect, transform]);\n\n return (\n <path\n className={classNames(\"connect-line\", {\n connecting:\n !!connectLineState &&\n connectLineTo &&\n // Do not show when the distance of mouse move is less than 5px\n (connectLineTo[0] - connectLineState.from[0]) ** 2 +\n (connectLineTo[1] - connectLineState.from[1]) ** 2 >\n 25,\n })}\n d={\n connectLineState && connectLineTo\n ? `M${connectLineState.from.join(\" \")}L${connectLineTo.join(\" \")}`\n : \"\"\n }\n fill=\"none\"\n stroke=\"gray\"\n strokeWidth={1}\n markerEnd={`url(#${markerEnd})`}\n />\n );\n}\n","import React, {\n createRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport type { UseSingleBrickConf } from \"@next-core/react-runtime\";\nimport { unwrapProvider } from \"@next-core/utils/general\";\nimport \"@next-core/theme\";\nimport { uniqueId } from \"lodash\";\nimport classNames from \"classnames\";\nimport { select } from \"d3-selection\";\nimport type { lockBodyScroll as _lockBodyScroll } from \"@next-bricks/basic/data-providers/lock-body-scroll/lock-body-scroll\";\nimport type {\n PositionTuple,\n RangeTuple,\n SizeTuple,\n TransformLiteral,\n} from \"../diagram/interfaces\";\nimport type {\n ActiveTarget,\n Cell,\n EdgeCell,\n InitialCell,\n NodeBrickConf,\n NodeCell,\n NodeId,\n DecoratorCell,\n DecoratorType,\n CellContextMenuDetail,\n ConnectLineState,\n Deferred,\n ConnectNodesDetail,\n EdgeLineConf,\n DecoratorTextChangeDetail,\n NodeView,\n LayoutType,\n LayoutOptions,\n} from \"./interfaces\";\nimport { rootReducer } from \"./reducers\";\nimport { MarkerComponent } from \"../diagram/MarkerComponent\";\nimport { isNodeCell } from \"./processors/asserts\";\nimport type { MoveCellPayload, ResizeCellPayload } from \"./reducers/interfaces\";\nimport { sameTarget } from \"./processors/sameTarget\";\nimport { handleKeyboard } from \"./processors/handleKeyboard\";\nimport { CellComponent } from \"./CellComponent\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { initializeCells } from \"./processors/initializeCells\";\nimport { updateCells } from \"./processors/updateCells\";\nimport { getUnrelatedCells } from \"./processors/getUnrelatedCells\";\nimport {\n DEFAULT_NODE_SIZE,\n DEFAULT_AREA_WIDTH,\n DEFAULT_AREA_HEIGHT,\n DEFAULT_DEGRADED_THRESHOLD,\n} from \"./constants\";\nimport { useZoom } from \"../shared/canvas/useZoom\";\nimport { useActiveTarget } from \"../shared/canvas/useActiveTarget\";\nimport { ZoomBarComponent } from \"../shared/canvas/ZoomBarComponent\";\nimport { useLayout } from \"../shared/canvas/useLayout\";\nimport { useReady } from \"../shared/canvas/useReady\";\nimport { useLineMarkers } from \"../shared/canvas/useLineMarkers\";\nimport styleText from \"../shared/canvas/styles.shadow.css\";\nimport zoomBarStyleText from \"../shared/canvas/ZoomBarComponent.shadow.css\";\n\nconst lockBodyScroll = unwrapProvider<typeof _lockBodyScroll>(\n \"basic.lock-body-scroll\"\n);\n\nconst { defineElement, property, method, event } = createDecorators();\n\nexport interface EoDrawCanvasProps {\n cells: InitialCell[] | undefined;\n layout: LayoutType;\n layoutOptions?: LayoutOptions;\n defaultNodeSize: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n degradedThreshold?: number;\n degradedNodeLabel?: string;\n activeTarget?: ActiveTarget | null;\n fadeUnrelatedCells?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\nexport interface DropNodeInfo extends AddNodeInfo {\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n}\n\nexport interface DropDecoratorInfo {\n decorator: DecoratorType;\n /** [PointerEvent::clientX, PointerEvent::clientY] */\n position: PositionTuple;\n text?: string;\n}\n\nexport interface AddNodeInfo {\n id: NodeId;\n useBrick?: UseSingleBrickConf;\n data?: unknown;\n size?: SizeTuple;\n}\n\nexport interface AddEdgeInfo {\n source: NodeId;\n target: NodeId;\n data?: unknown;\n}\n\nexport interface UpdateCellsContext {\n reason: \"add-related-nodes\";\n parent: NodeId;\n}\n\nexport interface AddNodesContext {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n}\n\nexport const EoDrawCanvasComponent = React.forwardRef(\n LegacyEoDrawCanvasComponent\n);\n\n/**\n * 用于手工绘图的画布。\n *\n * 注意:将配套另外一个用于展示的画布构件。\n */\nexport\n@defineElement(\"eo-draw-canvas\", {\n styleTexts: [styleText, zoomBarStyleText],\n})\nclass EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ type: String })\n accessor layout: LayoutType;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple = [DEFAULT_NODE_SIZE, DEFAULT_NODE_SIZE];\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | undefined;\n\n /**\n * 当节点数量达到或超过 `degradedThreshold` 时,节点将被降级展示。\n *\n * @default 500\n */\n @property({ type: Number })\n accessor degradedThreshold: number | undefined;\n\n // Set `attribute` to `false` event if it accepts string value.\n // Because when passing like \"<% DATA.node.data.name %>\", it will be\n // evaluated as object temporarily.\n /**\n * 设置节点将降级展示时显示的名称。\n *\n * @default \"<% DATA.node.id %>\"\n */\n @property({ attribute: false })\n accessor degradedNodeLabel: string | undefined;\n\n /**\n * 使用条件判断设置默认的边对应的连线。在 `if` 表达式中 `DATA` 为 `{ edge }`,例如:\n *\n * ```yaml\n * defaultEdgeLines:\n * - if: <% DATA.edge.data?.virtual %>\n * dashed: true\n * ```\n */\n @property({ attribute: false })\n accessor defaultEdgeLines: EdgeLineConf[] | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n /**\n * 当 `activeTarget` 不为 `null` 时,隐藏其他跟该 `activeTarget` 无关的元素。\n */\n @property({ type: Boolean })\n accessor fadeUnrelatedCells: boolean | undefined;\n\n @property({ type: Boolean })\n accessor zoomable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor scrollable: boolean | undefined = true;\n\n @property({ type: Boolean })\n accessor pannable: boolean | undefined = true;\n\n @property({ attribute: false })\n accessor scaleRange: RangeTuple | undefined;\n\n @event({ type: \"activeTarget.change\" })\n accessor #activeTargetChangeEvent!: EventEmitter<ActiveTarget | null>;\n\n #handleActiveTargetChange = (target: ActiveTarget | null) => {\n this.#activeTargetChangeEvent.emit(target);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n /**\n * @deprecated Use `cell.move` instead.\n */\n @event({ type: \"node.move\" })\n accessor #nodeMoveEvent!: EventEmitter<MoveCellPayload>;\n\n @event({ type: \"cell.move\" })\n accessor #cellMoveEvent!: EventEmitter<MoveCellPayload>;\n\n #handleCellMove = (info: MoveCellPayload) => {\n this.#cellMoveEvent.emit(info);\n if (info.type === \"node\") {\n this.#nodeMoveEvent.emit(info);\n }\n };\n\n @event({ type: \"cell.resize\" })\n accessor #cellResizeEvent!: EventEmitter<ResizeCellPayload>;\n\n #handleCellResize = (info: ResizeCellPayload) => {\n this.#cellResizeEvent.emit(info);\n };\n\n /**\n * @deprecated Use `cell.delete` instead.\n */\n @event({ type: \"node.delete\" })\n accessor #nodeDelete!: EventEmitter<Cell>;\n\n @event({ type: \"cell.delete\" })\n accessor #cellDelete!: EventEmitter<Cell>;\n\n #handleCellDelete = (cell: Cell) => {\n this.#cellDelete.emit(cell);\n if (cell.type === \"node\") {\n this.#nodeDelete.emit(cell);\n }\n };\n\n @event({ type: \"cell.contextmenu\" })\n accessor #cellContextMenu!: EventEmitter<CellContextMenuDetail>;\n\n #handleCellContextMenu = (detail: CellContextMenuDetail) => {\n this.#cellContextMenu.emit(detail);\n };\n\n @event({ type: \"decorator.text.change\" })\n accessor #decoratorTextChange!: EventEmitter<DecoratorTextChangeDetail>;\n\n #handleDecoratorTextChange = (detail: DecoratorTextChangeDetail) => {\n this.#decoratorTextChange.emit(detail);\n };\n\n /**\n * 缩放变化后,从素材库拖拽元素进画布时,拖拽图像应设置对应的缩放比例。\n */\n @event({ type: \"scale.change\" })\n accessor #scaleChange!: EventEmitter<number>;\n\n #handleScaleChange = (scale: number) => {\n this.#scaleChange.emit(scale);\n };\n\n @method()\n async dropNode({\n id,\n position,\n size,\n data,\n useBrick,\n }: DropNodeInfo): Promise<NodeCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newNode = {\n type: \"node\",\n id,\n view: {\n ...(this.layout === \"force\" || this.layout === \"dagre\"\n ? null\n : {\n x:\n (position[0] - boundingClientRect.left - transform.x) /\n transform.k,\n y:\n (position[1] - boundingClientRect.top - transform.y) /\n transform.k,\n }),\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n },\n data,\n useBrick,\n } as NodeCell;\n this.#canvasRef.current?.dropNode(newNode);\n return newNode;\n }\n return null;\n }\n\n @method()\n async dropDecorator({\n position,\n decorator,\n text,\n }: DropDecoratorInfo): Promise<DecoratorCell | null> {\n // Drag and then drop a node\n const droppedInside = document\n .elementsFromPoint?.(position[0], position[1])\n ?.includes(this);\n if (droppedInside) {\n const boundingClientRect = this.getBoundingClientRect();\n const transform = this.#canvasRef.current!.getTransform();\n const newDecorator: DecoratorCell = {\n type: \"decorator\",\n decorator,\n id: uuidV4(),\n view: {\n x:\n (position[0] - boundingClientRect.left - transform.x) / transform.k,\n y: (position[1] - boundingClientRect.top - transform.y) / transform.k,\n width: DEFAULT_AREA_WIDTH,\n height: DEFAULT_AREA_HEIGHT,\n text,\n },\n };\n this.#canvasRef.current?.dropDecorator(newDecorator);\n return newDecorator;\n }\n return null;\n }\n\n @method()\n async addNodes(nodes: AddNodeInfo[]): Promise<NodeCell[]> {\n if (nodes.length === 0) {\n return [];\n }\n const newNodes = nodes.map<NodeCell>(({ size, useBrick, id, data }) => ({\n type: \"node\",\n id,\n data,\n view: {\n width: size?.[0] ?? this.defaultNodeSize[0],\n height: size?.[1] ?? this.defaultNodeSize[0],\n } as NodeView,\n useBrick,\n }));\n return this.#canvasRef.current!.addNodes(newNodes, {\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n }\n\n @method()\n async addEdge({ source, target, data }: AddEdgeInfo): Promise<EdgeCell> {\n const newEdge: EdgeCell = {\n type: \"edge\",\n source,\n target,\n data,\n };\n this.#canvasRef.current?.addEdge(newEdge);\n return newEdge;\n }\n\n @method()\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail> {\n return this.#canvasRef.current!.manuallyConnectNodes(source);\n }\n\n @method()\n async updateCells(\n cells: InitialCell[],\n ctx?: UpdateCellsContext\n ): Promise<{ updated: Cell[] }> {\n await this.#waitForCanvasRef();\n const { updated } = this.#canvasRef.current!.updateCells(cells, {\n ...ctx,\n defaultNodeSize: this.defaultNodeSize,\n canvasWidth: this.clientWidth,\n canvasHeight: this.clientHeight,\n });\n return { updated };\n }\n\n #waitForCanvasRef() {\n return new Promise<void>((resolve) => {\n const check = () => {\n if (this.#canvasRef.current) {\n resolve();\n } else {\n setTimeout(check, 10);\n }\n };\n check();\n });\n }\n\n #canvasRef = createRef<DrawCanvasRef>();\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n lockBodyScroll(this, false);\n }\n\n render() {\n return (\n <EoDrawCanvasComponent\n host={this}\n ref={this.#canvasRef}\n layout={this.layout}\n layoutOptions={this.layoutOptions}\n cells={this.cells}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n degradedThreshold={this.degradedThreshold}\n degradedNodeLabel={this.degradedNodeLabel}\n activeTarget={this.activeTarget}\n fadeUnrelatedCells={this.fadeUnrelatedCells}\n zoomable={this.zoomable}\n scrollable={this.scrollable}\n pannable={this.pannable}\n scaleRange={this.scaleRange}\n onActiveTargetChange={this.#handleActiveTargetChange}\n onSwitchActiveTarget={this.#handleSwitchActiveTarget}\n onCellMove={this.#handleCellMove}\n onCellResize={this.#handleCellResize}\n onCellDelete={this.#handleCellDelete}\n onCellContextMenu={this.#handleCellContextMenu}\n onDecoratorTextChange={this.#handleDecoratorTextChange}\n onScaleChange={this.#handleScaleChange}\n />\n );\n }\n}\n\nexport interface EoDrawCanvasComponentProps extends EoDrawCanvasProps {\n host: HTMLElement;\n onActiveTargetChange(target: ActiveTarget | null): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellMove(info: MoveCellPayload): void;\n onCellResize(cell: ResizeCellPayload): void;\n onCellDelete(cell: Cell): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n onDecoratorTextChange(detail: DecoratorTextChangeDetail): void;\n onScaleChange(scale: number): void;\n}\n\nexport interface DrawCanvasRef {\n dropNode(node: NodeCell): void;\n dropDecorator(decorator: DecoratorCell): void;\n addNodes(nodes: NodeCell[], ctx: AddNodesContext): NodeCell[];\n addEdge(edge: EdgeCell): void;\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail>;\n updateCells(\n cells: InitialCell[],\n ctx: Partial<UpdateCellsContext> & {\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n }\n ): {\n cells: Cell[];\n updated: Cell[];\n };\n getTransform(): TransformLiteral;\n}\n\nfunction LegacyEoDrawCanvasComponent(\n {\n host,\n layout,\n layoutOptions,\n cells: initialCells,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n degradedThreshold,\n degradedNodeLabel,\n activeTarget: _activeTarget,\n fadeUnrelatedCells,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellMove,\n onCellResize,\n onCellDelete,\n onCellContextMenu,\n onDecoratorTextChange,\n onScaleChange,\n }: EoDrawCanvasComponentProps,\n ref: React.Ref<DrawCanvasRef>\n) {\n const [{ cells }, dispatch] = useReducer(\n rootReducer,\n initialCells,\n (initialCells) => ({\n cells: initializeCells(initialCells, { defaultNodeSize }),\n })\n );\n\n // When nodes are greater or equal to threshold, the diagram will be degraded.\n // Thus all nodes will be displayed as simple svg elements instead of bricks.\n const degraded = useMemo(\n () =>\n cells.filter(isNodeCell).length >=\n (degradedThreshold ?? DEFAULT_DEGRADED_THRESHOLD),\n [cells, degradedThreshold]\n );\n\n const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n const manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n const [editingTexts, setEditingTexts] = useState<string[]>([]);\n const { grabbing, transform, zoomer, scaleRange } = useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n });\n\n useEffect(() => {\n onScaleChange(transform.k);\n }, [onScaleChange, transform.k]);\n\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n const { centered, setCentered } = useLayout({\n layout,\n layoutOptions,\n rootRef,\n cells,\n zoomable,\n zoomer,\n scaleRange,\n dispatch,\n });\n\n useImperativeHandle(\n ref,\n () => ({\n dropNode(node) {\n // Do not apply auto centering when dropping a node.\n setCentered(true);\n dispatch({ type: \"drop-node\", payload: node });\n },\n dropDecorator(decorator) {\n // Do not apply auto centering when dropping a decorator.\n setCentered(true);\n dispatch({ type: \"drop-decorator\", payload: decorator });\n },\n addNodes(\n nodes,\n { defaultNodeSize, canvasWidth, canvasHeight }: AddNodesContext\n ) {\n const index =\n cells.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n const newCells = [\n ...cells.slice(0, index),\n ...nodes,\n ...cells.slice(index),\n ];\n const {\n cells: allCells,\n updated,\n shouldReCenter,\n } = updateCells({\n cells: newCells,\n layout,\n previousCells: cells,\n defaultNodeSize,\n canvasWidth,\n canvasHeight,\n scaleRange,\n transform,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: allCells });\n return updated.filter((node) =>\n nodes.includes(node as NodeCell)\n ) as NodeCell[];\n },\n addEdge(edge) {\n dispatch({ type: \"add-edge\", payload: edge });\n },\n updateCells(newCells, ctx) {\n const { shouldReCenter, ...result } = updateCells({\n ...ctx,\n layout,\n previousCells: cells,\n cells: newCells,\n scaleRange,\n transform,\n });\n if (shouldReCenter) {\n setCentered(false);\n }\n dispatch({ type: \"update-cells\", payload: result.cells });\n return result;\n },\n getTransform() {\n return transform;\n },\n manuallyConnectNodes(sourceId) {\n const source = cells.find(\n (cell) => isNodeCell(cell) && cell.id === sourceId\n ) as NodeCell | undefined;\n if (source) {\n const rect = rootRef.current!.getBoundingClientRect();\n setConnectLineState({\n source,\n from: [\n source.view.x + source.view.width / 2,\n source.view.y + source.view.height / 2,\n ],\n offset: [rect.left, rect.top],\n });\n const promise = new Promise<ConnectNodesDetail>((resolve, reject) => {\n manualConnectDeferredRef.current = { resolve, reject };\n });\n return promise;\n }\n return Promise.reject(null);\n },\n }),\n [cells, layout, scaleRange, setCentered, transform]\n );\n\n const handleConnect = useCallback(\n (state: ConnectLineState, to: PositionTuple) => {\n // Find the target node from top bo bottom,\n // detect whether the pointer is inside the target node.\n for (let i = 0; i < cells.length; i++) {\n const cell = cells[i];\n // Currently ignore connecting to self\n if (isNodeCell(cell) && cell.id !== state.source.id) {\n if (\n cell.view.x < to[0] &&\n cell.view.x + cell.view.width > to[0] &&\n cell.view.y < to[1] &&\n cell.view.y + cell.view.height > to[1]\n ) {\n manualConnectDeferredRef.current?.resolve({\n source: state.source,\n target: cell,\n });\n break;\n }\n }\n }\n manualConnectDeferredRef.current?.reject(null);\n setConnectLineState(null);\n },\n [cells]\n );\n\n useEffect(() => {\n lockBodyScroll(host, !!connectLineState);\n }, [connectLineState, host]);\n\n const activeTarget = useActiveTarget({\n cellsRef,\n activeTarget: _activeTarget,\n onActiveTargetChange,\n });\n\n const [unrelatedCells, setUnrelatedCells] = useState<Cell[]>([]);\n useEffect(() => {\n const nextUnrelated = fadeUnrelatedCells\n ? getUnrelatedCells(cells, connectLineState, activeTarget)\n : [];\n // Do not update the state when prev and next are both empty.\n setUnrelatedCells((prev) =>\n prev.length === 0 && nextUnrelated.length === 0 ? prev : nextUnrelated\n );\n }, [activeTarget, cells, connectLineState, fadeUnrelatedCells]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || editingTexts.length > 0) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n cells,\n activeTarget,\n });\n\n if (action?.action === \"delete-cell\") {\n onCellDelete(action.cell);\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [activeTarget, cells, editingTexts.length, onCellDelete]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n\n const handleCellMoving = useCallback((info: MoveCellPayload) => {\n dispatch({ type: \"move-cell\", payload: info });\n }, []);\n\n const handleCellMoved = useCallback(\n (info: MoveCellPayload) => {\n dispatch({ type: \"move-cell\", payload: info });\n onCellMove(info);\n },\n [onCellMove]\n );\n\n const handleCellResizing = useCallback((info: ResizeCellPayload) => {\n dispatch({ type: \"resize-cell\", payload: info });\n }, []);\n\n const handleCellResized = useCallback(\n (info: ResizeCellPayload) => {\n dispatch({ type: \"resize-cell\", payload: info });\n onCellResize(info);\n },\n [onCellResize]\n );\n\n const handleDecoratorTextEditing = useCallback(\n ({ id, editing }: { id: string; editing: boolean }) => {\n if (editing) {\n setEditingTexts((texts) =>\n texts.includes(id) ? texts : [...texts, id]\n );\n } else {\n setEditingTexts((texts) => texts.filter((text) => text !== id));\n }\n },\n []\n );\n\n const handleNodeBrickResize = useCallback(\n (id: string, size: SizeTuple | null) => {\n dispatch({ type: \"update-node-size\", payload: { id, size } });\n },\n []\n );\n\n const handleZoomSlide = useCallback(\n (value: number) => {\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n zoomer.scaleTo(select(rootRef.current!), value / 100);\n }\n },\n [zoomer]\n );\n\n const reCenter = useCallback(() => {\n setCentered(false);\n }, [setCentered]);\n const [lineConfMap, markers] = useLineMarkers({\n cells,\n defaultEdgeLines,\n markerPrefix,\n });\n\n const ready = useReady({ cells, layout, centered });\n\n return (\n <>\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable, ready })}\n tabIndex={-1}\n >\n <defs>\n {markers.map((marker, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type=\"arrow\"\n strokeColor={marker.strokeColor}\n />\n ))}\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n <g className=\"cells\" ref={cellsRef}>\n {cells.map((cell) => (\n <CellComponent\n key={`${cell.type}:${cell.type === \"edge\" ? `${cell.source}~${cell.target}` : cell.id}`}\n layout={layout}\n cell={cell}\n cells={cells}\n degraded={degraded}\n degradedNodeLabel={degradedNodeLabel}\n defaultNodeBricks={defaultNodeBricks}\n transform={transform}\n lineConfMap={lineConfMap}\n active={sameTarget(activeTarget, cell)}\n unrelatedCells={unrelatedCells}\n onCellMoving={handleCellMoving}\n onCellMoved={handleCellMoved}\n onCellResizing={handleCellResizing}\n onCellResized={handleCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n onDecoratorTextChange={onDecoratorTextChange}\n onDecoratorTextEditing={handleDecoratorTextEditing}\n onNodeBrickResize={handleNodeBrickResize}\n />\n ))}\n </g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={`${markerPrefix}0`}\n onConnect={handleConnect}\n />\n </g>\n </svg>\n <ZoomBarComponent\n shadowRoot={host.shadowRoot!}\n scale={transform.k}\n scaleRange={scaleRange}\n onZoomChange={handleZoomSlide}\n onReCenter={reCenter}\n />\n </>\n );\n}\n\nfunction uuidV4() {\n return \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\".replace(/[xy]/g, function (c) {\n const r = (Math.random() * 16) | 0,\n v = c == \"x\" ? r : (r & 0x3) | 0x8;\n return v.toString(16);\n });\n}\n","import type { ActiveTarget, Cell } from \"../interfaces\";\nimport { sameTarget } from \"./sameTarget\";\n\nexport type KeyboardAction = KeyboardActionDeleteCell;\n\nexport interface KeyboardActionDeleteCell {\n action: \"delete-cell\";\n cell: Cell;\n}\n\nexport function handleKeyboard(\n event: KeyboardEvent,\n {\n cells,\n activeTarget,\n }: {\n cells: Cell[];\n activeTarget: ActiveTarget | null | undefined;\n }\n): KeyboardAction | undefined {\n const activeCell = cells.find((cell) => sameTarget(cell, activeTarget));\n\n if (!activeCell) {\n return;\n }\n\n const key =\n event.key ||\n /* istanbul ignore next: compatibility */ event.keyCode ||\n /* istanbul ignore next: compatibility */ event.which;\n\n switch (key) {\n case \"Backspace\":\n case 8:\n case \"Delete\":\n case 46: {\n event.preventDefault();\n event.stopPropagation();\n return {\n action: \"delete-cell\",\n cell: activeCell,\n };\n }\n }\n}\n","import { without } from \"lodash\";\nimport type {\n RangeTuple,\n SizeTuple,\n TransformLiteral,\n} from \"../../diagram/interfaces\";\nimport { DEFAULT_NODE_GAP, SYMBOL_FOR_SIZE_INITIALIZED } from \"../constants\";\nimport type {\n Cell,\n InitialCell,\n LayoutType,\n NodeCell,\n NodeId,\n NodeView,\n} from \"../interfaces\";\nimport { isDecoratorCell, isEdgeCell, isNodeCell } from \"./asserts\";\nimport { initializeCells } from \"./initializeCells\";\nimport { transformToCenter } from \"./transformToCenter\";\nimport { forceLayout } from \"../../shared/canvas/forceLayout\";\nimport { dagreLayout } from \"../../shared/canvas/dagreLayout\";\n\nexport function updateCells({\n cells,\n layout,\n previousCells,\n defaultNodeSize,\n canvasWidth,\n canvasHeight,\n scaleRange,\n transform,\n reason,\n parent,\n}: {\n cells: InitialCell[];\n layout?: LayoutType;\n previousCells: Cell[];\n defaultNodeSize: SizeTuple;\n canvasWidth: number;\n canvasHeight: number;\n scaleRange: RangeTuple;\n transform: TransformLiteral;\n reason?: \"add-related-nodes\";\n parent?: NodeId;\n}): {\n cells: Cell[];\n updated: Cell[];\n shouldReCenter: boolean;\n} {\n const isManualLayout = layout !== \"force\" && layout !== \"dagre\";\n const newCells = initializeCells(cells, { defaultNodeSize });\n const updateCandidates: NodeCell[] = [];\n let shouldReCenter = false;\n\n const previousSizeInitializedNodes = new Map<string, NodeCell>();\n let previousShouldCentered = false;\n for (const cell of previousCells) {\n if (isDecoratorCell(cell)) {\n previousShouldCentered = true;\n } else if (isNodeCell(cell)) {\n previousShouldCentered = true;\n if (cell[SYMBOL_FOR_SIZE_INITIALIZED]) {\n previousSizeInitializedNodes.set(cell.id, cell);\n }\n }\n }\n\n const nodesMap = new Map<string, NodeCell>();\n for (const cell of newCells) {\n if (isNodeCell(cell)) {\n nodesMap.set(cell.id, cell);\n const previousNode = previousSizeInitializedNodes.get(cell.id);\n if (previousNode) {\n cell.view.width = previousNode.view.width;\n cell.view.height = previousNode.view.height;\n cell[SYMBOL_FOR_SIZE_INITIALIZED] = true;\n }\n }\n }\n\n let handled = false;\n\n if (reason === \"add-related-nodes\" && parent) {\n // Place these unpositioned downstream nodes below the parent node, and\n // on the right side of the positioned siblings.\n const downstreamNodeIds = new Set<string>();\n for (const cell of newCells) {\n if (\n isEdgeCell(cell) &&\n cell.source === parent &&\n cell.target !== parent\n ) {\n downstreamNodeIds.add(cell.target);\n }\n }\n const parentNode = nodesMap.get(parent);\n if (parentNode?.view.x !== undefined && parentNode.view.y !== undefined) {\n handled = true;\n const downstreamNodes = [...downstreamNodeIds]\n .map((id) => nodesMap.get(id))\n .filter(Boolean) as NodeCell[];\n let rightMostNode: NodeCell | undefined = undefined;\n for (const node of downstreamNodes) {\n if (node.view.x !== undefined && node.view.y !== undefined) {\n // Find the rightmost node that is below the parent node.\n if (\n (!rightMostNode || node.view.x > rightMostNode.view.x) &&\n node.view.y > parentNode.view.y\n ) {\n rightMostNode = node;\n }\n } else {\n // Unpositioned nodes\n updateCandidates.push(node);\n }\n }\n if (updateCandidates.length > 0 && isManualLayout) {\n let nextX: number;\n let nextY: number;\n if (rightMostNode) {\n // Place unpositioned nodes on the right side of the rightmost positioned siblings.\n nextX =\n rightMostNode.view.x + rightMostNode.view.width + DEFAULT_NODE_GAP;\n nextY = rightMostNode.view.y;\n } else {\n // If there are no positioned siblings, just place them below the parent.\n const totalWidth = updateCandidates.reduce(\n (acc, node) => acc + node.view.width + DEFAULT_NODE_GAP,\n -DEFAULT_NODE_GAP\n );\n nextX =\n parentNode.view.x - totalWidth / 2 + parentNode.view.width / 2;\n nextY = parentNode.view.y + parentNode.view.height + DEFAULT_NODE_GAP;\n }\n for (const node of updateCandidates) {\n node.view.x = nextX;\n node.view.y = nextY;\n nextX += node.view.width + DEFAULT_NODE_GAP;\n }\n }\n }\n }\n\n if (!handled) {\n // By default, place unpositioned nodes in a grid.\n let maxWidth = defaultNodeSize[0];\n let maxHeight = defaultNodeSize[1];\n let positionedNodesCount = 0;\n let hasDecorators = false;\n for (const cell of newCells) {\n if (isNodeCell(cell)) {\n if (cell.view.width > maxWidth) {\n maxWidth = cell.view.width;\n }\n if (cell.view.height > maxHeight) {\n maxHeight = cell.view.height;\n }\n if (cell.view.x === undefined || cell.view.y === undefined) {\n updateCandidates.push(cell);\n } else {\n positionedNodesCount++;\n }\n } else if (isDecoratorCell(cell)) {\n hasDecorators = true;\n }\n }\n\n if (isManualLayout) {\n if (!previousShouldCentered) {\n // If the previous cells are not centered, use the centered transform instead.\n transform = transformToCenter(without(newCells, ...updateCandidates), {\n canvasWidth,\n canvasHeight,\n scaleRange,\n });\n }\n\n let getNodeView: (id: NodeId) => NodeView;\n\n // If there is no positioned nodes, or only one while without decorators,\n // then there is no relative positions, we can place the nodes with dagre layout.\n // Otherwise, use the force layout.\n if (\n positionedNodesCount === 0 ||\n (positionedNodesCount === 1 && !hasDecorators)\n ) {\n ({ getNodeView } = dagreLayout({ cells: newCells }));\n shouldReCenter = true;\n } else {\n ({ getNodeView } = forceLayout({\n cells: newCells,\n fixedPosition: true,\n center: [\n (canvasWidth / 2 - transform.x) / transform.k,\n (canvasHeight / 2 - transform.y) / transform.k,\n ],\n }));\n }\n\n for (const cell of newCells) {\n if (isNodeCell(cell)) {\n const view = getNodeView(cell.id);\n cell.view.x = view.x;\n cell.view.y = view.y;\n }\n }\n }\n }\n\n return { cells: newCells, updated: updateCandidates, shouldReCenter };\n}\n","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n _next(undefined);\n });\n };\n}"],"names":["ConnectLineComponent","_ref","connectLineState","transform","markerEnd","onConnect","connectLineTo","setConnectLineTo","useState","useEffect","from","onMouseMove","e","clientX","x","offset","k","clientY","y","onMouseDown","stopPropagation","onClick","reset","document","removeEventListener","capture","addEventListener","React","className","classNames","connecting","d","concat","join","fill","stroke","strokeWidth","_EoDrawCanvas","lockBodyScroll","unwrapProvider","defineElement","property","method","event","createDecorators","EoDrawCanvasComponent","LegacyEoDrawCanvasComponent","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_EoDrawCanvas_brand","WeakSet","_handleActiveTargetChange","_handleSwitchActiveTarget","_P","_Q","_handleCellMove","_R","_handleCellResize","_S","_T","_handleCellDelete","_U","_handleCellContextMenu","_V","_handleDecoratorTextChange","_W","_handleScaleChange","_canvasRef","EoDrawCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_initProto","_init_cells","_init_extra_cells","_init_layout","_init_extra_layout","_init_layoutOptions","_init_extra_layoutOptions","_init_defaultNodeSize","DEFAULT_NODE_SIZE","_init_extra_defaultNodeSize","_init_defaultNodeBricks","_init_extra_defaultNodeBricks","_init_degradedThreshold","_init_extra_degradedThreshold","_init_degradedNodeLabel","_init_extra_degradedNodeLabel","_init_defaultEdgeLines","_init_extra_defaultEdgeLines","_init_activeTarget","_init_extra_activeTarget","_init_fadeUnrelatedCells","_init_extra_fadeUnrelatedCells","_init_zoomable","_init_extra_zoomable","_init_scrollable","_init_extra_scrollable","_init_pannable","_init_extra_pannable","_init_scaleRange","_init_extra_scaleRange","_init_activeTargetChangeEvent","_init_extra_activeTargetChangeEvent","target","_classPrivateGetter","this","_get_activeTargetChangeEvent","emit","sameTarget","activeTarget","_init_nodeMoveEvent","_init_extra_nodeMoveEvent","_init_cellMoveEvent","_init_extra_cellMoveEvent","info","_get_cellMoveEvent","type","_get_nodeMoveEvent","_init_cellResizeEvent","_init_extra_cellResizeEvent","_get_cellResizeEvent","_init_nodeDelete","_init_extra_nodeDelete","_init_cellDelete","_init_extra_cellDelete","cell","_get_cellDelete","_get_nodeDelete","_init_cellContextMenu","_init_extra_cellContextMenu","detail","_get_cellContextMenu","_init_decoratorTextChange","_init_extra_decoratorTextChange","_get_decoratorTextChange","_init_scaleChange","_init_extra_scaleChange","scale","_get_scaleChange","createRef","cells","_classPrivateFieldGet","v","_classPrivateFieldSet","layout","layoutOptions","defaultNodeSize","defaultNodeBricks","degradedThreshold","degradedNodeLabel","defaultEdgeLines","fadeUnrelatedCells","zoomable","scrollable","pannable","scaleRange","dropNode","_this","_asyncToGenerator","_document$elementsFro","_document","id","position","size","data","useBrick","elementsFromPoint","call","includes","_size$","_size$2","_classPrivateFieldGet2","boundingClientRect","getBoundingClientRect","current","getTransform","newNode","view","_objectSpread","left","top","width","height","dropDecorator","_ref2","_this2","_document$elementsFro2","_document2","decorator","text","_classPrivateFieldGet3","newDecorator","replace","c","r","Math","random","toString","DEFAULT_AREA_WIDTH","DEFAULT_AREA_HEIGHT","addNodes","nodes","_this3","length","newNodes","map","_ref3","_size$3","_size$4","canvasWidth","clientWidth","canvasHeight","clientHeight","addEdge","_ref4","_this4","_classPrivateFieldGet4","source","newEdge","manuallyConnectNodes","updateCells","ctx","_this5","_assertClassBrand","_waitForCanvasRef","updated","disconnectedCallback","super","render","host","ref","onActiveTargetChange","onSwitchActiveTarget","onCellMove","onCellResize","onCellDelete","onCellContextMenu","onDecoratorTextChange","onScaleChange","Promise","resolve","check","setTimeout","_ref5","initialCells","_activeTarget","_scaleRange","dispatch","useReducer","rootReducer","initializeCells","degraded","useMemo","filter","isNodeCell","DEFAULT_DEGRADED_THRESHOLD","rootRef","useRef","cellsRef","manualConnectDeferredRef","editingTexts","setEditingTexts","grabbing","zoomer","useZoom","setConnectLineState","centered","setCentered","useLayout","useImperativeHandle","node","payload","_ref6","index","findLastIndex","newCells","slice","allCells","shouldReCenter","previousCells","edge","_updateCells","result","_objectWithoutProperties","_excluded","sourceId","find","rect","reject","handleConnect","useCallback","state","to","_manualConnectDeferre2","i","_manualConnectDeferre","useActiveTarget","unrelatedCells","setUnrelatedCells","nextUnrelated","getUnrelatedCells","prev","root","onKeydown","action","handleKeyboard","defPrefix","uniqueId","markerPrefix","handleCellMoving","handleCellMoved","handleCellResizing","handleCellResized","handleDecoratorTextEditing","_ref7","editing","texts","handleNodeBrickResize","handleZoomSlide","value","scaleTo","select","reCenter","lineConfMap","markers","useLineMarkers","ready","useReady","tabIndex","marker","MarkerComponent","key","strokeColor","CellComponent","active","onCellMoving","onCellMoved","onCellResizing","onCellResized","onDecoratorTextEditing","onNodeBrickResize","ZoomBarComponent","shadowRoot","onZoomChange","onReCenter","_EoDrawCanvas2","_set_activeTargetChangeEvent","_set_nodeMoveEvent","_set_cellMoveEvent","_set_cellResizeEvent","_set_nodeDelete","_set_cellDelete","_set_cellContextMenu","_set_decoratorTextChange","_set_scaleChange","_initClass","_applyDecs","styleTexts","styleText","zoomBarStyleText","attribute","String","Number","Boolean","o","_","has","_checkInRHS","activeCell","keyCode","which","preventDefault","reason","parent","isManualLayout","updateCandidates","previousSizeInitializedNodes","Map","previousShouldCentered","isDecoratorCell","SYMBOL_FOR_SIZE_INITIALIZED","set","nodesMap","previousNode","get","handled","downstreamNodeIds","Set","isEdgeCell","add","parentNode","undefined","downstreamNodes","rightMostNode","push","nextX","nextY","DEFAULT_NODE_GAP","totalWidth","reduce","acc","getNodeView","maxWidth","maxHeight","positionedNodesCount","hasDecorators","transformToCenter","without","dagreLayout","forceLayout","fixedPosition","center","asyncGeneratorStep","gen","_next","_throw","arg","error","done","then","fn","self","args","apply","err"],"sourceRoot":""}