@logicflow/core 2.0.0-beta.0 → 2.0.0-beta.10
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 +2 -2
- package/.turbo/turbo-build.log +16 -22
- package/__tests__/bugs/1545-spec.test.ts +19 -15
- package/__tests__/util/edge.test.ts +57 -57
- package/dist/index.min.js +32 -0
- package/dist/index.min.js.map +1 -0
- package/es/LogicFlow.d.ts +88 -40
- package/es/LogicFlow.js +38 -33
- package/es/LogicFlow.js.map +1 -1
- package/es/algorithm/edge.js.map +1 -1
- package/es/algorithm/index.d.ts +2 -0
- package/es/algorithm/index.js +2 -0
- package/es/algorithm/index.js.map +1 -1
- package/es/algorithm/outline.d.ts +1 -1
- package/es/common/drag.d.ts +51 -0
- package/es/common/drag.js +145 -0
- package/es/common/drag.js.map +1 -0
- package/es/common/history.d.ts +28 -0
- package/es/common/history.js +92 -0
- package/es/common/history.js.map +1 -0
- package/es/common/index.d.ts +5 -0
- package/es/common/index.js +6 -0
- package/es/common/index.js.map +1 -0
- package/es/common/keyboard.d.ts +34 -0
- package/es/common/keyboard.js +80 -0
- package/es/common/keyboard.js.map +1 -0
- package/es/common/matrix.d.ts +30 -0
- package/es/common/matrix.js +155 -0
- package/es/common/matrix.js.map +1 -0
- package/es/common/vector.d.ts +23 -0
- package/es/common/vector.js +97 -0
- package/es/common/vector.js.map +1 -0
- package/es/constant/index.d.ts +39 -2
- package/es/constant/index.js +41 -1
- package/es/constant/index.js.map +1 -1
- package/es/event/eventArgs.d.ts +103 -25
- package/es/event/eventEmitter.d.ts +2 -2
- package/es/event/eventEmitter.js +0 -1
- package/es/event/eventEmitter.js.map +1 -1
- package/es/index.d.ts +6 -1
- package/es/index.js +6 -1
- package/es/index.js.map +1 -1
- package/es/keyboard/index.d.ts +1 -0
- package/es/keyboard/index.js +1 -0
- package/es/keyboard/index.js.map +1 -1
- package/es/keyboard/shortcut.d.ts +8 -0
- package/es/keyboard/shortcut.js +70 -8
- package/es/keyboard/shortcut.js.map +1 -1
- package/es/model/BaseModel.d.ts +16 -7
- package/es/model/EditConfigModel.d.ts +97 -36
- package/es/model/EditConfigModel.js +169 -82
- package/es/model/EditConfigModel.js.map +1 -1
- package/es/model/GraphModel.d.ts +36 -14
- package/es/model/GraphModel.js +60 -10
- package/es/model/GraphModel.js.map +1 -1
- package/es/model/SnaplineModel.d.ts +2 -0
- package/es/model/TransformModel.js +1 -1
- package/es/model/TransformModel.js.map +1 -1
- package/es/model/edge/BaseEdgeModel.d.ts +21 -17
- package/es/model/edge/BaseEdgeModel.js +64 -42
- package/es/model/edge/BaseEdgeModel.js.map +1 -1
- package/es/model/edge/BezierEdgeModel.d.ts +5 -3
- package/es/model/edge/BezierEdgeModel.js +7 -3
- package/es/model/edge/BezierEdgeModel.js.map +1 -1
- package/es/model/edge/LineEdgeModel.d.ts +2 -0
- package/es/model/edge/LineEdgeModel.js +2 -1
- package/es/model/edge/LineEdgeModel.js.map +1 -1
- package/es/model/edge/PolylineEdgeModel.d.ts +5 -3
- package/es/model/edge/PolylineEdgeModel.js +22 -15
- package/es/model/edge/PolylineEdgeModel.js.map +1 -1
- package/es/model/node/BaseNodeModel.d.ts +42 -14
- package/es/model/node/BaseNodeModel.js +62 -48
- package/es/model/node/BaseNodeModel.js.map +1 -1
- package/es/model/node/CircleNodeModel.d.ts +4 -3
- package/es/model/node/CircleNodeModel.js +4 -7
- package/es/model/node/CircleNodeModel.js.map +1 -1
- package/es/model/node/DiamondNodeModel.d.ts +5 -4
- package/es/model/node/DiamondNodeModel.js +4 -6
- package/es/model/node/DiamondNodeModel.js.map +1 -1
- package/es/model/node/EllipseNodeModel.d.ts +5 -4
- package/es/model/node/EllipseNodeModel.js +4 -6
- package/es/model/node/EllipseNodeModel.js.map +1 -1
- package/es/model/node/HtmlNodeModel.d.ts +4 -5
- package/es/model/node/HtmlNodeModel.js +2 -12
- package/es/model/node/HtmlNodeModel.js.map +1 -1
- package/es/model/node/PolygonNodeModel.d.ts +5 -4
- package/es/model/node/PolygonNodeModel.js +4 -7
- package/es/model/node/PolygonNodeModel.js.map +1 -1
- package/es/model/node/RectNodeModel.d.ts +7 -5
- package/es/model/node/RectNodeModel.js +10 -7
- package/es/model/node/RectNodeModel.js.map +1 -1
- package/es/model/node/TextNodeModel.d.ts +17 -9
- package/es/model/node/TextNodeModel.js +2 -1
- package/es/model/node/TextNodeModel.js.map +1 -1
- package/es/options.d.ts +11 -14
- package/es/options.js +3 -42
- package/es/options.js.map +1 -1
- package/es/tool/MultipleSelectTool.d.ts +1 -1
- package/es/tool/MultipleSelectTool.js +5 -5
- package/es/tool/MultipleSelectTool.js.map +1 -1
- package/es/tool/TextEditTool.d.ts +3 -3
- package/es/tool/TextEditTool.js +2 -2
- package/es/tool/TextEditTool.js.map +1 -1
- package/es/tool/index.d.ts +24 -2
- package/es/tool/index.js +82 -2
- package/es/tool/index.js.map +1 -1
- package/es/util/drag.d.ts +5 -5
- package/es/util/drag.js +3 -1
- package/es/util/drag.js.map +1 -1
- package/es/util/edge.d.ts +9 -2
- package/es/util/edge.js +23 -12
- package/es/util/edge.js.map +1 -1
- package/es/util/index.d.ts +1 -0
- package/es/util/index.js +1 -0
- package/es/util/index.js.map +1 -1
- package/es/util/node.d.ts +8 -7
- package/es/util/node.js +26 -7
- package/es/util/node.js.map +1 -1
- package/es/util/resize.d.ts +32 -0
- package/es/util/resize.js +197 -0
- package/es/util/resize.js.map +1 -0
- package/es/view/Anchor.d.ts +6 -7
- package/es/view/Anchor.js +6 -3
- package/es/view/Anchor.js.map +1 -1
- package/es/view/Control.d.ts +1 -1
- package/es/view/Control.js +88 -39
- package/es/view/Control.js.map +1 -1
- package/es/view/Graph.d.ts +5 -1
- package/es/view/Graph.js +45 -5
- package/es/view/Graph.js.map +1 -1
- package/es/view/Rotate.js +2 -1
- package/es/view/Rotate.js.map +1 -1
- package/es/view/behavior/index.d.ts +2 -0
- package/es/view/behavior/index.js +3 -0
- package/es/view/behavior/index.js.map +1 -0
- package/es/view/behavior/snapline.d.ts +3 -0
- package/es/{tool → view/behavior}/snapline.js +0 -1
- package/es/view/behavior/snapline.js.map +1 -0
- package/es/view/edge/AdjustPoint.js +12 -23
- package/es/view/edge/AdjustPoint.js.map +1 -1
- package/es/view/edge/BaseEdge.d.ts +2 -2
- package/es/view/edge/BaseEdge.js +30 -22
- package/es/view/edge/BaseEdge.js.map +1 -1
- package/es/view/node/BaseNode.d.ts +4 -4
- package/es/view/node/BaseNode.js +33 -24
- package/es/view/node/BaseNode.js.map +1 -1
- package/es/view/node/CircleNode.d.ts +1 -1
- package/es/view/node/CircleNode.js.map +1 -1
- package/es/view/node/DiamondNode.d.ts +1 -1
- package/es/view/node/DiamondNode.js.map +1 -1
- package/es/view/node/EllipseNode.d.ts +1 -1
- package/es/view/node/EllipseNode.js.map +1 -1
- package/es/view/node/HtmlNode.d.ts +1 -1
- package/es/view/node/HtmlNode.js +2 -2
- package/es/view/node/HtmlNode.js.map +1 -1
- package/es/view/node/PolygonNode.d.ts +1 -1
- package/es/view/node/PolygonNode.js.map +1 -1
- package/es/view/node/RectNode.d.ts +1 -1
- package/es/view/node/RectNode.js.map +1 -1
- package/es/view/node/TextNode.d.ts +1 -1
- package/es/view/node/TextNode.js +1 -1
- package/es/view/node/TextNode.js.map +1 -1
- package/es/view/overlay/CanvasOverlay.js +5 -4
- package/es/view/overlay/CanvasOverlay.js.map +1 -1
- package/es/view/overlay/Grid.d.ts +35 -20
- package/es/view/overlay/Grid.js +35 -26
- package/es/view/overlay/Grid.js.map +1 -1
- package/es/view/overlay/ToolOverlay.d.ts +1 -1
- package/es/view/overlay/ToolOverlay.js +1 -1
- package/es/view/overlay/ToolOverlay.js.map +1 -1
- package/es/view/shape/Circle.d.ts +9 -1
- package/es/view/shape/Circle.js +5 -5
- package/es/view/shape/Circle.js.map +1 -1
- package/es/view/shape/Ellipse.d.ts +10 -1
- package/es/view/shape/Ellipse.js +5 -5
- package/es/view/shape/Ellipse.js.map +1 -1
- package/es/view/shape/Line.d.ts +14 -1
- package/es/view/shape/Line.js +5 -7
- package/es/view/shape/Line.js.map +1 -1
- package/es/view/shape/Path.d.ts +3 -2
- package/es/view/shape/Path.js +3 -3
- package/es/view/shape/Path.js.map +1 -1
- package/es/view/shape/Polygon.d.ts +5 -3
- package/es/view/shape/Polygon.js +6 -6
- package/es/view/shape/Polygon.js.map +1 -1
- package/es/view/shape/Polyline.d.ts +7 -1
- package/es/view/shape/Polyline.js +8 -6
- package/es/view/shape/Polyline.js.map +1 -1
- package/es/view/shape/Rect.d.ts +11 -13
- package/es/view/shape/Rect.js +6 -9
- package/es/view/shape/Rect.js.map +1 -1
- package/es/view/shape/Text.d.ts +19 -1
- package/es/view/shape/Text.js +28 -21
- package/es/view/shape/Text.js.map +1 -1
- package/es/view/text/BaseText.d.ts +12 -15
- package/es/view/text/BaseText.js +43 -29
- package/es/view/text/BaseText.js.map +1 -1
- package/es/view/text/LineText.d.ts +19 -7
- package/es/view/text/LineText.js +62 -54
- package/es/view/text/LineText.js.map +1 -1
- package/lib/LogicFlow.d.ts +88 -40
- package/lib/LogicFlow.js +40 -35
- package/lib/LogicFlow.js.map +1 -1
- package/lib/algorithm/edge.js.map +1 -1
- package/lib/algorithm/index.d.ts +2 -0
- package/lib/algorithm/index.js +17 -1
- package/lib/algorithm/index.js.map +1 -1
- package/lib/algorithm/outline.d.ts +1 -1
- package/lib/common/drag.d.ts +51 -0
- package/lib/common/drag.js +148 -0
- package/lib/common/drag.js.map +1 -0
- package/lib/common/history.d.ts +28 -0
- package/lib/common/history.js +95 -0
- package/lib/common/history.js.map +1 -0
- package/lib/common/index.d.ts +5 -0
- package/lib/common/index.js +22 -0
- package/lib/common/index.js.map +1 -0
- package/lib/common/keyboard.d.ts +34 -0
- package/lib/common/keyboard.js +86 -0
- package/lib/common/keyboard.js.map +1 -0
- package/lib/common/matrix.d.ts +30 -0
- package/lib/common/matrix.js +158 -0
- package/lib/common/matrix.js.map +1 -0
- package/lib/common/vector.d.ts +23 -0
- package/lib/common/vector.js +101 -0
- package/lib/common/vector.js.map +1 -0
- package/lib/constant/index.d.ts +39 -2
- package/lib/constant/index.js +42 -2
- package/lib/constant/index.js.map +1 -1
- package/lib/event/eventArgs.d.ts +103 -25
- package/lib/event/eventEmitter.d.ts +2 -2
- package/lib/event/eventEmitter.js +0 -1
- package/lib/event/eventEmitter.js.map +1 -1
- package/lib/index.d.ts +6 -1
- package/lib/index.js +7 -2
- package/lib/index.js.map +1 -1
- package/lib/keyboard/index.d.ts +1 -0
- package/lib/keyboard/index.js +15 -0
- package/lib/keyboard/index.js.map +1 -1
- package/lib/keyboard/shortcut.d.ts +8 -0
- package/lib/keyboard/shortcut.js +75 -9
- package/lib/keyboard/shortcut.js.map +1 -1
- package/lib/model/BaseModel.d.ts +16 -7
- package/lib/model/EditConfigModel.d.ts +97 -36
- package/lib/model/EditConfigModel.js +168 -81
- package/lib/model/EditConfigModel.js.map +1 -1
- package/lib/model/GraphModel.d.ts +36 -14
- package/lib/model/GraphModel.js +59 -9
- package/lib/model/GraphModel.js.map +1 -1
- package/lib/model/SnaplineModel.d.ts +2 -0
- package/lib/model/TransformModel.js +1 -1
- package/lib/model/TransformModel.js.map +1 -1
- package/lib/model/edge/BaseEdgeModel.d.ts +21 -17
- package/lib/model/edge/BaseEdgeModel.js +61 -39
- package/lib/model/edge/BaseEdgeModel.js.map +1 -1
- package/lib/model/edge/BezierEdgeModel.d.ts +5 -3
- package/lib/model/edge/BezierEdgeModel.js +6 -2
- package/lib/model/edge/BezierEdgeModel.js.map +1 -1
- package/lib/model/edge/LineEdgeModel.d.ts +2 -0
- package/lib/model/edge/LineEdgeModel.js +2 -1
- package/lib/model/edge/LineEdgeModel.js.map +1 -1
- package/lib/model/edge/PolylineEdgeModel.d.ts +5 -3
- package/lib/model/edge/PolylineEdgeModel.js +21 -14
- package/lib/model/edge/PolylineEdgeModel.js.map +1 -1
- package/lib/model/node/BaseNodeModel.d.ts +42 -14
- package/lib/model/node/BaseNodeModel.js +60 -46
- package/lib/model/node/BaseNodeModel.js.map +1 -1
- package/lib/model/node/CircleNodeModel.d.ts +4 -3
- package/lib/model/node/CircleNodeModel.js +4 -7
- package/lib/model/node/CircleNodeModel.js.map +1 -1
- package/lib/model/node/DiamondNodeModel.d.ts +5 -4
- package/lib/model/node/DiamondNodeModel.js +4 -6
- package/lib/model/node/DiamondNodeModel.js.map +1 -1
- package/lib/model/node/EllipseNodeModel.d.ts +5 -4
- package/lib/model/node/EllipseNodeModel.js +4 -6
- package/lib/model/node/EllipseNodeModel.js.map +1 -1
- package/lib/model/node/HtmlNodeModel.d.ts +4 -5
- package/lib/model/node/HtmlNodeModel.js +2 -12
- package/lib/model/node/HtmlNodeModel.js.map +1 -1
- package/lib/model/node/PolygonNodeModel.d.ts +5 -4
- package/lib/model/node/PolygonNodeModel.js +4 -7
- package/lib/model/node/PolygonNodeModel.js.map +1 -1
- package/lib/model/node/RectNodeModel.d.ts +7 -5
- package/lib/model/node/RectNodeModel.js +10 -7
- package/lib/model/node/RectNodeModel.js.map +1 -1
- package/lib/model/node/TextNodeModel.d.ts +17 -9
- package/lib/model/node/TextNodeModel.js +2 -1
- package/lib/model/node/TextNodeModel.js.map +1 -1
- package/lib/options.d.ts +11 -14
- package/lib/options.js +3 -42
- package/lib/options.js.map +1 -1
- package/lib/tool/MultipleSelectTool.d.ts +1 -1
- package/lib/tool/MultipleSelectTool.js +5 -5
- package/lib/tool/MultipleSelectTool.js.map +1 -1
- package/lib/tool/TextEditTool.d.ts +3 -3
- package/lib/tool/TextEditTool.js +4 -4
- package/lib/tool/TextEditTool.js.map +1 -1
- package/lib/tool/index.d.ts +24 -2
- package/lib/tool/index.js +85 -15
- package/lib/tool/index.js.map +1 -1
- package/lib/util/drag.d.ts +5 -5
- package/lib/util/drag.js +3 -1
- package/lib/util/drag.js.map +1 -1
- package/lib/util/edge.d.ts +9 -2
- package/lib/util/edge.js +27 -15
- package/lib/util/edge.js.map +1 -1
- package/lib/util/index.d.ts +1 -0
- package/lib/util/index.js +1 -0
- package/lib/util/index.js.map +1 -1
- package/lib/util/node.d.ts +8 -7
- package/lib/util/node.js +28 -9
- package/lib/util/node.js.map +1 -1
- package/lib/util/resize.d.ts +32 -0
- package/lib/util/resize.js +204 -0
- package/lib/util/resize.js.map +1 -0
- package/lib/view/Anchor.d.ts +6 -7
- package/lib/view/Anchor.js +5 -2
- package/lib/view/Anchor.js.map +1 -1
- package/lib/view/Control.d.ts +1 -1
- package/lib/view/Control.js +87 -38
- package/lib/view/Control.js.map +1 -1
- package/lib/view/Graph.d.ts +5 -1
- package/lib/view/Graph.js +44 -4
- package/lib/view/Graph.js.map +1 -1
- package/lib/view/Rotate.js +2 -1
- package/lib/view/Rotate.js.map +1 -1
- package/lib/view/behavior/index.d.ts +2 -0
- package/lib/view/behavior/index.js +19 -0
- package/lib/view/behavior/index.js.map +1 -0
- package/lib/view/behavior/snapline.d.ts +3 -0
- package/lib/{tool → view/behavior}/snapline.js +0 -1
- package/lib/view/behavior/snapline.js.map +1 -0
- package/lib/view/edge/AdjustPoint.js +11 -22
- package/lib/view/edge/AdjustPoint.js.map +1 -1
- package/lib/view/edge/BaseEdge.d.ts +2 -2
- package/lib/view/edge/BaseEdge.js +29 -21
- package/lib/view/edge/BaseEdge.js.map +1 -1
- package/lib/view/node/BaseNode.d.ts +4 -4
- package/lib/view/node/BaseNode.js +32 -23
- package/lib/view/node/BaseNode.js.map +1 -1
- package/lib/view/node/CircleNode.d.ts +1 -1
- package/lib/view/node/CircleNode.js.map +1 -1
- package/lib/view/node/DiamondNode.d.ts +1 -1
- package/lib/view/node/DiamondNode.js.map +1 -1
- package/lib/view/node/EllipseNode.d.ts +1 -1
- package/lib/view/node/EllipseNode.js.map +1 -1
- package/lib/view/node/HtmlNode.d.ts +1 -1
- package/lib/view/node/HtmlNode.js +2 -2
- package/lib/view/node/HtmlNode.js.map +1 -1
- package/lib/view/node/PolygonNode.d.ts +1 -1
- package/lib/view/node/PolygonNode.js.map +1 -1
- package/lib/view/node/RectNode.d.ts +1 -1
- package/lib/view/node/RectNode.js.map +1 -1
- package/lib/view/node/TextNode.d.ts +1 -1
- package/lib/view/node/TextNode.js +1 -1
- package/lib/view/node/TextNode.js.map +1 -1
- package/lib/view/overlay/CanvasOverlay.js +5 -4
- package/lib/view/overlay/CanvasOverlay.js.map +1 -1
- package/lib/view/overlay/Grid.d.ts +35 -20
- package/lib/view/overlay/Grid.js +35 -26
- package/lib/view/overlay/Grid.js.map +1 -1
- package/lib/view/overlay/ToolOverlay.d.ts +1 -1
- package/lib/view/overlay/ToolOverlay.js +1 -1
- package/lib/view/overlay/ToolOverlay.js.map +1 -1
- package/lib/view/shape/Circle.d.ts +9 -1
- package/lib/view/shape/Circle.js +5 -5
- package/lib/view/shape/Circle.js.map +1 -1
- package/lib/view/shape/Ellipse.d.ts +10 -1
- package/lib/view/shape/Ellipse.js +5 -5
- package/lib/view/shape/Ellipse.js.map +1 -1
- package/lib/view/shape/Line.d.ts +14 -1
- package/lib/view/shape/Line.js +5 -7
- package/lib/view/shape/Line.js.map +1 -1
- package/lib/view/shape/Path.d.ts +3 -2
- package/lib/view/shape/Path.js +3 -3
- package/lib/view/shape/Path.js.map +1 -1
- package/lib/view/shape/Polygon.d.ts +5 -3
- package/lib/view/shape/Polygon.js +6 -6
- package/lib/view/shape/Polygon.js.map +1 -1
- package/lib/view/shape/Polyline.d.ts +7 -1
- package/lib/view/shape/Polyline.js +8 -6
- package/lib/view/shape/Polyline.js.map +1 -1
- package/lib/view/shape/Rect.d.ts +11 -13
- package/lib/view/shape/Rect.js +6 -9
- package/lib/view/shape/Rect.js.map +1 -1
- package/lib/view/shape/Text.d.ts +19 -1
- package/lib/view/shape/Text.js +29 -21
- package/lib/view/shape/Text.js.map +1 -1
- package/lib/view/text/BaseText.d.ts +12 -15
- package/lib/view/text/BaseText.js +46 -29
- package/lib/view/text/BaseText.js.map +1 -1
- package/lib/view/text/LineText.d.ts +19 -7
- package/lib/view/text/LineText.js +62 -57
- package/lib/view/text/LineText.js.map +1 -1
- package/package.json +5 -4
- package/src/LogicFlow.tsx +163 -79
- package/src/algorithm/edge.ts +1 -0
- package/src/algorithm/index.ts +2 -0
- package/src/algorithm/outline.ts +2 -2
- package/src/common/drag.ts +219 -0
- package/src/common/history.ts +108 -0
- package/src/common/index.ts +6 -0
- package/src/common/keyboard.ts +108 -0
- package/src/common/matrix.ts +122 -0
- package/src/common/vector.ts +93 -0
- package/src/constant/index.ts +43 -1
- package/src/event/eventArgs.ts +173 -34
- package/src/event/eventEmitter.ts +2 -3
- package/src/index.ts +6 -1
- package/src/keyboard/index.ts +2 -0
- package/src/keyboard/shortcut.ts +79 -8
- package/src/model/BaseModel.ts +18 -7
- package/src/model/EditConfigModel.ts +209 -97
- package/src/model/GraphModel.ts +64 -9
- package/src/model/TransformModel.ts +1 -1
- package/src/model/edge/BaseEdgeModel.ts +105 -42
- package/src/model/edge/BezierEdgeModel.ts +7 -6
- package/src/model/edge/LineEdgeModel.ts +2 -0
- package/src/model/edge/PolylineEdgeModel.ts +24 -18
- package/src/model/node/BaseNodeModel.ts +72 -47
- package/src/model/node/CircleNodeModel.ts +8 -7
- package/src/model/node/DiamondNodeModel.ts +9 -6
- package/src/model/node/EllipseNodeModel.ts +9 -6
- package/src/model/node/HtmlNodeModel.ts +8 -7
- package/src/model/node/PolygonNodeModel.ts +9 -7
- package/src/model/node/RectNodeModel.ts +16 -8
- package/src/model/node/TextNodeModel.ts +14 -1
- package/src/options.ts +18 -53
- package/src/tool/MultipleSelectTool.tsx +6 -6
- package/src/tool/TextEditTool.tsx +3 -3
- package/src/tool/index.ts +96 -2
- package/src/util/drag.ts +22 -6
- package/src/util/edge.ts +39 -13
- package/src/util/index.ts +1 -0
- package/src/util/node.ts +36 -13
- package/src/util/resize.ts +286 -0
- package/src/view/Anchor.tsx +7 -5
- package/src/view/Control.tsx +93 -62
- package/src/view/Graph.tsx +23 -6
- package/src/view/Rotate.tsx +2 -1
- package/src/view/behavior/index.ts +2 -0
- package/src/{tool → view/behavior}/snapline.ts +3 -4
- package/src/view/edge/AdjustPoint.tsx +35 -49
- package/src/view/edge/BaseEdge.tsx +65 -45
- package/src/view/node/BaseNode.tsx +55 -28
- package/src/view/node/CircleNode.tsx +3 -1
- package/src/view/node/DiamondNode.tsx +3 -1
- package/src/view/node/EllipseNode.tsx +3 -1
- package/src/view/node/HtmlNode.tsx +5 -3
- package/src/view/node/PolygonNode.tsx +3 -1
- package/src/view/node/RectNode.tsx +3 -1
- package/src/view/node/TextNode.tsx +4 -2
- package/src/view/overlay/CanvasOverlay.tsx +5 -4
- package/src/view/overlay/Grid.tsx +75 -53
- package/src/view/overlay/ToolOverlay.tsx +1 -1
- package/src/view/shape/Circle.tsx +21 -7
- package/src/view/shape/Ellipse.tsx +20 -6
- package/src/view/shape/Line.tsx +24 -9
- package/src/view/shape/Path.tsx +9 -6
- package/src/view/shape/Polygon.tsx +13 -10
- package/src/view/shape/Polyline.tsx +20 -8
- package/src/view/shape/Rect.tsx +19 -19
- package/src/view/shape/Text.tsx +64 -33
- package/src/view/text/BaseText.tsx +76 -42
- package/src/view/text/LineText.tsx +94 -80
- package/tsconfig.json +1 -1
- package/dist/index.js +0 -26
- package/dist/index.js.map +0 -1
- package/es/tool/snapline.d.ts +0 -3
- package/es/tool/snapline.js.map +0 -1
- package/es/tool/tool.d.ts +0 -22
- package/es/tool/tool.js +0 -43
- package/es/tool/tool.js.map +0 -1
- package/lib/tool/snapline.d.ts +0 -3
- package/lib/tool/snapline.js.map +0 -1
- package/lib/tool/tool.d.ts +0 -22
- package/lib/tool/tool.js +0 -49
- package/lib/tool/tool.js.map +0 -1
- package/src/tool/tool.ts +0 -66
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Model,
|
|
1
|
+
import { Model, BaseNodeModel, BaseEdgeModel, LineEdgeModel, BezierEdgeModel, PolylineEdgeModel } from '../model';
|
|
2
2
|
import OutlineInfo = Model.OutlineInfo;
|
|
3
3
|
export declare const getNodeOutline: (node: BaseNodeModel) => OutlineInfo;
|
|
4
4
|
export declare const getLineOutline: (edge: LineEdgeModel) => OutlineInfo;
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Model } from '../model';
|
|
2
|
+
import EventEmitter from '../event/eventEmitter';
|
|
3
|
+
export type IDragParams = {
|
|
4
|
+
deltaX: number;
|
|
5
|
+
deltaY: number;
|
|
6
|
+
event: MouseEvent | null;
|
|
7
|
+
[key: string]: unknown;
|
|
8
|
+
};
|
|
9
|
+
export type ICreateDragParams = {
|
|
10
|
+
onDragStart?: (params: Partial<IDragParams>) => void;
|
|
11
|
+
onDragging?: (param: IDragParams) => void;
|
|
12
|
+
onDragEnd?: (param: Partial<IDragParams>) => void;
|
|
13
|
+
step?: number;
|
|
14
|
+
isStopPropagation?: boolean;
|
|
15
|
+
};
|
|
16
|
+
export type IStepperDragProps = {
|
|
17
|
+
eventType?: 'NODE' | 'BLANK' | 'SELECTION' | 'ADJUST_POINT' | 'TEXT' | 'LABEL' | '';
|
|
18
|
+
eventCenter?: EventEmitter;
|
|
19
|
+
model?: Model.BaseModel;
|
|
20
|
+
data?: Record<string, unknown>;
|
|
21
|
+
[key: string]: unknown;
|
|
22
|
+
} & Partial<ICreateDragParams>;
|
|
23
|
+
/**
|
|
24
|
+
* 支持拖拽时按步长进行移动
|
|
25
|
+
* REMIND:在绘制的过程中因为放大缩小,移动的真实 step 是变化的
|
|
26
|
+
*/
|
|
27
|
+
export declare class StepperDrag {
|
|
28
|
+
onDragStart: (params: Partial<IDragParams>) => void;
|
|
29
|
+
onDragging: (params: IDragParams) => void;
|
|
30
|
+
onDragEnd: (params: Partial<IDragParams>) => void;
|
|
31
|
+
step: number;
|
|
32
|
+
isStopPropagation: boolean;
|
|
33
|
+
eventType: 'NODE' | 'BLANK' | 'SELECTION' | 'ADJUST_POINT' | 'TEXT' | 'LABEL' | '';
|
|
34
|
+
eventCenter?: EventEmitter;
|
|
35
|
+
model?: Model.BaseModel;
|
|
36
|
+
data?: Record<string, unknown>;
|
|
37
|
+
isDragging: boolean;
|
|
38
|
+
isStartDrag: boolean;
|
|
39
|
+
startX: number;
|
|
40
|
+
startY: number;
|
|
41
|
+
totalDeltaX: number;
|
|
42
|
+
totalDeltaY: number;
|
|
43
|
+
startTime?: number;
|
|
44
|
+
constructor({ onDragStart, onDragging, onDragEnd, step, eventType, isStopPropagation, eventCenter, model, data, }: IStepperDragProps);
|
|
45
|
+
setStep(step: number): void;
|
|
46
|
+
handleMouseMove: (e: MouseEvent) => void;
|
|
47
|
+
handleMouseUp: (e: MouseEvent) => void;
|
|
48
|
+
handleMouseDown: (e: MouseEvent) => void;
|
|
49
|
+
cancelDrag: () => void;
|
|
50
|
+
}
|
|
51
|
+
export default StepperDrag;
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StepperDrag = void 0;
|
|
4
|
+
var lodash_es_1 = require("lodash-es");
|
|
5
|
+
var constant_1 = require("../constant");
|
|
6
|
+
// TODO:这种方式在同构项目中,会报错,该如何解决(是否要求用户控制在浏览器环境时才初始化)
|
|
7
|
+
// const DOC: any = window?.document
|
|
8
|
+
var LEFT_MOUSE_BUTTON_CODE = 0;
|
|
9
|
+
/**
|
|
10
|
+
* 支持拖拽时按步长进行移动
|
|
11
|
+
* REMIND:在绘制的过程中因为放大缩小,移动的真实 step 是变化的
|
|
12
|
+
*/
|
|
13
|
+
var StepperDrag = /** @class */ (function () {
|
|
14
|
+
function StepperDrag(_a) {
|
|
15
|
+
var _b = _a.onDragStart, onDragStart = _b === void 0 ? lodash_es_1.noop : _b, _c = _a.onDragging, onDragging = _c === void 0 ? lodash_es_1.noop : _c, _d = _a.onDragEnd, onDragEnd = _d === void 0 ? lodash_es_1.noop : _d, _e = _a.step, step = _e === void 0 ? 1 : _e, _f = _a.eventType, eventType = _f === void 0 ? '' : _f, _g = _a.isStopPropagation, isStopPropagation = _g === void 0 ? true : _g, eventCenter = _a.eventCenter, model = _a.model, data = _a.data;
|
|
16
|
+
var _this = this;
|
|
17
|
+
// 运行时
|
|
18
|
+
this.isDragging = false;
|
|
19
|
+
this.isStartDrag = false;
|
|
20
|
+
this.startX = 0;
|
|
21
|
+
this.startY = 0;
|
|
22
|
+
this.totalDeltaX = 0;
|
|
23
|
+
this.totalDeltaY = 0;
|
|
24
|
+
this.handleMouseMove = function (e) {
|
|
25
|
+
var _a, _b;
|
|
26
|
+
if (_this.isStopPropagation)
|
|
27
|
+
e.stopPropagation();
|
|
28
|
+
if (!_this.isStartDrag)
|
|
29
|
+
return;
|
|
30
|
+
_this.totalDeltaX += e.clientX - _this.startX;
|
|
31
|
+
_this.totalDeltaY += e.clientY - _this.startY;
|
|
32
|
+
_this.startX = e.clientX;
|
|
33
|
+
_this.startY = e.clientY;
|
|
34
|
+
if (_this.step <= 1 ||
|
|
35
|
+
Math.abs(_this.totalDeltaX) > _this.step ||
|
|
36
|
+
Math.abs(_this.totalDeltaY) > _this.step) {
|
|
37
|
+
var remainderX = _this.totalDeltaX % _this.step;
|
|
38
|
+
var remainderY = _this.totalDeltaY % _this.step;
|
|
39
|
+
var deltaX_1 = _this.totalDeltaX - remainderX;
|
|
40
|
+
var deltaY_1 = _this.totalDeltaY - remainderY;
|
|
41
|
+
_this.totalDeltaX = remainderX;
|
|
42
|
+
_this.totalDeltaY = remainderY;
|
|
43
|
+
var elementData_1 = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
|
|
44
|
+
// REMIND: 为了区分点击和拖动,在鼠标没有拖动时,不触发 dragstart。
|
|
45
|
+
if (!_this.isDragging) {
|
|
46
|
+
if (_this.eventType) {
|
|
47
|
+
(_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(constant_1.EventType["".concat(_this.eventType, "_DRAGSTART")], {
|
|
48
|
+
e: e,
|
|
49
|
+
data: _this.data || elementData_1,
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
_this.onDragStart({ event: e });
|
|
53
|
+
}
|
|
54
|
+
_this.isDragging = true;
|
|
55
|
+
// REMIND: 为了让 dragstart 和 drag 不在同一个事件循环中,将 drag 事件放在下一个任务队列中。
|
|
56
|
+
// TODO: 测试用例是否可覆盖???
|
|
57
|
+
Promise.resolve().then(function () {
|
|
58
|
+
var _a, _b;
|
|
59
|
+
_this.onDragging({ deltaX: deltaX_1, deltaY: deltaY_1, event: e });
|
|
60
|
+
if (_this.eventType) {
|
|
61
|
+
(_a = _this.eventCenter) === null || _a === void 0 ? void 0 : _a.emit(constant_1.EventType["".concat(_this.eventType, "_MOUSEMOVE")], {
|
|
62
|
+
e: e,
|
|
63
|
+
data: _this.data || elementData_1,
|
|
64
|
+
});
|
|
65
|
+
(_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(constant_1.EventType["".concat(_this.eventType, "_DRAG")], {
|
|
66
|
+
e: e,
|
|
67
|
+
data: _this.data || elementData_1,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
this.handleMouseUp = function (e) {
|
|
74
|
+
var DOC = window === null || window === void 0 ? void 0 : window.document;
|
|
75
|
+
_this.isStartDrag = false;
|
|
76
|
+
if (_this.isStopPropagation)
|
|
77
|
+
e.stopPropagation();
|
|
78
|
+
// fix: issue#568, 如果 onDragging 在下一个时间循环中触发,而 drop 在当前事件循环,会出现问题
|
|
79
|
+
Promise.resolve().then(function () {
|
|
80
|
+
var _a, _b, _c;
|
|
81
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mousemove', _this.handleMouseMove, true);
|
|
82
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mouseup', _this.handleMouseUp, true);
|
|
83
|
+
var elementData = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
|
|
84
|
+
if (_this.eventType) {
|
|
85
|
+
(_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(constant_1.EventType["".concat(_this.eventType, "_MOUSEUP")], {
|
|
86
|
+
e: e,
|
|
87
|
+
data: _this.data || elementData,
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
if (!_this.isDragging)
|
|
91
|
+
return;
|
|
92
|
+
_this.isDragging = false;
|
|
93
|
+
_this.onDragEnd({ event: e });
|
|
94
|
+
if (_this.eventType) {
|
|
95
|
+
(_c = _this.eventCenter) === null || _c === void 0 ? void 0 : _c.emit(constant_1.EventType["".concat(_this.eventType, "_DROP")], {
|
|
96
|
+
e: e,
|
|
97
|
+
data: _this.data || elementData,
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
};
|
|
102
|
+
this.handleMouseDown = function (e) {
|
|
103
|
+
var _a, _b;
|
|
104
|
+
var DOC = window === null || window === void 0 ? void 0 : window.document;
|
|
105
|
+
// issue: LogicFlow交流群-3群 8.10 号抛出的事件相关的问题,是否是这引起的???
|
|
106
|
+
if (e.button !== LEFT_MOUSE_BUTTON_CODE)
|
|
107
|
+
return;
|
|
108
|
+
if (_this.isStopPropagation)
|
|
109
|
+
e.stopPropagation();
|
|
110
|
+
_this.isStartDrag = true;
|
|
111
|
+
_this.startX = e.clientX;
|
|
112
|
+
_this.startY = e.clientY;
|
|
113
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.addEventListener('mousemove', _this.handleMouseMove, true);
|
|
114
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.addEventListener('mouseup', _this.handleMouseUp, true);
|
|
115
|
+
var elementData = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
|
|
116
|
+
if (_this.eventType) {
|
|
117
|
+
(_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(constant_1.EventType["".concat(_this.eventType, "_MOUSEDOWN")], {
|
|
118
|
+
e: e,
|
|
119
|
+
data: _this.data || elementData,
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
_this.startTime = new Date().getTime();
|
|
123
|
+
};
|
|
124
|
+
this.cancelDrag = function () {
|
|
125
|
+
var DOC = window === null || window === void 0 ? void 0 : window.document;
|
|
126
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mousemove', _this.handleMouseMove, true);
|
|
127
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mouseup', _this.handleMouseUp, true);
|
|
128
|
+
_this.onDragEnd({ event: null });
|
|
129
|
+
_this.isDragging = false;
|
|
130
|
+
};
|
|
131
|
+
this.onDragStart = onDragStart;
|
|
132
|
+
this.onDragging = onDragging;
|
|
133
|
+
this.onDragEnd = onDragEnd;
|
|
134
|
+
this.step = step;
|
|
135
|
+
this.eventType = eventType;
|
|
136
|
+
this.isStopPropagation = isStopPropagation;
|
|
137
|
+
this.eventCenter = eventCenter;
|
|
138
|
+
this.model = model;
|
|
139
|
+
this.data = data;
|
|
140
|
+
}
|
|
141
|
+
StepperDrag.prototype.setStep = function (step) {
|
|
142
|
+
this.step = step;
|
|
143
|
+
};
|
|
144
|
+
return StepperDrag;
|
|
145
|
+
}());
|
|
146
|
+
exports.StepperDrag = StepperDrag;
|
|
147
|
+
exports.default = StepperDrag;
|
|
148
|
+
//# sourceMappingURL=drag.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"drag.js","sourceRoot":"","sources":["../../src/common/drag.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { IDisposer } from 'mobx-utils';
|
|
2
|
+
import { LogicFlow } from '../LogicFlow';
|
|
3
|
+
import { GraphModel } from '../model';
|
|
4
|
+
import EventEmitter from '../event/eventEmitter';
|
|
5
|
+
export type HistoryData = LogicFlow.GraphConfigData;
|
|
6
|
+
export declare class History {
|
|
7
|
+
undos: HistoryData[];
|
|
8
|
+
redos: HistoryData[];
|
|
9
|
+
stopWatch: IDisposer | null;
|
|
10
|
+
curData: HistoryData | null;
|
|
11
|
+
maxSize: number;
|
|
12
|
+
waitTime: number;
|
|
13
|
+
eventCenter: EventEmitter;
|
|
14
|
+
constructor(eventCenter: EventEmitter);
|
|
15
|
+
add(data: HistoryData): void;
|
|
16
|
+
undoAble(): boolean;
|
|
17
|
+
/**
|
|
18
|
+
* undo 方法触发:
|
|
19
|
+
* graphModel 重新渲染 nodes 和 edges
|
|
20
|
+
* graphModel 发生变化,触发 watch
|
|
21
|
+
* watch 触发 add
|
|
22
|
+
*/
|
|
23
|
+
undo(): LogicFlow.GraphConfigData | undefined;
|
|
24
|
+
redoAble(): boolean;
|
|
25
|
+
redo(): LogicFlow.GraphConfigData | undefined;
|
|
26
|
+
watch(model: GraphModel): void;
|
|
27
|
+
}
|
|
28
|
+
export default History;
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.History = void 0;
|
|
4
|
+
var lodash_es_1 = require("lodash-es");
|
|
5
|
+
var mobx_utils_1 = require("mobx-utils");
|
|
6
|
+
var History = /** @class */ (function () {
|
|
7
|
+
function History(eventCenter) {
|
|
8
|
+
this.undos = [];
|
|
9
|
+
this.redos = [];
|
|
10
|
+
this.stopWatch = null;
|
|
11
|
+
this.curData = null;
|
|
12
|
+
this.maxSize = 50;
|
|
13
|
+
// 发生数据变化后,最多再等 500ms,把距离上次的数据变更存储起来。
|
|
14
|
+
// 所以 waitTime 值越小,History 对数据变化越敏感,存的 undos 数据就越细
|
|
15
|
+
this.waitTime = 100;
|
|
16
|
+
this.eventCenter = eventCenter;
|
|
17
|
+
}
|
|
18
|
+
History.prototype.add = function (data) {
|
|
19
|
+
if ((0, lodash_es_1.isEqual)((0, lodash_es_1.last)(this.undos), data))
|
|
20
|
+
return;
|
|
21
|
+
this.undos.push(data);
|
|
22
|
+
// 因为 undo 的时候会触发 add.
|
|
23
|
+
// 所以需要区分这个 add 是 undo 触发的还是用户正常操作触发的
|
|
24
|
+
// 如果是用户正常操作触发的,需要清空 redos
|
|
25
|
+
if (!(0, lodash_es_1.isEqual)(this.curData, data)) {
|
|
26
|
+
this.redos = [];
|
|
27
|
+
}
|
|
28
|
+
// this.eventCenter.emit(EventType.HISTORY_CHANGE, {
|
|
29
|
+
// data: {
|
|
30
|
+
// undos: this.undos,
|
|
31
|
+
// redos: this.redos,
|
|
32
|
+
// undoAble: this.undos.length > 1,
|
|
33
|
+
// redoAble: this.redos.length > 0,
|
|
34
|
+
// },
|
|
35
|
+
// })
|
|
36
|
+
if (this.undos.length > this.maxSize) {
|
|
37
|
+
this.undos.shift();
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
History.prototype.undoAble = function () {
|
|
41
|
+
return this.undos.length > 1;
|
|
42
|
+
};
|
|
43
|
+
/**
|
|
44
|
+
* undo 方法触发:
|
|
45
|
+
* graphModel 重新渲染 nodes 和 edges
|
|
46
|
+
* graphModel 发生变化,触发 watch
|
|
47
|
+
* watch 触发 add
|
|
48
|
+
*/
|
|
49
|
+
History.prototype.undo = function () {
|
|
50
|
+
if (!this.undoAble())
|
|
51
|
+
return;
|
|
52
|
+
var preData = this.undos.pop();
|
|
53
|
+
if (preData) {
|
|
54
|
+
this.redos.push(preData);
|
|
55
|
+
}
|
|
56
|
+
var curData = this.undos.pop();
|
|
57
|
+
if (curData) {
|
|
58
|
+
this.curData = (0, lodash_es_1.cloneDeep)(curData);
|
|
59
|
+
}
|
|
60
|
+
return curData;
|
|
61
|
+
};
|
|
62
|
+
History.prototype.redoAble = function () {
|
|
63
|
+
return this.redos.length > 0;
|
|
64
|
+
};
|
|
65
|
+
History.prototype.redo = function () {
|
|
66
|
+
if (!this.redoAble())
|
|
67
|
+
return;
|
|
68
|
+
var curData = this.redos.pop();
|
|
69
|
+
if (curData) {
|
|
70
|
+
this.curData = (0, lodash_es_1.cloneDeep)(curData);
|
|
71
|
+
}
|
|
72
|
+
return curData;
|
|
73
|
+
};
|
|
74
|
+
History.prototype.watch = function (model) {
|
|
75
|
+
var _this = this;
|
|
76
|
+
this.stopWatch && this.stopWatch();
|
|
77
|
+
// 把当前 watch 的 model 转换一下数据存起来,无需清空 redos
|
|
78
|
+
var historyData = model.modelToHistoryData();
|
|
79
|
+
if (historyData) {
|
|
80
|
+
this.undos.push(historyData);
|
|
81
|
+
}
|
|
82
|
+
this.stopWatch = (0, mobx_utils_1.deepObserve)(model, (0, lodash_es_1.debounce)(function () {
|
|
83
|
+
// 数据变更后,把最新的当前 model 数据存起来,并清空 redos
|
|
84
|
+
// 因为这个回调函数的触发,一般是用户交互而引起的,所以按照正常逻辑需要清空 redos
|
|
85
|
+
var data = model.modelToHistoryData();
|
|
86
|
+
if (data) {
|
|
87
|
+
_this.add(data);
|
|
88
|
+
}
|
|
89
|
+
}, this.waitTime));
|
|
90
|
+
};
|
|
91
|
+
return History;
|
|
92
|
+
}());
|
|
93
|
+
exports.History = History;
|
|
94
|
+
exports.default = History;
|
|
95
|
+
//# sourceMappingURL=history.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"history.js","sourceRoot":"","sources":["../../src/common/history.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./drag"), exports);
|
|
18
|
+
__exportStar(require("./history"), exports);
|
|
19
|
+
__exportStar(require("./keyboard"), exports);
|
|
20
|
+
__exportStar(require("./matrix"), exports);
|
|
21
|
+
__exportStar(require("./vector"), exports);
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAsB;AACtB,4CAAyB;AACzB,6CAA0B;AAE1B,2CAAwB;AACxB,2CAAwB"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { MousetrapInstance } from 'mousetrap';
|
|
2
|
+
import LogicFlow from '..';
|
|
3
|
+
export declare class Keyboard {
|
|
4
|
+
private target;
|
|
5
|
+
readonly mousetrap: MousetrapInstance;
|
|
6
|
+
options: Required<Keyboard.Options>;
|
|
7
|
+
constructor(options: Keyboard.Options);
|
|
8
|
+
protected formatKey(key: string): string;
|
|
9
|
+
private getKeys;
|
|
10
|
+
get disabled(): boolean;
|
|
11
|
+
on(keys: string | string[], callback: Keyboard.HandlerFunc, action?: Keyboard.ActionType): void;
|
|
12
|
+
off(keys: string | string[], action?: Keyboard.ActionType): void;
|
|
13
|
+
enable(force: boolean): void;
|
|
14
|
+
disable(): void;
|
|
15
|
+
initShortcuts(): void;
|
|
16
|
+
}
|
|
17
|
+
export declare namespace Keyboard {
|
|
18
|
+
type ActionType = 'keypress' | 'keydown' | 'keyup';
|
|
19
|
+
type HandlerFunc = (e: KeyboardEvent) => void;
|
|
20
|
+
interface Shortcut {
|
|
21
|
+
keys: string | string[];
|
|
22
|
+
callback: HandlerFunc;
|
|
23
|
+
action?: ActionType;
|
|
24
|
+
}
|
|
25
|
+
interface KeyboardDef {
|
|
26
|
+
enabled: boolean;
|
|
27
|
+
shortcuts?: Shortcut | Shortcut[];
|
|
28
|
+
}
|
|
29
|
+
interface Options {
|
|
30
|
+
lf: LogicFlow;
|
|
31
|
+
keyboard?: KeyboardDef;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
export default Keyboard;
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Keyboard = void 0;
|
|
7
|
+
var mousetrap_1 = __importDefault(require("mousetrap"));
|
|
8
|
+
var lodash_es_1 = require("lodash-es");
|
|
9
|
+
var Keyboard = /** @class */ (function () {
|
|
10
|
+
function Keyboard(options) {
|
|
11
|
+
var _a;
|
|
12
|
+
var lf = options.lf;
|
|
13
|
+
if (!options.keyboard) {
|
|
14
|
+
options.keyboard = { enabled: false };
|
|
15
|
+
}
|
|
16
|
+
this.options = options;
|
|
17
|
+
this.target = lf.container;
|
|
18
|
+
this.mousetrap = new mousetrap_1.default(this.target);
|
|
19
|
+
if ((_a = options.keyboard) === null || _a === void 0 ? void 0 : _a.enabled) {
|
|
20
|
+
this.enable(true);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
Keyboard.prototype.formatKey = function (key) {
|
|
24
|
+
return key
|
|
25
|
+
.toLowerCase()
|
|
26
|
+
.replace(/\s/g, '')
|
|
27
|
+
.replace('delete', 'del')
|
|
28
|
+
.replace('cmd', 'command');
|
|
29
|
+
};
|
|
30
|
+
Keyboard.prototype.getKeys = function (keys) {
|
|
31
|
+
var _this = this;
|
|
32
|
+
return ((0, lodash_es_1.isArray)(keys) ? keys : [keys]).map(function (key) { return _this.formatKey(key); });
|
|
33
|
+
};
|
|
34
|
+
Object.defineProperty(Keyboard.prototype, "disabled", {
|
|
35
|
+
get: function () {
|
|
36
|
+
var _a;
|
|
37
|
+
return ((_a = this.options.keyboard) === null || _a === void 0 ? void 0 : _a.enabled) !== true;
|
|
38
|
+
},
|
|
39
|
+
enumerable: false,
|
|
40
|
+
configurable: true
|
|
41
|
+
});
|
|
42
|
+
Keyboard.prototype.on = function (keys, callback, action) {
|
|
43
|
+
this.mousetrap.bind(this.getKeys(keys), callback, action);
|
|
44
|
+
};
|
|
45
|
+
Keyboard.prototype.off = function (keys, action) {
|
|
46
|
+
this.mousetrap.unbind(this.getKeys(keys), action);
|
|
47
|
+
};
|
|
48
|
+
Keyboard.prototype.enable = function (force) {
|
|
49
|
+
if (this.disabled || force) {
|
|
50
|
+
this.options.keyboard.enabled = true;
|
|
51
|
+
if (this.target instanceof HTMLElement) {
|
|
52
|
+
this.target.setAttribute('tabindex', '-1');
|
|
53
|
+
// 去掉节点被选中时 container 出现的边框
|
|
54
|
+
this.target.style.outline = 'none';
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
Keyboard.prototype.disable = function () {
|
|
59
|
+
if (!this.disabled) {
|
|
60
|
+
this.options.keyboard.enabled = false;
|
|
61
|
+
if (this.target instanceof HTMLElement) {
|
|
62
|
+
this.target.removeAttribute('tabindex');
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
Keyboard.prototype.initShortcuts = function () {
|
|
67
|
+
var _this = this;
|
|
68
|
+
var shortcuts = this.options.keyboard.shortcuts;
|
|
69
|
+
if (shortcuts) {
|
|
70
|
+
if ((0, lodash_es_1.isArray)(shortcuts)) {
|
|
71
|
+
(0, lodash_es_1.forEach)(shortcuts, function (_a) {
|
|
72
|
+
var keys = _a.keys, callback = _a.callback, action = _a.action;
|
|
73
|
+
_this.on(keys, callback, action);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
var keys = shortcuts.keys, callback = shortcuts.callback, action = shortcuts.action;
|
|
78
|
+
this.on(keys, callback, action);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
return Keyboard;
|
|
83
|
+
}());
|
|
84
|
+
exports.Keyboard = Keyboard;
|
|
85
|
+
exports.default = Keyboard;
|
|
86
|
+
//# sourceMappingURL=keyboard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keyboard.js","sourceRoot":"","sources":["../../src/common/keyboard.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export declare class Matrix extends Array {
|
|
2
|
+
rows: number;
|
|
3
|
+
columns: number;
|
|
4
|
+
constructor(...vectors: any[]);
|
|
5
|
+
getRow(index: number): any;
|
|
6
|
+
getColumn(index: number): number[];
|
|
7
|
+
transpose(): Matrix;
|
|
8
|
+
cross(m1: Matrix): Matrix;
|
|
9
|
+
to2D(): any[][];
|
|
10
|
+
toString(): string;
|
|
11
|
+
translate(tx: number, ty: number): Matrix;
|
|
12
|
+
rotate(angle: number): Matrix;
|
|
13
|
+
scale(sx: number, sy: number): Matrix;
|
|
14
|
+
}
|
|
15
|
+
export declare class RotateMatrix extends Matrix {
|
|
16
|
+
constructor(theta: number);
|
|
17
|
+
inverse(): Matrix;
|
|
18
|
+
}
|
|
19
|
+
export declare class ScaleMatrix extends Matrix {
|
|
20
|
+
private readonly sx;
|
|
21
|
+
private readonly sy;
|
|
22
|
+
constructor(sx: number, sy: number);
|
|
23
|
+
inverse(): ScaleMatrix;
|
|
24
|
+
}
|
|
25
|
+
export declare class TranslateMatrix extends Matrix {
|
|
26
|
+
private readonly tx;
|
|
27
|
+
private readonly ty;
|
|
28
|
+
constructor(tx: number, ty: number);
|
|
29
|
+
inverse(): TranslateMatrix;
|
|
30
|
+
}
|