@next-bricks/diagram 0.21.0 → 0.22.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bricks.json +1 -1
- package/dist/chunks/2696.830146cb.js +2 -0
- package/dist/chunks/2696.830146cb.js.map +1 -0
- package/dist/chunks/5676.68d9676c.js +2 -0
- package/dist/chunks/5676.68d9676c.js.map +1 -0
- package/dist/chunks/eo-draw-canvas.1e9bd8dc.js +2 -0
- package/dist/chunks/eo-draw-canvas.1e9bd8dc.js.map +1 -0
- package/dist/chunks/{main.ab723174.js → main.242a00e6.js} +2 -2
- package/dist/chunks/{main.ab723174.js.map → main.242a00e6.js.map} +1 -1
- package/dist/examples.json +3 -3
- package/dist/index.a52ad469.js +2 -0
- package/dist/{index.d551bc1c.js.map → index.a52ad469.js.map} +1 -1
- package/dist/manifest.json +43 -38
- package/dist/types.json +77 -2
- package/dist-types/draw-canvas/index.d.ts +10 -4
- package/dist-types/draw-canvas/interfaces.d.ts +1 -1
- package/dist-types/draw-canvas/processors/initializeCells.d.ts +2 -2
- package/dist-types/draw-canvas/processors/updateCells.d.ts +11 -0
- package/dist-types/draw-canvas/processors/updateCells.spec.d.ts +1 -0
- package/dist-types/draw-canvas/reducers/interfaces.d.ts +5 -9
- package/docs/eo-draw-canvas.md +115 -64
- package/package.json +2 -2
- package/dist/chunks/5676.6ac89c98.js +0 -2
- package/dist/chunks/5676.6ac89c98.js.map +0 -1
- package/dist/chunks/7392.1d2a5114.js +0 -2
- package/dist/chunks/7392.1d2a5114.js.map +0 -1
- package/dist/chunks/eo-draw-canvas.a84b4006.js +0 -2
- package/dist/chunks/eo-draw-canvas.a84b4006.js.map +0 -1
- package/dist/index.d551bc1c.js +0 -2
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/5676.6ac89c98.js","mappings":"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","sources":["webpack:///./src/diagram/index.tsx","webpack:///./src/editable-label/index.tsx","webpack:///./src/draw-canvas/index.tsx","webpack:///./src/experimental-node/index.tsx","webpack:///./src/editable-label/styles.shadow.css","webpack:///./src/experimental-node/styles.shadow.css"],"sourcesContent":["import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { select } from \"d3-selection\";\nimport { ZoomTransform, zoom } from \"d3-zoom\";\nimport classNames from \"classnames\";\nimport { uniqueId } from \"lodash\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport type {\n DiagramEdge,\n DiagramNode,\n LayoutOptions,\n LineConf,\n NodeBrickConf,\n PositionTuple,\n RefRepository,\n RenderedLineLabel,\n TransformLiteral,\n LineTarget,\n ConnectLineDetail,\n ConnectNodesOptions,\n ConnectLineState,\n ActiveTarget,\n RangeTuple,\n LineLabel,\n LineLabelConf,\n TextOptions,\n DragNodesOptions,\n NodeMovement,\n ManualLayoutStatus,\n LineMaskRects,\n} from \"./interfaces\";\nimport { NodeComponentGroup } from \"./NodeComponent\";\nimport { handleKeyboard } from \"./processors/handleKeyboard\";\nimport { transformToCenter } from \"./processors/transformToCenter\";\nimport { getRenderedLines } from \"./processors/getRenderedLines\";\nimport { normalizeLinesAndMarkers } from \"./processors/normalizeLinesAndMarkers\";\nimport { LineLabelComponentGroup } from \"./LineLabelComponent\";\nimport { LineComponent } from \"./LineComponent\";\nimport { MarkerComponent } from \"./MarkerComponent\";\nimport { LineMaskComponent } from \"./LineMaskComponent\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { getRenderedLineLabels } from \"./processors/getRenderedLineLabels\";\nimport { handleNodesMouseDown } from \"./processors/handleNodesMouseDown\";\nimport { DEFAULT_SCALE_RANGE_MAX, DEFAULT_SCALE_RANGE_MIN } from \"./constants\";\nimport { useRenderedDiagram } from \"./hooks/useRenderedDiagram\";\nimport { adjustLineLabels } from \"./processors/adjustLineLabels\";\nimport styleText from \"./styles.shadow.css\";\nimport { useUserView } from \"./hooks/useUserView\";\nimport { sameTarget } from \"./processors/sameTarget\";\nimport { getLineMaskRects } from \"./processors/getLineMaskRects\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\nexport interface EoDiagramProps {\n layout?: \"dagre\" | \"force\";\n nodes?: DiagramNode[];\n edges?: DiagramEdge[];\n nodeBricks?: NodeBrickConf[];\n lines?: LineConf[];\n layoutOptions?: LayoutOptions;\n connectNodes?: ConnectNodesOptions;\n dragNodes?: DragNodesOptions;\n activeTarget?: ActiveTarget | null;\n disableKeyboardAction?: boolean;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n scaleRange?: RangeTuple;\n}\n\nexport interface DiagramRef {\n callOnLineLabel(id: string, method: string, ...args: unknown[]): void;\n}\n\nexport const EoDiagramComponent = forwardRef(LegacyEoDiagramComponent);\n\n/**\n * 构件 `eo-diagram`\n */\nexport\n@defineElement(\"eo-diagram\", {\n styleTexts: [styleText],\n})\nclass EoDiagram extends ReactNextElement implements EoDiagramProps {\n /**\n * @required\n */\n @property({ type: String })\n accessor layout: \"dagre\" | \"force\" | undefined;\n\n @property({ attribute: false })\n accessor nodes: DiagramNode[] | undefined;\n\n @property({ attribute: false })\n accessor edges: DiagramEdge[] | undefined;\n\n @property({ attribute: false })\n accessor nodeBricks: NodeBrickConf[] | undefined;\n\n @property({ attribute: false })\n accessor lines: LineConf[] | undefined;\n\n @property({ attribute: false })\n accessor layoutOptions: LayoutOptions | undefined;\n\n @property({ attribute: false })\n accessor activeTarget: ActiveTarget | null | undefined;\n\n @property({ type: Boolean })\n accessor disableKeyboardAction: boolean | undefined;\n\n @property({ attribute: false })\n accessor connectNodes: ConnectNodesOptions | undefined;\n\n @property({ attribute: false })\n accessor dragNodes: DragNodesOptions | 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 @event({ type: \"node.delete\" })\n accessor #nodeDelete!: EventEmitter<DiagramNode>;\n\n #handleNodeDelete = (node: DiagramNode) => {\n this.#nodeDelete.emit(node);\n };\n\n @event({ type: \"edge.delete\" })\n accessor #edgeDelete!: EventEmitter<DiagramEdge>;\n\n #handleEdgeDelete = (edge: DiagramEdge) => {\n this.#edgeDelete.emit(edge);\n };\n\n @event({ type: \"line.click\" })\n accessor #lineClick!: EventEmitter<LineTarget>;\n\n #handleLineClick = (line: LineTarget) => {\n this.#lineClick.emit(line);\n };\n\n @event({ type: \"line.dblclick\" })\n accessor #lineDoubleClick!: EventEmitter<LineTarget>;\n\n #handleLineDoubleClick = (line: LineTarget) => {\n this.#lineDoubleClick.emit(line);\n };\n\n @event({ type: \"nodes.connect\" })\n accessor #connectNodes!: EventEmitter<ConnectLineDetail>;\n\n #handleNodesConnect = (detail: ConnectLineDetail) => {\n this.#connectNodes.emit(detail);\n };\n\n #handleSwitchActiveTarget = (target: ActiveTarget | null) => {\n if (!sameTarget(target, this.activeTarget)) {\n this.activeTarget = target;\n }\n };\n\n #diagramRef = createRef<DiagramRef>();\n\n @method()\n callOnLineLabel(id: string, method: string, ...args: unknown[]) {\n this.#diagramRef.current?.callOnLineLabel(id, method, ...args);\n }\n\n render() {\n return (\n <EoDiagramComponent\n ref={this.#diagramRef}\n layout={this.layout}\n nodes={this.nodes}\n edges={this.edges}\n nodeBricks={this.nodeBricks}\n lines={this.lines}\n layoutOptions={this.layoutOptions}\n connectNodes={this.connectNodes}\n dragNodes={this.dragNodes}\n activeTarget={this.activeTarget}\n disableKeyboardAction={this.disableKeyboardAction}\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 onNodeDelete={this.#handleNodeDelete}\n onEdgeDelete={this.#handleEdgeDelete}\n onLineClick={this.#handleLineClick}\n onLineDoubleClick={this.#handleLineDoubleClick}\n onNodesConnect={this.#handleNodesConnect}\n />\n );\n }\n}\n\nexport interface EoDiagramComponentProps extends EoDiagramProps {\n onActiveTargetChange?(target: ActiveTarget | null): void;\n onSwitchActiveTarget?(target: ActiveTarget | null): void;\n onNodeDelete?(node: DiagramNode): void;\n onEdgeDelete?(edge: DiagramEdge): void;\n onLineClick?(line: LineTarget): void;\n onLineDoubleClick?(line: LineTarget): void;\n onNodesConnect?(detail: ConnectLineDetail): void;\n}\n\nexport function LegacyEoDiagramComponent(\n {\n layout,\n nodes,\n edges,\n nodeBricks,\n lines,\n layoutOptions,\n connectNodes,\n dragNodes,\n activeTarget: _activeTarget,\n disableKeyboardAction,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onNodeDelete,\n onEdgeDelete,\n onLineClick,\n onLineDoubleClick,\n onNodesConnect,\n }: EoDiagramComponentProps,\n ref: React.Ref<DiagramRef>\n) {\n const [nodesReady, setNodesReady] = useState(false);\n const [nodesRenderId, setNodesRenderId] = useState(0);\n const [nodesRefRepository, setNodesRefRepository] =\n useState<RefRepository | null>(null);\n const [lineLabelsReady, setLineLabelsReady] = useState(false);\n const [lineLabelsRenderId, setLineLabelsRenderId] = useState(0);\n const [lineLabelsRefRepository, setLineLabelsRefRepository] =\n useState<RefRepository | null>(null);\n const [renderedLineLabels, setRenderedLineLabels] = useState<\n RenderedLineLabel[]\n >([]);\n\n const [grabbing, setGrabbing] = useState(false);\n const [transform, setTransform] = useState<TransformLiteral>({\n k: 1,\n x: 0,\n y: 0,\n });\n\n const linePathsRef = useRef(new Map<string, SVGPathElement | null>());\n\n const rootRef = useRef<HTMLDivElement>(null);\n const nodesRef = useRef<HTMLDivElement>(null);\n const [centered, setCentered] = useState(false);\n\n const { userViewReady, userViewNodesMap, saveUserView } = useUserView(\n dragNodes?.save\n );\n\n const [connectLineTo, setConnectLineTo] = useState<PositionTuple>([0, 0]);\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n const [manualLayoutStatus, setManualLayoutStatus] =\n useState<ManualLayoutStatus>(\"initial\");\n const [nodeMovement, setNodeMovement] = useState<NodeMovement | null>(null);\n\n useImperativeHandle(ref, () => ({\n callOnLineLabel(id, method, ...args) {\n (\n lineLabelsRefRepository?.get(id)\n ?.firstElementChild as unknown as Record<string, Function>\n )?.[method](...args);\n },\n }));\n\n useEffect(() => {\n const onNodesMouseDown = (event: MouseEvent) => {\n handleNodesMouseDown(event, {\n nodes,\n nodesRefRepository,\n connectNodes,\n dragNodes,\n scale: transform.k,\n setConnectLineState,\n setConnectLineTo,\n setManualLayoutStatus,\n setNodeMovement,\n onSwitchActiveTarget,\n onNodesConnect,\n });\n };\n // Bind mousedown event manually, since the React event handler can't work with\n // d3-zoom inside shadow DOM.\n const nodesContainer = nodesRef.current;\n nodesContainer?.addEventListener(\"mousedown\", onNodesMouseDown);\n return () => {\n nodesContainer?.removeEventListener(\"mousedown\", onNodesMouseDown);\n };\n }, [\n nodes,\n connectNodes,\n dragNodes,\n transform.k,\n nodesRefRepository,\n onNodesConnect,\n onSwitchActiveTarget,\n ]);\n\n const { normalizedLines, normalizedLinesMap, markers } = useMemo(\n () => normalizeLinesAndMarkers(edges, lines),\n [edges, lines]\n );\n\n const lineLabels = useMemo(() => {\n return normalizedLines.flatMap(({ line: { text, label, $id }, edge }) => {\n if (!text && !label) {\n return [] as LineLabel[];\n }\n\n let key: \"label\" | \"text\";\n let list: LineLabelConf[] | TextOptions[];\n if (label) {\n key = \"label\";\n list = ([] as LineLabelConf[]).concat(label);\n } else {\n key = \"text\";\n list = ([] as TextOptions[]).concat(text!);\n }\n\n return list.map<LineLabel>((item) => ({\n [key as \"label\"]: item as LineLabelConf,\n id: `${$id}-${item.placement ?? \"center\"}`,\n edge,\n }));\n });\n }, [normalizedLines]);\n\n const { nodes: renderedNodes, edges: renderedEdges } = useRenderedDiagram({\n layout,\n nodes,\n edges,\n manualLayoutStatus,\n userViewReady,\n userViewNodesMap,\n nodeMovement,\n nodesRefRepository,\n lineLabelsRefRepository,\n normalizedLinesMap,\n layoutOptions,\n nodesRenderId,\n lineLabelsRenderId,\n });\n\n useEffect(\n () => {\n if (manualLayoutStatus === \"finished\") {\n saveUserView(\n renderedNodes.map((node) => ({\n id: node.id,\n x: node.x,\n y: node.y,\n }))\n );\n }\n },\n // Only save user view when manual layout is just finished.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [manualLayoutStatus]\n );\n\n const renderedLines = useMemo(\n () => getRenderedLines(renderedEdges, renderedNodes, normalizedLines),\n [normalizedLines, renderedNodes, renderedEdges]\n );\n\n const newActiveTarget = _activeTarget ?? null;\n const [activeTarget, setActiveTarget] = useState<ActiveTarget | null>(\n newActiveTarget\n );\n\n useEffect(() => {\n setActiveTarget((previous) =>\n sameTarget(previous, newActiveTarget) ? previous : newActiveTarget\n );\n }, [newActiveTarget]);\n\n const activeTargetChangeInitialized = useRef(false);\n useEffect(() => {\n if (!activeTargetChangeInitialized.current) {\n activeTargetChangeInitialized.current = true;\n return;\n }\n onActiveTargetChange?.(activeTarget);\n }, [activeTarget, onActiveTargetChange]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || disableKeyboardAction) {\n return;\n }\n const onKeydown = (event: KeyboardEvent) => {\n const action = handleKeyboard(event, {\n renderedNodes,\n activeTarget,\n });\n\n if (action?.action === \"delete-node\") {\n onNodeDelete?.(action.node);\n } else if (action?.action === \"delete-edge\") {\n onEdgeDelete?.(action.edge);\n } else if (action?.action === \"switch-active-node\" && action.node) {\n onSwitchActiveTarget?.({ type: \"node\", nodeId: action.node.id });\n }\n };\n root.addEventListener(\"keydown\", onKeydown);\n return () => {\n root.removeEventListener(\"keydown\", onKeydown);\n };\n }, [\n activeTarget,\n renderedNodes,\n disableKeyboardAction,\n onSwitchActiveTarget,\n onNodeDelete,\n onEdgeDelete,\n ]);\n\n const handleNodesRendered = useCallback(\n (refRepository: RefRepository | null) => {\n if (refRepository) {\n setNodesRenderId((previous) => previous + 1);\n setNodesRefRepository(refRepository);\n }\n setNodesReady((previous) => previous || !!refRepository);\n },\n []\n );\n\n const handleLineLabelsRendered = useCallback(\n (refRepository: RefRepository | null) => {\n if (refRepository) {\n setLineLabelsRenderId((previous) => previous + 1);\n setLineLabelsRefRepository(refRepository);\n }\n setLineLabelsReady((previous) => previous || !!refRepository);\n },\n []\n );\n\n const scaleRange = useMemo(\n () =>\n _scaleRange ??\n ([DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX] as RangeTuple),\n [_scaleRange]\n );\n\n const zoomer = useMemo(() => zoom<HTMLDivElement, unknown>(), []);\n\n useEffect(() => {\n let moved = false;\n zoomer\n .scaleExtent(zoomable ? scaleRange : [1, 1])\n .on(\"start\", () => {\n moved = false;\n setGrabbing(true);\n })\n .on(\"zoom\", (e: { transform: TransformLiteral }) => {\n moved = true;\n setTransform(e.transform);\n })\n .on(\"end\", () => {\n setGrabbing(false);\n if (!moved) {\n onSwitchActiveTarget?.(null);\n }\n });\n }, [onSwitchActiveTarget, scaleRange, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const rootSelection = select(root);\n\n const unsetZoom = () => {\n rootSelection\n .on(\".zoom\", null)\n .on(\".zoom.custom\", null)\n .on(\"wheel\", null);\n };\n\n if (!(zoomable || scrollable || pannable)) {\n unsetZoom();\n return;\n }\n\n if (zoomable || scrollable) {\n // Do not override default d3 zoom handler.\n // Only handles *panning*\n rootSelection.on(\n \"wheel.zoom.custom\",\n (e: WheelEvent & { wheelDeltaX: number; wheelDeltaY: number }) => {\n // Mac OS trackpad pinch event is emitted as a wheel.zoom and d3.event.ctrlKey set to true\n if (!e.ctrlKey) {\n // Stop immediate propagation for default d3 zoom handler\n e.stopImmediatePropagation();\n if (scrollable) {\n e.preventDefault();\n zoomer.translateBy(\n rootSelection,\n e.wheelDeltaX / 5,\n e.wheelDeltaY / 5\n );\n }\n }\n // zoomer.scaleBy(rootSelection, Math.pow(2, defaultWheelDelta(e)))\n }\n );\n }\n\n rootSelection\n .call(zoomer)\n .on(\"wheel\", (e: WheelEvent) => e.preventDefault())\n .on(\"dblclick.zoom\", null);\n\n if (!pannable) {\n rootSelection\n .on(\"mousedown.zoom\", null)\n .on(\"touchstart.zoom\", null)\n .on(\"touchmove.zoom\", null)\n .on(\"touchend.zoom\", null);\n }\n\n return unsetZoom;\n }, [pannable, scrollable, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (renderedNodes.length === 0 || !root || centered) {\n return;\n }\n const { k, x, y } = transformToCenter(renderedNodes, {\n canvasWidth: root.clientWidth,\n canvasHeight: root.clientHeight,\n scaleRange: zoomable ? scaleRange : undefined,\n });\n zoomer.transform(select(root), new ZoomTransform(k, x, y));\n setCentered(true);\n }, [centered, renderedNodes, scaleRange, zoomable, zoomer]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n const maskPrefix = `${defPrefix}mask-`;\n const activeLineMarkerPrefix = `${defPrefix}active-line-`;\n\n useEffect(() => {\n setRenderedLineLabels((previous) =>\n getRenderedLineLabels(previous, renderedLines, linePathsRef.current)\n );\n }, [renderedLines]);\n\n const [lineMaskRects, setLineMaskRects] = React.useState<LineMaskRects>(\n new Map()\n );\n\n useEffect(() => {\n if (!lineLabelsRefRepository) {\n return;\n }\n const updateLineMaskRects = () => {\n setLineMaskRects(\n getLineMaskRects(renderedLineLabels, lineLabelsRefRepository)\n );\n };\n\n adjustLineLabels(renderedLineLabels, lineLabelsRefRepository);\n\n const observer = new ResizeObserver(updateLineMaskRects);\n for (const lineLabel of lineLabelsRefRepository.values()) {\n observer.observe(lineLabel);\n }\n return () => {\n observer.disconnect();\n };\n }, [lineLabelsRenderId, lineLabelsRefRepository, renderedLineLabels]);\n\n if (layout !== \"dagre\" && layout !== \"force\") {\n return <div>{`Diagram layout not supported: \"${layout}\"`}</div>;\n }\n\n return (\n <div\n className={classNames(\"diagram\", {\n ready: nodesReady && centered,\n grabbing,\n pannable,\n })}\n tabIndex={-1}\n ref={rootRef}\n >\n <svg width=\"100%\" height=\"100%\" className=\"lines\">\n <defs>\n {markers.map(({ type, strokeColor }, index) => (\n <MarkerComponent\n key={index}\n id={`${markerPrefix}${index}`}\n type={type}\n strokeColor={strokeColor}\n />\n ))}\n {[...lineMaskRects].map(([lineId, rects]) => (\n <LineMaskComponent\n key={lineId}\n lineId={lineId}\n rects={rects}\n maskPrefix={maskPrefix}\n renderedLineLabels={renderedLineLabels}\n />\n ))}\n <marker\n id={`${activeLineMarkerPrefix}start`}\n viewBox=\"0 0 8 8\"\n refX={4}\n refY={4}\n markerWidth={8}\n markerHeight={8}\n orient=\"auto\"\n >\n <path\n d=\"M 0.5 0.5 H 7.5 V 7.5 H 0.5 Z\"\n stroke=\"var(--palette-gray-7)\"\n strokeWidth={1}\n fill=\"var(--palette-gray-1)\"\n />\n </marker>\n <marker\n id={`${activeLineMarkerPrefix}end`}\n viewBox=\"0 0 14 8\"\n refX={3}\n refY={4}\n markerWidth={14}\n markerHeight={8}\n orient=\"auto\"\n >\n <path\n d=\"M 0.5 1.5 L 5.5 4 L 0.5 6.5 z\"\n stroke=\"var(--palette-blue-3)\"\n strokeWidth={1}\n fill=\"var(--palette-blue-3)\"\n />\n <path\n d=\"M 6.5 0.5 H 13.5 V 7.5 H 6.5 Z\"\n stroke=\"var(--palette-gray-7)\"\n strokeWidth={1}\n fill=\"var(--palette-gray-1)\"\n />\n </marker>\n </defs>\n <g\n transform={`translate(${transform.x} ${transform.y}) scale(${transform.k})`}\n >\n {renderedLines.map((line) => (\n <LineComponent\n key={line.line.$id}\n line={line}\n linePaths={linePathsRef.current}\n lineMaskRects={lineMaskRects}\n maskPrefix={maskPrefix}\n markerPrefix={markerPrefix}\n activeLineMarkerPrefix={activeLineMarkerPrefix}\n active={\n activeTarget?.type === \"edge\" &&\n activeTarget.edge.source === line.edge.source &&\n activeTarget.edge.target === line.edge.target\n }\n activeRelated={\n activeTarget?.type === \"node\" &&\n (line.edge.source === activeTarget.nodeId ||\n line.edge.target === activeTarget.nodeId)\n }\n onLineClick={onLineClick}\n onLineDoubleClick={onLineDoubleClick}\n />\n ))}\n </g>\n </svg>\n <div\n className={classNames(\"line-labels\", { ready: lineLabelsReady })}\n style={{\n left: transform.x,\n top: transform.y,\n transform: `scale(${transform.k})`,\n }}\n >\n <LineLabelComponentGroup\n labels={lineLabels}\n onRendered={handleLineLabelsRendered}\n />\n </div>\n <div\n className=\"nodes\"\n ref={nodesRef}\n style={{\n left: transform.x,\n top: transform.y,\n transform: `scale(${transform.k})`,\n }}\n >\n <NodeComponentGroup\n nodes={nodes}\n nodeBricks={nodeBricks}\n // nodePositions={nodePositions}\n onRendered={handleNodesRendered}\n />\n </div>\n <ConnectLineComponent\n connectLineState={connectLineState}\n connectLineTo={connectLineTo}\n markerPrefix={markerPrefix}\n />\n </div>\n );\n}\n","import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport classNames from \"classnames\";\nimport styleText from \"./styles.shadow.css\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\nexport interface EditableLabelProps {\n label?: string;\n type?: LabelType;\n}\n\nexport type LabelType = \"line\" | \"default\";\n\nexport interface EditableLabelRef {\n enableEditing(): void;\n}\n\nexport const EditableLabelComponent = forwardRef(LegacyEditableLabelComponent);\n\n/**\n * 构件 `diagram.editable-label`\n */\nexport\n@defineElement(\"diagram.editable-label\", {\n styleTexts: [styleText],\n})\nclass EditableLabel extends ReactNextElement implements EditableLabelProps {\n @property()\n accessor label: string | undefined;\n\n @property({ render: false })\n accessor type: LabelType | undefined;\n\n @event({ type: \"label.editing.change\" })\n accessor #labelEditingChange!: EventEmitter<boolean>;\n\n #handleLabelEditingChange = (value: boolean) => {\n this.#labelEditingChange.emit(value);\n };\n\n @event({ type: \"label.change\" })\n accessor #labelChange!: EventEmitter<string>;\n\n #handleLabelChange = (value: string) => {\n this.#labelChange.emit(value);\n };\n\n @method()\n enableEditing() {\n this.#editableLabelRef.current?.enableEditing();\n }\n\n #editableLabelRef = createRef<EditableLabelRef>();\n\n render() {\n return (\n <EditableLabelComponent\n ref={this.#editableLabelRef}\n label={this.label}\n onLabelEditingChange={this.#handleLabelEditingChange}\n onLabelChange={this.#handleLabelChange}\n />\n );\n }\n}\n\nexport interface EditableLabelComponentProps extends EditableLabelProps {\n onLabelEditingChange?(value: boolean): void;\n onLabelChange?(value: string): void;\n}\n\nexport function LegacyEditableLabelComponent(\n {\n label: _label,\n onLabelChange,\n onLabelEditingChange,\n }: EditableLabelComponentProps,\n ref: React.Ref<EditableLabelRef>\n) {\n const label = _label ?? \"\";\n const [currentLabel, setCurrentLabel] = useState<string>(label);\n const [editingLabel, setEditingLabel] = useState(false);\n const editingLabelInitialized = useRef(false);\n const [shouldEmitLabelChange, setShouldEmitLabelChange] = useState(false);\n const labelInputRef = useRef<HTMLInputElement>(null);\n\n useImperativeHandle(ref, () => ({\n enableEditing() {\n setEditingLabel(true);\n },\n }));\n\n useEffect(() => {\n setCurrentLabel(label);\n }, [label]);\n\n const handleEditLabel = useCallback((e: React.MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setEditingLabel(true);\n }, []);\n\n useEffect(() => {\n if (editingLabel) {\n // Prevent scroll when focusing.\n // Otherwise the diagram svg may be clipped in Chrome.\n labelInputRef.current?.focus({ preventScroll: true });\n labelInputRef.current?.select();\n }\n }, [editingLabel]);\n\n useEffect(() => {\n if (editingLabelInitialized.current) {\n onLabelEditingChange?.(editingLabel);\n } else {\n editingLabelInitialized.current = true;\n }\n }, [editingLabel, onLabelEditingChange]);\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n setCurrentLabel(event.target.value);\n },\n []\n );\n\n const handleInputKeydown = useCallback((event: React.KeyboardEvent) => {\n const key =\n event.key ||\n /* istanbul ignore next: compatibility */ event.keyCode ||\n /* istanbul ignore next: compatibility */ event.which;\n if (key === \"Enter\" || key === 13) {\n labelInputRef.current?.blur();\n }\n }, []);\n\n const handleInputBlur = useCallback(() => {\n setEditingLabel(false);\n setShouldEmitLabelChange(true);\n }, []);\n\n useEffect(() => {\n if (shouldEmitLabelChange) {\n onLabelChange?.(currentLabel);\n setShouldEmitLabelChange(false);\n }\n }, [currentLabel, onLabelChange, shouldEmitLabelChange]);\n\n const stopPropagation = useCallback((e: React.MouseEvent) => {\n e.stopPropagation();\n }, []);\n\n return (\n <div\n className={classNames(\"label\", {\n editing: editingLabel,\n empty: !currentLabel,\n })}\n onDoubleClick={stopPropagation}\n onMouseDown={stopPropagation}\n >\n <input\n className=\"label-input\"\n value={currentLabel}\n ref={labelInputRef}\n onChange={handleInputChange}\n onKeyDown={handleInputKeydown}\n onBlur={handleInputBlur}\n />\n <div className=\"label-text\" onDoubleClick={handleEditLabel}>\n {currentLabel}\n </div>\n </div>\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 { select } from \"d3-selection\";\nimport { ZoomTransform, zoom } from \"d3-zoom\";\nimport classNames from \"classnames\";\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} 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 styleText from \"./styles.shadow.css\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { initializeCells } from \"./processors/initializeCells\";\nimport { transformToCenter } from \"./processors/transformToCenter\";\n\nconst DEFAULT_NODE_SIZE = 20;\nconst DEFAULT_AREA_WIDTH = 100;\nconst DEFAULT_AREA_HEIGHT = 60;\nconst DEFAULT_SCALE_RANGE_MIN = 0.5;\nconst DEFAULT_SCALE_RANGE_MAX = 2;\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 defaultNodeSize?: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n activeTarget?: ActiveTarget | null;\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}\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 const EoDrawCanvasComponent = React.forwardRef(\n LegacyEoDrawCanvasComponent\n);\n\n/**\n * 用于手工绘图的画布。\n *\n * 注意:将配套另外一个用于展示的画布构件。\n */\nexport\n@defineElement(\"eo-draw-canvas\", {\n styleTexts: [styleText],\n})\nclass EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | 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 @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 /**\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: NodeCell = {\n type: \"node\",\n id,\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: size?.[0] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE,\n height: size?.[1] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE,\n },\n data,\n useBrick,\n };\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 }: 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 },\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 firstNode = nodes[0];\n const width =\n firstNode.size?.[0] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE;\n const height =\n firstNode.size?.[1] ?? this.defaultNodeSize?.[1] ?? DEFAULT_NODE_SIZE;\n const gap = 20;\n // Todo(steve): canvas size\n const canvasHeight = 600;\n const rows = Math.floor(canvasHeight / (height + gap));\n // Assert: nodes are all brick nodes (no shape nodes)\n const positionedNodes = nodes.map<NodeCell>(\n ({ size, useBrick, ...node }, index) => ({\n ...node,\n type: \"node\",\n view: {\n x: Math.floor(index / rows) * (width + gap) + gap,\n y: (index % rows) * (height + gap) + gap,\n width: size?.[0] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE,\n height: size?.[1] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE,\n },\n useBrick,\n })\n );\n this.#canvasRef.current?.addNodes(positionedNodes);\n return positionedNodes;\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 updateCells(cells: InitialCell[]): void {\n this.#canvasRef.current!.updateCells(cells);\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 cells={this.cells}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n activeTarget={this.activeTarget}\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 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 onScaleChange(scale: number): void;\n}\n\nexport interface DrawCanvasRef {\n dropNode(node: NodeCell): void;\n dropDecorator(decorator: DecoratorCell): void;\n addNodes(nodes: NodeCell[]): void;\n addEdge(edge: EdgeCell): void;\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail>;\n updateCells(cells: InitialCell[]): void;\n getTransform(): TransformLiteral;\n}\n\nfunction LegacyEoDrawCanvasComponent(\n {\n host,\n cells: initialCells,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n activeTarget: _activeTarget,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellMove,\n onCellResize,\n onCellDelete,\n onCellContextMenu,\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 const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n const manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n\n const [grabbing, setGrabbing] = useState(false);\n const [transform, setTransform] = useState<TransformLiteral>({\n k: 1,\n x: 0,\n y: 0,\n });\n const [centered, setCentered] = useState(false);\n\n useEffect(() => {\n onScaleChange(transform.k);\n }, [onScaleChange, transform.k]);\n\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n const scaleRange = useMemo(\n () =>\n _scaleRange ??\n ([DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX] as RangeTuple),\n [_scaleRange]\n );\n\n const zoomer = useMemo(() => zoom<SVGSVGElement, unknown>(), []);\n\n // istanbul ignore next: d3-zoom currently hard to test\n useEffect(() => {\n let moved = false;\n zoomer\n .scaleExtent(zoomable ? scaleRange : [1, 1])\n .on(\"start\", () => {\n moved = false;\n setGrabbing(true);\n })\n .on(\"zoom\", (e: { transform: TransformLiteral }) => {\n moved = true;\n setTransform(e.transform);\n })\n .on(\"end\", () => {\n setGrabbing(false);\n if (!moved) {\n onSwitchActiveTarget?.(null);\n }\n });\n }, [onSwitchActiveTarget, scaleRange, zoomable, zoomer]);\n\n // istanbul ignore next: d3-zoom currently hard to test\n useEffect(() => {\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const rootSelection = select(root);\n\n const unsetZoom = () => {\n rootSelection\n .on(\".zoom\", null)\n .on(\".zoom.custom\", null)\n .on(\"wheel\", null);\n };\n\n if (!(zoomable || scrollable || pannable)) {\n unsetZoom();\n return;\n }\n\n if (zoomable || scrollable) {\n // Do not override default d3 zoom handler.\n // Only handles *panning*\n rootSelection.on(\n \"wheel.zoom.custom\",\n (e: WheelEvent & { wheelDeltaX: number; wheelDeltaY: number }) => {\n // Mac OS trackpad pinch event is emitted as a wheel.zoom and d3.event.ctrlKey set to true\n if (!e.ctrlKey) {\n // Stop immediate propagation for default d3 zoom handler\n e.stopImmediatePropagation();\n if (scrollable) {\n e.preventDefault();\n zoomer.translateBy(\n rootSelection,\n e.wheelDeltaX / 5,\n e.wheelDeltaY / 5\n );\n }\n }\n // zoomer.scaleBy(rootSelection, Math.pow(2, defaultWheelDelta(e)))\n }\n );\n }\n\n rootSelection\n .call(zoomer)\n .on(\"wheel\", (e: WheelEvent) => e.preventDefault())\n .on(\"dblclick.zoom\", null)\n .on(\"mousedown.zoom\", null);\n\n if (!pannable) {\n rootSelection\n .on(\"touchstart.zoom\", null)\n .on(\"touchmove.zoom\", null)\n .on(\"touchend.zoom\", null);\n }\n\n return unsetZoom;\n }, [pannable, scrollable, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || centered) {\n return;\n }\n const { k, x, y } = transformToCenter(cells, {\n canvasWidth: root.clientWidth,\n canvasHeight: root.clientHeight,\n scaleRange: zoomable ? scaleRange : undefined,\n });\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n // jsdom doesn't support svg baseVal yet.\n // https://github.com/jsdom/jsdom/issues/2531\n zoomer.transform(select(root), new ZoomTransform(k, x, y));\n }\n setCentered(true);\n }, [cells, centered, scaleRange, zoomable, zoomer]);\n\n useImperativeHandle(\n ref,\n () => ({\n dropNode(node) {\n dispatch({ type: \"drop-node\", payload: node });\n },\n dropDecorator(decorator) {\n dispatch({ type: \"drop-decorator\", payload: decorator });\n },\n addNodes(nodes) {\n dispatch({ type: \"add-nodes\", payload: nodes });\n },\n addEdge(edge) {\n dispatch({ type: \"add-edge\", payload: edge });\n },\n updateCells(cells) {\n dispatch({ type: \"update-all\", payload: { cells, defaultNodeSize } });\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, defaultNodeSize, 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 newActiveTarget = _activeTarget ?? null;\n const [activeTarget, setActiveTarget] = useState<ActiveTarget | null>(\n newActiveTarget\n );\n\n useEffect(() => {\n setActiveTarget((previous) =>\n sameTarget(previous, newActiveTarget) ? previous : newActiveTarget\n );\n }, [newActiveTarget]);\n\n const activeTargetChangeInitialized = useRef(false);\n useEffect(() => {\n if (!activeTargetChangeInitialized.current) {\n activeTargetChangeInitialized.current = true;\n return;\n }\n onActiveTargetChange(activeTarget);\n }, [activeTarget, onActiveTargetChange]);\n\n useEffect(() => {\n if (!activeTarget) {\n return;\n }\n const resetActiveTarget = (e: MouseEvent) => {\n const path = e.composedPath();\n const cellsContainerIndex = path.indexOf(cellsRef.current!);\n // Reset active target to null when clicking outside of the cells container,\n // Or inside the cells container but not on any cell.\n if (cellsContainerIndex <= 0) {\n setActiveTarget(null);\n }\n };\n document.addEventListener(\"click\", resetActiveTarget);\n return () => {\n document.removeEventListener(\"click\", resetActiveTarget);\n };\n }, [activeTarget]);\n\n useEffect(() => {\n const root = rootRef.current;\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, onCellDelete]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n const markerEnd = `${markerPrefix}1`;\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 return (\n // Todo(steve): canvas size\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable })}\n tabIndex={-1}\n >\n <defs>\n <MarkerComponent id={markerEnd} type=\"arrow\" strokeColor=\"gray\" />\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 cell={cell}\n cells={cells}\n defaultNodeBricks={defaultNodeBricks}\n defaultEdgeLines={defaultEdgeLines}\n transform={transform}\n markerEnd={markerEnd}\n active={sameTarget(activeTarget, cell)}\n onCellMoving={handleCellMoving}\n onCellMoved={handleCellMoved}\n onCellResizing={handleCellResizing}\n onCellResized={handleCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n />\n ))}\n </g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={markerEnd}\n onConnect={handleConnect}\n />\n </g>\n </svg>\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","// istanbul ignore file: experimental only\nimport React, { useCallback } from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport type { PositionTuple } from \"../diagram/interfaces\";\nimport styleText from \"./styles.shadow.css\";\nimport type { DecoratorType } from \"../draw-canvas/interfaces\";\n\nconst { defineElement, property, event } = createDecorators();\n\ntype ExperimentalUsage = \"library\" | \"dragging\" | \"default\";\ntype NodeStatus = \"highlighted\" | \"faded\" | \"default\";\n\nexport interface ExperimentalNodeProps {\n usage?: ExperimentalUsage;\n status?: NodeStatus;\n}\n\n/**\n * 构件 `diagram.experimental-node`\n */\nexport\n@defineElement(\"diagram.experimental-node\", {\n styleTexts: [styleText],\n})\nclass ExperimentalNode\n extends ReactNextElement\n implements ExperimentalNodeProps\n{\n @property()\n accessor usage: ExperimentalUsage | undefined;\n\n // 最终节点应该统一实现这个字段,保持类型一致\n @property({ type: String, render: false })\n accessor status: NodeStatus | undefined;\n\n // 最终节点应该统一实现这个字段,保持类型一致\n @property({ type: String })\n accessor decorator: DecoratorType | undefined;\n\n @event({ type: \"drag.start\" })\n accessor #dragStartEvent!: EventEmitter<PositionTuple>;\n\n #handleDragStart = (position: PositionTuple) => {\n this.#dragStartEvent.emit(position);\n };\n\n @event({ type: \"drag.move\" })\n accessor #dragMoveEvent!: EventEmitter<PositionTuple>;\n\n #handleDragMove = (position: PositionTuple) => {\n this.#dragMoveEvent.emit(position);\n };\n\n @event({ type: \"drag.end\" })\n accessor #dragEndEvent!: EventEmitter<PositionTuple>;\n\n #handleDragEnd = (position: PositionTuple) => {\n this.#dragEndEvent.emit(position);\n };\n\n render() {\n return (\n <ExperimentalNodeComponent\n usage={this.usage}\n onDragStart={this.#handleDragStart}\n onDragMove={this.#handleDragMove}\n onDragEnd={this.#handleDragEnd}\n />\n );\n }\n}\n\nexport interface ExperimentalNodeComponentProps extends ExperimentalNodeProps {\n onDragStart?(position: PositionTuple): void;\n onDragMove?(position: PositionTuple): void;\n onDragEnd?(position: PositionTuple): void;\n}\n\nexport function ExperimentalNodeComponent({\n usage,\n onDragStart,\n onDragMove,\n onDragEnd,\n}: ExperimentalNodeComponentProps) {\n const handleMouseDown = useCallback(\n (event: React.MouseEvent) => {\n if (usage !== \"library\") {\n return;\n }\n event.stopPropagation();\n event.preventDefault();\n const from: PositionTuple = [event.clientX, event.clientY];\n let moved = false;\n const onMouseMove = (e: MouseEvent) => {\n if (!moved) {\n moved = (e.clientX - from[0]) ** 2 + (e.clientY - from[1]) ** 2 >= 9;\n if (moved) {\n onDragStart?.([e.clientX, e.clientY]);\n }\n }\n if (moved) {\n onDragMove?.([e.clientX, e.clientY]);\n }\n };\n const onMouseUp = (e: MouseEvent) => {\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mouseup\", onMouseUp);\n if (moved) {\n onDragEnd?.([e.clientX, e.clientY]);\n }\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mouseup\", onMouseUp);\n },\n [onDragEnd, onDragMove, onDragStart, usage]\n );\n\n return (\n <div onMouseDown={handleMouseDown}>\n <slot />\n </div>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block;--local-label-line-height:inherit;--local-label-font-size:inherit;--local-label-color:inherit;--local-label-font-weight:inherit}:host([hidden]){display:none}:host([type=\"line\"]){--local-label-line-height:18px;--local-label-font-size:11px;--local-label-color:var(--color-secondary-text);--local-label-font-weight:400}*{box-sizing:border-box}.label{max-width:168px;margin:-3px}.label-text,\n.label-input{width:100%;height:24px;padding:3px;border:none;line-height:var(--local-label-line-height);font-size:var(--local-label-font-size);color:var(--local-label-color);font-weight:var(--local-label-font-weight);text-align:center;font-family:inherit;cursor:text;-webkit-user-select:text;-moz-user-select:text;user-select:text}.label-text{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.label.editing .label-text,\n.label.empty:not(.editing) .label-text,\n.label:not(.editing) .label-input{display:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `*{box-sizing:border-box}:host{display:block;border:1px solid var(--palette-gray-5);cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none}:host([hidden]){display:none}:host([usage=\"dragging\"]){opacity:0.75;position:fixed}:host(:not([usage=\"library\"])){background:var(--palette-gray-3);width:60px;height:60px}:host([usage=\"library\"]){width:180px;height:30px;margin-bottom:10px}div{width:100%;height:100%;display:flex;align-items:center;justify-content:center}:host([status=\"highlighted\"]){color:var(--palette-blue-5);background:var(--palette-blue-1);border-color:1px solid var(--palette-blue-4)}:host([status=\"faded\"]){opacity:0.3}:host([decorator=\"area\"]){width:100px;height:60px;background:rgba(119,141,195,0.1);border:none}:host([decorator=\"text\"]){width:auto;height:auto;background:none;border:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["_EoDiagram","defineElement","property","event","method","createDecorators","EoDiagramComponent","forwardRef","LegacyEoDiagramComponent","_classDecs","styleTexts","styleText","_dec","type","String","_dec2","attribute","_dec3","_dec4","_dec5","_dec6","_dec7","_dec8","Boolean","_dec9","_dec10","_dec11","_dec12","_dec13","_dec14","_dec15","_dec16","_dec17","_dec18","_dec19","_dec20","_dec21","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_O","_activeTargetChangeEvent","_handleActiveTargetChange","_P","_nodeDelete","_handleNodeDelete","_Q","_edgeDelete","_handleEdgeDelete","_R","_lineClick","_handleLineClick","_S","_lineDoubleClick","_handleLineDoubleClick","_T","_connectNodes","_handleNodesConnect","_handleSwitchActiveTarget","_diagramRef","EoDiagram","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","get","_get_connectNodes2","set","_set_connectNodes2","_get_lineDoubleClick2","_set_lineDoubleClick2","_get_lineClick2","_set_lineClick2","_get_edgeDelete2","_set_edgeDelete2","_get_nodeDelete2","_set_nodeDelete2","_get_activeTargetChangeEvent2","_set_activeTargetChangeEvent2","writable","value","_initProto","_init_layout","_init_nodes","_init_edges","_init_nodeBricks","_init_lines","_init_layoutOptions","_init_activeTarget","_init_disableKeyboardAction","_init_connectNodes","_init_dragNodes","_init_zoomable","_init_scrollable","_init_pannable","_init_scaleRange","_init_activeTargetChangeEvent","target","_classPrivateFieldGet","this","emit","_init_nodeDelete","node","_init_edgeDelete","edge","_init_lineClick","line","_init_lineDoubleClick","_init_connectNodes2","detail","sameTarget","activeTarget","createRef","layout","v","_classPrivateFieldSet","nodes","edges","nodeBricks","lines","layoutOptions","disableKeyboardAction","connectNodes","dragNodes","zoomable","scrollable","pannable","scaleRange","callOnLineLabel","id","_classPrivateFieldGet2","_len","length","args","Array","_key","current","render","React","ref","onActiveTargetChange","onSwitchActiveTarget","onNodeDelete","onEdgeDelete","onLineClick","onLineDoubleClick","onNodesConnect","_set_activeTargetChangeEvent","_get_activeTargetChangeEvent","_set_nodeDelete","_get_nodeDelete","_set_edgeDelete","_get_edgeDelete","_set_lineClick","_get_lineClick","_set_lineDoubleClick","_get_lineDoubleClick","_set_connectNodes","_get_connectNodes","_ref","_activeTarget","_scaleRange","nodesReady","setNodesReady","useState","nodesRenderId","setNodesRenderId","nodesRefRepository","setNodesRefRepository","lineLabelsReady","setLineLabelsReady","lineLabelsRenderId","setLineLabelsRenderId","lineLabelsRefRepository","setLineLabelsRefRepository","renderedLineLabels","setRenderedLineLabels","grabbing","setGrabbing","transform","setTransform","k","x","y","linePathsRef","useRef","Map","rootRef","nodesRef","centered","setCentered","userViewReady","userViewNodesMap","saveUserView","useUserView","save","connectLineTo","setConnectLineTo","connectLineState","setConnectLineState","manualLayoutStatus","setManualLayoutStatus","nodeMovement","setNodeMovement","useImperativeHandle","_lineLabelsRefReposit","_len2","_key2","firstElementChild","useEffect","onNodesMouseDown","handleNodesMouseDown","scale","nodesContainer","addEventListener","removeEventListener","normalizedLines","normalizedLinesMap","markers","useMemo","normalizeLinesAndMarkers","lineLabels","flatMap","_ref2","key","list","text","label","$id","concat","map","item","_item$placement","placement","renderedNodes","renderedEdges","useRenderedDiagram","renderedLines","getRenderedLines","newActiveTarget","setActiveTarget","previous","activeTargetChangeInitialized","root","onKeydown","action","handleKeyboard","nodeId","handleNodesRendered","useCallback","refRepository","handleLineLabelsRendered","DEFAULT_SCALE_RANGE_MIN","DEFAULT_SCALE_RANGE_MAX","zoomer","zoom","moved","scaleExtent","on","e","rootSelection","select","unsetZoom","ctrlKey","stopImmediatePropagation","preventDefault","translateBy","wheelDeltaX","wheelDeltaY","call","transformToCenter","canvasWidth","clientWidth","canvasHeight","clientHeight","undefined","ZoomTransform","defPrefix","uniqueId","markerPrefix","maskPrefix","activeLineMarkerPrefix","getRenderedLineLabels","lineMaskRects","setLineMaskRects","adjustLineLabels","observer","ResizeObserver","updateLineMaskRects","getLineMaskRects","lineLabel","values","observe","disconnect","className","classNames","ready","tabIndex","width","height","_ref3","index","strokeColor","MarkerComponent","_ref4","lineId","rects","LineMaskComponent","viewBox","refX","refY","markerWidth","markerHeight","orient","d","stroke","strokeWidth","fill","LineComponent","linePaths","active","source","activeRelated","style","left","top","LineLabelComponentGroup","labels","onRendered","NodeComponentGroup","ConnectLineComponent","_EoDiagram2","c","_initClass","_applyDecs","o","_","has","_checkInRHS","_EditableLabel","EditableLabelComponent","LegacyEditableLabelComponent","_labelEditingChange","_handleLabelEditingChange","_labelChange","_handleLabelChange","_editableLabelRef","EditableLabel","_get_labelChange2","_set_labelChange2","_get_labelEditingChange2","_set_labelEditingChange2","_init_label","_init_type","_init_labelEditingChange","_init_labelChange","enableEditing","onLabelEditingChange","onLabelChange","_set_labelEditingChange","_get_labelEditingChange","_set_labelChange","_get_labelChange","_label","currentLabel","setCurrentLabel","editingLabel","setEditingLabel","editingLabelInitialized","shouldEmitLabelChange","setShouldEmitLabelChange","labelInputRef","handleEditLabel","stopPropagation","_labelInputRef$curren","_labelInputRef$curren2","focus","preventScroll","handleInputChange","handleInputKeydown","_labelInputRef$curren3","keyCode","which","blur","handleInputBlur","editing","empty","onDoubleClick","onMouseDown","onChange","onKeyDown","onBlur","_EditableLabel2","_EoDrawCanvas","DEFAULT_NODE_SIZE","lockBodyScroll","unwrapProvider","EoDrawCanvasComponent","LegacyEoDrawCanvasComponent","_dec22","_dec23","_nodeMoveEvent","_cellMoveEvent","_handleCellMove","_cellResizeEvent","_handleCellResize","_cellDelete","_handleCellDelete","_cellContextMenu","_handleCellContextMenu","_scaleChange","_handleScaleChange","_canvasRef","EoDrawCanvas","_get_scaleChange2","_set_scaleChange2","_get_cellContextMenu2","_set_cellContextMenu2","_get_cellDelete2","_set_cellDelete2","_get_cellResizeEvent2","_set_cellResizeEvent2","_get_cellMoveEvent2","_set_cellMoveEvent2","_get_nodeMoveEvent2","_set_nodeMoveEvent2","_init_cells","_init_defaultNodeSize","_init_defaultNodeBricks","_init_defaultEdgeLines","_init_nodeMoveEvent","_init_cellMoveEvent","info","_init_cellResizeEvent","_init_cellDelete","cell","_init_cellContextMenu","_init_scaleChange","cells","defaultNodeSize","defaultNodeBricks","defaultEdgeLines","dropNode","_this","_asyncToGenerator","_document$elementsFro","_document","position","size","data","useBrick","document","elementsFromPoint","includes","_size$","_this$defaultNodeSize","_size$2","_this$defaultNodeSize2","boundingClientRect","getBoundingClientRect","getTransform","newNode","view","dropDecorator","_this2","_document$elementsFro2","_document2","decorator","_classPrivateFieldGet3","newDecorator","replace","r","Math","random","toString","addNodes","_this3","_ref5","_firstNode$size$","_firstNode$size","_this3$defaultNodeSiz","_ref6","_firstNode$size$2","_firstNode$size2","_this3$defaultNodeSiz2","_classPrivateFieldGet4","firstNode","rows","floor","positionedNodes","_ref7","_ref8","_size$3","_this3$defaultNodeSiz3","_ref9","_size$4","_this3$defaultNodeSiz4","_objectWithoutProperties","_excluded","_objectSpread","addEdge","_ref10","_this4","_classPrivateFieldGet5","newEdge","manuallyConnectNodes","updateCells","disconnectedCallback","super","host","onCellMove","onCellResize","onCellDelete","onCellContextMenu","onScaleChange","_set_nodeMoveEvent","_get_nodeMoveEvent","_set_cellMoveEvent","_get_cellMoveEvent","_set_cellResizeEvent","_get_cellResizeEvent","_set_cellDelete","_get_cellDelete","_set_cellContextMenu","_get_cellContextMenu","_set_scaleChange","_get_scaleChange","_ref11","initialCells","dispatch","useReducer","rootReducer","initializeCells","cellsRef","manualConnectDeferredRef","payload","sourceId","find","isNodeCell","rect","from","offset","Promise","resolve","reject","handleConnect","state","to","_manualConnectDeferre2","i","_manualConnectDeferre","resetActiveTarget","composedPath","indexOf","markerEnd","handleCellMoving","handleCellMoved","handleCellResizing","handleCellResized","CellComponent","onCellMoving","onCellMoved","onCellResizing","onCellResized","onConnect","_EoDrawCanvas2","_ExperimentalNode","_dragStartEvent","_handleDragStart","_dragMoveEvent","_handleDragMove","_dragEndEvent","_handleDragEnd","ExperimentalNode","_get_dragEndEvent2","_set_dragEndEvent2","_get_dragMoveEvent2","_set_dragMoveEvent2","_get_dragStartEvent2","_set_dragStartEvent2","_init_usage","_init_status","_init_decorator","_init_dragStartEvent","_init_dragMoveEvent","_init_dragEndEvent","usage","status","ExperimentalNodeComponent","onDragStart","onDragMove","onDragEnd","_set_dragStartEvent","_get_dragStartEvent","_set_dragMoveEvent","_get_dragMoveEvent","_set_dragEndEvent","_get_dragEndEvent","handleMouseDown","clientX","clientY","onMouseMove","onMouseUp","_ExperimentalNode2","___CSS_LOADER_EXPORT___","push","module"],"sourceRoot":""}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[7392],{5776:(e,t,n)=>{n.d(t,{s:()=>E});var r=n(5600),a=n.n(r),o=n(1252),i=n.n(o),c=n(7181),l=n(6960),d=n(960);function s(e,t){return e.find((e=>(0,c.G4)(e)&&e.id===t))}function u(e){var{edge:t,cells:n,markerEnd:o,defaultEdgeLines:c}=e,u=(0,r.useMemo)((()=>s(n,t.source)),[n,t.source]),h=(0,r.useMemo)((()=>s(n,t.target)),[n,t.target]),f=(0,r.useMemo)((()=>null==c?void 0:c.find((e=>(0,l.checkIfByTransform)(e,{edge:t})))),[c,t]),m=(0,r.useMemo)((()=>u&&h?(0,d.g)(v(u.view,5),v(h.view,5)):null),[u,h]);if(!m)return null;var p="M".concat(m[0].x," ").concat(m[0].y,"L").concat(m[1].x," ").concat(m[1].y);return a().createElement(a().Fragment,null,a().createElement("path",{d:p,fill:"none",stroke:"transparent",strokeWidth:16}),a().createElement("path",{className:i()("line",{dashed:null==f?void 0:f.dashed}),d:p,fill:"none",stroke:"gray",markerEnd:"url(#".concat(o,")")}),a().createElement("path",{className:"line-active-bg",d:p,fill:"none"}))}function v(e,t){return{x:e.x+e.width/2,y:e.y+e.height/2,width:e.width+t,height:e.height+t}}var h=n(6196);function f(e){var{node:t,defaultNodeBricks:n}=e,o=(0,r.useMemo)((()=>({node:{id:t.id,data:t.data}})),[t.id,t.data]),i=t.useBrick,c=(0,r.useMemo)((()=>{var e;return null!=i?i:null==n||null===(e=n.find((e=>(0,l.checkIfByTransform)(e,o))))||void 0===e?void 0:e.useBrick}),[n,i,o]);return c?a().createElement("foreignObject",{width:t.view.width,height:t.view.height,style:{overflow:"visible"}},c&&a().createElement(h.ReactUseBrick,{useBrick:c,data:o})):null}var m=n(7568);function p(e){return"edge"===e.type?(0,m.pick)(e,["type","source","target","data"]):(0,m.pick)(e,["type","id","data"])}function g(e,t){var{action:n,cell:r,scale:a,onCellMoving:o,onCellMoved:i,onCellResizing:c,onCellResized:l,onSwitchActiveTarget:d}=t;if(e.stopPropagation(),d(p(r)),"edge"!==r.type){var s=[e.clientX,e.clientY],u="move"===n?[r.view.x,r.view.y]:[r.view.width,r.view.height],v=!1,h=(e,t)=>{var d,h,f=function(e){return[(e.clientX-s[0])/a,(e.clientY-s[1])/a]}(e);v||(v=f[0]**2+f[1]**2>=9),v&&("move"===n?null===(d=t?i:o)||void 0===d||d({type:r.type,id:r.id,x:u[0]+f[0],y:u[1]+f[1]}):null===(h=t?l:c)||void 0===h||h({type:r.type,id:r.id,width:u[0]+f[0],height:u[1]+f[1]}))},f=e=>{h(e)},m=e=>{h(e,!0),v=!1,document.removeEventListener("mousemove",f),document.removeEventListener("mouseup",m)};document.addEventListener("mousemove",f),document.addEventListener("mouseup",m)}}function w(e){var{cell:t,transform:n,onCellResizing:o,onCellResized:i,onSwitchActiveTarget:c}=e,l=a().useRef(null);return(0,r.useEffect)((()=>{var e=l.current,r=e=>{g(e,{action:"resize",cell:t,scale:n.k,onCellResizing:o,onCellResized:i,onSwitchActiveTarget:c})};return null==e||e.addEventListener("mousedown",r),()=>{null==e||e.removeEventListener("mousedown",r)}}),[t,i,o,c,n.k]),a().createElement("g",{className:"decorator-area"},a().createElement("rect",{width:t.view.width,height:t.view.height,className:"area"}),a().createElement("g",{ref:l,className:"resize-handle",transform:"translate(".concat(t.view.width-20," ").concat(t.view.height-20,")")},a().createElement("rect",{width:20,height:20}),a().createElement("path",{d:"M10 18L18 10 M15 18L18 15"})))}function y(e){var{cell:t}=e;return a().createElement("text",{className:"decorator-text"},t.view.text||"未命名")}function k(e){var t,{cell:n,transform:r,onCellResizing:o,onCellResized:i,onSwitchActiveTarget:c}=e;switch(n.decorator){case"area":t=w;break;case"text":t=y;break;default:return console.error("Unknown decorator: ".concat(n.decorator)),null}return a().createElement(t,{cell:n,transform:r,onCellResizing:o,onCellResized:i,onSwitchActiveTarget:c})}function E(e){var{cell:t,cells:n,defaultNodeBricks:o,defaultEdgeLines:l,markerEnd:d,active:s,transform:v,onCellMoving:h,onCellMoved:m,onCellResizing:w,onCellResized:y,onSwitchActiveTarget:E,onCellContextMenu:x}=e,C=(0,r.useRef)(null);(0,r.useEffect)((()=>{var e=C.current,n=e=>{g(e,{action:"move",cell:t,scale:v.k,onCellMoving:h,onCellMoved:m,onSwitchActiveTarget:E})};return null==e||e.addEventListener("mousedown",n),()=>{null==e||e.removeEventListener("mousedown",n)}}),[t,m,h,E,v.k]);var z=(0,r.useCallback)((e=>{e.preventDefault(),E(p(t)),x({cell:t,clientX:e.clientX,clientY:e.clientY})}),[t,x,E]);return a().createElement("g",{className:i()("cell",{active:s}),ref:C,transform:"edge"===t.type?void 0:"translate(".concat(t.view.x," ").concat(t.view.y,")"),onContextMenu:z},(0,c.G4)(t)?a().createElement(f,{node:t,defaultNodeBricks:o}):(0,c.Wk)(t)?a().createElement(u,{edge:t,defaultEdgeLines:l,cells:n,markerEnd:d}):(0,c.c1)(t)?a().createElement(k,{cell:t,transform:v,onCellResizing:w,onCellResized:y,onSwitchActiveTarget:E}):null)}},8044:(e,t,n)=>{n.d(t,{E:()=>c});var r=n(5600),a=n.n(r),o=n(1252),i=n.n(o);function c(e){var{connectLineState:t,transform:n,markerEnd:o,onConnect:c}=e,[l,d]=(0,r.useState)(null);return(0,r.useEffect)((()=>{t&&d(t.from)}),[t]),(0,r.useEffect)((()=>{if(t){var e=e=>{d([(e.clientX-n.x-t.offset[0])/n.k,(e.clientY-n.y-t.offset[1])/n.k])},r=e=>{e.stopPropagation()},a=e=>{e.stopPropagation(),o(),c(t,[(e.clientX-n.x-t.offset[0])/n.k,(e.clientY-n.y-t.offset[1])/n.k])},o=()=>{document.removeEventListener("mousemove",e),document.removeEventListener("mousedown",r,{capture:!0}),document.removeEventListener("click",a,{capture:!0}),d(null)};return document.addEventListener("mousemove",e),document.addEventListener("mousedown",r,{capture:!0}),document.addEventListener("click",a,{capture:!0}),o}}),[t,c,n]),a().createElement("path",{className:i()("connect-line",{connecting:!!t&&l&&(l[0]-t.from[0])**2+(l[1]-t.from[1])**2>25}),d:t&&l?"M".concat(t.from.join(" "),"L").concat(l.join(" ")):"",fill:"none",stroke:"gray",strokeWidth:1,markerEnd:"url(#".concat(o,")")})}},7181:(e,t,n)=>{function r(e){return"node"===e.type}function a(e){return"decorator"===e.type}function o(e){return"node"===e.type}function i(e){return"edge"===e.type}n.d(t,{Cy:()=>o,G4:()=>r,Wk:()=>i,c1:()=>a})},6876:(e,t,n)=>{n.d(t,{Y:()=>a});var r=n(4552);function a(e,t){var{cells:n,activeTarget:a}=t,o=n.find((e=>(0,r.M)(e,a)));if(o)switch(e.key||e.keyCode||e.which){case"Backspace":case 8:case"Delete":case 46:return e.preventDefault(),e.stopPropagation(),{action:"delete-cell",cell:o}}}},7876:(e,t,n)=>{n.d(t,{S:()=>o});var r=n(4412),a=n(7181);function o(e){var{defaultNodeSize:t}=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=null!=e?e:[];return t?n.map((e=>!(0,a.Cy)(e)||void 0!==e.view.width&&void 0!==e.view.height?e:(0,r.c)((0,r.c)({},e),{},{view:(0,r.c)({width:t[0],height:t[1]},e.view)}))):n}},4552:(e,t,n)=>{function r(e,t){return e?!!t&&e.type===t.type&&("node"===e.type||"decorator"===e.type?e.id===t.id:e.source===t.source&&e.target===t.target):!t}n.d(t,{M:()=>r})},3788:(e,t,n)=>{n.d(t,{c:()=>a});var r=n(7181);function a(e,t){var{canvasWidth:n,canvasHeight:a,scaleRange:o}=t,i=1/0,c=1/0,l=-1/0,d=-1/0;for(var s of e)if(!(0,r.Wk)(s)){var{view:u}=s,v=u.x+u.width,h=u.y+u.height;u.x<i&&(i=u.x),v>l&&(l=v),u.y<c&&(c=u.y),h>d&&(d=h)}var f=l-i,m=d-c,p=o&&(f>n||m>a)?Math.max(Math.min(n/f,a/m,o[1]),o[0]):1;return{x:(n-f*p)/2-i*p,y:(a-m*p)/2-c*p,k:p}}},3876:(e,t,n)=>{n.d(t,{M:()=>c});var r=n(4412),a=n(7876);function o(e,t,n){var r=e.findLastIndex(n)+1;return[...e.slice(0,r),t,...e.slice(r)]}var i,c=(i={cells:(e,t)=>{switch(t.type){case"drop-node":return o(e,t.payload,(e=>!("decorator"===e.type&&"text"===e.decorator)));case"drop-decorator":return"text"===t.payload.decorator?[...e,t.payload]:o(e,t.payload,(e=>"decorator"===e.type&&"area"===e.decorator));case"add-nodes":var n=e.findLastIndex((e=>!("decorator"===e.type&&"text"===e.decorator)))+1;return[...e.slice(0,n),...t.payload,...e.slice(n)];case"add-edge":return o(e,t.payload,(e=>"edge"===e.type||"decorator"===e.type&&"area"===e.decorator));case"move-cell":var{type:i,id:c,x:l,y:d}=t.payload,s=e.findIndex((e=>e.type===i&&e.id===c));if(-1!==s){var u=e[s];return[...e.slice(0,s),(0,r.c)((0,r.c)({},u),{},{view:(0,r.c)((0,r.c)({},u.view),{},{x:l,y:d})}),...e.slice(s+1)]}return e;case"resize-cell":var{type:v,id:h,width:f,height:m}=t.payload,p=e.findIndex((e=>e.type===v&&e.id===h));if(-1!==p){var g=e[p];return[...e.slice(0,p),(0,r.c)((0,r.c)({},g),{},{view:(0,r.c)((0,r.c)({},g.view),{},{width:f,height:m})}),...e.slice(p+1)]}return e;case"update-all":var{cells:w,defaultNodeSize:y}=t.payload;return(0,a.S)(w,{defaultNodeSize:y})}return e}},(e,t)=>Object.fromEntries(Object.entries(i).map((n=>{var[r,a]=n;return[r,a(e[r],t)]}))))},7584:(e,t,n)=>{n.d(t,{c:()=>c});var r=n(8304),a=n.n(r),o=n(1849),i=n.n(o)()(a());i.push([e.id,"*{box-sizing:border-box}:host{display:block;position:relative;overflow:hidden}:host,\n.root{width:100%;height:100%}:host([hidden]){display:none}.root:focus{outline:none}.decorator-area .area{fill:rgba(119,141,195,0.1);stroke:none;stroke-width:0}.cell.active .decorator-area .area,\n.cell.active .line-active-bg{stroke:var(--palette-blue-5);stroke-dasharray:4;stroke-width:1}.cell.active .decorator-text{fill:var(--palette-blue-5)}.cell{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-handle{cursor:nwse-resize;opacity:0}.resize-handle rect{fill:transparent;stroke:none}.resize-handle path{fill:none;stroke:var(--palette-gray-5);stroke-width:1.5}.cell.active .decorator-area .resize-handle,\n.decorator-area:hover .resize-handle{opacity:1}.connect-line:not(.connecting){display:none}.line.dashed{stroke-dasharray:4}",""]);const c=i.toString()}}]);
|
|
2
|
-
//# sourceMappingURL=7392.1d2a5114.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/7392.1d2a5114.js","mappings":"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","sources":["webpack:///./src/draw-canvas/processors/findNode.ts","webpack:///./src/draw-canvas/EdgeComponent.tsx","webpack:///./src/draw-canvas/NodeComponent.tsx","webpack:///./src/draw-canvas/processors/cellToTarget.ts","webpack:///./src/draw-canvas/processors/handleMouseDown.ts","webpack:///./src/draw-canvas/decorators/DecoratorArea.tsx","webpack:///./src/draw-canvas/decorators/DecoratorText.tsx","webpack:///./src/draw-canvas/decorators/index.tsx","webpack:///./src/draw-canvas/CellComponent.tsx","webpack:///./src/draw-canvas/ConnectLineComponent.tsx","webpack:///./src/draw-canvas/processors/asserts.ts","webpack:///./src/draw-canvas/processors/handleKeyboard.ts","webpack:///./src/draw-canvas/processors/initializeCells.ts","webpack:///./src/draw-canvas/processors/sameTarget.ts","webpack:///./src/draw-canvas/processors/transformToCenter.ts","webpack:///./src/draw-canvas/reducers/cells.ts","webpack:///./src/draw-canvas/reducers/index.ts","webpack:///./src/draw-canvas/styles.shadow.css"],"sourcesContent":["import type { Cell, NodeCell, NodeId } from \"../interfaces\";\nimport { isNodeCell } from \"./asserts\";\n\nexport function findNode(cells: Cell[], id: NodeId): NodeCell | undefined {\n return cells.find((cell) => isNodeCell(cell) && cell.id === id) as\n | NodeCell\n | undefined;\n}\n","import React, { useMemo } from \"react\";\nimport { checkIfByTransform } from \"@next-core/runtime\";\nimport classNames from \"classnames\";\nimport type { Cell, EdgeCell, EdgeLineConf, NodeView } from \"./interfaces\";\nimport { getDirectLinePoints } from \"../diagram/lines/getDirectLinePoints\";\nimport type { NodeRect } from \"../diagram/interfaces\";\nimport { findNode } from \"./processors/findNode\";\n\nexport interface EdgeComponentProps {\n edge: EdgeCell;\n cells: Cell[];\n markerEnd: string;\n defaultEdgeLines?: EdgeLineConf[];\n}\n\nexport function EdgeComponent({\n edge,\n cells,\n markerEnd,\n defaultEdgeLines,\n}: EdgeComponentProps): JSX.Element | null {\n const sourceNode = useMemo(\n () => findNode(cells, edge.source),\n [cells, edge.source]\n );\n const targetNode = useMemo(\n () => findNode(cells, edge.target),\n [cells, edge.target]\n );\n const lineConf = useMemo(\n () => defaultEdgeLines?.find((item) => checkIfByTransform(item, { edge })),\n [defaultEdgeLines, edge]\n );\n\n const padding = 5;\n\n const line = useMemo(\n () =>\n sourceNode && targetNode\n ? getDirectLinePoints(\n nodeViewToNodeRect(sourceNode.view, padding),\n nodeViewToNodeRect(targetNode.view, padding)\n )\n : null,\n [sourceNode, targetNode]\n );\n\n if (!line) {\n // This happens when source or target is not found\n return null;\n }\n\n const d = `M${line[0].x} ${line[0].y}L${line[1].x} ${line[1].y}`;\n\n return (\n <>\n <path\n // This `path` is made for expanding interaction area of graph lines.\n d={d}\n fill=\"none\"\n stroke=\"transparent\"\n strokeWidth={16}\n />\n <path\n className={classNames(\"line\", { dashed: lineConf?.dashed })}\n d={d}\n fill=\"none\"\n stroke=\"gray\"\n markerEnd={`url(#${markerEnd})`}\n />\n <path className=\"line-active-bg\" d={d} fill=\"none\" />\n </>\n );\n}\n\nfunction nodeViewToNodeRect(view: NodeView, padding: number): NodeRect {\n return {\n x: view.x + view.width / 2,\n y: view.y + view.height / 2,\n width: view.width + padding,\n height: view.height + padding,\n };\n}\n","import React, { useMemo } from \"react\";\nimport { ReactUseBrick } from \"@next-core/react-runtime\";\nimport { checkIfByTransform } from \"@next-core/runtime\";\nimport type { NodeBrickCell, NodeBrickConf, NodeCell } from \"./interfaces\";\n\nexport interface NodeComponentProps {\n node: NodeCell;\n defaultNodeBricks?: NodeBrickConf[];\n}\n\nexport function NodeComponent({\n node,\n defaultNodeBricks,\n}: NodeComponentProps): JSX.Element | null {\n const memoizedData = useMemo(\n () => ({ node: { id: node.id, data: node.data } }),\n [node.id, node.data]\n );\n const specifiedUseBrick = (node as NodeBrickCell).useBrick;\n\n const useBrick = useMemo(() => {\n return (\n specifiedUseBrick ??\n defaultNodeBricks?.find((item) => checkIfByTransform(item, memoizedData))\n ?.useBrick\n );\n }, [defaultNodeBricks, specifiedUseBrick, memoizedData]);\n\n return useBrick ? (\n <foreignObject\n // x={node.view.x}\n // y={node.view.y}\n width={node.view.width}\n height={node.view.height}\n style={{ overflow: \"visible\" }}\n >\n {useBrick && <ReactUseBrick useBrick={useBrick} data={memoizedData} />}\n </foreignObject>\n ) : null;\n}\n","import { pick } from \"lodash\";\nimport type { ActiveTarget, Cell } from \"../interfaces\";\n\nexport function cellToTarget(cell: Cell): ActiveTarget {\n return cell.type === \"edge\"\n ? pick(cell, [\"type\", \"source\", \"target\", \"data\"])\n : pick(cell, [\"type\", \"id\", \"data\"]);\n}\n","import type { PositionTuple } from \"../../diagram/interfaces\";\nimport type { ActiveTarget, Cell } from \"../interfaces\";\nimport type {\n MoveCellPayload,\n ResizeCellPayload,\n} from \"../reducers/interfaces\";\nimport { cellToTarget } from \"./cellToTarget\";\n\nexport function handleMouseDown(\n event: MouseEvent,\n {\n action,\n cell,\n scale,\n onCellMoving,\n onCellMoved,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n }: {\n action: \"move\" | \"resize\";\n cell: Cell;\n scale: number;\n onCellMoving?(info: MoveCellPayload): void;\n onCellMoved?(info: MoveCellPayload): void;\n onCellResizing?(info: ResizeCellPayload): void;\n onCellResized?(info: ResizeCellPayload): void;\n onSwitchActiveTarget(activeTarget: ActiveTarget | null): void;\n }\n) {\n event.stopPropagation();\n // Drag node\n onSwitchActiveTarget(cellToTarget(cell));\n\n if (cell.type === \"edge\") {\n return;\n }\n\n const from: PositionTuple = [event.clientX, event.clientY];\n const original =\n action === \"move\"\n ? [cell.view.x, cell.view.y]\n : [cell.view.width, cell.view.height];\n\n function getMovement(e: MouseEvent): PositionTuple {\n return [(e.clientX - from[0]) / scale, (e.clientY - from[1]) / scale];\n }\n\n let moved = false;\n\n const handleMove = (e: MouseEvent, finished?: boolean) => {\n // Respect the scale\n const movement = getMovement(e);\n if (!moved) {\n moved = movement[0] ** 2 + movement[1] ** 2 >= 9;\n }\n // const [x, y] = getNewPosition(movement);\n // adjustCellPosition(x, y);\n if (moved) {\n if (action === \"move\") {\n (finished ? onCellMoved : onCellMoving)?.({\n type: cell.type,\n id: cell.id,\n x: original[0] + movement[0],\n y: original[1] + movement[1],\n });\n } else {\n (finished ? onCellResized : onCellResizing)?.({\n type: cell.type,\n id: cell.id,\n width: original[0] + movement[0],\n height: original[1] + movement[1],\n });\n }\n }\n };\n\n const onMouseMove = (e: MouseEvent) => {\n handleMove(e);\n };\n const onMouseUp = (e: MouseEvent) => {\n handleMove(e, true);\n moved = false;\n document.removeEventListener(\"mousemove\", onMouseMove);\n document.removeEventListener(\"mouseup\", onMouseUp);\n };\n document.addEventListener(\"mousemove\", onMouseMove);\n document.addEventListener(\"mouseup\", onMouseUp);\n}\n","import React, { useEffect } from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\nimport { handleMouseDown } from \"../processors/handleMouseDown\";\n\nexport function DecoratorArea({\n cell,\n transform,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n}: BasicDecoratorProps): JSX.Element {\n const resizeHandleRef = React.useRef<SVGGElement>(null);\n\n useEffect(() => {\n const resizeHandle = resizeHandleRef.current;\n const onMouseDown = (event: MouseEvent) => {\n handleMouseDown(event, {\n action: \"resize\",\n cell,\n scale: transform.k,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n });\n };\n resizeHandle?.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n resizeHandle?.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [cell, onCellResized, onCellResizing, onSwitchActiveTarget, transform.k]);\n\n return (\n <g className=\"decorator-area\">\n <rect\n // x={cell.view.x}\n // y={cell.view.y}\n width={cell.view.width}\n height={cell.view.height}\n className=\"area\"\n />\n <g\n ref={resizeHandleRef}\n className=\"resize-handle\"\n transform={`translate(${cell.view.width - 20} ${cell.view.height - 20})`}\n >\n <rect width={20} height={20} />\n <path d=\"M10 18L18 10 M15 18L18 15\" />\n </g>\n </g>\n );\n}\n","import React from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\n\nexport function DecoratorText({ cell }: BasicDecoratorProps): JSX.Element {\n return (\n <text\n // x={cell.view.x}\n // y={cell.view.y}\n className=\"decorator-text\"\n >\n {cell.view.text || \"未命名\"}\n </text>\n );\n}\n","import React from \"react\";\nimport type { BasicDecoratorProps } from \"../interfaces\";\nimport { DecoratorArea } from \"./DecoratorArea\";\nimport { DecoratorText } from \"./DecoratorText\";\n\nexport function DecoratorComponent({\n cell,\n transform,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n}: BasicDecoratorProps): JSX.Element | null {\n let SpecifiedComponent: (props: BasicDecoratorProps) => JSX.Element | null;\n\n switch (cell.decorator) {\n case \"area\":\n SpecifiedComponent = DecoratorArea;\n break;\n case \"text\":\n SpecifiedComponent = DecoratorText;\n break;\n // istanbul ignore next\n default:\n // eslint-disable-next-line no-console\n console.error(`Unknown decorator: ${cell.decorator}`);\n return null;\n }\n\n return (\n <SpecifiedComponent\n cell={cell}\n transform={transform}\n onCellResizing={onCellResizing}\n onCellResized={onCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n />\n );\n}\n","import React, { useCallback, useEffect, useRef } from \"react\";\nimport classNames from \"classnames\";\nimport type {\n ActiveTarget,\n Cell,\n CellContextMenuDetail,\n EdgeLineConf,\n NodeBrickConf,\n} from \"./interfaces\";\nimport { isDecoratorCell, isEdgeCell, isNodeCell } from \"./processors/asserts\";\nimport { EdgeComponent } from \"./EdgeComponent\";\nimport { NodeComponent } from \"./NodeComponent\";\nimport { handleMouseDown } from \"./processors/handleMouseDown\";\nimport type { MoveCellPayload, ResizeCellPayload } from \"./reducers/interfaces\";\nimport { DecoratorComponent } from \"./decorators\";\nimport { cellToTarget } from \"./processors/cellToTarget\";\nimport type { TransformLiteral } from \"../diagram/interfaces\";\n\nexport interface CellComponentProps {\n cell: Cell;\n cells: Cell[];\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n transform: TransformLiteral;\n markerEnd: string;\n active: boolean;\n onCellMoving(info: MoveCellPayload): void;\n onCellMoved(info: MoveCellPayload): void;\n onCellResizing(info: ResizeCellPayload): void;\n onCellResized(info: ResizeCellPayload): void;\n onSwitchActiveTarget(target: ActiveTarget | null): void;\n onCellContextMenu(detail: CellContextMenuDetail): void;\n}\n\nexport function CellComponent({\n cell,\n cells,\n defaultNodeBricks,\n defaultEdgeLines,\n markerEnd,\n active,\n transform,\n onCellMoving,\n onCellMoved,\n onCellResizing,\n onCellResized,\n onSwitchActiveTarget,\n onCellContextMenu,\n}: CellComponentProps): JSX.Element | null {\n const gRef = useRef<SVGGElement>(null);\n\n useEffect(() => {\n const g = gRef.current;\n const onMouseDown = (event: MouseEvent) => {\n handleMouseDown(event, {\n action: \"move\",\n cell,\n scale: transform.k,\n onCellMoving,\n onCellMoved,\n onSwitchActiveTarget,\n });\n };\n g?.addEventListener(\"mousedown\", onMouseDown);\n return () => {\n g?.removeEventListener(\"mousedown\", onMouseDown);\n };\n }, [cell, onCellMoved, onCellMoving, onSwitchActiveTarget, transform.k]);\n\n const handleContextMenu = useCallback(\n (event: React.MouseEvent<SVGGElement>) => {\n event.preventDefault();\n onSwitchActiveTarget(cellToTarget(cell));\n onCellContextMenu({\n cell,\n clientX: event.clientX,\n clientY: event.clientY,\n });\n },\n [cell, onCellContextMenu, onSwitchActiveTarget]\n );\n\n return (\n <g\n className={classNames(\"cell\", { active })}\n ref={gRef}\n transform={\n cell.type === \"edge\"\n ? undefined\n : `translate(${cell.view.x} ${cell.view.y})`\n }\n onContextMenu={handleContextMenu}\n >\n {isNodeCell(cell) ? (\n <NodeComponent node={cell} defaultNodeBricks={defaultNodeBricks} />\n ) : isEdgeCell(cell) ? (\n <EdgeComponent\n edge={cell}\n defaultEdgeLines={defaultEdgeLines}\n cells={cells}\n markerEnd={markerEnd}\n />\n ) : isDecoratorCell(cell) ? (\n <DecoratorComponent\n cell={cell}\n transform={transform}\n onCellResizing={onCellResizing}\n onCellResized={onCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n />\n ) : null}\n </g>\n );\n}\n","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 type {\n Cell,\n DecoratorCell,\n EdgeCell,\n InitialCell,\n InitialNodeCell,\n NodeCell,\n} from \"../interfaces\";\n\nexport function isNodeCell(cell: Cell): cell is NodeCell {\n return cell.type === \"node\";\n}\n\nexport function isDecoratorCell(cell: Cell): cell is DecoratorCell {\n return cell.type === \"decorator\";\n}\n\nexport function isInitialNodeCell(cell: InitialCell): cell is InitialNodeCell {\n return cell.type === \"node\";\n}\n\nexport function isEdgeCell(cell: Cell): cell is EdgeCell {\n return cell.type === \"edge\";\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 type { SizeTuple } from \"../../diagram/interfaces\";\nimport type { Cell, InitialCell, NodeCell } from \"../interfaces\";\nimport { isInitialNodeCell } from \"./asserts\";\n\nexport function initializeCells(\n initialCells: InitialCell[] | undefined,\n {\n defaultNodeSize,\n }: {\n defaultNodeSize?: SizeTuple;\n } = {}\n): Cell[] {\n const originalCells = initialCells ?? [];\n const finalCells: Cell[] = defaultNodeSize\n ? originalCells.map<Cell>((cell) => {\n if (\n !isInitialNodeCell(cell) ||\n (cell.view.width !== undefined && cell.view.height !== undefined)\n ) {\n return cell as NodeCell;\n }\n return {\n ...cell,\n view: {\n width: defaultNodeSize[0],\n height: defaultNodeSize[1],\n ...cell.view,\n },\n } as NodeCell;\n })\n : (originalCells as NodeCell[]);\n return finalCells;\n}\n","import type {\n ActiveTarget,\n ActiveTargetOfEdge,\n ActiveTargetOfNode,\n} from \"../interfaces\";\n\nexport function sameTarget(\n a: ActiveTarget | null | undefined,\n b: ActiveTarget | null | undefined\n): boolean {\n return a\n ? !!b &&\n a.type === b.type &&\n (a.type === \"node\" || a.type === \"decorator\"\n ? a.id === (b as ActiveTargetOfNode).id\n : a.source === (b as ActiveTargetOfEdge).source &&\n a.target === (b as ActiveTargetOfEdge).target)\n : !b;\n}\n","import type { TransformLiteral } from \"../../diagram/interfaces\";\nimport type { Cell } from \"../interfaces\";\nimport { isEdgeCell } from \"./asserts\";\n\nexport interface TransformToCenterOptions {\n canvasWidth: number;\n canvasHeight: number;\n scaleRange?: [min: number, max: number];\n}\n\nexport function transformToCenter(\n cells: Cell[],\n { canvasWidth, canvasHeight, scaleRange }: TransformToCenterOptions\n): TransformLiteral {\n let left = Infinity;\n let top = Infinity;\n let right = -Infinity;\n let bottom = -Infinity;\n for (const cell of cells) {\n if (!isEdgeCell(cell)) {\n const { view } = cell;\n const r = view.x + view.width;\n const b = view.y + view.height;\n if (view.x < left) {\n left = view.x;\n }\n if (r > right) {\n right = r;\n }\n if (view.y < top) {\n top = view.y;\n }\n if (b > bottom) {\n bottom = b;\n }\n }\n }\n\n const width = right - left;\n const height = bottom - top;\n\n const scale =\n scaleRange && (width > canvasWidth || height > canvasHeight)\n ? Math.max(\n Math.min(canvasWidth / width, canvasHeight / height, scaleRange[1]),\n scaleRange[0]\n )\n : 1;\n\n const x = (canvasWidth - width * scale) / 2 - left * scale;\n const y = (canvasHeight - height * scale) / 2 - top * scale;\n\n return { x, y, k: scale };\n}\n","import type { Reducer } from \"react\";\nimport type { DrawCanvasAction } from \"./interfaces\";\nimport type { Cell, NodeCell } from \"../interfaces\";\nimport { initializeCells } from \"../processors/initializeCells\";\n\nexport const cells: Reducer<Cell[], DrawCanvasAction> = (state, action) => {\n switch (action.type) {\n case \"drop-node\":\n return insertCellAfter(\n state,\n action.payload,\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n );\n case \"drop-decorator\": {\n if (action.payload.decorator === \"text\") {\n return [...state, action.payload];\n }\n return insertCellAfter(\n state,\n action.payload,\n (cell) => cell.type === \"decorator\" && cell.decorator === \"area\"\n );\n }\n case \"add-nodes\": {\n const index =\n state.findLastIndex(\n (cell) => !(cell.type === \"decorator\" && cell.decorator === \"text\")\n ) + 1;\n return [\n ...state.slice(0, index),\n ...action.payload,\n ...state.slice(index),\n ];\n }\n case \"add-edge\":\n // Add the edge to just next to the previous last edge or area decorator.\n // If not found, append to the start.\n return insertCellAfter(\n state,\n action.payload,\n (cell) =>\n cell.type === \"edge\" ||\n (cell.type === \"decorator\" && cell.decorator === \"area\")\n );\n case \"move-cell\": {\n const { type, id, x, y } = action.payload;\n const index = state.findIndex(\n (cell) => cell.type === type && cell.id === id\n );\n if (index !== -1) {\n const node = state[index] as NodeCell;\n return [\n ...state.slice(0, index),\n { ...node, view: { ...node.view, x, y } },\n ...state.slice(index + 1),\n ];\n }\n return state;\n }\n case \"resize-cell\": {\n const { type, id, width, height } = action.payload;\n const index = state.findIndex(\n (cell) => cell.type === type && cell.id === id\n );\n if (index !== -1) {\n const node = state[index] as NodeCell;\n return [\n ...state.slice(0, index),\n { ...node, view: { ...node.view, width, height } },\n ...state.slice(index + 1),\n ];\n }\n return state;\n }\n case \"update-all\": {\n const { cells, defaultNodeSize } = action.payload;\n return initializeCells(cells, { defaultNodeSize });\n }\n }\n return state;\n};\n\nfunction insertCellAfter(\n cells: Cell[],\n newCell: Cell,\n after: (cell: Cell) => boolean\n) {\n const index = cells.findLastIndex(after) + 1;\n return [...cells.slice(0, index), newCell, ...cells.slice(index)];\n}\n","import { Reducer } from \"react\";\nimport type { DrawCanvasAction, DrawCanvasState } from \"./interfaces\";\nimport { cells } from \"./cells\";\n\ntype ReducersMapObject<S, A> = {\n [K in keyof S]: Reducer<S[K], A>;\n};\n\nfunction combineReducers<S, A>(\n reducers: ReducersMapObject<S, A>\n): Reducer<S, A> {\n return ((state, action) =>\n Object.fromEntries(\n Object.entries<Reducer<any, A>>(reducers).map(([key, value]) => [\n key,\n value(state[key as keyof S], action),\n ])\n )) as Reducer<S, A>;\n}\n\nexport const rootReducer = combineReducers<DrawCanvasState, DrawCanvasAction>({\n cells,\n});\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `*{box-sizing:border-box}:host{display:block;position:relative;overflow:hidden}:host,\n.root{width:100%;height:100%}:host([hidden]){display:none}.root:focus{outline:none}.decorator-area .area{fill:rgba(119,141,195,0.1);stroke:none;stroke-width:0}.cell.active .decorator-area .area,\n.cell.active .line-active-bg{stroke:var(--palette-blue-5);stroke-dasharray:4;stroke-width:1}.cell.active .decorator-text{fill:var(--palette-blue-5)}.cell{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-handle{cursor:nwse-resize;opacity:0}.resize-handle rect{fill:transparent;stroke:none}.resize-handle path{fill:none;stroke:var(--palette-gray-5);stroke-width:1.5}.cell.active .decorator-area .resize-handle,\n.decorator-area:hover .resize-handle{opacity:1}.connect-line:not(.connecting){display:none}.line.dashed{stroke-dasharray:4}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["findNode","cells","id","find","cell","isNodeCell","EdgeComponent","_ref","edge","markerEnd","defaultEdgeLines","sourceNode","useMemo","source","targetNode","target","lineConf","item","checkIfByTransform","line","getDirectLinePoints","nodeViewToNodeRect","view","d","concat","x","y","React","fill","stroke","strokeWidth","className","classNames","dashed","padding","width","height","NodeComponent","node","defaultNodeBricks","memoizedData","data","specifiedUseBrick","useBrick","_defaultNodeBricks$fi","style","overflow","ReactUseBrick","cellToTarget","type","pick","handleMouseDown","event","action","scale","onCellMoving","onCellMoved","onCellResizing","onCellResized","onSwitchActiveTarget","stopPropagation","from","clientX","clientY","original","moved","handleMove","e","finished","_ref2","_ref3","movement","getMovement","onMouseMove","onMouseUp","document","removeEventListener","addEventListener","DecoratorArea","transform","resizeHandleRef","useEffect","resizeHandle","current","onMouseDown","k","ref","DecoratorText","text","DecoratorComponent","SpecifiedComponent","decorator","console","error","CellComponent","active","onCellContextMenu","gRef","useRef","g","handleContextMenu","useCallback","preventDefault","undefined","onContextMenu","isEdgeCell","isDecoratorCell","ConnectLineComponent","connectLineState","onConnect","connectLineTo","setConnectLineTo","useState","offset","onClick","reset","capture","connecting","join","isInitialNodeCell","handleKeyboard","activeTarget","activeCell","sameTarget","key","keyCode","which","initializeCells","initialCells","defaultNodeSize","arguments","length","originalCells","map","_objectSpread","a","b","transformToCenter","canvasWidth","canvasHeight","scaleRange","left","Infinity","top","right","bottom","r","Math","max","min","insertCellAfter","newCell","after","index","findLastIndex","slice","reducers","rootReducer","state","payload","findIndex","Object","fromEntries","entries","value","___CSS_LOADER_EXPORT___","push","module","toString"],"sourceRoot":""}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(self.webpackChunk_next_bricks_diagram=self.webpackChunk_next_bricks_diagram||[]).push([[7364],{8752:(e,t,a)=>{a.d(t,{y:()=>i});var n=a(5600),l=a.n(n);function i(e){var t,{id:a,type:n,strokeColor:i}=e;switch(n){case"0..1":t=o;break;case"0..N":t=c;break;default:t=r}return l().createElement(t,{id:a,strokeColor:i})}function r(e){var{id:t,strokeColor:a}=e;return l().createElement("marker",{id:t,viewBox:"0 0 6 6",refX:5,refY:3,markerWidth:6,markerHeight:6,orient:"auto-start-reverse",strokeLinejoin:"round"},l().createElement("path",{d:"M 0.5 0.5 L 5.5 3 L 0.5 5.5 z",stroke:a,strokeWidth:1,fill:a}))}function o(e){var{id:t,strokeColor:a}=e;return l().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},l().createElement("path",{d:"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 15.5 0.5 V 10.5 M 10.5 5.5 H 20.5",stroke:a,strokeWidth:1,fill:"none"}))}function c(e){var{id:t,strokeColor:a}=e;return l().createElement("marker",{id:t,viewBox:"0 0 21 11",refX:.5,refY:5.5,markerWidth:21,markerHeight:11,orient:"auto-start-reverse"},l().createElement("path",{d:"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 20.5 0.5 L 10.5 5.5 L 20.5 10.5 M 10.5 5.5 H 20.5",stroke:a,strokeWidth:1,fill:"none"}))}},960:(e,t,a)=>{a.d(t,{g:()=>l});var n=a(3208);function l(e,t){if(e===t||(0,n.e)(e,t,0,0))return null;var a,l,i,r,o=t.x-e.x,c=t.y-e.y,s=o>0?1:-1;if(0!==c){var u=Math.abs(o/c),d=c>0?1:-1;u<e.width/e.height?(a=e.x+u*e.height/2*s,l=e.y+e.height/2*d):(a=e.x+e.width/2*s,l=e.y+e.width/2/u*d),u<t.width/t.height?(i=t.x-u*t.height/2*s,r=t.y-t.height/2*d):(i=t.x-t.width/2*s,r=t.y-t.width/2/u*d)}else a=e.x+e.width/2*s,i=t.x-t.width/2*s,l=r=e.y;return[{x:a,y:l},{x:i,y:r}]}},3208:(e,t,a)=>{function n(e,t,a,n){var i=a?l(e,a):e,r=n?l(t,n):t,o=Math.min(i.x-i.width/2,r.x-r.width/2),c=Math.max(i.x+i.width/2,r.x+r.width/2),s=Math.min(i.y-i.height/2,r.y-r.height/2),u=Math.max(i.y+i.height/2,r.y+r.height/2);return c-o<i.width+r.width&&u-s<i.height+r.height}function l(e,t){return{x:e.x-e.width/2-t,y:e.y-e.height/2-t,width:e.width+2*t,height:e.height+2*t}}a.d(t,{e:()=>n})},3156:(e,t,a)=>{a.r(t),a.d(t,{EoDrawCanvas:()=>se,EoDrawCanvasComponent:()=>Oe});var n,l,i,r,o,c,s,u,d,h,v,f,p,w,g,m,k,y,x,b,M,C,E,z,W,N,S,R,B,T,L,D,H,P,A,_,Y,j,I,X,F,G,O,q,K,V,J,Q,U,Z,$,ee,te,ae,ne,le,ie,re,oe,ce,se,ue=a(4412),de=a(640),he=a(8944),ve=a(123),fe=a(592),pe=a(5866),we=a(1412),ge=a(8644),me=a(5600),ke=a.n(me),ye=a(7672),xe=a(8160),be=a(4516),Me=(a(48),a(7568)),Ce=a(5248),Ee=a(1920),ze=a(1252),We=a.n(ze),Ne=a(3876),Se=a(8752),Re=a(7181),Be=a(4552),Te=a(6876),Le=a(5776),De=a(7584),He=a(8044),Pe=a(7876),Ae=a(3788),_e=["size","useBrick"],Ye=20,je=(0,be.unwrapProvider)("basic.lock-body-scroll"),{defineElement:Ie,property:Xe,method:Fe,event:Ge}=(0,ye.createDecorators)(),Oe=ke().forwardRef(Xt);i=[Ie("eo-draw-canvas",{styleTexts:[De.c]})],r=Xe({attribute:!1}),c=Xe({attribute:!1}),u=Xe({attribute:!1}),h=Xe({attribute:!1}),f=Xe({attribute:!1}),w=Xe({type:Boolean}),m=Xe({type:Boolean}),y=Xe({type:Boolean}),b=Xe({attribute:!1}),C=Ge({type:"activeTarget.change"}),N=Ge({type:"node.move"}),T=Ge({type:"cell.move"}),P=Ge({type:"cell.resize"}),j=Ge({type:"node.delete"}),G=Ge({type:"cell.delete"}),V=Ge({type:"cell.contextmenu"}),Z=Ge({type:"scale.change"}),ae=Fe(),ne=Fe(),le=Fe(),ie=Fe(),re=Fe(),oe=Fe();var qe=new WeakMap,Ke=new WeakMap,Ve=new WeakMap,Je=new WeakMap,Qe=new WeakMap,Ue=new WeakMap,Ze=new WeakMap,$e=new WeakMap,et=new WeakMap,tt=new WeakMap,at=new WeakMap,nt=new WeakMap,lt=new WeakMap,it=new WeakMap,rt=new WeakMap,ot=new WeakMap,ct=new WeakMap,st=new WeakMap,ut=new WeakMap,dt=new WeakMap,ht=new WeakMap,vt=new WeakMap,ft=new WeakMap,pt=new WeakMap,wt=new WeakMap,gt=new WeakMap,mt=new WeakMap,kt=new WeakMap,yt=new WeakMap,xt=new WeakMap,bt=new WeakMap,Mt=new WeakMap,Ct=new WeakMap;class Et extends xe.ReactNextElement{constructor(){super(...arguments),(0,ve.c)(this,bt,{get:It,set:jt}),(0,ve.c)(this,kt,{get:Yt,set:_t}),(0,ve.c)(this,wt,{get:At,set:Pt}),(0,ve.c)(this,ft,{get:Ht,set:Dt}),(0,ve.c)(this,dt,{get:Lt,set:Tt}),(0,ve.c)(this,ct,{get:Bt,set:Rt}),(0,ve.c)(this,rt,{get:St,set:Nt}),(0,ve.c)(this,at,{get:Wt,set:zt}),(0,ve.c)(this,qe,{writable:!0,value:(n(this),o(this))}),(0,ve.c)(this,Ke,{writable:!0,value:s(this)}),(0,ve.c)(this,Ve,{writable:!0,value:d(this)}),(0,ve.c)(this,Je,{writable:!0,value:v(this)}),(0,ve.c)(this,Qe,{writable:!0,value:p(this)}),(0,ve.c)(this,Ue,{writable:!0,value:g(this,!0)}),(0,ve.c)(this,Ze,{writable:!0,value:k(this,!0)}),(0,ve.c)(this,$e,{writable:!0,value:x(this,!0)}),(0,ve.c)(this,et,{writable:!0,value:M(this)}),(0,ve.c)(this,tt,{writable:!0,value:E(this)}),(0,ve.c)(this,nt,{writable:!0,value:e=>{(0,we.c)(this,at).emit(e)}}),(0,ve.c)(this,lt,{writable:!0,value:e=>{(0,Be.M)(e,this.activeTarget)||(this.activeTarget=e)}}),(0,ve.c)(this,it,{writable:!0,value:S(this)}),(0,ve.c)(this,ot,{writable:!0,value:L(this)}),(0,ve.c)(this,st,{writable:!0,value:e=>{(0,we.c)(this,ct).emit(e),"node"===e.type&&(0,we.c)(this,rt).emit(e)}}),(0,ve.c)(this,ut,{writable:!0,value:A(this)}),(0,ve.c)(this,ht,{writable:!0,value:e=>{(0,we.c)(this,dt).emit(e)}}),(0,ve.c)(this,vt,{writable:!0,value:I(this)}),(0,ve.c)(this,pt,{writable:!0,value:O(this)}),(0,ve.c)(this,gt,{writable:!0,value:e=>{(0,we.c)(this,wt).emit(e),"node"===e.type&&(0,we.c)(this,ft).emit(e)}}),(0,ve.c)(this,mt,{writable:!0,value:J(this)}),(0,ve.c)(this,yt,{writable:!0,value:e=>{(0,we.c)(this,kt).emit(e)}}),(0,ve.c)(this,xt,{writable:!0,value:$(this)}),(0,ve.c)(this,Mt,{writable:!0,value:e=>{(0,we.c)(this,bt).emit(e)}}),(0,ve.c)(this,Ct,{writable:!0,value:(0,me.createRef)()})}get cells(){return(0,we.c)(this,qe)}set cells(e){(0,pe.c)(this,qe,e)}get defaultNodeSize(){return(0,we.c)(this,Ke)}set defaultNodeSize(e){(0,pe.c)(this,Ke,e)}get defaultNodeBricks(){return(0,we.c)(this,Ve)}set defaultNodeBricks(e){(0,pe.c)(this,Ve,e)}get defaultEdgeLines(){return(0,we.c)(this,Je)}set defaultEdgeLines(e){(0,pe.c)(this,Je,e)}get activeTarget(){return(0,we.c)(this,Qe)}set activeTarget(e){(0,pe.c)(this,Qe,e)}get zoomable(){return(0,we.c)(this,Ue)}set zoomable(e){(0,pe.c)(this,Ue,e)}get scrollable(){return(0,we.c)(this,Ze)}set scrollable(e){(0,pe.c)(this,Ze,e)}get pannable(){return(0,we.c)(this,$e)}set pannable(e){(0,pe.c)(this,$e,e)}get scaleRange(){return(0,we.c)(this,et)}set scaleRange(e){(0,pe.c)(this,et,e)}dropNode(e){var t=this;return(0,he.c)((function*(){var a,n,{id:l,position:i,size:r,data:o,useBrick:c}=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 s,u,d,h,v,f,p,w=t.getBoundingClientRect(),g=(0,we.c)(t,Ct).current.getTransform(),m={type:"node",id:l,view:{x:(i[0]-w.left-g.x)/g.k,y:(i[1]-w.top-g.y)/g.k,width:null!==(s=null!==(u=null==r?void 0:r[0])&&void 0!==u?u:null===(d=t.defaultNodeSize)||void 0===d?void 0:d[0])&&void 0!==s?s:Ye,height:null!==(h=null!==(v=null==r?void 0:r[1])&&void 0!==v?v:null===(f=t.defaultNodeSize)||void 0===f?void 0:f[0])&&void 0!==h?h:Ye},data:o,useBrick:c};return null===(p=(0,we.c)(t,Ct).current)||void 0===p||p.dropNode(m),m}return null}))()}dropDecorator(e){var t=this;return(0,he.c)((function*(){var a,n,{position:l,decorator:i}=e;if(null===(a=(n=document).elementsFromPoint)||void 0===a||null===(a=a.call(n,l[0],l[1]))||void 0===a?void 0:a.includes(t)){var r,o=t.getBoundingClientRect(),c=(0,we.c)(t,Ct).current.getTransform(),s={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:(l[0]-o.left-c.x)/c.k,y:(l[1]-o.top-c.y)/c.k,width:100,height:60}};return null===(r=(0,we.c)(t,Ct).current)||void 0===r||r.dropDecorator(s),s}return null}))()}addNodes(e){var t=this;return(0,he.c)((function*(){var a,n,l,i,r,o,c,s,u;if(0===e.length)return[];var d=e[0],h=null!==(a=null!==(n=null===(l=d.size)||void 0===l?void 0:l[0])&&void 0!==n?n:null===(i=t.defaultNodeSize)||void 0===i?void 0:i[0])&&void 0!==a?a:Ye,v=null!==(r=null!==(o=null===(c=d.size)||void 0===c?void 0:c[1])&&void 0!==o?o:null===(s=t.defaultNodeSize)||void 0===s?void 0:s[1])&&void 0!==r?r:Ye,f=Math.floor(600/(v+20)),p=e.map(((e,a)=>{var n,l,i,r,o,c,{size:s,useBrick:u}=e,d=(0,de.c)(e,_e);return(0,ue.c)((0,ue.c)({},d),{},{type:"node",view:{x:Math.floor(a/f)*(h+20)+20,y:a%f*(v+20)+20,width:null!==(n=null!==(l=null==s?void 0:s[0])&&void 0!==l?l:null===(i=t.defaultNodeSize)||void 0===i?void 0:i[0])&&void 0!==n?n:Ye,height:null!==(r=null!==(o=null==s?void 0:s[1])&&void 0!==o?o:null===(c=t.defaultNodeSize)||void 0===c?void 0:c[0])&&void 0!==r?r:Ye},useBrick:u})}));return null===(u=(0,we.c)(t,Ct).current)||void 0===u||u.addNodes(p),p}))()}addEdge(e){var t=this;return(0,he.c)((function*(){var a,{source:n,target:l,data:i}=e,r={type:"edge",source:n,target:l,data:i};return null===(a=(0,we.c)(t,Ct).current)||void 0===a||a.addEdge(r),r}))()}manuallyConnectNodes(e){return(0,we.c)(this,Ct).current.manuallyConnectNodes(e)}updateCells(e){(0,we.c)(this,Ct).current.updateCells(e)}disconnectedCallback(){super.disconnectedCallback(),je(this,!1)}render(){return ke().createElement(Oe,{host:this,ref:(0,we.c)(this,Ct),cells:this.cells,defaultNodeSize:this.defaultNodeSize,defaultNodeBricks:this.defaultNodeBricks,defaultEdgeLines:this.defaultEdgeLines,activeTarget:this.activeTarget,zoomable:this.zoomable,scrollable:this.scrollable,pannable:this.pannable,scaleRange:this.scaleRange,onActiveTargetChange:(0,we.c)(this,nt),onSwitchActiveTarget:(0,we.c)(this,lt),onCellMove:(0,we.c)(this,st),onCellResize:(0,we.c)(this,ht),onCellDelete:(0,we.c)(this,gt),onCellContextMenu:(0,we.c)(this,yt),onScaleChange:(0,we.c)(this,Mt)})}}function zt(e){W(this,e)}function Wt(){return z(this)}function Nt(e){B(this,e)}function St(){return R(this)}function Rt(e){H(this,e)}function Bt(){return D(this)}function Tt(e){Y(this,e)}function Lt(){return _(this)}function Dt(e){F(this,e)}function Ht(){return X(this)}function Pt(e){K(this,e)}function At(){return q(this)}function _t(e){U(this,e)}function Yt(){return Q(this)}function jt(e){te(this,e)}function It(){return ee(this)}function Xt(e,t){var{host:a,cells:n,defaultNodeSize:l,defaultNodeBricks:i,defaultEdgeLines:r,activeTarget:o,zoomable:c,scrollable:s,pannable:u,scaleRange:d,onActiveTargetChange:h,onSwitchActiveTarget:v,onCellMove:f,onCellResize:p,onCellDelete:w,onCellContextMenu:g,onScaleChange:m}=e,[{cells:k},y]=(0,me.useReducer)(Ne.M,n,(e=>({cells:(0,Pe.S)(e,{defaultNodeSize:l})}))),x=(0,me.useRef)(null),b=(0,me.useRef)(null),M=(0,me.useRef)(null),[C,E]=(0,me.useState)(!1),[z,W]=(0,me.useState)({k:1,x:0,y:0}),[N,S]=(0,me.useState)(!1);(0,me.useEffect)((()=>{m(z.k)}),[m,z.k]);var[R,B]=(0,me.useState)(null),T=(0,me.useMemo)((()=>null!=d?d:[.5,2]),[d]),L=(0,me.useMemo)((()=>(0,Ee.AT)()),[]);(0,me.useEffect)((()=>{var e=!1;L.scaleExtent(c?T:[1,1]).on("start",(()=>{e=!1,E(!0)})).on("zoom",(t=>{e=!0,W(t.transform)})).on("end",(()=>{E(!1),e||null==v||v(null)}))}),[v,T,c,L]),(0,me.useEffect)((()=>{var e=x.current;if(e){var t=(0,Ce.c)(e),a=()=>{t.on(".zoom",null).on(".zoom.custom",null).on("wheel",null)};if(c||s||u)return(c||s)&&t.on("wheel.zoom.custom",(e=>{e.ctrlKey||(e.stopImmediatePropagation(),s&&(e.preventDefault(),L.translateBy(t,e.wheelDeltaX/5,e.wheelDeltaY/5)))})),t.call(L).on("wheel",(e=>e.preventDefault())).on("dblclick.zoom",null).on("mousedown.zoom",null),u||t.on("touchstart.zoom",null).on("touchmove.zoom",null).on("touchend.zoom",null),a;a()}}),[u,s,c,L]),(0,me.useEffect)((()=>{var e=x.current;if(e&&!N){var{k:t,x:a,y:n}=(0,Ae.c)(k,{canvasWidth:e.clientWidth,canvasHeight:e.clientHeight,scaleRange:c?T:void 0});L.transform((0,Ce.c)(e),new Ee.O(t,a,n)),S(!0)}}),[k,N,T,c,L]),(0,me.useImperativeHandle)(t,(()=>({dropNode(e){y({type:"drop-node",payload:e})},dropDecorator(e){y({type:"drop-decorator",payload:e})},addNodes(e){y({type:"add-nodes",payload:e})},addEdge(e){y({type:"add-edge",payload:e})},updateCells(e){y({type:"update-all",payload:{cells:e,defaultNodeSize:l}})},getTransform:()=>z,manuallyConnectNodes(e){var t=k.find((t=>(0,Re.G4)(t)&&t.id===e));if(t){var a=x.current.getBoundingClientRect();return B({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)=>{M.current={resolve:e,reject:t}}))}return Promise.reject(null)}})),[k,l,z]);var D=(0,me.useCallback)(((e,t)=>{for(var a,n=0;n<k.length;n++){var l=k[n];if((0,Re.G4)(l)&&l.id!==e.source.id&&l.view.x<t[0]&&l.view.x+l.view.width>t[0]&&l.view.y<t[1]&&l.view.y+l.view.height>t[1]){var i;null===(i=M.current)||void 0===i||i.resolve({source:e.source,target:l});break}}null===(a=M.current)||void 0===a||a.reject(null),B(null)}),[k]);(0,me.useEffect)((()=>{je(a,!!R)}),[R,a]);var H=null!=o?o:null,[P,A]=(0,me.useState)(H);(0,me.useEffect)((()=>{A((e=>(0,Be.M)(e,H)?e:H))}),[H]);var _=(0,me.useRef)(!1);(0,me.useEffect)((()=>{_.current?h(P):_.current=!0}),[P,h]),(0,me.useEffect)((()=>{if(P){var e=e=>{e.composedPath().indexOf(b.current)<=0&&A(null)};return document.addEventListener("click",e),()=>{document.removeEventListener("click",e)}}}),[P]),(0,me.useEffect)((()=>{var e=x.current,t=e=>{var t=(0,Te.Y)(e,{cells:k,activeTarget:P});"delete-cell"===(null==t?void 0:t.action)&&w(t.cell)};return null==e||e.addEventListener("keydown",t),()=>{null==e||e.removeEventListener("keydown",t)}}),[P,k,w]);var Y=(0,me.useMemo)((()=>"".concat((0,Me.uniqueId)("diagram-"),"-")),[]),j="".concat(Y,"line-arrow-"),I="".concat(j,"1"),X=(0,me.useCallback)((e=>{y({type:"move-cell",payload:e})}),[]),F=(0,me.useCallback)((e=>{y({type:"move-cell",payload:e}),f(e)}),[f]),G=(0,me.useCallback)((e=>{y({type:"resize-cell",payload:e})}),[]),O=(0,me.useCallback)((e=>{y({type:"resize-cell",payload:e}),p(e)}),[p]);return ke().createElement("svg",{width:"100%",height:"100%",ref:x,className:We()("root",{grabbing:C,pannable:u}),tabIndex:-1},ke().createElement("defs",null,ke().createElement(Se.y,{id:I,type:"arrow",strokeColor:"gray"})),ke().createElement("g",{transform:"translate(".concat(z.x," ").concat(z.y,") scale(").concat(z.k,")")},ke().createElement("g",{className:"cells",ref:b},k.map((e=>ke().createElement(Le.s,{key:"".concat(e.type,":").concat("edge"===e.type?"".concat(e.source,"~").concat(e.target):e.id),cell:e,cells:k,defaultNodeBricks:i,defaultEdgeLines:r,transform:z,markerEnd:I,active:(0,Be.M)(P,e),onCellMoving:X,onCellMoved:F,onCellResizing:G,onCellResized:O,onSwitchActiveTarget:v,onCellContextMenu:g})))),ke().createElement(He.E,{connectLineState:R,transform:z,markerEnd:I,onConnect:D})))}ce=Et,({e:[o,s,d,v,p,g,k,x,M,E,z,W,S,R,B,L,D,H,A,_,Y,I,X,F,O,q,K,J,Q,U,$,ee,te,n],c:[se,l]}=(0,ge.c)(ce,[[r,1,"cells"],[c,1,"defaultNodeSize"],[u,1,"defaultNodeBricks"],[h,1,"defaultEdgeLines"],[f,1,"activeTarget"],[w,1,"zoomable"],[m,1,"scrollable"],[y,1,"pannable"],[b,1,"scaleRange"],[C,1,"activeTargetChangeEvent",e=>(0,we.c)(e,tt),(e,t)=>(0,pe.c)(e,tt,t)],[N,1,"nodeMoveEvent",e=>(0,we.c)(e,it),(e,t)=>(0,pe.c)(e,it,t)],[T,1,"cellMoveEvent",e=>(0,we.c)(e,ot),(e,t)=>(0,pe.c)(e,ot,t)],[P,1,"cellResizeEvent",e=>(0,we.c)(e,ut),(e,t)=>(0,pe.c)(e,ut,t)],[j,1,"nodeDelete",e=>(0,we.c)(e,vt),(e,t)=>(0,pe.c)(e,vt,t)],[G,1,"cellDelete",e=>(0,we.c)(e,pt),(e,t)=>(0,pe.c)(e,pt,t)],[V,1,"cellContextMenu",e=>(0,we.c)(e,mt),(e,t)=>(0,pe.c)(e,mt,t)],[Z,1,"scaleChange",e=>(0,we.c)(e,xt),(e,t)=>(0,pe.c)(e,xt,t)],[ae,2,"dropNode"],[ne,2,"dropDecorator"],[le,2,"addNodes"],[ie,2,"addEdge"],[re,2,"manuallyConnectNodes"],[oe,2,"updateCells"]],i,0,(e=>Ct.has((0,fe.c)(e))),xe.ReactNextElement)),l()}}]);
|
|
2
|
-
//# sourceMappingURL=eo-draw-canvas.a84b4006.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/eo-draw-canvas.a84b4006.js","mappings":"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","sources":["webpack:///./src/diagram/MarkerComponent.tsx","webpack:///./src/diagram/lines/getDirectLinePoints.ts","webpack:///./src/diagram/processors/doTwoNodesOverlap.ts","webpack:///./src/draw-canvas/index.tsx"],"sourcesContent":["import React from \"react\";\nimport type { LineMarkerType } from \"./interfaces\";\n\nexport interface MarkerComponentProps extends BaseMarkerComponentProps {\n type: LineMarkerType;\n}\n\nexport interface BaseMarkerComponentProps {\n id: string;\n strokeColor?: string;\n}\n\nexport function MarkerComponent({\n id,\n type,\n strokeColor,\n}: MarkerComponentProps): JSX.Element {\n let Component: (props: BaseMarkerComponentProps) => JSX.Element;\n\n switch (type) {\n case \"0..1\":\n Component = EntityRelationZeroOrOneMarker;\n break;\n case \"0..N\":\n Component = EntityRelationZeroOrManyMarker;\n break;\n default:\n Component = ArrowMarker;\n }\n\n return <Component id={id} strokeColor={strokeColor} />;\n}\n\nfunction ArrowMarker({\n id,\n strokeColor,\n}: BaseMarkerComponentProps): JSX.Element {\n return (\n <marker\n id={id}\n viewBox=\"0 0 6 6\"\n refX={5}\n refY={3}\n markerWidth={6}\n markerHeight={6}\n orient=\"auto-start-reverse\"\n strokeLinejoin=\"round\"\n >\n <path\n d=\"M 0.5 0.5 L 5.5 3 L 0.5 5.5 z\"\n stroke={strokeColor}\n strokeWidth={1}\n fill={strokeColor}\n />\n </marker>\n );\n}\n\nfunction EntityRelationZeroOrOneMarker({\n id,\n strokeColor,\n}: BaseMarkerComponentProps): JSX.Element {\n return (\n <marker\n id={id}\n viewBox=\"0 0 21 11\"\n refX={0.5}\n refY={5.5}\n markerWidth={21}\n markerHeight={11}\n orient=\"auto-start-reverse\"\n >\n <path\n d=\"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 15.5 0.5 V 10.5 M 10.5 5.5 H 20.5\"\n stroke={strokeColor}\n strokeWidth={1}\n fill=\"none\"\n />\n </marker>\n );\n}\n\nfunction EntityRelationZeroOrManyMarker({\n id,\n strokeColor,\n}: BaseMarkerComponentProps): JSX.Element {\n return (\n <marker\n id={id}\n viewBox=\"0 0 21 11\"\n refX={0.5}\n refY={5.5}\n markerWidth={21}\n markerHeight={11}\n orient=\"auto-start-reverse\"\n >\n <path\n d=\"M 5.5 5.5 m 5 0 a 5 5 0 1 0 -10 0 a 5 5 0 1 0 10 0 M 20.5 0.5 L 10.5 5.5 L 20.5 10.5 M 10.5 5.5 H 20.5\"\n stroke={strokeColor}\n strokeWidth={1}\n fill=\"none\"\n />\n </marker>\n );\n}\n","import type { NodePosition, NodeRect } from \"../interfaces\";\nimport { doTwoNodesOverlap } from \"../processors/doTwoNodesOverlap\";\n\nexport function getDirectLinePoints(\n source: NodeRect,\n target: NodeRect\n): NodePosition[] | null {\n // Ignore if two nodes are the same.\n // Ignore if two nodes overlap.\n if (source === target || doTwoNodesOverlap(source, target, 0, 0)) {\n return null;\n }\n\n const dx = target.x - source.x;\n const dy = target.y - source.y;\n\n let x0: number, y0: number, x1: number, y1: number;\n const directionX = dx > 0 ? 1 : -1;\n if (dy !== 0) {\n const deltaRadio = Math.abs(dx / dy);\n const directionY = dy > 0 ? 1 : -1;\n const sourceRadio = source.width / source.height;\n if (deltaRadio < sourceRadio) {\n x0 = source.x + ((deltaRadio * source.height) / 2) * directionX;\n y0 = source.y + (source.height / 2) * directionY;\n } else {\n x0 = source.x + (source.width / 2) * directionX;\n y0 = source.y + (source.width / 2 / deltaRadio) * directionY;\n }\n const targetRadio = target.width / target.height;\n if (deltaRadio < targetRadio) {\n x1 = target.x - ((deltaRadio * target.height) / 2) * directionX;\n y1 = target.y - (target.height / 2) * directionY;\n } else {\n x1 = target.x - (target.width / 2) * directionX;\n y1 = target.y - (target.width / 2 / deltaRadio) * directionY;\n }\n } else {\n x0 = source.x + (source.width / 2) * directionX;\n x1 = target.x - (target.width / 2) * directionX;\n y0 = y1 = source.y;\n }\n\n return [\n { x: x0, y: y0 },\n { x: x1, y: y1 },\n ];\n}\n","import type { NodeRect } from \"../interfaces\";\n\nexport function doTwoNodesOverlap(\n a: NodeRect,\n b: NodeRect,\n paddingA: number,\n paddingB: number\n): boolean {\n const A = paddingA ? getNodesWithPadding(a, paddingA) : a;\n const B = paddingB ? getNodesWithPadding(b, paddingB) : b;\n const left = Math.min(A.x - A.width / 2, B.x - B.width / 2);\n const right = Math.max(A.x + A.width / 2, B.x + B.width / 2);\n const top = Math.min(A.y - A.height / 2, B.y - B.height / 2);\n const bottom = Math.max(A.y + A.height / 2, B.y + B.height / 2);\n return right - left < A.width + B.width && bottom - top < A.height + B.height;\n}\n\nfunction getNodesWithPadding(node: NodeRect, padding: number) {\n return {\n x: node.x - node.width / 2 - padding,\n y: node.y - node.height / 2 - padding,\n width: node.width + padding * 2,\n height: node.height + padding * 2,\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 { select } from \"d3-selection\";\nimport { ZoomTransform, zoom } from \"d3-zoom\";\nimport classNames from \"classnames\";\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} 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 styleText from \"./styles.shadow.css\";\nimport { ConnectLineComponent } from \"./ConnectLineComponent\";\nimport { initializeCells } from \"./processors/initializeCells\";\nimport { transformToCenter } from \"./processors/transformToCenter\";\n\nconst DEFAULT_NODE_SIZE = 20;\nconst DEFAULT_AREA_WIDTH = 100;\nconst DEFAULT_AREA_HEIGHT = 60;\nconst DEFAULT_SCALE_RANGE_MIN = 0.5;\nconst DEFAULT_SCALE_RANGE_MAX = 2;\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 defaultNodeSize?: SizeTuple;\n defaultNodeBricks?: NodeBrickConf[];\n defaultEdgeLines?: EdgeLineConf[];\n activeTarget?: ActiveTarget | null;\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}\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 const EoDrawCanvasComponent = React.forwardRef(\n LegacyEoDrawCanvasComponent\n);\n\n/**\n * 用于手工绘图的画布。\n *\n * 注意:将配套另外一个用于展示的画布构件。\n */\nexport\n@defineElement(\"eo-draw-canvas\", {\n styleTexts: [styleText],\n})\nclass EoDrawCanvas extends ReactNextElement implements EoDrawCanvasProps {\n /**\n * 仅当初始化时使用,渲染后重新设置 `cells` 将无效。\n */\n @property({ attribute: false })\n accessor cells: InitialCell[] | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeSize: SizeTuple | undefined;\n\n @property({ attribute: false })\n accessor defaultNodeBricks: NodeBrickConf[] | 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 @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 /**\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: NodeCell = {\n type: \"node\",\n id,\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: size?.[0] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE,\n height: size?.[1] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE,\n },\n data,\n useBrick,\n };\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 }: 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 },\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 firstNode = nodes[0];\n const width =\n firstNode.size?.[0] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE;\n const height =\n firstNode.size?.[1] ?? this.defaultNodeSize?.[1] ?? DEFAULT_NODE_SIZE;\n const gap = 20;\n // Todo(steve): canvas size\n const canvasHeight = 600;\n const rows = Math.floor(canvasHeight / (height + gap));\n // Assert: nodes are all brick nodes (no shape nodes)\n const positionedNodes = nodes.map<NodeCell>(\n ({ size, useBrick, ...node }, index) => ({\n ...node,\n type: \"node\",\n view: {\n x: Math.floor(index / rows) * (width + gap) + gap,\n y: (index % rows) * (height + gap) + gap,\n width: size?.[0] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE,\n height: size?.[1] ?? this.defaultNodeSize?.[0] ?? DEFAULT_NODE_SIZE,\n },\n useBrick,\n })\n );\n this.#canvasRef.current?.addNodes(positionedNodes);\n return positionedNodes;\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 updateCells(cells: InitialCell[]): void {\n this.#canvasRef.current!.updateCells(cells);\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 cells={this.cells}\n defaultNodeSize={this.defaultNodeSize}\n defaultNodeBricks={this.defaultNodeBricks}\n defaultEdgeLines={this.defaultEdgeLines}\n activeTarget={this.activeTarget}\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 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 onScaleChange(scale: number): void;\n}\n\nexport interface DrawCanvasRef {\n dropNode(node: NodeCell): void;\n dropDecorator(decorator: DecoratorCell): void;\n addNodes(nodes: NodeCell[]): void;\n addEdge(edge: EdgeCell): void;\n manuallyConnectNodes(source: NodeId): Promise<ConnectNodesDetail>;\n updateCells(cells: InitialCell[]): void;\n getTransform(): TransformLiteral;\n}\n\nfunction LegacyEoDrawCanvasComponent(\n {\n host,\n cells: initialCells,\n defaultNodeSize,\n defaultNodeBricks,\n defaultEdgeLines,\n activeTarget: _activeTarget,\n zoomable,\n scrollable,\n pannable,\n scaleRange: _scaleRange,\n onActiveTargetChange,\n onSwitchActiveTarget,\n onCellMove,\n onCellResize,\n onCellDelete,\n onCellContextMenu,\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 const rootRef = useRef<SVGSVGElement>(null);\n const cellsRef = useRef<SVGGElement>(null);\n const manualConnectDeferredRef = useRef<Deferred<ConnectNodesDetail> | null>(\n null\n );\n\n const [grabbing, setGrabbing] = useState(false);\n const [transform, setTransform] = useState<TransformLiteral>({\n k: 1,\n x: 0,\n y: 0,\n });\n const [centered, setCentered] = useState(false);\n\n useEffect(() => {\n onScaleChange(transform.k);\n }, [onScaleChange, transform.k]);\n\n const [connectLineState, setConnectLineState] =\n useState<ConnectLineState | null>(null);\n\n const scaleRange = useMemo(\n () =>\n _scaleRange ??\n ([DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX] as RangeTuple),\n [_scaleRange]\n );\n\n const zoomer = useMemo(() => zoom<SVGSVGElement, unknown>(), []);\n\n // istanbul ignore next: d3-zoom currently hard to test\n useEffect(() => {\n let moved = false;\n zoomer\n .scaleExtent(zoomable ? scaleRange : [1, 1])\n .on(\"start\", () => {\n moved = false;\n setGrabbing(true);\n })\n .on(\"zoom\", (e: { transform: TransformLiteral }) => {\n moved = true;\n setTransform(e.transform);\n })\n .on(\"end\", () => {\n setGrabbing(false);\n if (!moved) {\n onSwitchActiveTarget?.(null);\n }\n });\n }, [onSwitchActiveTarget, scaleRange, zoomable, zoomer]);\n\n // istanbul ignore next: d3-zoom currently hard to test\n useEffect(() => {\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const rootSelection = select(root);\n\n const unsetZoom = () => {\n rootSelection\n .on(\".zoom\", null)\n .on(\".zoom.custom\", null)\n .on(\"wheel\", null);\n };\n\n if (!(zoomable || scrollable || pannable)) {\n unsetZoom();\n return;\n }\n\n if (zoomable || scrollable) {\n // Do not override default d3 zoom handler.\n // Only handles *panning*\n rootSelection.on(\n \"wheel.zoom.custom\",\n (e: WheelEvent & { wheelDeltaX: number; wheelDeltaY: number }) => {\n // Mac OS trackpad pinch event is emitted as a wheel.zoom and d3.event.ctrlKey set to true\n if (!e.ctrlKey) {\n // Stop immediate propagation for default d3 zoom handler\n e.stopImmediatePropagation();\n if (scrollable) {\n e.preventDefault();\n zoomer.translateBy(\n rootSelection,\n e.wheelDeltaX / 5,\n e.wheelDeltaY / 5\n );\n }\n }\n // zoomer.scaleBy(rootSelection, Math.pow(2, defaultWheelDelta(e)))\n }\n );\n }\n\n rootSelection\n .call(zoomer)\n .on(\"wheel\", (e: WheelEvent) => e.preventDefault())\n .on(\"dblclick.zoom\", null)\n .on(\"mousedown.zoom\", null);\n\n if (!pannable) {\n rootSelection\n .on(\"touchstart.zoom\", null)\n .on(\"touchmove.zoom\", null)\n .on(\"touchend.zoom\", null);\n }\n\n return unsetZoom;\n }, [pannable, scrollable, zoomable, zoomer]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || centered) {\n return;\n }\n const { k, x, y } = transformToCenter(cells, {\n canvasWidth: root.clientWidth,\n canvasHeight: root.clientHeight,\n scaleRange: zoomable ? scaleRange : undefined,\n });\n // istanbul ignore next\n if (process.env.NODE_ENV !== \"test\") {\n // jsdom doesn't support svg baseVal yet.\n // https://github.com/jsdom/jsdom/issues/2531\n zoomer.transform(select(root), new ZoomTransform(k, x, y));\n }\n setCentered(true);\n }, [cells, centered, scaleRange, zoomable, zoomer]);\n\n useImperativeHandle(\n ref,\n () => ({\n dropNode(node) {\n dispatch({ type: \"drop-node\", payload: node });\n },\n dropDecorator(decorator) {\n dispatch({ type: \"drop-decorator\", payload: decorator });\n },\n addNodes(nodes) {\n dispatch({ type: \"add-nodes\", payload: nodes });\n },\n addEdge(edge) {\n dispatch({ type: \"add-edge\", payload: edge });\n },\n updateCells(cells) {\n dispatch({ type: \"update-all\", payload: { cells, defaultNodeSize } });\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, defaultNodeSize, 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 newActiveTarget = _activeTarget ?? null;\n const [activeTarget, setActiveTarget] = useState<ActiveTarget | null>(\n newActiveTarget\n );\n\n useEffect(() => {\n setActiveTarget((previous) =>\n sameTarget(previous, newActiveTarget) ? previous : newActiveTarget\n );\n }, [newActiveTarget]);\n\n const activeTargetChangeInitialized = useRef(false);\n useEffect(() => {\n if (!activeTargetChangeInitialized.current) {\n activeTargetChangeInitialized.current = true;\n return;\n }\n onActiveTargetChange(activeTarget);\n }, [activeTarget, onActiveTargetChange]);\n\n useEffect(() => {\n if (!activeTarget) {\n return;\n }\n const resetActiveTarget = (e: MouseEvent) => {\n const path = e.composedPath();\n const cellsContainerIndex = path.indexOf(cellsRef.current!);\n // Reset active target to null when clicking outside of the cells container,\n // Or inside the cells container but not on any cell.\n if (cellsContainerIndex <= 0) {\n setActiveTarget(null);\n }\n };\n document.addEventListener(\"click\", resetActiveTarget);\n return () => {\n document.removeEventListener(\"click\", resetActiveTarget);\n };\n }, [activeTarget]);\n\n useEffect(() => {\n const root = rootRef.current;\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, onCellDelete]);\n\n const defPrefix = useMemo(() => `${uniqueId(\"diagram-\")}-`, []);\n const markerPrefix = `${defPrefix}line-arrow-`;\n const markerEnd = `${markerPrefix}1`;\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 return (\n // Todo(steve): canvas size\n <svg\n width=\"100%\"\n height=\"100%\"\n ref={rootRef}\n className={classNames(\"root\", { grabbing, pannable })}\n tabIndex={-1}\n >\n <defs>\n <MarkerComponent id={markerEnd} type=\"arrow\" strokeColor=\"gray\" />\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 cell={cell}\n cells={cells}\n defaultNodeBricks={defaultNodeBricks}\n defaultEdgeLines={defaultEdgeLines}\n transform={transform}\n markerEnd={markerEnd}\n active={sameTarget(activeTarget, cell)}\n onCellMoving={handleCellMoving}\n onCellMoved={handleCellMoved}\n onCellResizing={handleCellResizing}\n onCellResized={handleCellResized}\n onSwitchActiveTarget={onSwitchActiveTarget}\n onCellContextMenu={onCellContextMenu}\n />\n ))}\n </g>\n <ConnectLineComponent\n connectLineState={connectLineState}\n transform={transform}\n markerEnd={markerEnd}\n onConnect={handleConnect}\n />\n </g>\n </svg>\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"],"names":["MarkerComponent","_ref","Component","id","type","strokeColor","EntityRelationZeroOrOneMarker","EntityRelationZeroOrManyMarker","ArrowMarker","React","_ref2","viewBox","refX","refY","markerWidth","markerHeight","orient","strokeLinejoin","d","stroke","strokeWidth","fill","_ref3","_ref4","getDirectLinePoints","source","target","doTwoNodesOverlap","x0","y0","x1","y1","dx","x","dy","y","directionX","deltaRadio","Math","abs","directionY","width","height","a","b","paddingA","paddingB","A","getNodesWithPadding","B","left","min","right","max","top","bottom","node","padding","_EoDrawCanvas","DEFAULT_NODE_SIZE","lockBodyScroll","unwrapProvider","defineElement","property","method","event","createDecorators","EoDrawCanvasComponent","LegacyEoDrawCanvasComponent","_classDecs","styleTexts","styleText","_dec","attribute","_dec2","_dec3","_dec4","_dec5","_dec6","Boolean","_dec7","_dec8","_dec9","_dec10","_dec11","_dec12","_dec13","_dec14","_dec15","_dec16","_dec17","_dec18","_dec19","_dec20","_dec21","_dec22","_dec23","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_J","_activeTargetChangeEvent","_handleActiveTargetChange","_handleSwitchActiveTarget","_K","_nodeMoveEvent","_L","_cellMoveEvent","_handleCellMove","_M","_cellResizeEvent","_handleCellResize","_N","_nodeDelete","_O","_cellDelete","_handleCellDelete","_P","_cellContextMenu","_handleCellContextMenu","_Q","_scaleChange","_handleScaleChange","_canvasRef","EoDrawCanvas","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","get","_get_scaleChange2","set","_set_scaleChange2","_get_cellContextMenu2","_set_cellContextMenu2","_get_cellDelete2","_set_cellDelete2","_get_nodeDelete2","_set_nodeDelete2","_get_cellResizeEvent2","_set_cellResizeEvent2","_get_cellMoveEvent2","_set_cellMoveEvent2","_get_nodeMoveEvent2","_set_nodeMoveEvent2","_get_activeTargetChangeEvent2","_set_activeTargetChangeEvent2","writable","value","_initProto","_init_cells","_init_defaultNodeSize","_init_defaultNodeBricks","_init_defaultEdgeLines","_init_activeTarget","_init_zoomable","_init_scrollable","_init_pannable","_init_scaleRange","_init_activeTargetChangeEvent","_classPrivateFieldGet","this","emit","sameTarget","activeTarget","_init_nodeMoveEvent","_init_cellMoveEvent","info","_init_cellResizeEvent","_init_nodeDelete","_init_cellDelete","cell","_init_cellContextMenu","detail","_init_scaleChange","scale","createRef","cells","v","_classPrivateFieldSet","defaultNodeSize","defaultNodeBricks","defaultEdgeLines","zoomable","scrollable","pannable","scaleRange","dropNode","_this","_asyncToGenerator","_document$elementsFro","_document","position","size","data","useBrick","document","elementsFromPoint","call","includes","_size$","_this$defaultNodeSize","_size$2","_this$defaultNodeSize2","_classPrivateFieldGet2","boundingClientRect","getBoundingClientRect","transform","current","getTransform","newNode","view","k","dropDecorator","_this2","_document$elementsFro2","_document2","decorator","_classPrivateFieldGet3","newDecorator","replace","c","r","random","toString","addNodes","nodes","_this3","_ref5","_firstNode$size$","_firstNode$size","_this3$defaultNodeSiz","_ref6","_firstNode$size$2","_firstNode$size2","_this3$defaultNodeSiz2","_classPrivateFieldGet4","length","firstNode","rows","floor","positionedNodes","map","_ref7","index","_ref8","_size$3","_this3$defaultNodeSiz3","_ref9","_size$4","_this3$defaultNodeSiz4","_objectWithoutProperties","_excluded","_objectSpread","addEdge","_ref10","_this4","_classPrivateFieldGet5","newEdge","manuallyConnectNodes","updateCells","disconnectedCallback","super","render","host","ref","onActiveTargetChange","onSwitchActiveTarget","onCellMove","onCellResize","onCellDelete","onCellContextMenu","onScaleChange","_set_activeTargetChangeEvent","_get_activeTargetChangeEvent","_set_nodeMoveEvent","_get_nodeMoveEvent","_set_cellMoveEvent","_get_cellMoveEvent","_set_cellResizeEvent","_get_cellResizeEvent","_set_nodeDelete","_get_nodeDelete","_set_cellDelete","_get_cellDelete","_set_cellContextMenu","_get_cellContextMenu","_set_scaleChange","_get_scaleChange","_ref11","initialCells","_activeTarget","_scaleRange","dispatch","useReducer","rootReducer","initializeCells","rootRef","useRef","cellsRef","manualConnectDeferredRef","grabbing","setGrabbing","useState","setTransform","centered","setCentered","useEffect","connectLineState","setConnectLineState","useMemo","zoomer","zoom","moved","scaleExtent","on","e","root","rootSelection","select","unsetZoom","ctrlKey","stopImmediatePropagation","preventDefault","translateBy","wheelDeltaX","wheelDeltaY","transformToCenter","canvasWidth","clientWidth","canvasHeight","clientHeight","undefined","ZoomTransform","useImperativeHandle","payload","edge","sourceId","find","isNodeCell","rect","from","offset","Promise","resolve","reject","handleConnect","useCallback","state","to","_manualConnectDeferre2","i","_manualConnectDeferre","newActiveTarget","setActiveTarget","previous","activeTargetChangeInitialized","resetActiveTarget","composedPath","indexOf","addEventListener","removeEventListener","onKeydown","action","handleKeyboard","defPrefix","concat","uniqueId","markerPrefix","markerEnd","handleCellMoving","handleCellMoved","handleCellResizing","handleCellResized","className","classNames","tabIndex","CellComponent","key","active","onCellMoving","onCellMoved","onCellResizing","onCellResized","ConnectLineComponent","onConnect","_EoDrawCanvas2","_initClass","_applyDecs","o","_","has","_checkInRHS"],"sourceRoot":""}
|