@logicflow/core 2.0.0-beta.1 → 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 +9 -9
- package/__tests__/bugs/1545-spec.test.ts +19 -15
- package/__tests__/util/edge.test.ts +57 -57
- package/dist/index.min.js +9 -3
- 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 +6 -3
- package/es/options.js +2 -11
- 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 +43 -3
- 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/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 +6 -3
- package/lib/options.js +2 -11
- 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 +42 -2
- 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/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 +2 -1
- 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 +75 -44
- 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 +11 -15
- 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 +21 -4
- 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/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/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
|
@@ -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,145 @@
|
|
|
1
|
+
import { noop } from 'lodash-es';
|
|
2
|
+
import { EventType } from '../constant';
|
|
3
|
+
// TODO:这种方式在同构项目中,会报错,该如何解决(是否要求用户控制在浏览器环境时才初始化)
|
|
4
|
+
// const DOC: any = window?.document
|
|
5
|
+
var LEFT_MOUSE_BUTTON_CODE = 0;
|
|
6
|
+
/**
|
|
7
|
+
* 支持拖拽时按步长进行移动
|
|
8
|
+
* REMIND:在绘制的过程中因为放大缩小,移动的真实 step 是变化的
|
|
9
|
+
*/
|
|
10
|
+
var StepperDrag = /** @class */ (function () {
|
|
11
|
+
function StepperDrag(_a) {
|
|
12
|
+
var _b = _a.onDragStart, onDragStart = _b === void 0 ? noop : _b, _c = _a.onDragging, onDragging = _c === void 0 ? noop : _c, _d = _a.onDragEnd, onDragEnd = _d === void 0 ? 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;
|
|
13
|
+
var _this = this;
|
|
14
|
+
// 运行时
|
|
15
|
+
this.isDragging = false;
|
|
16
|
+
this.isStartDrag = false;
|
|
17
|
+
this.startX = 0;
|
|
18
|
+
this.startY = 0;
|
|
19
|
+
this.totalDeltaX = 0;
|
|
20
|
+
this.totalDeltaY = 0;
|
|
21
|
+
this.handleMouseMove = function (e) {
|
|
22
|
+
var _a, _b;
|
|
23
|
+
if (_this.isStopPropagation)
|
|
24
|
+
e.stopPropagation();
|
|
25
|
+
if (!_this.isStartDrag)
|
|
26
|
+
return;
|
|
27
|
+
_this.totalDeltaX += e.clientX - _this.startX;
|
|
28
|
+
_this.totalDeltaY += e.clientY - _this.startY;
|
|
29
|
+
_this.startX = e.clientX;
|
|
30
|
+
_this.startY = e.clientY;
|
|
31
|
+
if (_this.step <= 1 ||
|
|
32
|
+
Math.abs(_this.totalDeltaX) > _this.step ||
|
|
33
|
+
Math.abs(_this.totalDeltaY) > _this.step) {
|
|
34
|
+
var remainderX = _this.totalDeltaX % _this.step;
|
|
35
|
+
var remainderY = _this.totalDeltaY % _this.step;
|
|
36
|
+
var deltaX_1 = _this.totalDeltaX - remainderX;
|
|
37
|
+
var deltaY_1 = _this.totalDeltaY - remainderY;
|
|
38
|
+
_this.totalDeltaX = remainderX;
|
|
39
|
+
_this.totalDeltaY = remainderY;
|
|
40
|
+
var elementData_1 = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
|
|
41
|
+
// REMIND: 为了区分点击和拖动,在鼠标没有拖动时,不触发 dragstart。
|
|
42
|
+
if (!_this.isDragging) {
|
|
43
|
+
if (_this.eventType) {
|
|
44
|
+
(_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(EventType["".concat(_this.eventType, "_DRAGSTART")], {
|
|
45
|
+
e: e,
|
|
46
|
+
data: _this.data || elementData_1,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
_this.onDragStart({ event: e });
|
|
50
|
+
}
|
|
51
|
+
_this.isDragging = true;
|
|
52
|
+
// REMIND: 为了让 dragstart 和 drag 不在同一个事件循环中,将 drag 事件放在下一个任务队列中。
|
|
53
|
+
// TODO: 测试用例是否可覆盖???
|
|
54
|
+
Promise.resolve().then(function () {
|
|
55
|
+
var _a, _b;
|
|
56
|
+
_this.onDragging({ deltaX: deltaX_1, deltaY: deltaY_1, event: e });
|
|
57
|
+
if (_this.eventType) {
|
|
58
|
+
(_a = _this.eventCenter) === null || _a === void 0 ? void 0 : _a.emit(EventType["".concat(_this.eventType, "_MOUSEMOVE")], {
|
|
59
|
+
e: e,
|
|
60
|
+
data: _this.data || elementData_1,
|
|
61
|
+
});
|
|
62
|
+
(_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(EventType["".concat(_this.eventType, "_DRAG")], {
|
|
63
|
+
e: e,
|
|
64
|
+
data: _this.data || elementData_1,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
this.handleMouseUp = function (e) {
|
|
71
|
+
var DOC = window === null || window === void 0 ? void 0 : window.document;
|
|
72
|
+
_this.isStartDrag = false;
|
|
73
|
+
if (_this.isStopPropagation)
|
|
74
|
+
e.stopPropagation();
|
|
75
|
+
// fix: issue#568, 如果 onDragging 在下一个时间循环中触发,而 drop 在当前事件循环,会出现问题
|
|
76
|
+
Promise.resolve().then(function () {
|
|
77
|
+
var _a, _b, _c;
|
|
78
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mousemove', _this.handleMouseMove, true);
|
|
79
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mouseup', _this.handleMouseUp, true);
|
|
80
|
+
var elementData = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
|
|
81
|
+
if (_this.eventType) {
|
|
82
|
+
(_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(EventType["".concat(_this.eventType, "_MOUSEUP")], {
|
|
83
|
+
e: e,
|
|
84
|
+
data: _this.data || elementData,
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
if (!_this.isDragging)
|
|
88
|
+
return;
|
|
89
|
+
_this.isDragging = false;
|
|
90
|
+
_this.onDragEnd({ event: e });
|
|
91
|
+
if (_this.eventType) {
|
|
92
|
+
(_c = _this.eventCenter) === null || _c === void 0 ? void 0 : _c.emit(EventType["".concat(_this.eventType, "_DROP")], {
|
|
93
|
+
e: e,
|
|
94
|
+
data: _this.data || elementData,
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
};
|
|
99
|
+
this.handleMouseDown = function (e) {
|
|
100
|
+
var _a, _b;
|
|
101
|
+
var DOC = window === null || window === void 0 ? void 0 : window.document;
|
|
102
|
+
// issue: LogicFlow交流群-3群 8.10 号抛出的事件相关的问题,是否是这引起的???
|
|
103
|
+
if (e.button !== LEFT_MOUSE_BUTTON_CODE)
|
|
104
|
+
return;
|
|
105
|
+
if (_this.isStopPropagation)
|
|
106
|
+
e.stopPropagation();
|
|
107
|
+
_this.isStartDrag = true;
|
|
108
|
+
_this.startX = e.clientX;
|
|
109
|
+
_this.startY = e.clientY;
|
|
110
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.addEventListener('mousemove', _this.handleMouseMove, true);
|
|
111
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.addEventListener('mouseup', _this.handleMouseUp, true);
|
|
112
|
+
var elementData = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
|
|
113
|
+
if (_this.eventType) {
|
|
114
|
+
(_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(EventType["".concat(_this.eventType, "_MOUSEDOWN")], {
|
|
115
|
+
e: e,
|
|
116
|
+
data: _this.data || elementData,
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
_this.startTime = new Date().getTime();
|
|
120
|
+
};
|
|
121
|
+
this.cancelDrag = function () {
|
|
122
|
+
var DOC = window === null || window === void 0 ? void 0 : window.document;
|
|
123
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mousemove', _this.handleMouseMove, true);
|
|
124
|
+
DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mouseup', _this.handleMouseUp, true);
|
|
125
|
+
_this.onDragEnd({ event: null });
|
|
126
|
+
_this.isDragging = false;
|
|
127
|
+
};
|
|
128
|
+
this.onDragStart = onDragStart;
|
|
129
|
+
this.onDragging = onDragging;
|
|
130
|
+
this.onDragEnd = onDragEnd;
|
|
131
|
+
this.step = step;
|
|
132
|
+
this.eventType = eventType;
|
|
133
|
+
this.isStopPropagation = isStopPropagation;
|
|
134
|
+
this.eventCenter = eventCenter;
|
|
135
|
+
this.model = model;
|
|
136
|
+
this.data = data;
|
|
137
|
+
}
|
|
138
|
+
StepperDrag.prototype.setStep = function (step) {
|
|
139
|
+
this.step = step;
|
|
140
|
+
};
|
|
141
|
+
return StepperDrag;
|
|
142
|
+
}());
|
|
143
|
+
export { StepperDrag };
|
|
144
|
+
export default StepperDrag;
|
|
145
|
+
//# 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,92 @@
|
|
|
1
|
+
import { cloneDeep, debounce, isEqual, last } from 'lodash-es';
|
|
2
|
+
import { deepObserve } from 'mobx-utils';
|
|
3
|
+
var History = /** @class */ (function () {
|
|
4
|
+
function History(eventCenter) {
|
|
5
|
+
this.undos = [];
|
|
6
|
+
this.redos = [];
|
|
7
|
+
this.stopWatch = null;
|
|
8
|
+
this.curData = null;
|
|
9
|
+
this.maxSize = 50;
|
|
10
|
+
// 发生数据变化后,最多再等 500ms,把距离上次的数据变更存储起来。
|
|
11
|
+
// 所以 waitTime 值越小,History 对数据变化越敏感,存的 undos 数据就越细
|
|
12
|
+
this.waitTime = 100;
|
|
13
|
+
this.eventCenter = eventCenter;
|
|
14
|
+
}
|
|
15
|
+
History.prototype.add = function (data) {
|
|
16
|
+
if (isEqual(last(this.undos), data))
|
|
17
|
+
return;
|
|
18
|
+
this.undos.push(data);
|
|
19
|
+
// 因为 undo 的时候会触发 add.
|
|
20
|
+
// 所以需要区分这个 add 是 undo 触发的还是用户正常操作触发的
|
|
21
|
+
// 如果是用户正常操作触发的,需要清空 redos
|
|
22
|
+
if (!isEqual(this.curData, data)) {
|
|
23
|
+
this.redos = [];
|
|
24
|
+
}
|
|
25
|
+
// this.eventCenter.emit(EventType.HISTORY_CHANGE, {
|
|
26
|
+
// data: {
|
|
27
|
+
// undos: this.undos,
|
|
28
|
+
// redos: this.redos,
|
|
29
|
+
// undoAble: this.undos.length > 1,
|
|
30
|
+
// redoAble: this.redos.length > 0,
|
|
31
|
+
// },
|
|
32
|
+
// })
|
|
33
|
+
if (this.undos.length > this.maxSize) {
|
|
34
|
+
this.undos.shift();
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
History.prototype.undoAble = function () {
|
|
38
|
+
return this.undos.length > 1;
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* undo 方法触发:
|
|
42
|
+
* graphModel 重新渲染 nodes 和 edges
|
|
43
|
+
* graphModel 发生变化,触发 watch
|
|
44
|
+
* watch 触发 add
|
|
45
|
+
*/
|
|
46
|
+
History.prototype.undo = function () {
|
|
47
|
+
if (!this.undoAble())
|
|
48
|
+
return;
|
|
49
|
+
var preData = this.undos.pop();
|
|
50
|
+
if (preData) {
|
|
51
|
+
this.redos.push(preData);
|
|
52
|
+
}
|
|
53
|
+
var curData = this.undos.pop();
|
|
54
|
+
if (curData) {
|
|
55
|
+
this.curData = cloneDeep(curData);
|
|
56
|
+
}
|
|
57
|
+
return curData;
|
|
58
|
+
};
|
|
59
|
+
History.prototype.redoAble = function () {
|
|
60
|
+
return this.redos.length > 0;
|
|
61
|
+
};
|
|
62
|
+
History.prototype.redo = function () {
|
|
63
|
+
if (!this.redoAble())
|
|
64
|
+
return;
|
|
65
|
+
var curData = this.redos.pop();
|
|
66
|
+
if (curData) {
|
|
67
|
+
this.curData = cloneDeep(curData);
|
|
68
|
+
}
|
|
69
|
+
return curData;
|
|
70
|
+
};
|
|
71
|
+
History.prototype.watch = function (model) {
|
|
72
|
+
var _this = this;
|
|
73
|
+
this.stopWatch && this.stopWatch();
|
|
74
|
+
// 把当前 watch 的 model 转换一下数据存起来,无需清空 redos
|
|
75
|
+
var historyData = model.modelToHistoryData();
|
|
76
|
+
if (historyData) {
|
|
77
|
+
this.undos.push(historyData);
|
|
78
|
+
}
|
|
79
|
+
this.stopWatch = deepObserve(model, debounce(function () {
|
|
80
|
+
// 数据变更后,把最新的当前 model 数据存起来,并清空 redos
|
|
81
|
+
// 因为这个回调函数的触发,一般是用户交互而引起的,所以按照正常逻辑需要清空 redos
|
|
82
|
+
var data = model.modelToHistoryData();
|
|
83
|
+
if (data) {
|
|
84
|
+
_this.add(data);
|
|
85
|
+
}
|
|
86
|
+
}, this.waitTime));
|
|
87
|
+
};
|
|
88
|
+
return History;
|
|
89
|
+
}());
|
|
90
|
+
export { History };
|
|
91
|
+
export default History;
|
|
92
|
+
//# 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 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA;AACtB,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAE1B,cAAc,UAAU,CAAA;AACxB,cAAc,UAAU,CAAA"}
|
|
@@ -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,80 @@
|
|
|
1
|
+
import Mousetrap from 'mousetrap';
|
|
2
|
+
import { forEach, isArray } from 'lodash-es';
|
|
3
|
+
var Keyboard = /** @class */ (function () {
|
|
4
|
+
function Keyboard(options) {
|
|
5
|
+
var _a;
|
|
6
|
+
var lf = options.lf;
|
|
7
|
+
if (!options.keyboard) {
|
|
8
|
+
options.keyboard = { enabled: false };
|
|
9
|
+
}
|
|
10
|
+
this.options = options;
|
|
11
|
+
this.target = lf.container;
|
|
12
|
+
this.mousetrap = new Mousetrap(this.target);
|
|
13
|
+
if ((_a = options.keyboard) === null || _a === void 0 ? void 0 : _a.enabled) {
|
|
14
|
+
this.enable(true);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
Keyboard.prototype.formatKey = function (key) {
|
|
18
|
+
return key
|
|
19
|
+
.toLowerCase()
|
|
20
|
+
.replace(/\s/g, '')
|
|
21
|
+
.replace('delete', 'del')
|
|
22
|
+
.replace('cmd', 'command');
|
|
23
|
+
};
|
|
24
|
+
Keyboard.prototype.getKeys = function (keys) {
|
|
25
|
+
var _this = this;
|
|
26
|
+
return (isArray(keys) ? keys : [keys]).map(function (key) { return _this.formatKey(key); });
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(Keyboard.prototype, "disabled", {
|
|
29
|
+
get: function () {
|
|
30
|
+
var _a;
|
|
31
|
+
return ((_a = this.options.keyboard) === null || _a === void 0 ? void 0 : _a.enabled) !== true;
|
|
32
|
+
},
|
|
33
|
+
enumerable: false,
|
|
34
|
+
configurable: true
|
|
35
|
+
});
|
|
36
|
+
Keyboard.prototype.on = function (keys, callback, action) {
|
|
37
|
+
this.mousetrap.bind(this.getKeys(keys), callback, action);
|
|
38
|
+
};
|
|
39
|
+
Keyboard.prototype.off = function (keys, action) {
|
|
40
|
+
this.mousetrap.unbind(this.getKeys(keys), action);
|
|
41
|
+
};
|
|
42
|
+
Keyboard.prototype.enable = function (force) {
|
|
43
|
+
if (this.disabled || force) {
|
|
44
|
+
this.options.keyboard.enabled = true;
|
|
45
|
+
if (this.target instanceof HTMLElement) {
|
|
46
|
+
this.target.setAttribute('tabindex', '-1');
|
|
47
|
+
// 去掉节点被选中时 container 出现的边框
|
|
48
|
+
this.target.style.outline = 'none';
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
Keyboard.prototype.disable = function () {
|
|
53
|
+
if (!this.disabled) {
|
|
54
|
+
this.options.keyboard.enabled = false;
|
|
55
|
+
if (this.target instanceof HTMLElement) {
|
|
56
|
+
this.target.removeAttribute('tabindex');
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
Keyboard.prototype.initShortcuts = function () {
|
|
61
|
+
var _this = this;
|
|
62
|
+
var shortcuts = this.options.keyboard.shortcuts;
|
|
63
|
+
if (shortcuts) {
|
|
64
|
+
if (isArray(shortcuts)) {
|
|
65
|
+
forEach(shortcuts, function (_a) {
|
|
66
|
+
var keys = _a.keys, callback = _a.callback, action = _a.action;
|
|
67
|
+
_this.on(keys, callback, action);
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
var keys = shortcuts.keys, callback = shortcuts.callback, action = shortcuts.action;
|
|
72
|
+
this.on(keys, callback, action);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
return Keyboard;
|
|
77
|
+
}());
|
|
78
|
+
export { Keyboard };
|
|
79
|
+
export default Keyboard;
|
|
80
|
+
//# sourceMappingURL=keyboard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keyboard.js","sourceRoot":"","sources":["../../src/common/keyboard.ts"],"names":[],"mappings":"AAAA,OAAO,SAAgC,MAAM,WAAW,CAAA;AACxD,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAG5C;IAKE,kBAAY,OAAyB;;QAC3B,IAAA,EAAE,GAAK,OAAO,GAAZ,CAAY;QACtB,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YACtB,OAAO,CAAC,QAAQ,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,CAAA;QACvC,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,OAAqC,CAAA;QACpD,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC,SAAS,CAAA;QAC1B,IAAI,CAAC,SAAS,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAE3C,IAAI,MAAA,OAAO,CAAC,QAAQ,0CAAE,OAAO,EAAE,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QACnB,CAAC;IACH,CAAC;IAES,4BAAS,GAAnB,UAAoB,GAAW;QAC7B,OAAO,GAAG;aACP,WAAW,EAAE;aACb,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;aAClB,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC;aACxB,OAAO,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;IAC9B,CAAC;IAEO,0BAAO,GAAf,UAAgB,IAAuB;QAAvC,iBAEC;QADC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,UAAC,GAAG,IAAK,OAAA,KAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAnB,CAAmB,CAAC,CAAA;IAC1E,CAAC;IAED,sBAAI,8BAAQ;aAAZ;;YACE,OAAO,CAAA,MAAA,IAAI,CAAC,OAAO,CAAC,QAAQ,0CAAE,OAAO,MAAK,IAAI,CAAA;QAChD,CAAC;;;OAAA;IAED,qBAAE,GAAF,UACE,IAAuB,EACvB,QAA8B,EAC9B,MAA4B;QAE5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IAC3D,CAAC;IAED,sBAAG,GAAH,UAAI,IAAuB,EAAE,MAA4B;QACvD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAA;IACnD,CAAC;IAED,yBAAM,GAAN,UAAO,KAAc;QACnB,IAAI,IAAI,CAAC,QAAQ,IAAI,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAA;YACpC,IAAI,IAAI,CAAC,MAAM,YAAY,WAAW,EAAE,CAAC;gBACvC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,CAAA;gBAC1C,2BAA2B;gBAC3B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAA;YACpC,CAAC;QACH,CAAC;IACH,CAAC;IAED,0BAAO,GAAP;QACE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,GAAG,KAAK,CAAA;YACrC,IAAI,IAAI,CAAC,MAAM,YAAY,WAAW,EAAE,CAAC;gBACvC,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,UAAU,CAAC,CAAA;YACzC,CAAC;QACH,CAAC;IACH,CAAC;IAED,gCAAa,GAAb;QAAA,iBAYC;QAXS,IAAA,SAAS,GAAK,IAAI,CAAC,OAAO,CAAC,QAAQ,UAA1B,CAA0B;QAC3C,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;gBACvB,OAAO,CAAC,SAAS,EAAE,UAAC,EAA0B;wBAAxB,IAAI,UAAA,EAAE,QAAQ,cAAA,EAAE,MAAM,YAAA;oBAC1C,KAAI,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;gBACjC,CAAC,CAAC,CAAA;YACJ,CAAC;iBAAM,CAAC;gBACE,IAAA,IAAI,GAAuB,SAAS,KAAhC,EAAE,QAAQ,GAAa,SAAS,SAAtB,EAAE,MAAM,GAAK,SAAS,OAAd,CAAc;gBAC5C,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;YACjC,CAAC;QACH,CAAC;IACH,CAAC;IACH,eAAC;AAAD,CAAC,AAhFD,IAgFC;;AAuBD,eAAe,QAAQ,CAAA"}
|
|
@@ -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
|
+
}
|
|
@@ -0,0 +1,155 @@
|
|
|
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 __read = (this && this.__read) || function (o, n) {
|
|
17
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
18
|
+
if (!m) return o;
|
|
19
|
+
var i = m.call(o), r, ar = [], e;
|
|
20
|
+
try {
|
|
21
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
22
|
+
}
|
|
23
|
+
catch (error) { e = { error: error }; }
|
|
24
|
+
finally {
|
|
25
|
+
try {
|
|
26
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
27
|
+
}
|
|
28
|
+
finally { if (e) throw e.error; }
|
|
29
|
+
}
|
|
30
|
+
return ar;
|
|
31
|
+
};
|
|
32
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
33
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
34
|
+
if (ar || !(i in from)) {
|
|
35
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
36
|
+
ar[i] = from[i];
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
40
|
+
};
|
|
41
|
+
import { Vector } from './vector';
|
|
42
|
+
var Matrix = /** @class */ (function (_super) {
|
|
43
|
+
__extends(Matrix, _super);
|
|
44
|
+
function Matrix() {
|
|
45
|
+
var vectors = [];
|
|
46
|
+
for (var _i = 0; _i < arguments.length; _i++) {
|
|
47
|
+
vectors[_i] = arguments[_i];
|
|
48
|
+
}
|
|
49
|
+
var _this = _super.call(this, vectors.length) || this;
|
|
50
|
+
_this.fill(new Array(3));
|
|
51
|
+
vectors.forEach(function (v, index) {
|
|
52
|
+
_this[index] = v;
|
|
53
|
+
});
|
|
54
|
+
_this.columns = vectors[0].length;
|
|
55
|
+
_this.rows = vectors.length;
|
|
56
|
+
Object.setPrototypeOf(_this, Matrix.prototype);
|
|
57
|
+
return _this;
|
|
58
|
+
}
|
|
59
|
+
Matrix.prototype.getRow = function (index) {
|
|
60
|
+
return this[index];
|
|
61
|
+
};
|
|
62
|
+
Matrix.prototype.getColumn = function (index) {
|
|
63
|
+
return __spreadArray([], __read(this.map(function (row) { return row[index]; })), false);
|
|
64
|
+
};
|
|
65
|
+
// 转置
|
|
66
|
+
Matrix.prototype.transpose = function () {
|
|
67
|
+
var rows = [];
|
|
68
|
+
for (var i = 0; i < this.columns; i++) {
|
|
69
|
+
rows.push(this.getColumn(i));
|
|
70
|
+
}
|
|
71
|
+
return new (Matrix.bind.apply(Matrix, __spreadArray([void 0], __read(rows), false)))();
|
|
72
|
+
};
|
|
73
|
+
// 叉乘
|
|
74
|
+
Matrix.prototype.cross = function (m1) {
|
|
75
|
+
var arr = new Array(this.rows).fill('').map(function () { return []; });
|
|
76
|
+
if (this.columns === m1.rows) {
|
|
77
|
+
for (var i = 0; i < this.rows; i++) {
|
|
78
|
+
var row = this.getRow(i);
|
|
79
|
+
var _loop_1 = function (j) {
|
|
80
|
+
var column = m1.getColumn(j);
|
|
81
|
+
arr[i][j] = row.reduce(function (prev, r, index) {
|
|
82
|
+
return prev + r * column[index];
|
|
83
|
+
}, 0);
|
|
84
|
+
};
|
|
85
|
+
for (var j = 0; j < m1.columns; j++) {
|
|
86
|
+
_loop_1(j);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return new (Matrix.bind.apply(Matrix, __spreadArray([void 0], __read(arr), false)))();
|
|
91
|
+
};
|
|
92
|
+
// 返回二维坐标(降维)
|
|
93
|
+
Matrix.prototype.to2D = function () {
|
|
94
|
+
return this.map(function (item) { return [item[0], item[1]]; });
|
|
95
|
+
};
|
|
96
|
+
Matrix.prototype.toString = function () {
|
|
97
|
+
var _a = __read(this, 3), _b = __read(_a[0], 2), a = _b[0], b = _b[1], _c = __read(_a[1], 2), c = _c[0], d = _c[1], _d = __read(_a[2], 2), e = _d[0], f = _d[1];
|
|
98
|
+
return "matrix(".concat(a, " ").concat(b, " ").concat(c, " ").concat(d, " ").concat(e, " ").concat(f, ")");
|
|
99
|
+
};
|
|
100
|
+
Matrix.prototype.translate = function (tx, ty) {
|
|
101
|
+
return this.cross(new TranslateMatrix(tx, ty));
|
|
102
|
+
};
|
|
103
|
+
Matrix.prototype.rotate = function (angle) {
|
|
104
|
+
return this.cross(new RotateMatrix(angle));
|
|
105
|
+
};
|
|
106
|
+
Matrix.prototype.scale = function (sx, sy) {
|
|
107
|
+
return this.cross(new ScaleMatrix(sx, sy));
|
|
108
|
+
};
|
|
109
|
+
return Matrix;
|
|
110
|
+
}(Array));
|
|
111
|
+
export { Matrix };
|
|
112
|
+
var RotateMatrix = /** @class */ (function (_super) {
|
|
113
|
+
__extends(RotateMatrix, _super);
|
|
114
|
+
function RotateMatrix(theta) {
|
|
115
|
+
var _this = _super.call(this, new Vector(+Math.cos(theta).toFixed(2), +Math.sin(theta).toFixed(2), 0), new Vector(-Math.sin(theta).toFixed(2), +Math.cos(theta).toFixed(2), 0), new Vector(0, 0, 1)) || this;
|
|
116
|
+
Object.setPrototypeOf(_this, RotateMatrix.prototype);
|
|
117
|
+
return _this;
|
|
118
|
+
}
|
|
119
|
+
RotateMatrix.prototype.inverse = function () {
|
|
120
|
+
return this.transpose();
|
|
121
|
+
};
|
|
122
|
+
return RotateMatrix;
|
|
123
|
+
}(Matrix));
|
|
124
|
+
export { RotateMatrix };
|
|
125
|
+
var ScaleMatrix = /** @class */ (function (_super) {
|
|
126
|
+
__extends(ScaleMatrix, _super);
|
|
127
|
+
function ScaleMatrix(sx, sy) {
|
|
128
|
+
var _this = _super.call(this, new Vector(sx, 0, 0), new Vector(0, sy, 0), new Vector(0, 0, 1)) || this;
|
|
129
|
+
_this.sx = sx;
|
|
130
|
+
_this.sy = sy;
|
|
131
|
+
Object.setPrototypeOf(_this, ScaleMatrix.prototype);
|
|
132
|
+
return _this;
|
|
133
|
+
}
|
|
134
|
+
ScaleMatrix.prototype.inverse = function () {
|
|
135
|
+
return new ScaleMatrix(1 / this.sx, 1 / this.sy);
|
|
136
|
+
};
|
|
137
|
+
return ScaleMatrix;
|
|
138
|
+
}(Matrix));
|
|
139
|
+
export { ScaleMatrix };
|
|
140
|
+
var TranslateMatrix = /** @class */ (function (_super) {
|
|
141
|
+
__extends(TranslateMatrix, _super);
|
|
142
|
+
function TranslateMatrix(tx, ty) {
|
|
143
|
+
var _this = _super.call(this, new Vector(1, 0, 0), new Vector(0, 1, 0), new Vector(tx, ty, 1)) || this;
|
|
144
|
+
_this.tx = tx;
|
|
145
|
+
_this.ty = ty;
|
|
146
|
+
Object.setPrototypeOf(_this, TranslateMatrix.prototype);
|
|
147
|
+
return _this;
|
|
148
|
+
}
|
|
149
|
+
TranslateMatrix.prototype.inverse = function () {
|
|
150
|
+
return new TranslateMatrix(-this.tx, -this.ty);
|
|
151
|
+
};
|
|
152
|
+
return TranslateMatrix;
|
|
153
|
+
}(Matrix));
|
|
154
|
+
export { TranslateMatrix };
|
|
155
|
+
//# sourceMappingURL=matrix.js.map
|