@logicflow/core 1.2.27 → 2.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build$colon$dev.log +10 -0
- package/.turbo/turbo-build.log +36 -0
- package/CHANGELOG.md +2114 -0
- package/LICENSE +206 -0
- package/__tests__/algorithm/egde.test.ts +118 -0
- package/__tests__/algorithm/index.test.ts +69 -0
- package/__tests__/algorithm/outline.test.ts +43 -0
- package/__tests__/bugs/1545-spec.test.ts +38 -0
- package/__tests__/event/event.test.ts +22 -0
- package/__tests__/history/history.test.ts +28 -0
- package/__tests__/logicflow.test.ts +567 -0
- package/__tests__/model/graphmodel.test.ts +67 -0
- package/__tests__/util/compatible.test.ts +48 -0
- package/__tests__/util/edge.test.ts +224 -0
- package/__tests__/util/geometry.test.ts +14 -0
- package/__tests__/util/graph.test.ts +16 -0
- package/__tests__/util/matrix.test.ts +41 -0
- package/__tests__/util/node.test.ts +68 -0
- package/__tests__/util/sampling.test.ts +16 -0
- package/__tests__/util/vector.test.ts +50 -0
- package/__tests__/util/zIndex.test.ts +10 -0
- package/dist/{style/index.css → index.css} +64 -52
- package/dist/index.min.js +26 -0
- package/dist/index.min.js.map +1 -0
- package/es/LogicFlow.d.ts +966 -0
- package/es/LogicFlow.js +1174 -0
- package/es/LogicFlow.js.map +1 -0
- package/es/algorithm/edge.d.ts +15 -0
- package/es/algorithm/edge.js +57 -0
- package/es/algorithm/edge.js.map +1 -0
- package/es/algorithm/index.js +71 -0
- package/es/algorithm/index.js.map +1 -0
- package/es/algorithm/outline.d.ts +7 -0
- package/es/algorithm/outline.js +61 -0
- package/es/algorithm/outline.js.map +1 -0
- package/{types/constant/constant.d.ts → es/constant/index.d.ts} +23 -22
- package/es/constant/index.js +117 -0
- package/es/constant/index.js.map +1 -0
- package/es/event/eventArgs.d.ts +428 -0
- package/es/event/eventArgs.js +2 -0
- package/es/event/eventArgs.js.map +1 -0
- package/es/event/eventEmitter.d.ts +48 -0
- package/es/event/eventEmitter.js +92 -0
- package/es/event/eventEmitter.js.map +1 -0
- package/es/history/index.d.ts +23 -0
- package/es/history/index.js +111 -0
- package/es/history/index.js.map +1 -0
- package/es/index.css +210 -0
- package/{types → es}/index.d.ts +4 -6
- package/es/index.js +16 -0
- package/es/index.js.map +1 -0
- package/es/index.less +1 -0
- package/{types → es}/keyboard/index.d.ts +7 -8
- package/es/keyboard/index.js +87 -0
- package/es/keyboard/index.js.map +1 -0
- package/es/keyboard/shortcut.js +116 -0
- package/es/keyboard/shortcut.js.map +1 -0
- package/es/model/BaseModel.d.ts +181 -0
- package/es/model/BaseModel.js +2 -0
- package/es/model/BaseModel.js.map +1 -0
- package/{types → es}/model/EditConfigModel.d.ts +13 -8
- package/es/model/EditConfigModel.js +192 -0
- package/es/model/EditConfigModel.js.map +1 -0
- package/{types → es}/model/GraphModel.d.ts +118 -178
- package/es/model/GraphModel.js +1473 -0
- package/es/model/GraphModel.js.map +1 -0
- package/es/model/SnaplineModel.d.ts +34 -0
- package/es/model/SnaplineModel.js +217 -0
- package/es/model/SnaplineModel.js.map +1 -0
- package/{types → es}/model/TransformModel.d.ts +21 -11
- package/es/model/TransformModel.js +240 -0
- package/es/model/TransformModel.js.map +1 -0
- package/{types → es}/model/edge/BaseEdgeModel.d.ts +82 -63
- package/es/model/edge/BaseEdgeModel.js +739 -0
- package/es/model/edge/BaseEdgeModel.js.map +1 -0
- package/es/model/edge/BezierEdgeModel.d.ts +63 -0
- package/es/model/edge/BezierEdgeModel.js +244 -0
- package/es/model/edge/BezierEdgeModel.js.map +1 -0
- package/es/model/edge/LineEdgeModel.d.ts +19 -0
- package/es/model/edge/LineEdgeModel.js +77 -0
- package/es/model/edge/LineEdgeModel.js.map +1 -0
- package/es/model/edge/PolylineEdgeModel.d.ts +85 -0
- package/es/model/edge/PolylineEdgeModel.js +593 -0
- package/es/model/edge/PolylineEdgeModel.js.map +1 -0
- package/es/model/edge/index.js +5 -0
- package/es/model/edge/index.js.map +1 -0
- package/es/model/index.js +8 -0
- package/es/model/index.js.map +1 -0
- package/es/model/node/BaseNodeModel.d.ts +260 -0
- package/es/model/node/BaseNodeModel.js +883 -0
- package/es/model/node/BaseNodeModel.js.map +1 -0
- package/es/model/node/CircleNodeModel.d.ts +40 -0
- package/es/model/node/CircleNodeModel.js +110 -0
- package/es/model/node/CircleNodeModel.js.map +1 -0
- package/es/model/node/DiamondNodeModel.d.ts +46 -0
- package/es/model/node/DiamondNodeModel.js +187 -0
- package/es/model/node/DiamondNodeModel.js.map +1 -0
- package/es/model/node/EllipseNodeModel.d.ts +42 -0
- package/es/model/node/EllipseNodeModel.js +118 -0
- package/es/model/node/EllipseNodeModel.js.map +1 -0
- package/es/model/node/HtmlNodeModel.d.ts +21 -0
- package/es/model/node/HtmlNodeModel.js +59 -0
- package/es/model/node/HtmlNodeModel.js.map +1 -0
- package/es/model/node/PolygonNodeModel.d.ts +50 -0
- package/es/model/node/PolygonNodeModel.js +196 -0
- package/es/model/node/PolygonNodeModel.js.map +1 -0
- package/es/model/node/RectNodeModel.d.ts +34 -0
- package/es/model/node/RectNodeModel.js +80 -0
- package/es/model/node/RectNodeModel.js.map +1 -0
- package/es/model/node/TextNodeModel.d.ts +27 -0
- package/es/model/node/TextNodeModel.js +113 -0
- package/es/model/node/TextNodeModel.js.map +1 -0
- package/es/model/node/index.js +9 -0
- package/es/model/node/index.js.map +1 -0
- package/es/options.d.ts +80 -0
- package/es/options.js +44 -0
- package/es/options.js.map +1 -0
- package/es/style/index.css +210 -0
- package/es/style/index.less +256 -0
- package/es/style/raw.d.ts +4 -0
- package/es/style/raw.js +6 -0
- package/es/style/raw.js.map +1 -0
- package/es/tool/MultipleSelectTool.d.ts +13 -0
- package/es/tool/MultipleSelectTool.js +159 -0
- package/es/tool/MultipleSelectTool.js.map +1 -0
- package/es/tool/TextEditTool.d.ts +26 -0
- package/es/tool/TextEditTool.js +187 -0
- package/es/tool/TextEditTool.js.map +1 -0
- package/es/tool/index.d.ts +2 -0
- package/es/tool/index.js +3 -0
- package/es/tool/index.js.map +1 -0
- package/{types/tool/SnaplineTool.d.ts → es/tool/snapline.d.ts} +1 -1
- package/es/tool/snapline.js +13 -0
- package/es/tool/snapline.js.map +1 -0
- package/es/tool/tool.d.ts +22 -0
- package/es/tool/tool.js +43 -0
- package/es/tool/tool.js.map +1 -0
- package/es/util/animation.d.ts +12 -0
- package/es/util/animation.js +20 -0
- package/es/util/animation.js.map +1 -0
- package/es/util/browser.js +3 -0
- package/es/util/browser.js.map +1 -0
- package/es/util/compatible.d.ts +6 -0
- package/es/util/compatible.js +17 -0
- package/es/util/compatible.js.map +1 -0
- package/es/util/drag.d.ts +47 -0
- package/es/util/drag.js +139 -0
- package/es/util/drag.js.map +1 -0
- package/es/util/edge.d.ts +94 -0
- package/es/util/edge.js +833 -0
- package/es/util/edge.js.map +1 -0
- package/es/util/geometry.d.ts +11 -0
- package/es/util/geometry.js +72 -0
- package/es/util/geometry.js.map +1 -0
- package/{types → es}/util/graph.d.ts +4 -3
- package/es/util/graph.js +54 -0
- package/es/util/graph.js.map +1 -0
- package/es/util/index.d.ts +16 -0
- package/es/util/index.js +17 -0
- package/es/util/index.js.map +1 -0
- package/{types → es}/util/matrix.d.ts +1 -1
- package/es/util/matrix.js +161 -0
- package/es/util/matrix.js.map +1 -0
- package/es/util/mobx.js +4 -0
- package/es/util/mobx.js.map +1 -0
- package/es/util/node.d.ts +69 -0
- package/es/util/node.js +402 -0
- package/es/util/node.js.map +1 -0
- package/es/util/raf.d.ts +2 -0
- package/es/util/raf.js +24 -0
- package/es/util/raf.js.map +1 -0
- package/{types → es}/util/sampling.d.ts +4 -2
- package/es/util/sampling.js +66 -0
- package/es/util/sampling.js.map +1 -0
- package/es/util/theme.d.ts +4 -0
- package/es/util/theme.js +156 -0
- package/es/util/theme.js.map +1 -0
- package/es/util/uuid.d.ts +7 -0
- package/es/util/uuid.js +20 -0
- package/es/util/uuid.js.map +1 -0
- package/{types → es}/util/vector.d.ts +2 -2
- package/es/util/vector.js +97 -0
- package/es/util/vector.js.map +1 -0
- package/es/util/zIndex.js +5 -0
- package/es/util/zIndex.js.map +1 -0
- package/es/view/Anchor.d.ts +47 -0
- package/es/view/Anchor.js +315 -0
- package/es/view/Anchor.js.map +1 -0
- package/es/view/Control.d.ts +100 -0
- package/es/view/Control.js +324 -0
- package/es/view/Control.js.map +1 -0
- package/es/view/Graph.d.ts +18 -0
- package/es/view/Graph.js +77 -0
- package/es/view/Graph.js.map +1 -0
- package/{types → es}/view/Rotate.d.ts +9 -9
- package/es/view/Rotate.js +108 -0
- package/es/view/Rotate.js.map +1 -0
- package/es/view/behavior/dnd.d.ts +27 -0
- package/es/view/behavior/dnd.js +110 -0
- package/es/view/behavior/dnd.js.map +1 -0
- package/es/view/edge/AdjustPoint.d.ts +50 -0
- package/es/view/edge/AdjustPoint.js +368 -0
- package/es/view/edge/AdjustPoint.js.map +1 -0
- package/es/view/edge/Arrow.d.ts +25 -0
- package/es/view/edge/Arrow.js +60 -0
- package/es/view/edge/Arrow.js.map +1 -0
- package/{types → es}/view/edge/BaseEdge.d.ts +25 -17
- package/es/view/edge/BaseEdge.js +381 -0
- package/es/view/edge/BaseEdge.js.map +1 -0
- package/es/view/edge/BezierEdge.d.ts +26 -0
- package/es/view/edge/BezierEdge.js +118 -0
- package/es/view/edge/BezierEdge.js.map +1 -0
- package/{types → es}/view/edge/LineEdge.d.ts +9 -4
- package/es/view/edge/LineEdge.js +78 -0
- package/es/view/edge/LineEdge.js.map +1 -0
- package/{types → es}/view/edge/PolylineEdge.d.ts +18 -8
- package/es/view/edge/PolylineEdge.js +274 -0
- package/es/view/edge/PolylineEdge.js.map +1 -0
- package/es/view/edge/index.d.ts +6 -0
- package/es/view/edge/index.js +7 -0
- package/es/view/edge/index.js.map +1 -0
- package/es/view/index.d.ts +7 -0
- package/es/view/index.js +8 -0
- package/es/view/index.js.map +1 -0
- package/es/view/node/BaseNode.d.ts +49 -0
- package/es/view/node/BaseNode.js +420 -0
- package/es/view/node/BaseNode.js.map +1 -0
- package/es/view/node/CircleNode.d.ts +10 -0
- package/es/view/node/CircleNode.js +45 -0
- package/es/view/node/CircleNode.js.map +1 -0
- package/es/view/node/DiamondNode.d.ts +10 -0
- package/es/view/node/DiamondNode.js +44 -0
- package/es/view/node/DiamondNode.js.map +1 -0
- package/es/view/node/EllipseNode.d.ts +10 -0
- package/es/view/node/EllipseNode.js +44 -0
- package/es/view/node/EllipseNode.js.map +1 -0
- package/{types → es}/view/node/HtmlNode.d.ts +15 -9
- package/es/view/node/HtmlNode.js +129 -0
- package/es/view/node/HtmlNode.js.map +1 -0
- package/es/view/node/PolygonNode.d.ts +10 -0
- package/es/view/node/PolygonNode.js +48 -0
- package/es/view/node/PolygonNode.js.map +1 -0
- package/es/view/node/RectNode.d.ts +11 -0
- package/es/view/node/RectNode.js +44 -0
- package/es/view/node/RectNode.js.map +1 -0
- package/es/view/node/TextNode.d.ts +12 -0
- package/es/view/node/TextNode.js +55 -0
- package/es/view/node/TextNode.js.map +1 -0
- package/es/view/node/index.d.ts +8 -0
- package/es/view/node/index.js +9 -0
- package/es/view/node/index.js.map +1 -0
- package/{types → es}/view/overlay/BackgroundOverlay.d.ts +7 -7
- package/es/view/overlay/BackgroundOverlay.js +31 -0
- package/es/view/overlay/BackgroundOverlay.js.map +1 -0
- package/es/view/overlay/BezierAdjustOverlay.d.ts +31 -0
- package/es/view/overlay/BezierAdjustOverlay.js +142 -0
- package/es/view/overlay/BezierAdjustOverlay.js.map +1 -0
- package/{types → es}/view/overlay/CanvasOverlay.d.ts +8 -11
- package/es/view/overlay/CanvasOverlay.js +172 -0
- package/es/view/overlay/CanvasOverlay.js.map +1 -0
- package/es/view/overlay/Grid.d.ts +45 -0
- package/es/view/overlay/Grid.js +127 -0
- package/es/view/overlay/Grid.js.map +1 -0
- package/es/view/overlay/ModificationOverlay.d.ts +9 -0
- package/es/view/overlay/ModificationOverlay.js +43 -0
- package/es/view/overlay/ModificationOverlay.js.map +1 -0
- package/es/view/overlay/OutlineOverlay.d.ts +14 -0
- package/es/view/overlay/OutlineOverlay.js +134 -0
- package/es/view/overlay/OutlineOverlay.js.map +1 -0
- package/es/view/overlay/SnaplineOverlay.d.ts +10 -0
- package/es/view/overlay/SnaplineOverlay.js +60 -0
- package/es/view/overlay/SnaplineOverlay.js.map +1 -0
- package/es/view/overlay/ToolOverlay.d.ts +19 -0
- package/es/view/overlay/ToolOverlay.js +76 -0
- package/es/view/overlay/ToolOverlay.js.map +1 -0
- package/{types → es}/view/overlay/getTransformHoc.d.ts +17 -14
- package/es/view/overlay/getTransformHoc.js +57 -0
- package/es/view/overlay/getTransformHoc.js.map +1 -0
- package/es/view/overlay/index.d.ts +8 -0
- package/es/view/overlay/index.js +9 -0
- package/es/view/overlay/index.js.map +1 -0
- package/es/view/shape/Circle.d.ts +2 -0
- package/es/view/shape/Circle.js +57 -0
- package/es/view/shape/Circle.js.map +1 -0
- package/es/view/shape/Ellipse.d.ts +2 -0
- package/es/view/shape/Ellipse.js +58 -0
- package/es/view/shape/Ellipse.js.map +1 -0
- package/es/view/shape/Line.d.ts +2 -0
- package/es/view/shape/Line.js +54 -0
- package/es/view/shape/Line.js.map +1 -0
- package/es/view/shape/Path.d.ts +6 -0
- package/es/view/shape/Path.js +43 -0
- package/es/view/shape/Path.js.map +1 -0
- package/es/view/shape/Polygon.d.ts +8 -0
- package/es/view/shape/Polygon.js +56 -0
- package/es/view/shape/Polygon.js.map +1 -0
- package/es/view/shape/Polyline.d.ts +2 -0
- package/es/view/shape/Polyline.js +49 -0
- package/es/view/shape/Polyline.js.map +1 -0
- package/es/view/shape/Rect.d.ts +15 -0
- package/es/view/shape/Rect.js +60 -0
- package/es/view/shape/Rect.js.map +1 -0
- package/es/view/shape/Text.d.ts +2 -0
- package/es/view/shape/Text.js +110 -0
- package/es/view/shape/Text.js.map +1 -0
- package/es/view/shape/index.d.ts +8 -0
- package/es/view/shape/index.js +9 -0
- package/es/view/shape/index.js.map +1 -0
- package/es/view/text/BaseText.d.ts +25 -0
- package/es/view/text/BaseText.js +114 -0
- package/es/view/text/BaseText.js.map +1 -0
- package/es/view/text/LineText.d.ts +9 -0
- package/es/view/text/LineText.js +149 -0
- package/es/view/text/LineText.js.map +1 -0
- package/es/view/text/index.d.ts +2 -0
- package/es/view/text/index.js +3 -0
- package/es/view/text/index.js.map +1 -0
- package/lib/LogicFlow.d.ts +966 -0
- package/lib/LogicFlow.js +1203 -0
- package/lib/LogicFlow.js.map +1 -0
- package/lib/algorithm/edge.d.ts +15 -0
- package/lib/algorithm/edge.js +62 -0
- package/lib/algorithm/edge.js.map +1 -0
- package/lib/algorithm/index.d.ts +6 -0
- package/lib/algorithm/index.js +75 -0
- package/lib/algorithm/index.js.map +1 -0
- package/lib/algorithm/outline.d.ts +7 -0
- package/lib/algorithm/outline.js +69 -0
- package/lib/algorithm/outline.js.map +1 -0
- package/lib/constant/index.d.ts +102 -0
- package/lib/constant/index.js +120 -0
- package/lib/constant/index.js.map +1 -0
- package/lib/event/eventArgs.d.ts +428 -0
- package/lib/event/eventArgs.js +3 -0
- package/lib/event/eventArgs.js.map +1 -0
- package/lib/event/eventEmitter.d.ts +48 -0
- package/lib/event/eventEmitter.js +95 -0
- package/lib/event/eventEmitter.js.map +1 -0
- package/lib/history/index.d.ts +23 -0
- package/lib/history/index.js +114 -0
- package/lib/history/index.js.map +1 -0
- package/lib/index.css +210 -0
- package/lib/index.d.ts +12 -0
- package/lib/index.js +58 -0
- package/lib/index.js.map +1 -0
- package/lib/index.less +1 -0
- package/lib/keyboard/index.d.ts +31 -0
- package/lib/keyboard/index.js +93 -0
- package/lib/keyboard/index.js.map +1 -0
- package/lib/keyboard/shortcut.d.ts +3 -0
- package/lib/keyboard/shortcut.js +120 -0
- package/lib/keyboard/shortcut.js.map +1 -0
- package/lib/model/BaseModel.d.ts +181 -0
- package/lib/model/BaseModel.js +3 -0
- package/lib/model/BaseModel.js.map +1 -0
- package/lib/model/EditConfigModel.d.ts +114 -0
- package/lib/model/EditConfigModel.js +195 -0
- package/lib/model/EditConfigModel.js.map +1 -0
- package/lib/model/GraphModel.d.ts +426 -0
- package/lib/model/GraphModel.js +1479 -0
- package/lib/model/GraphModel.js.map +1 -0
- package/lib/model/SnaplineModel.d.ts +34 -0
- package/lib/model/SnaplineModel.js +220 -0
- package/lib/model/SnaplineModel.js.map +1 -0
- package/lib/model/TransformModel.d.ts +101 -0
- package/lib/model/TransformModel.js +243 -0
- package/lib/model/TransformModel.js.map +1 -0
- package/lib/model/edge/BaseEdgeModel.d.ts +270 -0
- package/lib/model/edge/BaseEdgeModel.js +742 -0
- package/lib/model/edge/BaseEdgeModel.js.map +1 -0
- package/lib/model/edge/BezierEdgeModel.d.ts +63 -0
- package/lib/model/edge/BezierEdgeModel.js +250 -0
- package/lib/model/edge/BezierEdgeModel.js.map +1 -0
- package/lib/model/edge/LineEdgeModel.d.ts +19 -0
- package/lib/model/edge/LineEdgeModel.js +83 -0
- package/lib/model/edge/LineEdgeModel.js.map +1 -0
- package/lib/model/edge/PolylineEdgeModel.d.ts +85 -0
- package/lib/model/edge/PolylineEdgeModel.js +596 -0
- package/lib/model/edge/PolylineEdgeModel.js.map +1 -0
- package/lib/model/edge/index.d.ts +4 -0
- package/lib/model/edge/index.js +21 -0
- package/lib/model/edge/index.js.map +1 -0
- package/lib/model/index.d.ts +7 -0
- package/lib/model/index.js +24 -0
- package/lib/model/index.js.map +1 -0
- package/lib/model/node/BaseNodeModel.d.ts +260 -0
- package/lib/model/node/BaseNodeModel.js +886 -0
- package/lib/model/node/BaseNodeModel.js.map +1 -0
- package/lib/model/node/CircleNodeModel.d.ts +40 -0
- package/lib/model/node/CircleNodeModel.js +116 -0
- package/lib/model/node/CircleNodeModel.js.map +1 -0
- package/lib/model/node/DiamondNodeModel.d.ts +46 -0
- package/lib/model/node/DiamondNodeModel.js +193 -0
- package/lib/model/node/DiamondNodeModel.js.map +1 -0
- package/lib/model/node/EllipseNodeModel.d.ts +42 -0
- package/lib/model/node/EllipseNodeModel.js +124 -0
- package/lib/model/node/EllipseNodeModel.js.map +1 -0
- package/lib/model/node/HtmlNodeModel.d.ts +21 -0
- package/lib/model/node/HtmlNodeModel.js +65 -0
- package/lib/model/node/HtmlNodeModel.js.map +1 -0
- package/lib/model/node/PolygonNodeModel.d.ts +50 -0
- package/lib/model/node/PolygonNodeModel.js +202 -0
- package/lib/model/node/PolygonNodeModel.js.map +1 -0
- package/lib/model/node/RectNodeModel.d.ts +34 -0
- package/lib/model/node/RectNodeModel.js +86 -0
- package/lib/model/node/RectNodeModel.js.map +1 -0
- package/lib/model/node/TextNodeModel.d.ts +27 -0
- package/lib/model/node/TextNodeModel.js +119 -0
- package/lib/model/node/TextNodeModel.js.map +1 -0
- package/lib/model/node/index.d.ts +8 -0
- package/lib/model/node/index.js +25 -0
- package/lib/model/node/index.js.map +1 -0
- package/lib/options.d.ts +80 -0
- package/lib/options.js +47 -0
- package/lib/options.js.map +1 -0
- package/lib/style/index.css +210 -0
- package/lib/style/index.less +256 -0
- package/lib/style/raw.d.ts +4 -0
- package/lib/style/raw.js +9 -0
- package/lib/style/raw.js.map +1 -0
- package/lib/tool/MultipleSelectTool.d.ts +13 -0
- package/lib/tool/MultipleSelectTool.js +161 -0
- package/lib/tool/MultipleSelectTool.js.map +1 -0
- package/lib/tool/TextEditTool.d.ts +26 -0
- package/lib/tool/TextEditTool.js +190 -0
- package/lib/tool/TextEditTool.js.map +1 -0
- package/lib/tool/index.d.ts +2 -0
- package/lib/tool/index.js +19 -0
- package/lib/tool/index.js.map +1 -0
- package/lib/tool/snapline.d.ts +3 -0
- package/lib/tool/snapline.js +17 -0
- package/lib/tool/snapline.js.map +1 -0
- package/lib/tool/tool.d.ts +22 -0
- package/lib/tool/tool.js +49 -0
- package/lib/tool/tool.js.map +1 -0
- package/lib/util/animation.d.ts +12 -0
- package/lib/util/animation.js +24 -0
- package/lib/util/animation.js.map +1 -0
- package/lib/util/browser.d.ts +1 -0
- package/lib/util/browser.js +6 -0
- package/lib/util/browser.js.map +1 -0
- package/lib/util/compatible.d.ts +6 -0
- package/lib/util/compatible.js +21 -0
- package/lib/util/compatible.js.map +1 -0
- package/lib/util/drag.d.ts +47 -0
- package/lib/util/drag.js +142 -0
- package/lib/util/drag.js.map +1 -0
- package/lib/util/edge.d.ts +94 -0
- package/lib/util/edge.js +879 -0
- package/lib/util/edge.js.map +1 -0
- package/lib/util/geometry.d.ts +11 -0
- package/lib/util/geometry.js +78 -0
- package/lib/util/geometry.js.map +1 -0
- package/lib/util/graph.d.ts +13 -0
- package/lib/util/graph.js +59 -0
- package/lib/util/graph.js.map +1 -0
- package/lib/util/index.d.ts +16 -0
- package/lib/util/index.js +33 -0
- package/lib/util/index.js.map +1 -0
- package/lib/util/matrix.d.ts +32 -0
- package/lib/util/matrix.js +164 -0
- package/lib/util/matrix.js.map +1 -0
- package/lib/util/mobx.d.ts +2 -0
- package/lib/util/mobx.js +13 -0
- package/lib/util/mobx.js.map +1 -0
- package/lib/util/node.d.ts +69 -0
- package/lib/util/node.js +424 -0
- package/lib/util/node.js.map +1 -0
- package/lib/util/raf.d.ts +2 -0
- package/lib/util/raf.js +29 -0
- package/lib/util/raf.js.map +1 -0
- package/lib/util/sampling.d.ts +6 -0
- package/lib/util/sampling.js +72 -0
- package/lib/util/sampling.js.map +1 -0
- package/lib/util/theme.d.ts +4 -0
- package/lib/util/theme.js +160 -0
- package/lib/util/theme.js.map +1 -0
- package/lib/util/uuid.d.ts +7 -0
- package/lib/util/uuid.js +25 -0
- package/lib/util/uuid.js.map +1 -0
- package/lib/util/vector.d.ts +23 -0
- package/lib/util/vector.js +101 -0
- package/lib/util/vector.js.map +1 -0
- package/lib/util/zIndex.d.ts +2 -0
- package/lib/util/zIndex.js +10 -0
- package/lib/util/zIndex.js.map +1 -0
- package/lib/view/Anchor.d.ts +47 -0
- package/lib/view/Anchor.js +317 -0
- package/lib/view/Anchor.js.map +1 -0
- package/lib/view/Control.d.ts +100 -0
- package/lib/view/Control.js +327 -0
- package/lib/view/Control.js.map +1 -0
- package/lib/view/Graph.d.ts +18 -0
- package/lib/view/Graph.js +79 -0
- package/lib/view/Graph.js.map +1 -0
- package/lib/view/Rotate.d.ts +21 -0
- package/lib/view/Rotate.js +113 -0
- package/lib/view/Rotate.js.map +1 -0
- package/lib/view/behavior/dnd.d.ts +27 -0
- package/lib/view/behavior/dnd.js +113 -0
- package/lib/view/behavior/dnd.js.map +1 -0
- package/lib/view/edge/AdjustPoint.d.ts +50 -0
- package/lib/view/edge/AdjustPoint.js +371 -0
- package/lib/view/edge/AdjustPoint.js.map +1 -0
- package/lib/view/edge/Arrow.d.ts +25 -0
- package/lib/view/edge/Arrow.js +63 -0
- package/lib/view/edge/Arrow.js.map +1 -0
- package/lib/view/edge/BaseEdge.d.ts +148 -0
- package/lib/view/edge/BaseEdge.js +407 -0
- package/lib/view/edge/BaseEdge.js.map +1 -0
- package/lib/view/edge/BezierEdge.d.ts +26 -0
- package/lib/view/edge/BezierEdge.js +124 -0
- package/lib/view/edge/BezierEdge.js.map +1 -0
- package/{types/view/edge/BezierEdge.d.ts → lib/view/edge/LineEdge.d.ts} +9 -10
- package/lib/view/edge/LineEdge.js +84 -0
- package/lib/view/edge/LineEdge.js.map +1 -0
- package/lib/view/edge/PolylineEdge.d.ts +55 -0
- package/lib/view/edge/PolylineEdge.js +280 -0
- package/lib/view/edge/PolylineEdge.js.map +1 -0
- package/lib/view/edge/index.d.ts +6 -0
- package/lib/view/edge/index.js +23 -0
- package/lib/view/edge/index.js.map +1 -0
- package/lib/view/index.d.ts +7 -0
- package/lib/view/index.js +24 -0
- package/lib/view/index.js.map +1 -0
- package/lib/view/node/BaseNode.d.ts +49 -0
- package/lib/view/node/BaseNode.js +424 -0
- package/lib/view/node/BaseNode.js.map +1 -0
- package/lib/view/node/CircleNode.d.ts +10 -0
- package/lib/view/node/CircleNode.js +51 -0
- package/lib/view/node/CircleNode.js.map +1 -0
- package/lib/view/node/DiamondNode.d.ts +10 -0
- package/lib/view/node/DiamondNode.js +50 -0
- package/lib/view/node/DiamondNode.js.map +1 -0
- package/lib/view/node/EllipseNode.d.ts +10 -0
- package/lib/view/node/EllipseNode.js +50 -0
- package/lib/view/node/EllipseNode.js.map +1 -0
- package/lib/view/node/HtmlNode.d.ts +38 -0
- package/lib/view/node/HtmlNode.js +135 -0
- package/lib/view/node/HtmlNode.js.map +1 -0
- package/lib/view/node/PolygonNode.d.ts +10 -0
- package/lib/view/node/PolygonNode.js +54 -0
- package/lib/view/node/PolygonNode.js.map +1 -0
- package/lib/view/node/RectNode.d.ts +11 -0
- package/lib/view/node/RectNode.js +50 -0
- package/lib/view/node/RectNode.js.map +1 -0
- package/lib/view/node/TextNode.d.ts +12 -0
- package/lib/view/node/TextNode.js +61 -0
- package/lib/view/node/TextNode.js.map +1 -0
- package/lib/view/node/index.d.ts +8 -0
- package/lib/view/node/index.js +25 -0
- package/lib/view/node/index.js.map +1 -0
- package/lib/view/overlay/BackgroundOverlay.d.ts +28 -0
- package/lib/view/overlay/BackgroundOverlay.js +34 -0
- package/lib/view/overlay/BackgroundOverlay.js.map +1 -0
- package/lib/view/overlay/BezierAdjustOverlay.d.ts +31 -0
- package/lib/view/overlay/BezierAdjustOverlay.js +145 -0
- package/lib/view/overlay/BezierAdjustOverlay.js.map +1 -0
- package/lib/view/overlay/CanvasOverlay.d.ts +25 -0
- package/lib/view/overlay/CanvasOverlay.js +175 -0
- package/lib/view/overlay/CanvasOverlay.js.map +1 -0
- package/lib/view/overlay/Grid.d.ts +45 -0
- package/lib/view/overlay/Grid.js +130 -0
- package/lib/view/overlay/Grid.js.map +1 -0
- package/lib/view/overlay/ModificationOverlay.d.ts +9 -0
- package/lib/view/overlay/ModificationOverlay.js +46 -0
- package/lib/view/overlay/ModificationOverlay.js.map +1 -0
- package/lib/view/overlay/OutlineOverlay.d.ts +14 -0
- package/lib/view/overlay/OutlineOverlay.js +137 -0
- package/lib/view/overlay/OutlineOverlay.js.map +1 -0
- package/lib/view/overlay/SnaplineOverlay.d.ts +10 -0
- package/lib/view/overlay/SnaplineOverlay.js +66 -0
- package/lib/view/overlay/SnaplineOverlay.js.map +1 -0
- package/lib/view/overlay/ToolOverlay.d.ts +19 -0
- package/lib/view/overlay/ToolOverlay.js +79 -0
- package/lib/view/overlay/ToolOverlay.js.map +1 -0
- package/lib/view/overlay/getTransformHoc.d.ts +37 -0
- package/lib/view/overlay/getTransformHoc.js +61 -0
- package/lib/view/overlay/getTransformHoc.js.map +1 -0
- package/lib/view/overlay/index.d.ts +8 -0
- package/lib/view/overlay/index.js +25 -0
- package/lib/view/overlay/index.js.map +1 -0
- package/lib/view/shape/Circle.d.ts +2 -0
- package/lib/view/shape/Circle.js +61 -0
- package/lib/view/shape/Circle.js.map +1 -0
- package/lib/view/shape/Ellipse.d.ts +2 -0
- package/lib/view/shape/Ellipse.js +62 -0
- package/lib/view/shape/Ellipse.js.map +1 -0
- package/lib/view/shape/Line.d.ts +2 -0
- package/lib/view/shape/Line.js +58 -0
- package/lib/view/shape/Line.js.map +1 -0
- package/lib/view/shape/Path.d.ts +6 -0
- package/lib/view/shape/Path.js +47 -0
- package/lib/view/shape/Path.js.map +1 -0
- package/lib/view/shape/Polygon.d.ts +8 -0
- package/lib/view/shape/Polygon.js +60 -0
- package/lib/view/shape/Polygon.js.map +1 -0
- package/lib/view/shape/Polyline.d.ts +2 -0
- package/lib/view/shape/Polyline.js +53 -0
- package/lib/view/shape/Polyline.js.map +1 -0
- package/lib/view/shape/Rect.d.ts +15 -0
- package/lib/view/shape/Rect.js +64 -0
- package/lib/view/shape/Rect.js.map +1 -0
- package/lib/view/shape/Text.d.ts +2 -0
- package/lib/view/shape/Text.js +114 -0
- package/lib/view/shape/Text.js.map +1 -0
- package/lib/view/shape/index.d.ts +8 -0
- package/lib/view/shape/index.js +25 -0
- package/lib/view/shape/index.js.map +1 -0
- package/lib/view/text/BaseText.d.ts +25 -0
- package/lib/view/text/BaseText.js +117 -0
- package/lib/view/text/BaseText.js.map +1 -0
- package/lib/view/text/LineText.d.ts +9 -0
- package/lib/view/text/LineText.js +155 -0
- package/lib/view/text/LineText.js.map +1 -0
- package/lib/view/text/index.d.ts +2 -0
- package/lib/view/text/index.js +19 -0
- package/lib/view/text/index.js.map +1 -0
- package/package.json +41 -88
- package/rollup.config.js +15 -0
- package/src/LogicFlow.tsx +1831 -0
- package/src/algorithm/edge.ts +68 -0
- package/src/algorithm/index.ts +68 -0
- package/src/algorithm/outline.ts +77 -0
- package/src/constant/index.ts +127 -0
- package/src/event/event.md +66 -0
- package/src/event/eventArgs.ts +476 -0
- package/src/event/eventEmitter.ts +153 -0
- package/src/history/index.ts +112 -0
- package/src/index.less +1 -0
- package/src/index.ts +21 -0
- package/src/keyboard/index.ts +106 -0
- package/src/keyboard/shortcut.ts +123 -0
- package/src/model/BaseModel.ts +223 -0
- package/src/model/EditConfigModel.ts +215 -0
- package/src/model/GraphModel.ts +1516 -0
- package/src/model/SnaplineModel.ts +238 -0
- package/src/model/TransformModel.ts +258 -0
- package/src/model/edge/BaseEdgeModel.ts +720 -0
- package/src/model/edge/BezierEdgeModel.ts +196 -0
- package/src/model/edge/LineEdgeModel.ts +26 -0
- package/src/model/edge/PolylineEdgeModel.ts +656 -0
- package/src/model/edge/index.ts +4 -0
- package/src/model/index.ts +8 -0
- package/src/model/node/BaseNodeModel.ts +839 -0
- package/src/model/node/CircleNodeModel.ts +89 -0
- package/src/model/node/DiamondNodeModel.ts +128 -0
- package/src/model/node/EllipseNodeModel.ts +94 -0
- package/src/model/node/HtmlNodeModel.ts +49 -0
- package/src/model/node/PolygonNodeModel.ts +147 -0
- package/src/model/node/RectNodeModel.ts +57 -0
- package/src/model/node/TextNodeModel.ts +41 -0
- package/src/model/node/index.ts +8 -0
- package/src/options.ts +142 -0
- package/src/style/index.less +256 -0
- package/src/style/raw.ts +217 -0
- package/src/tool/MultipleSelectTool.tsx +132 -0
- package/src/tool/TextEditTool.tsx +193 -0
- package/src/tool/index.ts +2 -0
- package/src/tool/snapline.ts +17 -0
- package/src/tool/tool.ts +66 -0
- package/src/typings.d.ts +5 -0
- package/src/util/animation.ts +29 -0
- package/src/util/browser.ts +4 -0
- package/src/util/compatible.ts +15 -0
- package/src/util/drag.ts +186 -0
- package/src/util/edge.ts +1034 -0
- package/src/util/geometry.ts +53 -0
- package/src/util/graph.ts +46 -0
- package/src/util/index.ts +16 -0
- package/src/util/matrix.ts +129 -0
- package/src/util/mobx.ts +23 -0
- package/src/util/node.ts +519 -0
- package/src/util/raf.ts +28 -0
- package/src/util/sampling.ts +85 -0
- package/src/util/theme.ts +180 -0
- package/src/util/uuid.ts +26 -0
- package/src/util/vector.ts +93 -0
- package/src/util/zIndex.ts +6 -0
- package/src/view/Anchor.tsx +407 -0
- package/src/view/Control.tsx +446 -0
- package/src/view/Graph.tsx +104 -0
- package/src/view/Rotate.tsx +112 -0
- package/src/view/behavior/dnd.ts +116 -0
- package/src/view/edge/AdjustPoint.tsx +439 -0
- package/src/view/edge/Arrow.tsx +54 -0
- package/src/view/edge/BaseEdge.tsx +489 -0
- package/src/view/edge/BezierEdge.tsx +101 -0
- package/src/view/edge/LineEdge.tsx +81 -0
- package/src/view/edge/PolylineEdge.tsx +299 -0
- package/src/view/edge/index.ts +6 -0
- package/src/view/index.ts +8 -0
- package/src/view/node/BaseNode.tsx +494 -0
- package/src/view/node/CircleNode.tsx +19 -0
- package/src/view/node/DiamondNode.tsx +22 -0
- package/src/view/node/EllipseNode.tsx +20 -0
- package/src/view/node/HtmlNode.tsx +92 -0
- package/src/view/node/PolygonNode.tsx +26 -0
- package/src/view/node/RectNode.tsx +28 -0
- package/src/view/node/TextNode.tsx +37 -0
- package/src/view/node/index.ts +8 -0
- package/src/view/overlay/BackgroundOverlay.tsx +39 -0
- package/src/view/overlay/BezierAdjustOverlay.tsx +150 -0
- package/src/view/overlay/CanvasOverlay.tsx +180 -0
- package/src/view/overlay/Grid.tsx +157 -0
- package/src/view/overlay/ModificationOverlay.tsx +31 -0
- package/src/view/overlay/OutlineOverlay.tsx +170 -0
- package/src/view/overlay/SnaplineOverlay.tsx +44 -0
- package/src/view/overlay/ToolOverlay.tsx +65 -0
- package/src/view/overlay/getTransformHoc.tsx +50 -0
- package/src/view/overlay/index.ts +8 -0
- package/src/view/shape/Circle.tsx +27 -0
- package/src/view/shape/Ellipse.tsx +28 -0
- package/src/view/shape/Line.tsx +24 -0
- package/src/view/shape/Path.tsx +19 -0
- package/src/view/shape/Polygon.tsx +36 -0
- package/src/view/shape/Polyline.tsx +19 -0
- package/src/view/shape/Rect.tsx +44 -0
- package/src/view/shape/Text.tsx +138 -0
- package/src/view/shape/index.ts +8 -0
- package/src/view/text/BaseText.tsx +96 -0
- package/src/view/text/LineText.tsx +154 -0
- package/src/view/text/index.ts +2 -0
- package/tsconfig.json +18 -0
- package/dist/entry.js +0 -7
- package/dist/logic-flow.js +0 -23
- package/dist/logic-flow.min.js +0 -23
- package/types/LogicFlow.d.ts +0 -581
- package/types/algorithm/edge.d.ts +0 -6
- package/types/algorithm/outline.d.ts +0 -35
- package/types/constant/DefaultAnimation.d.ts +0 -12
- package/types/constant/DefaultTheme.d.ts +0 -270
- package/types/event/eventEmitter.d.ts +0 -36
- package/types/history/History.d.ts +0 -20
- package/types/model/BaseModel.d.ts +0 -99
- package/types/model/SnaplineModel.d.ts +0 -33
- package/types/model/edge/BezierEdgeModel.d.ts +0 -51
- package/types/model/edge/LineEdgeModel.d.ts +0 -14
- package/types/model/edge/PolylineEdgeModel.d.ts +0 -63
- package/types/model/node/BaseNodeModel.d.ts +0 -232
- package/types/model/node/CircleNodeModel.d.ts +0 -21
- package/types/model/node/DiamondNodeModel.d.ts +0 -25
- package/types/model/node/EllipseNodeModel.d.ts +0 -22
- package/types/model/node/HtmlNodeModel.d.ts +0 -12
- package/types/model/node/PolygonNodeModel.d.ts +0 -28
- package/types/model/node/RectNodeModel.d.ts +0 -19
- package/types/model/node/TextNodeModel.d.ts +0 -19
- package/types/options.d.ts +0 -240
- package/types/tool/MultipleSelectTool.d.ts +0 -20
- package/types/tool/TextEditTool.d.ts +0 -34
- package/types/tool/index.d.ts +0 -13
- package/types/type/index.d.ts +0 -429
- package/types/util/animation.d.ts +0 -2
- package/types/util/compatible.d.ts +0 -1
- package/types/util/drag.d.ts +0 -38
- package/types/util/edge.d.ts +0 -108
- package/types/util/geometry.d.ts +0 -2
- package/types/util/index.d.ts +0 -7
- package/types/util/node.d.ts +0 -66
- package/types/util/raf.d.ts +0 -2
- package/types/util/theme.d.ts +0 -2
- package/types/util/uuid.d.ts +0 -6
- package/types/view/Anchor.d.ts +0 -54
- package/types/view/Graph.d.ts +0 -21
- package/types/view/basic-shape/Circle.d.ts +0 -2
- package/types/view/basic-shape/Ellipse.d.ts +0 -2
- package/types/view/basic-shape/Line.d.ts +0 -3
- package/types/view/basic-shape/LinearGradient.d.ts +0 -1
- package/types/view/basic-shape/Path.d.ts +0 -7
- package/types/view/basic-shape/Polygon.d.ts +0 -2
- package/types/view/basic-shape/Polyline.d.ts +0 -3
- package/types/view/basic-shape/Rect.d.ts +0 -14
- package/types/view/basic-shape/Text.d.ts +0 -2
- package/types/view/behavior/DnD.d.ts +0 -35
- package/types/view/behavior/Transform.d.ts +0 -4
- package/types/view/edge/AdjustPoint.d.ts +0 -56
- package/types/view/edge/Arrow.d.ts +0 -24
- package/types/view/edge/index.d.ts +0 -6
- package/types/view/index.d.ts +0 -2
- package/types/view/node/BaseNode.d.ts +0 -57
- package/types/view/node/CircleNode.d.ts +0 -5
- package/types/view/node/DiamondNode.d.ts +0 -5
- package/types/view/node/EllipseNode.d.ts +0 -5
- package/types/view/node/PolygonNode.d.ts +0 -5
- package/types/view/node/RectNode.d.ts +0 -5
- package/types/view/node/TextNode.d.ts +0 -6
- package/types/view/node/index.d.ts +0 -9
- package/types/view/overlay/BezierAdjustOverlay.d.ts +0 -12
- package/types/view/overlay/Grid.d.ts +0 -30
- package/types/view/overlay/HtmlOverlay.d.ts +0 -15
- package/types/view/overlay/ModificationOverlay.d.ts +0 -9
- package/types/view/overlay/OutlineOverlay.d.ts +0 -17
- package/types/view/overlay/SnaplineOverlay.d.ts +0 -9
- package/types/view/overlay/ToolOverlay.d.ts +0 -17
- package/types/view/text/BaseText.d.ts +0 -29
- package/types/view/text/LineText.d.ts +0 -9
- /package/{types → es}/algorithm/index.d.ts +0 -0
- /package/{types → es}/keyboard/shortcut.d.ts +0 -0
- /package/{types → es}/model/edge/index.d.ts +0 -0
- /package/{types → es}/model/index.d.ts +0 -0
- /package/{types → es}/model/node/index.d.ts +0 -0
- /package/{types → es}/util/browser.d.ts +0 -0
- /package/{types → es}/util/mobx.d.ts +0 -0
- /package/{types → es}/util/zIndex.d.ts +0 -0
|
@@ -1,28 +1,25 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Component } from 'preact/compat';
|
|
2
|
+
import Dnd from '../behavior/dnd';
|
|
2
3
|
import GraphModel from '../../model/GraphModel';
|
|
3
|
-
import { StepDrag } from '../../util
|
|
4
|
-
|
|
5
|
-
declare type IProps = {
|
|
4
|
+
import { StepDrag, IDragParams } from '../../util';
|
|
5
|
+
type IProps = {
|
|
6
6
|
graphModel: GraphModel;
|
|
7
7
|
dnd: Dnd;
|
|
8
8
|
};
|
|
9
|
-
|
|
9
|
+
type IState = {
|
|
10
10
|
isDragging: boolean;
|
|
11
11
|
};
|
|
12
|
-
declare class CanvasOverlay extends Component<IProps, IState> {
|
|
12
|
+
export declare class CanvasOverlay extends Component<IProps, IState> {
|
|
13
13
|
stepDrag: StepDrag;
|
|
14
14
|
stepScrollX: number;
|
|
15
15
|
stepScrollY: number;
|
|
16
16
|
constructor(props: IProps);
|
|
17
|
-
onDragging: ({ deltaX, deltaY }:
|
|
18
|
-
deltaX: any;
|
|
19
|
-
deltaY: any;
|
|
20
|
-
}) => void;
|
|
17
|
+
onDragging: ({ deltaX, deltaY }: IDragParams) => void;
|
|
21
18
|
onDragEnd: () => void;
|
|
22
19
|
zoomHandler: (ev: WheelEvent) => void;
|
|
23
20
|
clickHandler: (ev: MouseEvent) => void;
|
|
24
21
|
handleContextMenu: (ev: MouseEvent) => void;
|
|
25
22
|
mouseDownHandler: (ev: MouseEvent) => void;
|
|
26
|
-
render():
|
|
23
|
+
render(): import("preact/compat").JSX.Element;
|
|
27
24
|
}
|
|
28
25
|
export default CanvasOverlay;
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
var __extends = (this && this.__extends) || (function () {
|
|
2
|
+
var extendStatics = function (d, b) {
|
|
3
|
+
extendStatics = Object.setPrototypeOf ||
|
|
4
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
6
|
+
return extendStatics(d, b);
|
|
7
|
+
};
|
|
8
|
+
return function (d, b) {
|
|
9
|
+
if (typeof b !== "function" && b !== null)
|
|
10
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
11
|
+
extendStatics(d, b);
|
|
12
|
+
function __() { this.constructor = d; }
|
|
13
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
14
|
+
};
|
|
15
|
+
})();
|
|
16
|
+
var __assign = (this && this.__assign) || function () {
|
|
17
|
+
__assign = Object.assign || function(t) {
|
|
18
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
19
|
+
s = arguments[i];
|
|
20
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
21
|
+
t[p] = s[p];
|
|
22
|
+
}
|
|
23
|
+
return t;
|
|
24
|
+
};
|
|
25
|
+
return __assign.apply(this, arguments);
|
|
26
|
+
};
|
|
27
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
28
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
29
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
30
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
31
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
32
|
+
};
|
|
33
|
+
import { jsx as _jsx } from "preact/jsx-runtime";
|
|
34
|
+
import { Component } from 'preact/compat';
|
|
35
|
+
import { observer } from '../..';
|
|
36
|
+
import { EventType } from '../../constant';
|
|
37
|
+
import { StepDrag } from '../../util';
|
|
38
|
+
var CanvasOverlay = /** @class */ (function (_super) {
|
|
39
|
+
__extends(CanvasOverlay, _super);
|
|
40
|
+
function CanvasOverlay(props) {
|
|
41
|
+
var _this = _super.call(this) || this;
|
|
42
|
+
_this.stepScrollX = 0;
|
|
43
|
+
_this.stepScrollY = 0;
|
|
44
|
+
// get InjectedProps() {
|
|
45
|
+
// return this.props as InjectedProps;
|
|
46
|
+
// }
|
|
47
|
+
_this.onDragging = function (_a) {
|
|
48
|
+
var deltaX = _a.deltaX, deltaY = _a.deltaY;
|
|
49
|
+
_this.setState({
|
|
50
|
+
isDragging: true,
|
|
51
|
+
});
|
|
52
|
+
var _b = _this.props.graphModel, transformModel = _b.transformModel, editConfigModel = _b.editConfigModel;
|
|
53
|
+
if (editConfigModel.stopMoveGraph === true) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
transformModel.translate(deltaX, deltaY);
|
|
57
|
+
};
|
|
58
|
+
_this.onDragEnd = function () {
|
|
59
|
+
_this.setState({
|
|
60
|
+
isDragging: false,
|
|
61
|
+
});
|
|
62
|
+
};
|
|
63
|
+
_this.zoomHandler = function (ev) {
|
|
64
|
+
var _a = _this.props, _b = _a.graphModel, editConfigModel = _b.editConfigModel, transformModel = _b.transformModel, gridSize = _b.gridSize, graphModel = _a.graphModel;
|
|
65
|
+
var eX = ev.deltaX, eY = ev.deltaY;
|
|
66
|
+
// 如果没有禁止滚动移动画布, 并且当前触发的时候ctrl键没有按住, 那么移动画布
|
|
67
|
+
if (!editConfigModel.stopScrollGraph && ev.ctrlKey !== true) {
|
|
68
|
+
ev.preventDefault();
|
|
69
|
+
_this.stepScrollX += eX;
|
|
70
|
+
_this.stepScrollY += eY;
|
|
71
|
+
if (Math.abs(_this.stepScrollX) >= gridSize) {
|
|
72
|
+
var remainderX = _this.stepScrollX % gridSize;
|
|
73
|
+
var moveDistance = _this.stepScrollX - remainderX;
|
|
74
|
+
transformModel.translate(-moveDistance * transformModel.SCALE_X, 0);
|
|
75
|
+
_this.stepScrollX = remainderX;
|
|
76
|
+
}
|
|
77
|
+
if (Math.abs(_this.stepScrollY) >= gridSize) {
|
|
78
|
+
var remainderY = _this.stepScrollY % gridSize;
|
|
79
|
+
var moveDistanceY = _this.stepScrollY - remainderY;
|
|
80
|
+
transformModel.translate(0, -moveDistanceY * transformModel.SCALE_Y);
|
|
81
|
+
_this.stepScrollY = remainderY;
|
|
82
|
+
}
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
// 如果没有禁止缩放画布,那么进行缩放. 在禁止缩放画布后,按住ctrl键也不能缩放了。
|
|
86
|
+
if (!editConfigModel.stopZoomGraph) {
|
|
87
|
+
ev.preventDefault();
|
|
88
|
+
var position = graphModel.getPointByClient({
|
|
89
|
+
x: ev.clientX,
|
|
90
|
+
y: ev.clientY,
|
|
91
|
+
});
|
|
92
|
+
var _c = position.canvasOverlayPosition, x = _c.x, y = _c.y;
|
|
93
|
+
transformModel.zoom(ev.deltaY < 0, [x, y]);
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
_this.clickHandler = function (ev) {
|
|
97
|
+
// 点击空白处取消节点选中状态, 不包括冒泡过来的事件。
|
|
98
|
+
var target = ev.target;
|
|
99
|
+
if (target.getAttribute('name') === 'canvas-overlay') {
|
|
100
|
+
var graphModel = _this.props.graphModel;
|
|
101
|
+
var selectElements = graphModel.selectElements;
|
|
102
|
+
if (selectElements.size > 0) {
|
|
103
|
+
graphModel.clearSelectElements();
|
|
104
|
+
}
|
|
105
|
+
graphModel.eventCenter.emit(EventType.BLANK_CLICK, { e: ev });
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
_this.handleContextMenu = function (ev) {
|
|
109
|
+
var target = ev.target;
|
|
110
|
+
if (target.getAttribute('name') === 'canvas-overlay') {
|
|
111
|
+
ev.preventDefault();
|
|
112
|
+
var graphModel = _this.props.graphModel;
|
|
113
|
+
var position = graphModel.getPointByClient({
|
|
114
|
+
x: ev.clientX,
|
|
115
|
+
y: ev.clientY,
|
|
116
|
+
});
|
|
117
|
+
// graphModel.setElementState(ElementState.SHOW_MENU, position.domOverlayPosition);
|
|
118
|
+
graphModel.eventCenter.emit(EventType.BLANK_CONTEXTMENU, {
|
|
119
|
+
e: ev,
|
|
120
|
+
position: position,
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
_this.mouseDownHandler = function (ev) {
|
|
125
|
+
var _a = _this.props.graphModel, eventCenter = _a.eventCenter, editConfigModel = _a.editConfigModel, SCALE_X = _a.transformModel.SCALE_X, gridSize = _a.gridSize;
|
|
126
|
+
var target = ev.target;
|
|
127
|
+
var isFrozenElement = !editConfigModel.adjustEdge && !editConfigModel.adjustNodePosition;
|
|
128
|
+
if (target.getAttribute('name') === 'canvas-overlay' || isFrozenElement) {
|
|
129
|
+
if (editConfigModel.stopMoveGraph !== true) {
|
|
130
|
+
_this.stepDrag.setStep(gridSize * SCALE_X);
|
|
131
|
+
_this.stepDrag.handleMouseDown(ev);
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
eventCenter.emit(EventType.BLANK_MOUSEDOWN, { e: ev });
|
|
135
|
+
}
|
|
136
|
+
// 为了处理画布移动的时候,编辑和菜单仍然存在的问题。
|
|
137
|
+
_this.clickHandler(ev);
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
var _a = props.graphModel, gridSize = _a.gridSize, eventCenter = _a.eventCenter;
|
|
141
|
+
_this.stepDrag = new StepDrag({
|
|
142
|
+
onDragging: _this.onDragging,
|
|
143
|
+
onDragEnd: _this.onDragEnd,
|
|
144
|
+
step: gridSize,
|
|
145
|
+
eventType: 'BLANK',
|
|
146
|
+
isStopPropagation: false,
|
|
147
|
+
eventCenter: eventCenter,
|
|
148
|
+
model: undefined,
|
|
149
|
+
});
|
|
150
|
+
// 当ctrl键被按住的时候,可以放大缩小。
|
|
151
|
+
_this.state = {
|
|
152
|
+
isDragging: false,
|
|
153
|
+
};
|
|
154
|
+
return _this;
|
|
155
|
+
}
|
|
156
|
+
CanvasOverlay.prototype.render = function () {
|
|
157
|
+
var transformModel = this.props.graphModel.transformModel;
|
|
158
|
+
var transform = transformModel.getTransformStyle().transform;
|
|
159
|
+
var _a = this.props, children = _a.children, dnd = _a.dnd;
|
|
160
|
+
var isDragging = this.state.isDragging;
|
|
161
|
+
return (_jsx("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", width: "100%", height: "100%", name: "canvas-overlay", onWheel: this.zoomHandler, onMouseDown: this.mouseDownHandler, onContextMenu: this.handleContextMenu, className: isDragging
|
|
162
|
+
? 'lf-canvas-overlay lf-dragging'
|
|
163
|
+
: 'lf-canvas-overlay lf-drag-able' }, dnd.eventMap(), { children: _jsx("g", { transform: transform, children: children }) })));
|
|
164
|
+
};
|
|
165
|
+
CanvasOverlay = __decorate([
|
|
166
|
+
observer
|
|
167
|
+
], CanvasOverlay);
|
|
168
|
+
return CanvasOverlay;
|
|
169
|
+
}(Component));
|
|
170
|
+
export { CanvasOverlay };
|
|
171
|
+
export default CanvasOverlay;
|
|
172
|
+
//# sourceMappingURL=CanvasOverlay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CanvasOverlay.js","sourceRoot":"","sources":["../../../src/view/overlay/CanvasOverlay.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { Component } from 'preact/compat';
|
|
2
|
+
import { GraphModel } from '../../model';
|
|
3
|
+
import GridOptions = Grid.GridOptions;
|
|
4
|
+
type IProps = GridOptions & {
|
|
5
|
+
graphModel: GraphModel;
|
|
6
|
+
};
|
|
7
|
+
export declare class Grid extends Component<IProps> {
|
|
8
|
+
readonly id: string;
|
|
9
|
+
renderDot(): import("preact/compat").JSX.Element;
|
|
10
|
+
renderMesh(): import("preact/compat").JSX.Element;
|
|
11
|
+
render(): import("preact/compat").JSX.Element;
|
|
12
|
+
}
|
|
13
|
+
export declare namespace Grid {
|
|
14
|
+
type GridOptions = {
|
|
15
|
+
/**
|
|
16
|
+
* 网格格子间距
|
|
17
|
+
*/
|
|
18
|
+
size?: number;
|
|
19
|
+
/**
|
|
20
|
+
* 网格是否可见
|
|
21
|
+
*/
|
|
22
|
+
visible?: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* 网格类型
|
|
25
|
+
* - `dot` 点状网格
|
|
26
|
+
* - `mesh` 交叉线网格
|
|
27
|
+
*/
|
|
28
|
+
type?: 'dot' | 'mesh';
|
|
29
|
+
config?: {
|
|
30
|
+
/**
|
|
31
|
+
* 网格的颜色
|
|
32
|
+
*/
|
|
33
|
+
color: string;
|
|
34
|
+
/**
|
|
35
|
+
* 网格的宽度
|
|
36
|
+
* - 对于 `dot` 点状网格,表示点的大小
|
|
37
|
+
* - 对于 `mesh` 交叉线网格,表示线的宽度
|
|
38
|
+
*/
|
|
39
|
+
thickness?: number;
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
const defaultProps: GridOptions;
|
|
43
|
+
function getGridOptions(options: number | boolean | GridOptions): GridOptions;
|
|
44
|
+
}
|
|
45
|
+
export {};
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
var __extends = (this && this.__extends) || (function () {
|
|
2
|
+
var extendStatics = function (d, b) {
|
|
3
|
+
extendStatics = Object.setPrototypeOf ||
|
|
4
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
6
|
+
return extendStatics(d, b);
|
|
7
|
+
};
|
|
8
|
+
return function (d, b) {
|
|
9
|
+
if (typeof b !== "function" && b !== null)
|
|
10
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
11
|
+
extendStatics(d, b);
|
|
12
|
+
function __() { this.constructor = d; }
|
|
13
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
14
|
+
};
|
|
15
|
+
})();
|
|
16
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
17
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
18
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
19
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
20
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
21
|
+
};
|
|
22
|
+
var __read = (this && this.__read) || function (o, n) {
|
|
23
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
24
|
+
if (!m) return o;
|
|
25
|
+
var i = m.call(o), r, ar = [], e;
|
|
26
|
+
try {
|
|
27
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
28
|
+
}
|
|
29
|
+
catch (error) { e = { error: error }; }
|
|
30
|
+
finally {
|
|
31
|
+
try {
|
|
32
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
33
|
+
}
|
|
34
|
+
finally { if (e) throw e.error; }
|
|
35
|
+
}
|
|
36
|
+
return ar;
|
|
37
|
+
};
|
|
38
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
39
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
40
|
+
if (ar || !(i in from)) {
|
|
41
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
42
|
+
ar[i] = from[i];
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
46
|
+
};
|
|
47
|
+
import { jsx as _jsx, jsxs as _jsxs } from "preact/jsx-runtime";
|
|
48
|
+
import { Component } from 'preact/compat';
|
|
49
|
+
import { cloneDeep, assign } from 'lodash-es';
|
|
50
|
+
import { observer } from '../..';
|
|
51
|
+
import { createUuid } from '../../util';
|
|
52
|
+
import { DEFAULT_GRID_SIZE } from '../../constant';
|
|
53
|
+
var Grid = /** @class */ (function (_super) {
|
|
54
|
+
__extends(Grid, _super);
|
|
55
|
+
function Grid() {
|
|
56
|
+
var _this = _super.apply(this, __spreadArray([], __read(arguments), false)) || this;
|
|
57
|
+
_this.id = createUuid();
|
|
58
|
+
return _this;
|
|
59
|
+
}
|
|
60
|
+
// 网格类型为点状
|
|
61
|
+
Grid.prototype.renderDot = function () {
|
|
62
|
+
var _a = this.props, config = _a.config, _b = _a.size, size = _b === void 0 ? 1 : _b, visible = _a.visible;
|
|
63
|
+
var _c = config !== null && config !== void 0 ? config : {}, color = _c.color, _d = _c.thickness, thickness = _d === void 0 ? 2 : _d;
|
|
64
|
+
// 对于点状网格,点的半径不能大于网格大小的四分之一
|
|
65
|
+
var radius = Math.min(Math.max(2, thickness), size / 4);
|
|
66
|
+
var opacity = visible ? 1 : 0;
|
|
67
|
+
return (_jsxs("g", { fill: color, opacity: opacity, children: [_jsx("circle", { cx: 0, cy: 0, r: radius / 2 }), _jsx("circle", { cx: 0, cy: size, r: radius / 2 }), _jsx("circle", { cx: size, cy: 0, r: radius / 2 }), _jsx("circle", { cx: size, cy: size, r: radius / 2 })] }));
|
|
68
|
+
};
|
|
69
|
+
// 网格类型为交叉线
|
|
70
|
+
// todo: 采用背景缩放的方式,实现更好的体验
|
|
71
|
+
Grid.prototype.renderMesh = function () {
|
|
72
|
+
var _a = this.props, config = _a.config, _b = _a.size, size = _b === void 0 ? 1 : _b, visible = _a.visible;
|
|
73
|
+
var _c = config !== null && config !== void 0 ? config : {}, color = _c.color, _d = _c.thickness, thickness = _d === void 0 ? 1 : _d;
|
|
74
|
+
// 对于交叉线网格,线的宽度不能大于网格大小的一半
|
|
75
|
+
var strokeWidth = Math.min(Math.max(1, thickness), size / 2);
|
|
76
|
+
var d = "M 0 0 H ".concat(size, " V ").concat(size, " H 0 Z");
|
|
77
|
+
var opacity = visible ? 1 : 0;
|
|
78
|
+
return (_jsx("path", { d: d, stroke: color, strokeWidth: strokeWidth, opacity: opacity, fill: "transparent" }));
|
|
79
|
+
};
|
|
80
|
+
Grid.prototype.render = function () {
|
|
81
|
+
var _a = this.props, type = _a.type, _b = _a.size, size = _b === void 0 ? 1 : _b, transformModel = _a.graphModel.transformModel;
|
|
82
|
+
var SCALE_X = transformModel.SCALE_X, SKEW_Y = transformModel.SKEW_Y, SKEW_X = transformModel.SKEW_X, SCALE_Y = transformModel.SCALE_Y, TRANSLATE_X = transformModel.TRANSLATE_X, TRANSLATE_Y = transformModel.TRANSLATE_Y;
|
|
83
|
+
var matrixString = [
|
|
84
|
+
SCALE_X,
|
|
85
|
+
SKEW_Y,
|
|
86
|
+
SKEW_X,
|
|
87
|
+
SCALE_Y,
|
|
88
|
+
TRANSLATE_X,
|
|
89
|
+
TRANSLATE_Y,
|
|
90
|
+
].join(',');
|
|
91
|
+
var transform = "matrix(".concat(matrixString, ")");
|
|
92
|
+
// const transitionStyle = {
|
|
93
|
+
// transition: 'all 0.1s ease',
|
|
94
|
+
// };
|
|
95
|
+
return (_jsx("div", { className: "lf-grid", children: _jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", version: "1.1", width: "100%", height: "100%", children: [_jsx("defs", { children: _jsxs("pattern", { id: this.id, patternUnits: "userSpaceOnUse", patternTransform: transform, x: "0", y: "0", width: size, height: size, children: [type === 'dot' && this.renderDot(), type === 'mesh' && this.renderMesh()] }) }), _jsx("rect", { width: "100%", height: "100%", fill: "url(#".concat(this.id, ")") })] }) }));
|
|
96
|
+
};
|
|
97
|
+
Grid = __decorate([
|
|
98
|
+
observer
|
|
99
|
+
], Grid);
|
|
100
|
+
return Grid;
|
|
101
|
+
}(Component));
|
|
102
|
+
export { Grid };
|
|
103
|
+
(function (Grid) {
|
|
104
|
+
Grid.defaultProps = {
|
|
105
|
+
size: DEFAULT_GRID_SIZE,
|
|
106
|
+
visible: true,
|
|
107
|
+
type: 'dot',
|
|
108
|
+
config: {
|
|
109
|
+
color: '#ababab',
|
|
110
|
+
thickness: 1,
|
|
111
|
+
},
|
|
112
|
+
};
|
|
113
|
+
function getGridOptions(options) {
|
|
114
|
+
var defaultOptions = cloneDeep(Grid.defaultProps);
|
|
115
|
+
if (typeof options === 'number') {
|
|
116
|
+
return assign(defaultOptions, { size: options });
|
|
117
|
+
}
|
|
118
|
+
else if (typeof options === 'boolean') {
|
|
119
|
+
return assign(defaultOptions, { visible: options });
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
return assign(defaultOptions, options);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
Grid.getGridOptions = getGridOptions;
|
|
126
|
+
})(Grid || (Grid = {}));
|
|
127
|
+
//# sourceMappingURL=Grid.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Grid.js","sourceRoot":"","sources":["../../../src/view/overlay/Grid.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Component } from 'preact/compat';
|
|
2
|
+
import GraphModel from '../../model/GraphModel';
|
|
3
|
+
type IProps = {
|
|
4
|
+
graphModel: GraphModel;
|
|
5
|
+
};
|
|
6
|
+
export declare class ModificationOverlay extends Component<IProps> {
|
|
7
|
+
render(): import("preact/compat").JSX.Element;
|
|
8
|
+
}
|
|
9
|
+
export default ModificationOverlay;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
var __extends = (this && this.__extends) || (function () {
|
|
2
|
+
var extendStatics = function (d, b) {
|
|
3
|
+
extendStatics = Object.setPrototypeOf ||
|
|
4
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
6
|
+
return extendStatics(d, b);
|
|
7
|
+
};
|
|
8
|
+
return function (d, b) {
|
|
9
|
+
if (typeof b !== "function" && b !== null)
|
|
10
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
11
|
+
extendStatics(d, b);
|
|
12
|
+
function __() { this.constructor = d; }
|
|
13
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
14
|
+
};
|
|
15
|
+
})();
|
|
16
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
17
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
18
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
19
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
20
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
21
|
+
};
|
|
22
|
+
import { jsx as _jsx } from "preact/jsx-runtime";
|
|
23
|
+
import { Component } from 'preact/compat';
|
|
24
|
+
import { observer } from '../..';
|
|
25
|
+
var ModificationOverlay = /** @class */ (function (_super) {
|
|
26
|
+
__extends(ModificationOverlay, _super);
|
|
27
|
+
function ModificationOverlay() {
|
|
28
|
+
return _super !== null && _super.apply(this, arguments) || this;
|
|
29
|
+
}
|
|
30
|
+
ModificationOverlay.prototype.render = function () {
|
|
31
|
+
var transformModel = this.props.graphModel.transformModel;
|
|
32
|
+
var transform = transformModel.getTransformStyle().transform;
|
|
33
|
+
var children = this.props.children;
|
|
34
|
+
return (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", version: "1.1", width: "100%", height: "100%", className: "modification-overlay", children: _jsx("g", { transform: transform, children: children }) }));
|
|
35
|
+
};
|
|
36
|
+
ModificationOverlay = __decorate([
|
|
37
|
+
observer
|
|
38
|
+
], ModificationOverlay);
|
|
39
|
+
return ModificationOverlay;
|
|
40
|
+
}(Component));
|
|
41
|
+
export { ModificationOverlay };
|
|
42
|
+
export default ModificationOverlay;
|
|
43
|
+
//# sourceMappingURL=ModificationOverlay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModificationOverlay.js","sourceRoot":"","sources":["../../../src/view/overlay/ModificationOverlay.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAQhC;IAAyC,uCAAiB;IAA1D;;IAmBA,CAAC;IAlBC,oCAAM,GAAN;QAEkB,IAAA,cAAc,GAC1B,IAAI,CAAC,KAAK,0BADgB,CAChB;QACN,IAAA,SAAS,GAAK,cAAc,CAAC,iBAAiB,EAAE,UAAvC,CAAuC;QAChD,IAAA,QAAQ,GAAK,IAAI,CAAC,KAAK,SAAf,CAAe;QAC/B,OAAO,CACL,cACE,KAAK,EAAC,4BAA4B,EAClC,OAAO,EAAC,KAAK,EACb,KAAK,EAAC,MAAM,EACZ,MAAM,EAAC,MAAM,EACb,SAAS,EAAC,sBAAsB,YAEhC,YAAG,SAAS,EAAE,SAAS,YAAG,QAAQ,GAAK,GACnC,CACP,CAAA;IACH,CAAC;IAlBU,mBAAmB;QAD/B,QAAQ;OACI,mBAAmB,CAmB/B;IAAD,0BAAC;CAAA,AAnBD,CAAyC,SAAS,GAmBjD;SAnBY,mBAAmB;AAqBhC,eAAe,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Component } from 'preact/compat';
|
|
2
|
+
import { GraphModel, LineEdgeModel, BezierEdgeModel, PolylineEdgeModel } from '../../model';
|
|
3
|
+
type IProps = {
|
|
4
|
+
graphModel: GraphModel;
|
|
5
|
+
};
|
|
6
|
+
export declare class OutlineOverlay extends Component<IProps> {
|
|
7
|
+
getNodesOutline(): any;
|
|
8
|
+
getEdgeOutline(): any;
|
|
9
|
+
getLineOutline(line: LineEdgeModel): import("preact/compat").JSX.Element;
|
|
10
|
+
getPolylineOutline(polyline: PolylineEdgeModel): import("preact/compat").JSX.Element;
|
|
11
|
+
getBezierOutline(bezier: BezierEdgeModel): import("preact/compat").JSX.Element;
|
|
12
|
+
render(): import("preact/compat").JSX.Element;
|
|
13
|
+
}
|
|
14
|
+
export default OutlineOverlay;
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
var __extends = (this && this.__extends) || (function () {
|
|
2
|
+
var extendStatics = function (d, b) {
|
|
3
|
+
extendStatics = Object.setPrototypeOf ||
|
|
4
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
6
|
+
return extendStatics(d, b);
|
|
7
|
+
};
|
|
8
|
+
return function (d, b) {
|
|
9
|
+
if (typeof b !== "function" && b !== null)
|
|
10
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
11
|
+
extendStatics(d, b);
|
|
12
|
+
function __() { this.constructor = d; }
|
|
13
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
14
|
+
};
|
|
15
|
+
})();
|
|
16
|
+
var __assign = (this && this.__assign) || function () {
|
|
17
|
+
__assign = Object.assign || function(t) {
|
|
18
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
19
|
+
s = arguments[i];
|
|
20
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
21
|
+
t[p] = s[p];
|
|
22
|
+
}
|
|
23
|
+
return t;
|
|
24
|
+
};
|
|
25
|
+
return __assign.apply(this, arguments);
|
|
26
|
+
};
|
|
27
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
28
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
29
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
30
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
31
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
32
|
+
};
|
|
33
|
+
import { jsx as _jsx, jsxs as _jsxs } from "preact/jsx-runtime";
|
|
34
|
+
import { Component } from 'preact/compat';
|
|
35
|
+
import { Rect } from '../shape';
|
|
36
|
+
import { observer } from '../..';
|
|
37
|
+
import { ModelType } from '../../constant';
|
|
38
|
+
import { points2PointsList, getBezierPoints, getBBoxOfPoints } from '../../util';
|
|
39
|
+
var OutlineOverlay = /** @class */ (function (_super) {
|
|
40
|
+
__extends(OutlineOverlay, _super);
|
|
41
|
+
function OutlineOverlay() {
|
|
42
|
+
return _super !== null && _super.apply(this, arguments) || this;
|
|
43
|
+
}
|
|
44
|
+
// 节点outline
|
|
45
|
+
OutlineOverlay.prototype.getNodesOutline = function () {
|
|
46
|
+
var graphModel = this.props.graphModel;
|
|
47
|
+
var nodes = graphModel.nodes, _a = graphModel.editConfigModel, hoverOutline = _a.hoverOutline, nodeSelectedOutline = _a.nodeSelectedOutline;
|
|
48
|
+
var nodeOutline = [];
|
|
49
|
+
nodes.forEach(function (element) {
|
|
50
|
+
if (element.isHovered || element.isSelected) {
|
|
51
|
+
var isHovered = element.isHovered, isSelected = element.isSelected, x = element.x, y = element.y, width = element.width, height = element.height;
|
|
52
|
+
if ((nodeSelectedOutline && isSelected) ||
|
|
53
|
+
(hoverOutline && isHovered)) {
|
|
54
|
+
var style_1 = element.getOutlineStyle();
|
|
55
|
+
var attributes_1 = {};
|
|
56
|
+
Object.keys(style_1).forEach(function (key) {
|
|
57
|
+
if (key !== 'hover') {
|
|
58
|
+
attributes_1[key] = style_1[key];
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
if (isHovered) {
|
|
62
|
+
var hoverStyle = style_1.hover;
|
|
63
|
+
attributes_1 = __assign(__assign({}, attributes_1), hoverStyle);
|
|
64
|
+
}
|
|
65
|
+
nodeOutline.push(_jsx(Rect, __assign({ transform: element.transform, className: "lf-outline-node", x: x, y: y,
|
|
66
|
+
// width: width + 10,
|
|
67
|
+
// height: height + 10,
|
|
68
|
+
width: width + 10,
|
|
69
|
+
height: height + 10 }, attributes_1)));
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
return nodeOutline;
|
|
74
|
+
};
|
|
75
|
+
// 边的outline
|
|
76
|
+
OutlineOverlay.prototype.getEdgeOutline = function () {
|
|
77
|
+
var _a = this.props.graphModel, edgeList = _a.edges, _b = _a.editConfigModel, edgeSelectedOutline = _b.edgeSelectedOutline, hoverOutline = _b.hoverOutline;
|
|
78
|
+
var edgeOutline = [];
|
|
79
|
+
for (var i = 0; i < edgeList.length; i++) {
|
|
80
|
+
var edge = edgeList[i];
|
|
81
|
+
if ((edgeSelectedOutline && edge.isSelected) ||
|
|
82
|
+
(hoverOutline && edge.isHovered)) {
|
|
83
|
+
if (edge.modelType === ModelType.LINE_EDGE) {
|
|
84
|
+
edgeOutline.push(this.getLineOutline(edge));
|
|
85
|
+
}
|
|
86
|
+
else if (edge.modelType === ModelType.POLYLINE_EDGE) {
|
|
87
|
+
edgeOutline.push(this.getPolylineOutline(edge));
|
|
88
|
+
}
|
|
89
|
+
else if (edge.modelType === ModelType.BEZIER_EDGE) {
|
|
90
|
+
edgeOutline.push(this.getBezierOutline(edge));
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
return edgeOutline;
|
|
95
|
+
};
|
|
96
|
+
// 直线outline
|
|
97
|
+
OutlineOverlay.prototype.getLineOutline = function (line) {
|
|
98
|
+
var startPoint = line.startPoint, endPoint = line.endPoint;
|
|
99
|
+
var x = (startPoint.x + endPoint.x) / 2;
|
|
100
|
+
var y = (startPoint.y + endPoint.y) / 2;
|
|
101
|
+
var width = Math.abs(startPoint.x - endPoint.x) + 10;
|
|
102
|
+
var height = Math.abs(startPoint.y - endPoint.y) + 10;
|
|
103
|
+
var style = line.getOutlineStyle();
|
|
104
|
+
return (_jsx(Rect, __assign({ className: "lf-outline-edge", x: x, y: y, width: width, height: height }, style)));
|
|
105
|
+
};
|
|
106
|
+
// 折线outline
|
|
107
|
+
OutlineOverlay.prototype.getPolylineOutline = function (polyline) {
|
|
108
|
+
var points = polyline.points;
|
|
109
|
+
var pointsList = points2PointsList(points);
|
|
110
|
+
var bbox = getBBoxOfPoints(pointsList, 8);
|
|
111
|
+
var x = bbox.x, y = bbox.y, width = bbox.width, height = bbox.height;
|
|
112
|
+
var style = polyline.getOutlineStyle();
|
|
113
|
+
return (_jsx(Rect, __assign({ className: "lf-outline", x: x, y: y, width: width, height: height }, style)));
|
|
114
|
+
};
|
|
115
|
+
// 曲线outline
|
|
116
|
+
OutlineOverlay.prototype.getBezierOutline = function (bezier) {
|
|
117
|
+
var path = bezier.path;
|
|
118
|
+
var pointsList = getBezierPoints(path);
|
|
119
|
+
var bbox = getBBoxOfPoints(pointsList, 8);
|
|
120
|
+
var x = bbox.x, y = bbox.y, width = bbox.width, height = bbox.height;
|
|
121
|
+
var style = bezier.getOutlineStyle();
|
|
122
|
+
return (_jsx(Rect, __assign({ className: "lf-outline", x: x, y: y, width: width, height: height }, style)));
|
|
123
|
+
};
|
|
124
|
+
OutlineOverlay.prototype.render = function () {
|
|
125
|
+
return (_jsxs("g", { className: "lf-outline", children: [this.getNodesOutline(), this.getEdgeOutline()] }));
|
|
126
|
+
};
|
|
127
|
+
OutlineOverlay = __decorate([
|
|
128
|
+
observer
|
|
129
|
+
], OutlineOverlay);
|
|
130
|
+
return OutlineOverlay;
|
|
131
|
+
}(Component));
|
|
132
|
+
export { OutlineOverlay };
|
|
133
|
+
export default OutlineOverlay;
|
|
134
|
+
//# sourceMappingURL=OutlineOverlay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OutlineOverlay.js","sourceRoot":"","sources":["../../../src/view/overlay/OutlineOverlay.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Component } from 'preact/compat';
|
|
2
|
+
import SnaplineModel from '../../model/SnaplineModel';
|
|
3
|
+
import OutlineOverlay from './OutlineOverlay';
|
|
4
|
+
type IProps = {
|
|
5
|
+
snaplineModel?: SnaplineModel;
|
|
6
|
+
};
|
|
7
|
+
export declare class SnaplineOverlay extends Component<IProps> {
|
|
8
|
+
render(): import("preact/compat").JSX.Element;
|
|
9
|
+
}
|
|
10
|
+
export default OutlineOverlay;
|