js-draw 0.25.1 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +80 -26
- package/build-config.json +22 -21
- package/dist/Editor.css +1281 -0
- package/dist/bundle.js +3 -3
- package/dist/bundledStyles.js +1 -1
- package/dist/cjs/Editor.d.ts +91 -12
- package/dist/cjs/Editor.js +619 -590
- package/dist/cjs/EditorImage.d.ts +5 -2
- package/dist/cjs/EditorImage.js +258 -297
- package/dist/cjs/EventDispatcher.js +17 -19
- package/dist/cjs/Pointer.d.ts +3 -1
- package/dist/cjs/Pointer.js +41 -44
- package/dist/cjs/SVGLoader.d.ts +7 -1
- package/dist/cjs/SVGLoader.js +373 -474
- package/dist/cjs/UndoRedoHistory.js +28 -40
- package/dist/cjs/Viewport.d.ts +1 -4
- package/dist/cjs/Viewport.js +150 -193
- package/dist/cjs/bundle/bundled.js +4 -1
- package/dist/cjs/commands/Command.js +22 -49
- package/dist/cjs/commands/Duplicate.js +28 -44
- package/dist/cjs/commands/Erase.js +36 -54
- package/dist/cjs/commands/SerializableCommand.js +20 -35
- package/dist/cjs/commands/UnresolvedCommand.js +14 -29
- package/dist/cjs/commands/invertCommand.js +29 -51
- package/dist/cjs/commands/lib.js +9 -6
- package/dist/cjs/commands/localization.d.ts +1 -1
- package/dist/cjs/commands/localization.js +9 -9
- package/dist/cjs/commands/uniteCommands.js +57 -87
- package/dist/cjs/components/AbstractComponent.d.ts +11 -3
- package/dist/cjs/components/AbstractComponent.js +141 -169
- package/dist/cjs/components/BackgroundComponent.d.ts +3 -6
- package/dist/cjs/components/BackgroundComponent.js +124 -149
- package/dist/cjs/components/ImageComponent.d.ts +3 -5
- package/dist/cjs/components/ImageComponent.js +95 -175
- package/dist/cjs/components/RestylableComponent.d.ts +1 -1
- package/dist/cjs/components/RestylableComponent.js +41 -56
- package/dist/cjs/components/SVGGlobalAttributesObject.d.ts +1 -3
- package/dist/cjs/components/SVGGlobalAttributesObject.js +34 -51
- package/dist/cjs/components/Stroke.d.ts +4 -6
- package/dist/cjs/components/Stroke.js +95 -121
- package/dist/cjs/components/TextComponent.d.ts +2 -4
- package/dist/cjs/components/TextComponent.js +189 -234
- package/dist/cjs/components/UnknownSVGObject.d.ts +1 -3
- package/dist/cjs/components/UnknownSVGObject.js +30 -43
- package/dist/cjs/components/builders/ArrowBuilder.d.ts +1 -1
- package/dist/cjs/components/builders/ArrowBuilder.js +43 -42
- package/dist/cjs/components/builders/CircleBuilder.js +43 -43
- package/dist/cjs/components/builders/FreehandLineBuilder.d.ts +3 -2
- package/dist/cjs/components/builders/FreehandLineBuilder.js +73 -86
- package/dist/cjs/components/builders/LineBuilder.d.ts +1 -1
- package/dist/cjs/components/builders/LineBuilder.js +38 -36
- package/dist/cjs/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +1 -1
- package/dist/cjs/components/builders/PressureSensitiveFreehandLineBuilder.js +131 -139
- package/dist/cjs/components/builders/RectangleBuilder.d.ts +1 -1
- package/dist/cjs/components/builders/RectangleBuilder.js +31 -31
- package/dist/cjs/components/builders/types.d.ts +1 -1
- package/dist/cjs/components/lib.d.ts +3 -1
- package/dist/cjs/components/lib.js +10 -7
- package/dist/cjs/components/localization.js +4 -4
- package/dist/cjs/components/util/StrokeSmoother.d.ts +1 -2
- package/dist/cjs/components/util/StrokeSmoother.js +67 -72
- package/dist/cjs/components/util/describeComponentList.d.ts +1 -1
- package/dist/cjs/components/util/describeComponentList.js +4 -5
- package/dist/cjs/dialogs/makeAboutDialog.d.ts +15 -0
- package/dist/cjs/dialogs/makeAboutDialog.js +54 -0
- package/dist/cjs/inputEvents.d.ts +84 -0
- package/dist/cjs/inputEvents.js +40 -0
- package/dist/cjs/lib.d.ts +29 -13
- package/dist/cjs/lib.js +38 -23
- package/dist/cjs/localization.js +19 -18
- package/dist/cjs/localizations/de.js +117 -13
- package/dist/cjs/localizations/en.js +4 -13
- package/dist/cjs/localizations/es.js +62 -23
- package/dist/cjs/localizations/getLocalizationTable.js +15 -13
- package/dist/cjs/rendering/Display.d.ts +1 -2
- package/dist/cjs/rendering/Display.js +70 -83
- package/dist/cjs/rendering/RenderablePathSpec.d.ts +15 -0
- package/dist/cjs/rendering/RenderablePathSpec.js +70 -0
- package/dist/cjs/rendering/RenderingStyle.d.ts +4 -4
- package/dist/cjs/rendering/RenderingStyle.js +18 -28
- package/dist/cjs/rendering/TextRenderingStyle.d.ts +10 -10
- package/dist/cjs/rendering/TextRenderingStyle.js +13 -18
- package/dist/cjs/rendering/caching/CacheRecord.d.ts +1 -2
- package/dist/cjs/rendering/caching/CacheRecord.js +20 -22
- package/dist/cjs/rendering/caching/CacheRecordManager.d.ts +1 -1
- package/dist/cjs/rendering/caching/CacheRecordManager.js +17 -15
- package/dist/cjs/rendering/caching/RenderingCache.js +19 -19
- package/dist/cjs/rendering/caching/RenderingCacheNode.d.ts +1 -1
- package/dist/cjs/rendering/caching/RenderingCacheNode.js +98 -118
- package/dist/cjs/rendering/caching/testUtils.js +24 -23
- package/dist/cjs/rendering/caching/types.d.ts +3 -3
- package/dist/cjs/rendering/lib.js +8 -5
- package/dist/cjs/rendering/localization.js +5 -5
- package/dist/cjs/rendering/renderers/AbstractRenderer.d.ts +2 -11
- package/dist/cjs/rendering/renderers/AbstractRenderer.js +53 -57
- package/dist/cjs/rendering/renderers/CanvasRenderer.d.ts +3 -5
- package/dist/cjs/rendering/renderers/CanvasRenderer.js +91 -106
- package/dist/cjs/rendering/renderers/DummyRenderer.d.ts +1 -4
- package/dist/cjs/rendering/renderers/DummyRenderer.js +56 -76
- package/dist/cjs/rendering/renderers/SVGRenderer.d.ts +5 -5
- package/dist/cjs/rendering/renderers/SVGRenderer.js +194 -176
- package/dist/cjs/rendering/renderers/TextOnlyRenderer.d.ts +1 -3
- package/dist/cjs/rendering/renderers/TextOnlyRenderer.js +47 -72
- package/dist/cjs/shortcuts/KeyBinding.d.ts +5 -0
- package/dist/cjs/shortcuts/KeyBinding.js +94 -70
- package/dist/cjs/shortcuts/KeyboardShortcutManager.d.ts +1 -1
- package/dist/cjs/shortcuts/KeyboardShortcutManager.js +36 -45
- package/dist/cjs/shortcuts/lib.js +5 -2
- package/dist/cjs/testing/createEditor.js +7 -4
- package/dist/cjs/testing/getUniquePointerId.js +4 -5
- package/dist/cjs/testing/lib.js +5 -2
- package/dist/cjs/testing/sendPenEvent.d.ts +2 -2
- package/dist/cjs/testing/sendPenEvent.js +10 -7
- package/dist/cjs/testing/sendTouchEvent.d.ts +2 -2
- package/dist/cjs/testing/sendTouchEvent.js +34 -16
- package/dist/cjs/toolbar/AbstractToolbar.d.ts +166 -0
- package/dist/cjs/toolbar/AbstractToolbar.js +410 -0
- package/dist/cjs/toolbar/DropdownToolbar.d.ts +43 -0
- package/dist/cjs/toolbar/DropdownToolbar.js +176 -0
- package/dist/cjs/toolbar/EdgeToolbar.d.ts +47 -0
- package/dist/cjs/toolbar/EdgeToolbar.js +422 -0
- package/dist/cjs/toolbar/IconProvider.d.ts +54 -30
- package/dist/cjs/toolbar/IconProvider.js +652 -224
- package/dist/cjs/toolbar/constants.d.ts +1 -0
- package/dist/cjs/toolbar/constants.js +4 -0
- package/dist/cjs/toolbar/lib.d.ts +4 -2
- package/dist/cjs/toolbar/lib.js +10 -3
- package/dist/cjs/toolbar/localization.d.ts +9 -2
- package/dist/cjs/toolbar/localization.js +26 -19
- package/dist/cjs/toolbar/types.d.ts +7 -0
- package/dist/cjs/toolbar/widgets/ActionButtonWidget.d.ts +1 -1
- package/dist/cjs/toolbar/widgets/ActionButtonWidget.js +23 -39
- package/dist/cjs/toolbar/widgets/BaseToolWidget.d.ts +1 -1
- package/dist/cjs/toolbar/widgets/BaseToolWidget.js +35 -37
- package/dist/cjs/toolbar/widgets/BaseWidget.d.ts +60 -5
- package/dist/cjs/toolbar/widgets/BaseWidget.js +232 -177
- package/dist/cjs/toolbar/widgets/DocumentPropertiesWidget.js +130 -117
- package/dist/cjs/toolbar/widgets/EraserToolWidget.d.ts +1 -3
- package/dist/cjs/toolbar/widgets/EraserToolWidget.js +45 -73
- package/dist/cjs/toolbar/widgets/HandToolWidget.d.ts +1 -0
- package/dist/cjs/toolbar/widgets/HandToolWidget.js +126 -141
- package/dist/cjs/toolbar/widgets/InsertImageWidget.d.ts +9 -7
- package/dist/cjs/toolbar/widgets/InsertImageWidget.js +147 -212
- package/dist/cjs/toolbar/widgets/OverflowWidget.js +33 -61
- package/dist/cjs/toolbar/widgets/PenToolWidget.d.ts +8 -1
- package/dist/cjs/toolbar/widgets/PenToolWidget.js +162 -234
- package/dist/cjs/toolbar/widgets/SelectionToolWidget.d.ts +3 -1
- package/dist/cjs/toolbar/widgets/SelectionToolWidget.js +105 -177
- package/dist/cjs/toolbar/widgets/TextToolWidget.js +64 -87
- package/dist/cjs/toolbar/widgets/components/makeColorInput.d.ts +10 -0
- package/dist/cjs/toolbar/{makeColorInput.js → widgets/components/makeColorInput.js} +57 -34
- package/dist/cjs/toolbar/widgets/components/makeFileInput.d.ts +12 -0
- package/dist/cjs/toolbar/widgets/components/makeFileInput.js +111 -0
- package/dist/cjs/toolbar/widgets/components/makeGridSelector.d.ts +24 -0
- package/dist/cjs/toolbar/widgets/components/makeGridSelector.js +127 -0
- package/dist/cjs/toolbar/widgets/components/makeSeparator.d.ts +7 -0
- package/dist/cjs/toolbar/widgets/components/makeSeparator.js +16 -0
- package/dist/cjs/toolbar/widgets/components/makeThicknessSlider.d.ts +8 -0
- package/dist/cjs/toolbar/widgets/components/makeThicknessSlider.js +47 -0
- package/dist/cjs/toolbar/widgets/keybindings.js +8 -5
- package/dist/cjs/toolbar/widgets/layout/DropdownLayoutManager.d.ts +21 -0
- package/dist/cjs/toolbar/widgets/layout/DropdownLayoutManager.js +199 -0
- package/dist/cjs/toolbar/widgets/layout/EdgeToolbarLayoutManager.d.ts +14 -0
- package/dist/cjs/toolbar/widgets/layout/EdgeToolbarLayoutManager.js +60 -0
- package/dist/cjs/toolbar/widgets/layout/types.d.ts +63 -0
- package/dist/cjs/toolbar/widgets/layout/types.js +2 -0
- package/dist/cjs/toolbar/widgets/lib.d.ts +1 -1
- package/dist/cjs/toolbar/widgets/lib.js +15 -11
- package/dist/cjs/tools/BaseTool.d.ts +28 -9
- package/dist/cjs/tools/BaseTool.js +128 -51
- package/dist/cjs/tools/Eraser.d.ts +8 -1
- package/dist/cjs/tools/Eraser.js +82 -92
- package/dist/cjs/tools/FindTool.d.ts +1 -1
- package/dist/cjs/tools/FindTool.js +61 -77
- package/dist/cjs/tools/InputFilter/FunctionMapper.d.ts +12 -0
- package/dist/cjs/tools/InputFilter/FunctionMapper.js +21 -0
- package/dist/cjs/tools/InputFilter/InputMapper.d.ts +23 -0
- package/dist/cjs/tools/InputFilter/InputMapper.js +38 -0
- package/dist/cjs/tools/InputFilter/InputPipeline.d.ts +15 -0
- package/dist/cjs/tools/InputFilter/InputPipeline.js +54 -0
- package/dist/cjs/tools/InputFilter/InputStabilizer.d.ts +29 -0
- package/dist/cjs/tools/InputFilter/InputStabilizer.js +181 -0
- package/dist/cjs/tools/InputFilter/StrokeKeyboardControl.d.ts +21 -0
- package/dist/cjs/tools/InputFilter/StrokeKeyboardControl.js +84 -0
- package/dist/cjs/tools/PanZoom.d.ts +4 -2
- package/dist/cjs/tools/PanZoom.js +186 -248
- package/dist/cjs/tools/PasteHandler.d.ts +1 -1
- package/dist/cjs/tools/PasteHandler.js +49 -148
- package/dist/cjs/tools/Pen.d.ts +12 -11
- package/dist/cjs/tools/Pen.js +123 -158
- package/dist/cjs/tools/PipetteTool.d.ts +11 -2
- package/dist/cjs/tools/PipetteTool.js +51 -48
- package/dist/cjs/tools/SelectionTool/SelectAllShortcutHandler.d.ts +1 -1
- package/dist/cjs/tools/SelectionTool/SelectAllShortcutHandler.js +15 -30
- package/dist/cjs/tools/SelectionTool/Selection.d.ts +5 -5
- package/dist/cjs/tools/SelectionTool/Selection.js +308 -415
- package/dist/cjs/tools/SelectionTool/SelectionHandle.d.ts +15 -5
- package/dist/cjs/tools/SelectionTool/SelectionHandle.js +63 -37
- package/dist/cjs/tools/SelectionTool/SelectionTool.d.ts +4 -4
- package/dist/cjs/tools/SelectionTool/SelectionTool.js +164 -187
- package/dist/cjs/tools/SelectionTool/TransformMode.d.ts +1 -1
- package/dist/cjs/tools/SelectionTool/TransformMode.js +65 -66
- package/dist/cjs/tools/SoundUITool.d.ts +2 -1
- package/dist/cjs/tools/SoundUITool.js +70 -84
- package/dist/cjs/tools/TextTool.d.ts +5 -3
- package/dist/cjs/tools/TextTool.js +169 -173
- package/dist/cjs/tools/ToolController.d.ts +16 -2
- package/dist/cjs/tools/ToolController.js +124 -100
- package/dist/cjs/tools/ToolEnabledGroup.js +6 -9
- package/dist/cjs/tools/ToolSwitcherShortcut.d.ts +1 -1
- package/dist/cjs/tools/ToolSwitcherShortcut.js +16 -32
- package/dist/cjs/tools/ToolbarShortcutHandler.d.ts +1 -1
- package/dist/cjs/tools/ToolbarShortcutHandler.js +17 -33
- package/dist/cjs/tools/UndoRedoShortcut.d.ts +1 -1
- package/dist/cjs/tools/UndoRedoShortcut.js +12 -27
- package/dist/cjs/tools/keybindings.js +21 -18
- package/dist/cjs/tools/lib.js +17 -14
- package/dist/cjs/tools/localization.d.ts +2 -1
- package/dist/cjs/tools/localization.js +8 -7
- package/dist/cjs/types.d.ts +22 -80
- package/dist/cjs/types.js +8 -16
- package/dist/cjs/util/ReactiveValue.d.ts +65 -0
- package/dist/cjs/util/ReactiveValue.js +166 -0
- package/dist/cjs/util/assertions.js +5 -8
- package/dist/cjs/util/fileToBase64.js +6 -6
- package/dist/cjs/util/guessKeyCodeFromKey.d.ts +9 -0
- package/dist/cjs/util/guessKeyCodeFromKey.js +32 -0
- package/dist/cjs/util/listPrefixMatch.d.ts +6 -0
- package/dist/cjs/util/listPrefixMatch.js +17 -0
- package/dist/cjs/util/stopPropagationOfScrollingWheelEvents.d.ts +2 -0
- package/dist/cjs/util/stopPropagationOfScrollingWheelEvents.js +17 -0
- package/dist/cjs/util/untilNextAnimationFrame.js +3 -3
- package/dist/cjs/util/waitForAll.js +3 -3
- package/dist/cjs/util/waitForTimeout.js +3 -3
- package/dist/cjs/version.d.ts +4 -0
- package/dist/cjs/version.js +5 -0
- package/dist/mjs/Editor.d.ts +91 -12
- package/dist/mjs/Editor.mjs +565 -563
- package/dist/mjs/EditorImage.d.ts +5 -2
- package/dist/mjs/EditorImage.mjs +248 -291
- package/dist/mjs/EventDispatcher.mjs +17 -20
- package/dist/mjs/Pointer.d.ts +3 -1
- package/dist/mjs/Pointer.mjs +40 -44
- package/dist/mjs/SVGLoader.d.ts +7 -1
- package/dist/mjs/SVGLoader.mjs +338 -466
- package/dist/mjs/UndoRedoHistory.mjs +27 -39
- package/dist/mjs/Viewport.d.ts +1 -4
- package/dist/mjs/Viewport.mjs +139 -187
- package/dist/mjs/commands/Command.mjs +21 -49
- package/dist/mjs/commands/Duplicate.mjs +22 -41
- package/dist/mjs/commands/Erase.mjs +30 -51
- package/dist/mjs/commands/SerializableCommand.mjs +16 -34
- package/dist/mjs/commands/UnresolvedCommand.mjs +10 -29
- package/dist/mjs/commands/invertCommand.mjs +24 -49
- package/dist/mjs/commands/localization.d.ts +1 -1
- package/dist/mjs/commands/localization.mjs +10 -10
- package/dist/mjs/commands/uniteCommands.mjs +52 -85
- package/dist/mjs/components/AbstractComponent.d.ts +11 -3
- package/dist/mjs/components/AbstractComponent.mjs +135 -166
- package/dist/mjs/components/BackgroundComponent.d.ts +3 -6
- package/dist/mjs/components/BackgroundComponent.mjs +107 -136
- package/dist/mjs/components/ImageComponent.d.ts +3 -5
- package/dist/mjs/components/ImageComponent.mjs +90 -174
- package/dist/mjs/components/RestylableComponent.d.ts +1 -1
- package/dist/mjs/components/RestylableComponent.mjs +35 -53
- package/dist/mjs/components/SVGGlobalAttributesObject.d.ts +1 -3
- package/dist/mjs/components/SVGGlobalAttributesObject.mjs +29 -50
- package/dist/mjs/components/Stroke.d.ts +4 -6
- package/dist/mjs/components/Stroke.mjs +89 -119
- package/dist/mjs/components/TextComponent.d.ts +2 -4
- package/dist/mjs/components/TextComponent.mjs +180 -228
- package/dist/mjs/components/UnknownSVGObject.d.ts +1 -3
- package/dist/mjs/components/UnknownSVGObject.mjs +26 -43
- package/dist/mjs/components/builders/ArrowBuilder.d.ts +1 -1
- package/dist/mjs/components/builders/ArrowBuilder.mjs +32 -35
- package/dist/mjs/components/builders/CircleBuilder.mjs +35 -38
- package/dist/mjs/components/builders/FreehandLineBuilder.d.ts +3 -2
- package/dist/mjs/components/builders/FreehandLineBuilder.mjs +52 -69
- package/dist/mjs/components/builders/LineBuilder.d.ts +1 -1
- package/dist/mjs/components/builders/LineBuilder.mjs +30 -32
- package/dist/mjs/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +1 -1
- package/dist/mjs/components/builders/PressureSensitiveFreehandLineBuilder.mjs +103 -115
- package/dist/mjs/components/builders/RectangleBuilder.d.ts +1 -1
- package/dist/mjs/components/builders/RectangleBuilder.mjs +27 -31
- package/dist/mjs/components/builders/types.d.ts +1 -1
- package/dist/mjs/components/lib.d.ts +3 -1
- package/dist/mjs/components/lib.mjs +1 -1
- package/dist/mjs/components/localization.mjs +5 -5
- package/dist/mjs/components/util/StrokeSmoother.d.ts +1 -2
- package/dist/mjs/components/util/StrokeSmoother.mjs +63 -69
- package/dist/mjs/components/util/describeComponentList.d.ts +1 -1
- package/dist/mjs/components/util/describeComponentList.mjs +4 -5
- package/dist/mjs/dialogs/makeAboutDialog.d.ts +15 -0
- package/dist/mjs/dialogs/makeAboutDialog.mjs +52 -0
- package/dist/mjs/inputEvents.d.ts +84 -0
- package/dist/mjs/inputEvents.mjs +34 -0
- package/dist/mjs/lib.d.ts +29 -13
- package/dist/mjs/lib.mjs +30 -13
- package/dist/mjs/localization.mjs +14 -13
- package/dist/mjs/localizations/de.mjs +116 -12
- package/dist/mjs/localizations/en.mjs +3 -12
- package/dist/mjs/localizations/es.mjs +61 -22
- package/dist/mjs/localizations/getLocalizationTable.mjs +12 -13
- package/dist/mjs/rendering/Display.d.ts +1 -2
- package/dist/mjs/rendering/Display.mjs +62 -79
- package/dist/mjs/rendering/RenderablePathSpec.d.ts +15 -0
- package/dist/mjs/rendering/RenderablePathSpec.mjs +64 -0
- package/dist/mjs/rendering/RenderingStyle.d.ts +4 -4
- package/dist/mjs/rendering/RenderingStyle.mjs +16 -26
- package/dist/mjs/rendering/TextRenderingStyle.d.ts +10 -10
- package/dist/mjs/rendering/TextRenderingStyle.mjs +12 -17
- package/dist/mjs/rendering/caching/CacheRecord.d.ts +1 -2
- package/dist/mjs/rendering/caching/CacheRecord.mjs +20 -23
- package/dist/mjs/rendering/caching/CacheRecordManager.d.ts +1 -1
- package/dist/mjs/rendering/caching/CacheRecordManager.mjs +13 -15
- package/dist/mjs/rendering/caching/RenderingCache.mjs +13 -17
- package/dist/mjs/rendering/caching/RenderingCacheNode.d.ts +1 -1
- package/dist/mjs/rendering/caching/RenderingCacheNode.mjs +94 -115
- package/dist/mjs/rendering/caching/testUtils.mjs +19 -21
- package/dist/mjs/rendering/caching/types.d.ts +3 -3
- package/dist/mjs/rendering/localization.mjs +6 -6
- package/dist/mjs/rendering/renderers/AbstractRenderer.d.ts +2 -11
- package/dist/mjs/rendering/renderers/AbstractRenderer.mjs +47 -52
- package/dist/mjs/rendering/renderers/CanvasRenderer.d.ts +3 -5
- package/dist/mjs/rendering/renderers/CanvasRenderer.mjs +84 -103
- package/dist/mjs/rendering/renderers/DummyRenderer.d.ts +1 -4
- package/dist/mjs/rendering/renderers/DummyRenderer.mjs +51 -75
- package/dist/mjs/rendering/renderers/SVGRenderer.d.ts +5 -5
- package/dist/mjs/rendering/renderers/SVGRenderer.mjs +185 -171
- package/dist/mjs/rendering/renderers/TextOnlyRenderer.d.ts +1 -3
- package/dist/mjs/rendering/renderers/TextOnlyRenderer.mjs +43 -72
- package/dist/mjs/shortcuts/KeyBinding.d.ts +5 -0
- package/dist/mjs/shortcuts/KeyBinding.mjs +94 -71
- package/dist/mjs/shortcuts/KeyboardShortcutManager.d.ts +1 -1
- package/dist/mjs/shortcuts/KeyboardShortcutManager.mjs +32 -44
- package/dist/mjs/testing/createEditor.mjs +2 -2
- package/dist/mjs/testing/getUniquePointerId.mjs +4 -5
- package/dist/mjs/testing/sendPenEvent.d.ts +2 -2
- package/dist/mjs/testing/sendPenEvent.mjs +5 -5
- package/dist/mjs/testing/sendTouchEvent.d.ts +2 -2
- package/dist/mjs/testing/sendTouchEvent.mjs +8 -16
- package/dist/mjs/toolbar/AbstractToolbar.d.ts +166 -0
- package/dist/mjs/toolbar/AbstractToolbar.mjs +405 -0
- package/dist/mjs/toolbar/DropdownToolbar.d.ts +43 -0
- package/dist/mjs/toolbar/DropdownToolbar.mjs +168 -0
- package/dist/mjs/toolbar/EdgeToolbar.d.ts +47 -0
- package/dist/mjs/toolbar/EdgeToolbar.mjs +414 -0
- package/dist/mjs/toolbar/IconProvider.d.ts +54 -30
- package/dist/mjs/toolbar/IconProvider.mjs +644 -219
- package/dist/mjs/toolbar/constants.d.ts +1 -0
- package/dist/mjs/toolbar/constants.mjs +1 -0
- package/dist/mjs/toolbar/lib.d.ts +4 -2
- package/dist/mjs/toolbar/lib.mjs +3 -1
- package/dist/mjs/toolbar/localization.d.ts +9 -2
- package/dist/mjs/toolbar/localization.mjs +27 -20
- package/dist/mjs/toolbar/types.d.ts +7 -0
- package/dist/mjs/toolbar/widgets/ActionButtonWidget.d.ts +1 -1
- package/dist/mjs/toolbar/widgets/ActionButtonWidget.mjs +19 -39
- package/dist/mjs/toolbar/widgets/BaseToolWidget.d.ts +1 -1
- package/dist/mjs/toolbar/widgets/BaseToolWidget.mjs +30 -36
- package/dist/mjs/toolbar/widgets/BaseWidget.d.ts +60 -5
- package/dist/mjs/toolbar/widgets/BaseWidget.mjs +227 -176
- package/dist/mjs/toolbar/widgets/DocumentPropertiesWidget.mjs +98 -111
- package/dist/mjs/toolbar/widgets/EraserToolWidget.d.ts +1 -3
- package/dist/mjs/toolbar/widgets/EraserToolWidget.mjs +41 -73
- package/dist/mjs/toolbar/widgets/HandToolWidget.d.ts +1 -0
- package/dist/mjs/toolbar/widgets/HandToolWidget.mjs +94 -136
- package/dist/mjs/toolbar/widgets/InsertImageWidget.d.ts +9 -7
- package/dist/mjs/toolbar/widgets/InsertImageWidget.mjs +140 -208
- package/dist/mjs/toolbar/widgets/OverflowWidget.mjs +30 -62
- package/dist/mjs/toolbar/widgets/PenToolWidget.d.ts +8 -1
- package/dist/mjs/toolbar/widgets/PenToolWidget.mjs +150 -225
- package/dist/mjs/toolbar/widgets/SelectionToolWidget.d.ts +3 -1
- package/dist/mjs/toolbar/widgets/SelectionToolWidget.mjs +97 -173
- package/dist/mjs/toolbar/widgets/TextToolWidget.mjs +59 -85
- package/dist/mjs/toolbar/widgets/components/makeColorInput.d.ts +10 -0
- package/dist/mjs/toolbar/{makeColorInput.mjs → widgets/components/makeColorInput.mjs} +53 -33
- package/dist/mjs/toolbar/widgets/components/makeFileInput.d.ts +12 -0
- package/dist/mjs/toolbar/widgets/components/makeFileInput.mjs +106 -0
- package/dist/mjs/toolbar/widgets/components/makeGridSelector.d.ts +24 -0
- package/dist/mjs/toolbar/widgets/components/makeGridSelector.mjs +122 -0
- package/dist/mjs/toolbar/widgets/components/makeSeparator.d.ts +7 -0
- package/dist/mjs/toolbar/widgets/components/makeSeparator.mjs +14 -0
- package/dist/mjs/toolbar/widgets/components/makeThicknessSlider.d.ts +8 -0
- package/dist/mjs/toolbar/widgets/components/makeThicknessSlider.mjs +45 -0
- package/dist/mjs/toolbar/widgets/keybindings.mjs +5 -5
- package/dist/mjs/toolbar/widgets/layout/DropdownLayoutManager.d.ts +21 -0
- package/dist/mjs/toolbar/widgets/layout/DropdownLayoutManager.mjs +193 -0
- package/dist/mjs/toolbar/widgets/layout/EdgeToolbarLayoutManager.d.ts +14 -0
- package/dist/mjs/toolbar/widgets/layout/EdgeToolbarLayoutManager.mjs +57 -0
- package/dist/mjs/toolbar/widgets/layout/types.d.ts +63 -0
- package/dist/mjs/toolbar/widgets/lib.d.ts +1 -1
- package/dist/mjs/toolbar/widgets/lib.mjs +1 -1
- package/dist/mjs/tools/BaseTool.d.ts +28 -9
- package/dist/mjs/tools/BaseTool.mjs +127 -50
- package/dist/mjs/tools/Eraser.d.ts +8 -1
- package/dist/mjs/tools/Eraser.mjs +72 -86
- package/dist/mjs/tools/FindTool.d.ts +1 -1
- package/dist/mjs/tools/FindTool.mjs +55 -75
- package/dist/mjs/tools/InputFilter/FunctionMapper.d.ts +12 -0
- package/dist/mjs/tools/InputFilter/FunctionMapper.mjs +15 -0
- package/dist/mjs/tools/InputFilter/InputMapper.d.ts +23 -0
- package/dist/mjs/tools/InputFilter/InputMapper.mjs +36 -0
- package/dist/mjs/tools/InputFilter/InputPipeline.d.ts +15 -0
- package/dist/mjs/tools/InputFilter/InputPipeline.mjs +49 -0
- package/dist/mjs/tools/InputFilter/InputStabilizer.d.ts +29 -0
- package/dist/mjs/tools/InputFilter/InputStabilizer.mjs +175 -0
- package/dist/mjs/tools/InputFilter/StrokeKeyboardControl.d.ts +21 -0
- package/dist/mjs/tools/InputFilter/StrokeKeyboardControl.mjs +78 -0
- package/dist/mjs/tools/PanZoom.d.ts +4 -2
- package/dist/mjs/tools/PanZoom.mjs +169 -235
- package/dist/mjs/tools/PasteHandler.d.ts +1 -1
- package/dist/mjs/tools/PasteHandler.mjs +42 -145
- package/dist/mjs/tools/Pen.d.ts +12 -11
- package/dist/mjs/tools/Pen.mjs +115 -154
- package/dist/mjs/tools/PipetteTool.d.ts +11 -2
- package/dist/mjs/tools/PipetteTool.mjs +47 -48
- package/dist/mjs/tools/SelectionTool/SelectAllShortcutHandler.d.ts +1 -1
- package/dist/mjs/tools/SelectionTool/SelectAllShortcutHandler.mjs +9 -28
- package/dist/mjs/tools/SelectionTool/Selection.d.ts +5 -5
- package/dist/mjs/tools/SelectionTool/Selection.mjs +268 -401
- package/dist/mjs/tools/SelectionTool/SelectionHandle.d.ts +15 -5
- package/dist/mjs/tools/SelectionTool/SelectionHandle.mjs +62 -37
- package/dist/mjs/tools/SelectionTool/SelectionTool.d.ts +4 -4
- package/dist/mjs/tools/SelectionTool/SelectionTool.mjs +153 -179
- package/dist/mjs/tools/SelectionTool/TransformMode.d.ts +1 -1
- package/dist/mjs/tools/SelectionTool/TransformMode.mjs +52 -59
- package/dist/mjs/tools/SoundUITool.d.ts +2 -1
- package/dist/mjs/tools/SoundUITool.mjs +66 -84
- package/dist/mjs/tools/TextTool.d.ts +5 -3
- package/dist/mjs/tools/TextTool.mjs +155 -163
- package/dist/mjs/tools/ToolController.d.ts +16 -2
- package/dist/mjs/tools/ToolController.mjs +81 -84
- package/dist/mjs/tools/ToolEnabledGroup.mjs +6 -10
- package/dist/mjs/tools/ToolSwitcherShortcut.d.ts +1 -1
- package/dist/mjs/tools/ToolSwitcherShortcut.mjs +12 -32
- package/dist/mjs/tools/ToolbarShortcutHandler.d.ts +1 -1
- package/dist/mjs/tools/ToolbarShortcutHandler.mjs +13 -33
- package/dist/mjs/tools/UndoRedoShortcut.d.ts +1 -1
- package/dist/mjs/tools/UndoRedoShortcut.mjs +7 -26
- package/dist/mjs/tools/keybindings.mjs +34 -34
- package/dist/mjs/tools/localization.d.ts +2 -1
- package/dist/mjs/tools/localization.mjs +9 -8
- package/dist/mjs/types.d.ts +22 -80
- package/dist/mjs/types.mjs +7 -15
- package/dist/mjs/util/ReactiveValue.d.ts +65 -0
- package/dist/mjs/util/ReactiveValue.mjs +161 -0
- package/dist/mjs/util/assertions.mjs +5 -8
- package/dist/mjs/util/fileToBase64.mjs +6 -6
- package/dist/mjs/util/guessKeyCodeFromKey.d.ts +9 -0
- package/dist/mjs/util/guessKeyCodeFromKey.mjs +30 -0
- package/dist/mjs/util/listPrefixMatch.d.ts +6 -0
- package/dist/mjs/util/listPrefixMatch.mjs +15 -0
- package/dist/mjs/util/stopPropagationOfScrollingWheelEvents.d.ts +2 -0
- package/dist/mjs/util/stopPropagationOfScrollingWheelEvents.mjs +15 -0
- package/dist/mjs/util/untilNextAnimationFrame.mjs +3 -3
- package/dist/mjs/util/waitForAll.mjs +3 -3
- package/dist/mjs/util/waitForTimeout.mjs +3 -3
- package/dist/mjs/version.d.ts +4 -0
- package/dist/mjs/version.mjs +3 -0
- package/dist-test/test_imports/package.json +1 -1
- package/dist-test/test_imports/test-imports.js +5 -11
- package/dist-test/test_imports/test-require.cjs +6 -11
- package/package.json +11 -22
- package/src/Coloris.css +8 -8
- package/src/Editor.loadFrom.test.ts +1 -1
- package/src/Editor.scss +148 -0
- package/src/Editor.test.ts +107 -0
- package/src/Editor.toSVG.test.ts +184 -1
- package/src/Editor.ts +325 -53
- package/src/EditorImage.test.ts +4 -7
- package/src/EditorImage.ts +10 -4
- package/src/Pointer.ts +18 -5
- package/src/SVGLoader.ts +77 -15
- package/src/UndoRedoHistory.test.ts +2 -1
- package/src/Viewport.ts +1 -4
- package/src/commands/Erase.ts +1 -0
- package/src/commands/localization.ts +1 -1
- package/src/commands/uniteCommands.test.ts +3 -3
- package/src/components/AbstractComponent.transformBy.test.ts +2 -1
- package/src/components/AbstractComponent.ts +12 -3
- package/src/components/BackgroundComponent.test.ts +1 -2
- package/src/components/BackgroundComponent.ts +3 -8
- package/src/components/ImageComponent.ts +1 -3
- package/src/components/RestylableComponent.ts +1 -1
- package/src/components/SVGGlobalAttributesObject.ts +1 -3
- package/src/components/Stroke.test.ts +4 -6
- package/src/components/Stroke.ts +5 -7
- package/src/components/TextComponent.test.ts +1 -3
- package/src/components/TextComponent.ts +1 -4
- package/src/components/UnknownSVGObject.ts +3 -3
- package/src/components/builders/ArrowBuilder.ts +1 -2
- package/src/components/builders/CircleBuilder.ts +3 -5
- package/src/components/builders/FreehandLineBuilder.test.ts +2 -3
- package/src/components/builders/FreehandLineBuilder.ts +3 -5
- package/src/components/builders/LineBuilder.ts +3 -3
- package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +3 -4
- package/src/components/builders/RectangleBuilder.ts +3 -4
- package/src/components/builders/types.ts +1 -1
- package/src/components/lib.ts +1 -1
- package/src/components/util/StrokeSmoother.ts +7 -7
- package/src/dialogs/dialogs.scss +36 -0
- package/src/dialogs/makeAboutDialog.scss +41 -0
- package/src/dialogs/makeAboutDialog.ts +82 -0
- package/src/inputEvents.ts +143 -0
- package/src/lib.ts +35 -13
- package/src/localizations/de.ts +2 -2
- package/src/localizations/es.ts +5 -5
- package/src/rendering/Display.ts +1 -2
- package/src/rendering/RenderablePathSpec.ts +88 -0
- package/src/rendering/RenderingStyle.test.ts +1 -1
- package/src/rendering/RenderingStyle.ts +1 -1
- package/src/rendering/caching/CacheRecord.test.ts +1 -2
- package/src/rendering/caching/CacheRecord.ts +1 -2
- package/src/rendering/caching/CacheRecordManager.ts +1 -1
- package/src/rendering/caching/RenderingCache.test.ts +3 -4
- package/src/rendering/caching/RenderingCache.ts +1 -1
- package/src/rendering/caching/RenderingCacheNode.ts +1 -2
- package/src/rendering/caching/testUtils.ts +1 -1
- package/src/rendering/caching/types.ts +3 -3
- package/src/rendering/renderers/AbstractRenderer.ts +4 -14
- package/src/rendering/renderers/CanvasRenderer.ts +17 -12
- package/src/rendering/renderers/DummyRenderer.test.ts +1 -2
- package/src/rendering/renderers/DummyRenderer.ts +1 -4
- package/src/rendering/renderers/SVGRenderer.ts +68 -11
- package/src/rendering/renderers/TextOnlyRenderer.ts +1 -4
- package/src/shortcuts/KeyBinding.test.ts +10 -0
- package/src/shortcuts/KeyBinding.ts +74 -35
- package/src/shortcuts/KeyboardShortcutManager.test.ts +1 -1
- package/src/styles.js +1 -1
- package/src/testing/sendPenEvent.ts +2 -2
- package/src/testing/sendTouchEvent.ts +2 -2
- package/src/toolbar/{toolbar.css → AbstractToolbar.scss} +47 -85
- package/src/toolbar/AbstractToolbar.ts +542 -0
- package/src/toolbar/DropdownToolbar.scss +46 -0
- package/src/toolbar/DropdownToolbar.ts +220 -0
- package/src/toolbar/EdgeToolbar.scss +511 -0
- package/src/toolbar/EdgeToolbar.test.ts +54 -0
- package/src/toolbar/EdgeToolbar.ts +543 -0
- package/src/toolbar/IconProvider.ts +189 -133
- package/src/toolbar/constants.ts +1 -0
- package/src/toolbar/lib.ts +4 -2
- package/src/toolbar/localization.ts +39 -17
- package/src/toolbar/toolbar.scss +11 -0
- package/src/toolbar/types.ts +8 -0
- package/src/toolbar/widgets/ActionButtonWidget.ts +2 -2
- package/src/toolbar/widgets/BaseToolWidget.ts +17 -1
- package/src/toolbar/widgets/BaseWidget.ts +179 -112
- package/src/toolbar/widgets/DocumentPropertiesWidget.scss +7 -0
- package/src/toolbar/widgets/DocumentPropertiesWidget.ts +26 -10
- package/src/toolbar/widgets/EraserToolWidget.ts +21 -22
- package/src/toolbar/widgets/HandToolWidget.scss +14 -0
- package/src/toolbar/widgets/HandToolWidget.ts +21 -32
- package/src/toolbar/widgets/InsertImageWidget.scss +41 -0
- package/src/toolbar/widgets/InsertImageWidget.ts +90 -65
- package/src/toolbar/widgets/PenToolWidget.css +0 -51
- package/src/toolbar/widgets/PenToolWidget.ts +106 -146
- package/src/toolbar/widgets/SelectionToolWidget.scss +6 -0
- package/src/toolbar/widgets/SelectionToolWidget.ts +83 -85
- package/src/toolbar/widgets/TextToolWidget.ts +9 -5
- package/src/toolbar/widgets/components/components.scss +5 -0
- package/src/toolbar/widgets/components/makeColorInput.scss +82 -0
- package/src/toolbar/{makeColorInput.ts → widgets/components/makeColorInput.ts} +39 -14
- package/src/toolbar/widgets/components/makeFileInput.scss +77 -0
- package/src/toolbar/widgets/components/makeFileInput.ts +128 -0
- package/src/toolbar/widgets/components/makeGridSelector.scss +60 -0
- package/src/toolbar/widgets/components/makeGridSelector.ts +179 -0
- package/src/toolbar/widgets/components/makeSeparator.scss +14 -0
- package/src/toolbar/widgets/components/makeSeparator.ts +17 -0
- package/src/toolbar/widgets/components/makeThicknessSlider.scss +9 -0
- package/src/toolbar/widgets/components/makeThicknessSlider.ts +62 -0
- package/src/toolbar/widgets/keybindings.ts +1 -3
- package/src/toolbar/widgets/layout/DropdownLayoutManager.ts +262 -0
- package/src/toolbar/widgets/layout/EdgeToolbarLayoutManager.ts +71 -0
- package/src/toolbar/widgets/layout/types.ts +74 -0
- package/src/toolbar/widgets/lib.ts +2 -2
- package/src/tools/BaseTool.ts +102 -30
- package/src/tools/Eraser.test.ts +2 -2
- package/src/tools/Eraser.ts +24 -11
- package/src/tools/FindTool.css +3 -3
- package/src/tools/FindTool.test.ts +67 -0
- package/src/tools/FindTool.ts +3 -3
- package/src/tools/InputFilter/FunctionMapper.ts +17 -0
- package/src/tools/InputFilter/InputMapper.ts +41 -0
- package/src/tools/InputFilter/InputPipeline.test.ts +41 -0
- package/src/tools/InputFilter/InputPipeline.ts +34 -0
- package/src/tools/InputFilter/InputStabilizer.ts +254 -0
- package/src/tools/InputFilter/StrokeKeyboardControl.ts +104 -0
- package/src/tools/PanZoom.test.ts +3 -13
- package/src/tools/PanZoom.ts +33 -10
- package/src/tools/PasteHandler.ts +2 -3
- package/src/tools/Pen.test.ts +2 -4
- package/src/tools/Pen.ts +54 -70
- package/src/tools/PipetteTool.ts +31 -2
- package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +1 -1
- package/src/tools/SelectionTool/Selection.ts +52 -16
- package/src/tools/SelectionTool/SelectionHandle.ts +46 -12
- package/src/tools/SelectionTool/SelectionTool.css +23 -11
- package/src/tools/SelectionTool/SelectionTool.test.ts +130 -21
- package/src/tools/SelectionTool/SelectionTool.ts +62 -48
- package/src/tools/SelectionTool/TransformMode.ts +1 -3
- package/src/tools/SoundUITool.ts +13 -4
- package/src/tools/TextTool.ts +29 -30
- package/src/tools/ToolController.ts +60 -36
- package/src/tools/ToolSwitcherShortcut.ts +1 -1
- package/src/tools/ToolbarShortcutHandler.ts +1 -1
- package/src/tools/UndoRedoShortcut.test.ts +10 -4
- package/src/tools/UndoRedoShortcut.ts +1 -1
- package/src/tools/keybindings.ts +17 -17
- package/src/tools/localization.ts +4 -2
- package/src/tools/tools.scss +4 -0
- package/src/types.ts +25 -113
- package/src/util/ReactiveValue.test.ts +168 -0
- package/src/util/ReactiveValue.ts +241 -0
- package/src/util/guessKeyCodeFromKey.ts +36 -0
- package/src/util/listPrefixMatch.ts +19 -0
- package/src/util/stopPropagationOfScrollingWheelEvents.ts +20 -0
- package/src/version.test.ts +12 -0
- package/src/version.ts +3 -0
- package/tsconfig.json +1 -1
- package/typedoc.json +4 -0
- package/dist/cjs/Color4.d.ts +0 -69
- package/dist/cjs/Color4.js +0 -263
- package/dist/cjs/math/Mat33.d.ts +0 -123
- package/dist/cjs/math/Mat33.js +0 -340
- package/dist/cjs/math/Vec2.d.ts +0 -33
- package/dist/cjs/math/Vec2.js +0 -37
- package/dist/cjs/math/Vec3.d.ts +0 -106
- package/dist/cjs/math/Vec3.js +0 -183
- package/dist/cjs/math/lib.d.ts +0 -7
- package/dist/cjs/math/lib.js +0 -15
- package/dist/cjs/math/polynomial/solveQuadratic.d.ts +0 -9
- package/dist/cjs/math/polynomial/solveQuadratic.js +0 -39
- package/dist/cjs/math/rounding.d.ts +0 -4
- package/dist/cjs/math/rounding.js +0 -140
- package/dist/cjs/math/shapes/Abstract2DShape.d.ts +0 -49
- package/dist/cjs/math/shapes/Abstract2DShape.js +0 -42
- package/dist/cjs/math/shapes/BezierJSWrapper.d.ts +0 -36
- package/dist/cjs/math/shapes/BezierJSWrapper.js +0 -109
- package/dist/cjs/math/shapes/CubicBezier.d.ts +0 -17
- package/dist/cjs/math/shapes/CubicBezier.js +0 -50
- package/dist/cjs/math/shapes/LineSegment2.d.ts +0 -70
- package/dist/cjs/math/shapes/LineSegment2.js +0 -204
- package/dist/cjs/math/shapes/Path.d.ts +0 -93
- package/dist/cjs/math/shapes/Path.js +0 -865
- package/dist/cjs/math/shapes/PointShape2D.d.ts +0 -18
- package/dist/cjs/math/shapes/PointShape2D.js +0 -46
- package/dist/cjs/math/shapes/QuadraticBezier.d.ts +0 -34
- package/dist/cjs/math/shapes/QuadraticBezier.js +0 -133
- package/dist/cjs/math/shapes/Rect2.d.ts +0 -57
- package/dist/cjs/math/shapes/Rect2.js +0 -311
- package/dist/cjs/math/shapes/Triangle.d.ts +0 -46
- package/dist/cjs/math/shapes/Triangle.js +0 -148
- package/dist/cjs/toolbar/HTMLToolbar.d.ts +0 -105
- package/dist/cjs/toolbar/HTMLToolbar.js +0 -465
- package/dist/cjs/toolbar/makeColorInput.d.ts +0 -6
- package/dist/mjs/Color4.d.ts +0 -69
- package/dist/mjs/Color4.mjs +0 -260
- package/dist/mjs/Color4.test.d.ts +0 -1
- package/dist/mjs/math/Mat33.d.ts +0 -123
- package/dist/mjs/math/Mat33.mjs +0 -338
- package/dist/mjs/math/Mat33.test.d.ts +0 -1
- package/dist/mjs/math/Vec2.d.ts +0 -33
- package/dist/mjs/math/Vec2.mjs +0 -34
- package/dist/mjs/math/Vec2.test.d.ts +0 -1
- package/dist/mjs/math/Vec3.d.ts +0 -106
- package/dist/mjs/math/Vec3.mjs +0 -181
- package/dist/mjs/math/Vec3.test.d.ts +0 -1
- package/dist/mjs/math/lib.d.ts +0 -7
- package/dist/mjs/math/lib.mjs +0 -7
- package/dist/mjs/math/polynomial/solveQuadratic.d.ts +0 -9
- package/dist/mjs/math/polynomial/solveQuadratic.mjs +0 -37
- package/dist/mjs/math/polynomial/solveQuadratic.test.d.ts +0 -1
- package/dist/mjs/math/rounding.d.ts +0 -4
- package/dist/mjs/math/rounding.mjs +0 -133
- package/dist/mjs/math/rounding.test.d.ts +0 -1
- package/dist/mjs/math/shapes/Abstract2DShape.d.ts +0 -49
- package/dist/mjs/math/shapes/Abstract2DShape.mjs +0 -40
- package/dist/mjs/math/shapes/BezierJSWrapper.d.ts +0 -36
- package/dist/mjs/math/shapes/BezierJSWrapper.mjs +0 -107
- package/dist/mjs/math/shapes/CubicBezier.d.ts +0 -17
- package/dist/mjs/math/shapes/CubicBezier.mjs +0 -48
- package/dist/mjs/math/shapes/LineSegment2.d.ts +0 -70
- package/dist/mjs/math/shapes/LineSegment2.mjs +0 -202
- package/dist/mjs/math/shapes/LineSegment2.test.d.ts +0 -1
- package/dist/mjs/math/shapes/Path.d.ts +0 -93
- package/dist/mjs/math/shapes/Path.fromString.test.d.ts +0 -1
- package/dist/mjs/math/shapes/Path.mjs +0 -862
- package/dist/mjs/math/shapes/Path.test.d.ts +0 -1
- package/dist/mjs/math/shapes/Path.toString.test.d.ts +0 -1
- package/dist/mjs/math/shapes/PointShape2D.d.ts +0 -18
- package/dist/mjs/math/shapes/PointShape2D.mjs +0 -44
- package/dist/mjs/math/shapes/QuadraticBezier.d.ts +0 -34
- package/dist/mjs/math/shapes/QuadraticBezier.mjs +0 -131
- package/dist/mjs/math/shapes/QuadraticBezier.test.d.ts +0 -1
- package/dist/mjs/math/shapes/Rect2.d.ts +0 -57
- package/dist/mjs/math/shapes/Rect2.mjs +0 -309
- package/dist/mjs/math/shapes/Rect2.test.d.ts +0 -1
- package/dist/mjs/math/shapes/Triangle.d.ts +0 -46
- package/dist/mjs/math/shapes/Triangle.mjs +0 -146
- package/dist/mjs/math/shapes/Triangle.test.d.ts +0 -1
- package/dist/mjs/toolbar/HTMLToolbar.d.ts +0 -105
- package/dist/mjs/toolbar/HTMLToolbar.mjs +0 -462
- package/dist/mjs/toolbar/makeColorInput.d.ts +0 -6
- package/src/Color4.test.ts +0 -47
- package/src/Color4.ts +0 -304
- package/src/Editor.css +0 -98
- package/src/math/Mat33.test.ts +0 -244
- package/src/math/Mat33.ts +0 -442
- package/src/math/Vec2.test.ts +0 -30
- package/src/math/Vec2.ts +0 -40
- package/src/math/Vec3.test.ts +0 -44
- package/src/math/Vec3.ts +0 -218
- package/src/math/lib.ts +0 -15
- package/src/math/polynomial/solveQuadratic.test.ts +0 -39
- package/src/math/polynomial/solveQuadratic.ts +0 -43
- package/src/math/rounding.test.ts +0 -65
- package/src/math/rounding.ts +0 -156
- package/src/math/shapes/Abstract2DShape.ts +0 -63
- package/src/math/shapes/BezierJSWrapper.ts +0 -93
- package/src/math/shapes/CubicBezier.ts +0 -35
- package/src/math/shapes/LineSegment2.test.ts +0 -99
- package/src/math/shapes/LineSegment2.ts +0 -231
- package/src/math/shapes/Path.fromString.test.ts +0 -223
- package/src/math/shapes/Path.test.ts +0 -309
- package/src/math/shapes/Path.toString.test.ts +0 -77
- package/src/math/shapes/Path.ts +0 -1027
- package/src/math/shapes/PointShape2D.ts +0 -33
- package/src/math/shapes/QuadraticBezier.test.ts +0 -31
- package/src/math/shapes/QuadraticBezier.ts +0 -141
- package/src/math/shapes/Rect2.test.ts +0 -209
- package/src/math/shapes/Rect2.ts +0 -344
- package/src/math/shapes/Triangle.test.ts +0 -61
- package/src/math/shapes/Triangle.ts +0 -139
- package/src/toolbar/HTMLToolbar.ts +0 -567
- package/src/toolbar/widgets/InsertImageWidget.css +0 -44
- package/src/tools/tools.css +0 -4
- /package/dist/cjs/{Color4.test.d.ts → Editor.test.d.ts} +0 -0
- /package/dist/cjs/{math/Mat33.test.d.ts → toolbar/EdgeToolbar.test.d.ts} +0 -0
- /package/dist/cjs/{math/Vec2.test.d.ts → tools/FindTool.test.d.ts} +0 -0
- /package/dist/cjs/{math/Vec3.test.d.ts → tools/InputFilter/InputPipeline.test.d.ts} +0 -0
- /package/dist/cjs/{math/polynomial/solveQuadratic.test.d.ts → util/ReactiveValue.test.d.ts} +0 -0
- /package/dist/cjs/{math/rounding.test.d.ts → version.test.d.ts} +0 -0
- /package/dist/{cjs/math/shapes/LineSegment2.test.d.ts → mjs/Editor.test.d.ts} +0 -0
- /package/dist/{cjs/math/shapes/Path.fromString.test.d.ts → mjs/toolbar/EdgeToolbar.test.d.ts} +0 -0
- /package/dist/{cjs/math/shapes/Path.test.d.ts → mjs/toolbar/widgets/layout/types.mjs} +0 -0
- /package/dist/{cjs/math/shapes/Path.toString.test.d.ts → mjs/tools/FindTool.test.d.ts} +0 -0
- /package/dist/{cjs/math/shapes/QuadraticBezier.test.d.ts → mjs/tools/InputFilter/InputPipeline.test.d.ts} +0 -0
- /package/dist/{cjs/math/shapes/Rect2.test.d.ts → mjs/util/ReactiveValue.test.d.ts} +0 -0
- /package/dist/{cjs/math/shapes/Triangle.test.d.ts → mjs/version.test.d.ts} +0 -0
@@ -1,23 +1,35 @@
|
|
1
1
|
|
2
2
|
.selection-tool-selection-background {
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
3
|
+
background-color: var(--selection-background-color);
|
4
|
+
opacity: 0.5;
|
5
|
+
overflow: visible;
|
6
|
+
position: absolute;
|
7
7
|
}
|
8
8
|
|
9
9
|
.selection-tool-handle {
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
10
|
+
border: 1px solid var(--foreground-color-1);
|
11
|
+
background: var(--background-color-1);
|
12
|
+
position: absolute;
|
13
|
+
cursor: grab;
|
14
14
|
}
|
15
15
|
|
16
16
|
.selection-tool-handle.selection-tool-circle {
|
17
|
-
|
17
|
+
border-radius: 100%;
|
18
18
|
}
|
19
19
|
|
20
20
|
.overlay.handleOverlay {
|
21
|
-
|
22
|
-
|
21
|
+
height: 0;
|
22
|
+
overflow: visible;
|
23
|
+
}
|
24
|
+
|
25
|
+
@keyframes selection-duplicated-animation {
|
26
|
+
0% { transform: scale(1, 1); }
|
27
|
+
50% { transform: scale(1.02, 1.02); }
|
28
|
+
100% { transform: scale(1, 1); }
|
29
|
+
}
|
30
|
+
|
31
|
+
/* Do not run the animation when the user has disabled motion animations. */
|
32
|
+
@media (prefers-reduced-motion: reduce) {
|
33
|
+
@keyframes selection-duplicated-animation {
|
34
|
+
}
|
23
35
|
}
|
@@ -1,16 +1,15 @@
|
|
1
|
-
import Color4 from '../../Color4';
|
2
1
|
import Stroke from '../../components/Stroke';
|
3
2
|
import Editor from '../../Editor';
|
4
3
|
import EditorImage from '../../EditorImage';
|
5
|
-
import
|
6
|
-
import { Vec2 } from '../../math/Vec2';
|
7
|
-
import { InputEvtType } from '../../types';
|
4
|
+
import { InputEvtType } from '../../inputEvents';
|
8
5
|
import Selection from './Selection';
|
9
6
|
import SelectionTool from './SelectionTool';
|
10
7
|
import createEditor from '../../testing/createEditor';
|
11
8
|
import Pointer from '../../Pointer';
|
12
|
-
import { Rect2 } from '
|
9
|
+
import { Rect2, Vec2, Path, Color4 } from '@js-draw/math';
|
13
10
|
import sendPenEvent from '../../testing/sendPenEvent';
|
11
|
+
import { pathToRenderable } from '../../rendering/RenderablePathSpec';
|
12
|
+
import { EditorEventType } from '../../types';
|
14
13
|
|
15
14
|
const getSelectionTool = (editor: Editor): SelectionTool => {
|
16
15
|
return editor.toolController.getMatchingTools(SelectionTool)[0];
|
@@ -19,7 +18,7 @@ const getSelectionTool = (editor: Editor): SelectionTool => {
|
|
19
18
|
const createSquareStroke = (size: number = 1) => {
|
20
19
|
const testStroke = new Stroke([
|
21
20
|
// A filled square
|
22
|
-
Path.fromString(`M0,0 L${size},0 L${size},${size} L0,${size} Z`)
|
21
|
+
pathToRenderable(Path.fromString(`M0,0 L${size},0 L${size},${size} L0,${size} Z`), { fill: Color4.blue }),
|
23
22
|
]);
|
24
23
|
const addTestStrokeCommand = EditorImage.addElement(testStroke);
|
25
24
|
|
@@ -42,9 +41,7 @@ const createEditorWithSingleObjectSelection = (objectSize: number = 50) => {
|
|
42
41
|
};
|
43
42
|
|
44
43
|
const dragSelection = (editor: Editor, selection: Selection, startPt: Vec2, endPt: Vec2) => {
|
45
|
-
|
46
|
-
|
47
|
-
selection.onDragStart(Pointer.ofCanvasPoint(startPt, true, editor.viewport), backgroundElem);
|
44
|
+
selection.onDragStart(Pointer.ofCanvasPoint(startPt, true, editor.viewport));
|
48
45
|
jest.advanceTimersByTime(100);
|
49
46
|
|
50
47
|
selection.onDragUpdate(Pointer.ofCanvasPoint(endPt, true, editor.viewport));
|
@@ -143,13 +140,13 @@ describe('SelectionTool', () => {
|
|
143
140
|
editor.sendKeyboardEvent(InputEvtType.KeyUpEvent, 'Shift');
|
144
141
|
|
145
142
|
// Select the larger stroke without shift pressed
|
146
|
-
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(
|
147
|
-
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(
|
143
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(600, 600));
|
144
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(200, 200));
|
148
145
|
expect(selectionTool.getSelectedObjects()).toHaveLength(1);
|
149
146
|
|
150
147
|
// Select nothing
|
151
|
-
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(
|
152
|
-
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(
|
148
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(2000, 200));
|
149
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(2001, 201));
|
153
150
|
expect(selectionTool.getSelectedObjects()).toHaveLength(0);
|
154
151
|
});
|
155
152
|
|
@@ -157,8 +154,7 @@ describe('SelectionTool', () => {
|
|
157
154
|
const { editor, selectionTool } = createEditorWithSingleObjectSelection(50);
|
158
155
|
|
159
156
|
const selection = selectionTool.getSelection()!;
|
160
|
-
|
161
|
-
selection.onDragStart(Pointer.ofCanvasPoint(Vec2.of(0, 0), true, editor.viewport), backgroundElem);
|
157
|
+
selection.onDragStart(Pointer.ofCanvasPoint(Vec2.of(0, 0), true, editor.viewport));
|
162
158
|
jest.advanceTimersByTime(100);
|
163
159
|
selection.onDragUpdate(Pointer.ofCanvasPoint(Vec2.of(20, 0), true, editor.viewport));
|
164
160
|
jest.advanceTimersByTime(100);
|
@@ -197,15 +193,64 @@ describe('SelectionTool', () => {
|
|
197
193
|
expect(testStroke.getBBox().topLeft).objEq(Vec2.of(10, 0));
|
198
194
|
});
|
199
195
|
|
196
|
+
it('rotation handle should rotate the selection', () => {
|
197
|
+
const { addTestStrokeCommand: strokeCommand } = createSquareStroke(50);
|
198
|
+
|
199
|
+
const editor = createEditor();
|
200
|
+
editor.dispatch(strokeCommand);
|
201
|
+
|
202
|
+
// Select the first stroke
|
203
|
+
const selectionTool = getSelectionTool(editor);
|
204
|
+
selectionTool.setEnabled(true);
|
205
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(40, 40));
|
206
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(100, 100));
|
207
|
+
|
208
|
+
// Drag the rotate handle, which should be located halfway across
|
209
|
+
// the top of the selection box
|
210
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(25, 0));
|
211
|
+
sendPenEvent(editor, InputEvtType.PointerMoveEvt, Vec2.of(30, 0));
|
212
|
+
sendPenEvent(editor, InputEvtType.PointerMoveEvt, Vec2.of(0, 25));
|
213
|
+
|
214
|
+
// Rotate 45 degrees:
|
215
|
+
// Drag start (resize circle)
|
216
|
+
// ↓
|
217
|
+
// .---o---x ← y=0, drag end
|
218
|
+
// | |
|
219
|
+
// | |
|
220
|
+
// | |
|
221
|
+
// .-------.
|
222
|
+
sendPenEvent(editor, InputEvtType.PointerMoveEvt, Vec2.of(50, 0));
|
223
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(50, 0));
|
224
|
+
|
225
|
+
expect(selectionTool.getSelectedObjects()).toHaveLength(1);
|
226
|
+
|
227
|
+
// Deselect & add the item back to the editor
|
228
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(1250, 0));
|
229
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(1250, 0));
|
230
|
+
|
231
|
+
expect(selectionTool.getSelectedObjects()).toHaveLength(0);
|
232
|
+
|
233
|
+
const imageStrokes = editor.image.getAllElements();
|
234
|
+
expect(imageStrokes).toHaveLength(1);
|
235
|
+
|
236
|
+
const transformedStroke = imageStrokes[0] as Stroke;
|
237
|
+
const strokePoints = transformedStroke.getPath().polylineApproximation().map(line => line.p1);
|
238
|
+
|
239
|
+
// One point should now be just above the center of the square:
|
240
|
+
// . ←
|
241
|
+
// . .
|
242
|
+
// .
|
243
|
+
//
|
244
|
+
expect(strokePoints.filter(point => point.eq(Vec2.of(Math.hypot(25, 0), 0)))).toHaveLength(1);
|
245
|
+
});
|
246
|
+
|
200
247
|
it('dragCancel should return a selection to its original position', () => {
|
201
248
|
const { editor, selectionTool, testStroke } = createEditorWithSingleObjectSelection(150);
|
202
249
|
|
203
250
|
const selection = selectionTool.getSelection()!;
|
204
|
-
const dragBackground = selection.getBackgroundElem();
|
205
|
-
|
206
251
|
expect(testStroke.getBBox().topLeft).objEq(Vec2.zero);
|
207
252
|
|
208
|
-
selection.onDragStart(Pointer.ofCanvasPoint(Vec2.of(10, 0), true, editor.viewport)
|
253
|
+
selection.onDragStart(Pointer.ofCanvasPoint(Vec2.of(10, 0), true, editor.viewport));
|
209
254
|
jest.advanceTimersByTime(100);
|
210
255
|
selection.onDragUpdate(Pointer.ofCanvasPoint(Vec2.of(200, 10), true, editor.viewport));
|
211
256
|
jest.advanceTimersByTime(100);
|
@@ -219,9 +264,7 @@ describe('SelectionTool', () => {
|
|
219
264
|
const { editor, selectionTool, testStroke } = createEditorWithSingleObjectSelection(150);
|
220
265
|
|
221
266
|
const selection = selectionTool.getSelection()!;
|
222
|
-
|
223
|
-
|
224
|
-
selection.onDragStart(Pointer.ofCanvasPoint(Vec2.of(0, 0), true, editor.viewport), dragBackground);
|
267
|
+
selection.onDragStart(Pointer.ofCanvasPoint(Vec2.of(0, 0), true, editor.viewport));
|
225
268
|
jest.advanceTimersByTime(100);
|
226
269
|
selection.onDragUpdate(Pointer.ofCanvasPoint(Vec2.of(20, 0), true, editor.viewport));
|
227
270
|
|
@@ -258,4 +301,70 @@ describe('SelectionTool', () => {
|
|
258
301
|
expect(editor.image.findParent(testStroke)).not.toBeNull();
|
259
302
|
expect(testStroke.getBBox()).objEq(new Rect2(30, 10, 150, 150));
|
260
303
|
});
|
304
|
+
|
305
|
+
it('should only fire the SelectionChanged event if the selection changed', () => {
|
306
|
+
const { editor, selectionTool, testStroke } = createEditorWithSingleObjectSelection(150);
|
307
|
+
|
308
|
+
selectionTool.clearSelection();
|
309
|
+
|
310
|
+
const updatedListener = jest.fn();
|
311
|
+
editor.notifier.on(EditorEventType.SelectionUpdated, updatedListener);
|
312
|
+
|
313
|
+
expect(updatedListener).toHaveBeenCalledTimes(0);
|
314
|
+
|
315
|
+
selectionTool.setEnabled(true);
|
316
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(0, 0));
|
317
|
+
sendPenEvent(editor, InputEvtType.PointerMoveEvt, Vec2.of(10, 10));
|
318
|
+
|
319
|
+
// Should not be notified until the selection ends
|
320
|
+
expect(updatedListener).toHaveBeenCalledTimes(0);
|
321
|
+
|
322
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(5, 5));
|
323
|
+
|
324
|
+
expect(updatedListener).toHaveBeenCalledTimes(1);
|
325
|
+
expect(updatedListener).toHaveBeenLastCalledWith({
|
326
|
+
kind: EditorEventType.SelectionUpdated,
|
327
|
+
tool: selectionTool,
|
328
|
+
selectedComponents: [ testStroke ]
|
329
|
+
});
|
330
|
+
|
331
|
+
// Selecting the same content should not re-fire the listener
|
332
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(0, 0));
|
333
|
+
sendPenEvent(editor, InputEvtType.PointerMoveEvt, Vec2.of(10, 10));
|
334
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(5, 5));
|
335
|
+
|
336
|
+
expect(updatedListener).toHaveBeenCalledTimes(1);
|
337
|
+
|
338
|
+
// ...but selecting a different item should.
|
339
|
+
const secondStroke = createSquareStroke(3000); // Large to ensure that we don't drag the selection instead.
|
340
|
+
editor.dispatch(secondStroke.addTestStrokeCommand);
|
341
|
+
|
342
|
+
expect(updatedListener).toHaveBeenCalledTimes(1);
|
343
|
+
|
344
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(2999, 2999));
|
345
|
+
sendPenEvent(editor, InputEvtType.PointerMoveEvt, Vec2.of(3001, 3001));
|
346
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(3002, 3002));
|
347
|
+
|
348
|
+
expect(updatedListener).toHaveBeenCalledTimes(2);
|
349
|
+
expect(updatedListener).toHaveBeenLastCalledWith({
|
350
|
+
kind: EditorEventType.SelectionUpdated,
|
351
|
+
tool: selectionTool,
|
352
|
+
selectedComponents: [ secondStroke.testStroke ],
|
353
|
+
});
|
354
|
+
});
|
355
|
+
|
356
|
+
it('should remove the selection box after ending an empty selection', () => {
|
357
|
+
const { editor, selectionTool } = createEditorWithSingleObjectSelection(150);
|
358
|
+
|
359
|
+
// Should have a selection when objects are selected
|
360
|
+
expect(selectionTool.getSelection()).not.toBe(null);
|
361
|
+
|
362
|
+
// Select nothing
|
363
|
+
sendPenEvent(editor, InputEvtType.PointerDownEvt, Vec2.of(2999, 2999));
|
364
|
+
sendPenEvent(editor, InputEvtType.PointerMoveEvt, Vec2.of(3001, 3001));
|
365
|
+
sendPenEvent(editor, InputEvtType.PointerUpEvt, Vec2.of(3002, 3002));
|
366
|
+
|
367
|
+
// Should not have a selection after setting the selection to contain no objects
|
368
|
+
expect(selectionTool.getSelection()).toBe(null);
|
369
|
+
});
|
261
370
|
});
|
@@ -1,9 +1,8 @@
|
|
1
1
|
import AbstractComponent from '../../components/AbstractComponent';
|
2
2
|
import Editor from '../../Editor';
|
3
|
-
import Mat33 from '
|
4
|
-
import
|
5
|
-
import {
|
6
|
-
import { CopyEvent, EditorEventType, KeyPressEvent, KeyUpEvent, PointerEvt } from '../../types';
|
3
|
+
import { Mat33, Rect2, Point2, Vec2 } from '@js-draw/math';
|
4
|
+
import { EditorEventType } from '../../types';
|
5
|
+
import { CopyEvent, KeyPressEvent, KeyUpEvent, PointerEvt } from '../../inputEvents';
|
7
6
|
import Viewport from '../../Viewport';
|
8
7
|
import BaseTool from '../BaseTool';
|
9
8
|
import SVGRenderer from '../../rendering/renderers/SVGRenderer';
|
@@ -17,11 +16,10 @@ export const cssPrefix = 'selection-tool-';
|
|
17
16
|
// With respect to `extend`ing, `SelectionTool` is not stable.
|
18
17
|
export default class SelectionTool extends BaseTool {
|
19
18
|
private handleOverlay: HTMLElement;
|
20
|
-
private prevSelectionBox: Selection|null;
|
21
|
-
private selectionBox: Selection|null;
|
22
|
-
private lastEvtTarget: EventTarget|null = null;
|
19
|
+
private prevSelectionBox: Selection | null;
|
20
|
+
private selectionBox: Selection | null;
|
23
21
|
|
24
|
-
private startPoint: Vec2|null = null; // canvas position
|
22
|
+
private startPoint: Vec2 | null = null; // canvas position
|
25
23
|
private expandingSelectionBox: boolean = false;
|
26
24
|
private shiftKeyPressed: boolean = false;
|
27
25
|
private snapToGrid: boolean = false;
|
@@ -44,12 +42,7 @@ export default class SelectionTool extends BaseTool {
|
|
44
42
|
});
|
45
43
|
|
46
44
|
this.editor.handleKeyEventsFrom(this.handleOverlay);
|
47
|
-
this.editor.handlePointerEventsFrom(this.handleOverlay
|
48
|
-
if (eventName === 'pointerdown') {
|
49
|
-
this.lastEvtTarget = htmlEvent.target;
|
50
|
-
}
|
51
|
-
return true;
|
52
|
-
});
|
45
|
+
this.editor.handlePointerEventsFrom(this.handleOverlay);
|
53
46
|
}
|
54
47
|
|
55
48
|
private makeSelectionBox(selectionStartPos: Point2) {
|
@@ -90,12 +83,12 @@ export default class SelectionTool extends BaseTool {
|
|
90
83
|
|
91
84
|
let transforming = false;
|
92
85
|
|
93
|
-
if (this.
|
86
|
+
if (this.selectionBox) {
|
94
87
|
if (snapToGrid) {
|
95
88
|
this.snapSelectionToGrid();
|
96
89
|
}
|
97
90
|
|
98
|
-
const dragStartResult = this.selectionBox.onDragStart(current
|
91
|
+
const dragStartResult = this.selectionBox.onDragStart(current);
|
99
92
|
|
100
93
|
if (dragStartResult) {
|
101
94
|
transforming = true;
|
@@ -136,30 +129,8 @@ export default class SelectionTool extends BaseTool {
|
|
136
129
|
}
|
137
130
|
}
|
138
131
|
|
139
|
-
private onSelectionUpdated() {
|
140
|
-
// Note that the selection has changed
|
141
|
-
this.editor.notifier.dispatch(EditorEventType.ToolUpdated, {
|
142
|
-
kind: EditorEventType.ToolUpdated,
|
143
|
-
tool: this,
|
144
|
-
});
|
145
|
-
|
146
|
-
const selectedItemCount = this.selectionBox?.getSelectedItemCount() ?? 0;
|
147
|
-
if (selectedItemCount > 0) {
|
148
|
-
this.editor.announceForAccessibility(
|
149
|
-
this.editor.localization.selectedElements(selectedItemCount)
|
150
|
-
);
|
151
|
-
this.zoomToSelection();
|
152
|
-
} else if (this.selectionBox) {
|
153
|
-
this.selectionBox.cancelSelection();
|
154
|
-
this.prevSelectionBox = this.selectionBox;
|
155
|
-
this.selectionBox = null;
|
156
|
-
}
|
157
|
-
}
|
158
|
-
|
159
132
|
// Called after a gestureCancel and a pointerUp
|
160
133
|
private onGestureEnd() {
|
161
|
-
this.lastEvtTarget = null;
|
162
|
-
|
163
134
|
if (!this.selectionBox) return;
|
164
135
|
|
165
136
|
if (!this.selectionBoxHandlingEvt) {
|
@@ -174,13 +145,6 @@ export default class SelectionTool extends BaseTool {
|
|
174
145
|
this.selectionBoxHandlingEvt = false;
|
175
146
|
}
|
176
147
|
|
177
|
-
private zoomToSelection() {
|
178
|
-
if (this.selectionBox) {
|
179
|
-
const selectionRect = this.selectionBox.region;
|
180
|
-
this.editor.dispatchNoAnnounce(this.editor.viewport.zoomTo(selectionRect, false), false);
|
181
|
-
}
|
182
|
-
}
|
183
|
-
|
184
148
|
public override onPointerUp(event: PointerEvt): void {
|
185
149
|
if (!this.selectionBox) return;
|
186
150
|
|
@@ -220,6 +184,53 @@ export default class SelectionTool extends BaseTool {
|
|
220
184
|
this.expandingSelectionBox = false;
|
221
185
|
}
|
222
186
|
|
187
|
+
private lastSelectedObjects: AbstractComponent[] = [];
|
188
|
+
|
189
|
+
private onSelectionUpdated() {
|
190
|
+
const selectedItemCount = this.selectionBox?.getSelectedItemCount() ?? 0;
|
191
|
+
const selectedObjects = this.selectionBox?.getSelectedObjects() ?? [];
|
192
|
+
const hasDifferentSelection =
|
193
|
+
this.lastSelectedObjects.length !== selectedItemCount
|
194
|
+
|| selectedObjects.some((obj, i) => this.lastSelectedObjects[i] !== obj);
|
195
|
+
|
196
|
+
if (hasDifferentSelection) {
|
197
|
+
this.lastSelectedObjects = selectedObjects;
|
198
|
+
|
199
|
+
// Note that the selection has changed
|
200
|
+
this.editor.notifier.dispatch(EditorEventType.ToolUpdated, {
|
201
|
+
kind: EditorEventType.ToolUpdated,
|
202
|
+
tool: this,
|
203
|
+
});
|
204
|
+
|
205
|
+
// Only fire the SelectionUpdated event if the selection really updated.
|
206
|
+
this.editor.notifier.dispatch(EditorEventType.SelectionUpdated, {
|
207
|
+
kind: EditorEventType.SelectionUpdated,
|
208
|
+
selectedComponents: selectedObjects,
|
209
|
+
tool: this,
|
210
|
+
});
|
211
|
+
|
212
|
+
if (selectedItemCount > 0) {
|
213
|
+
this.editor.announceForAccessibility(
|
214
|
+
this.editor.localization.selectedElements(selectedItemCount)
|
215
|
+
);
|
216
|
+
this.zoomToSelection();
|
217
|
+
}
|
218
|
+
}
|
219
|
+
|
220
|
+
if (selectedItemCount === 0 && this.selectionBox) {
|
221
|
+
this.selectionBox.cancelSelection();
|
222
|
+
this.prevSelectionBox = this.selectionBox;
|
223
|
+
this.selectionBox = null;
|
224
|
+
}
|
225
|
+
}
|
226
|
+
|
227
|
+
private zoomToSelection() {
|
228
|
+
if (this.selectionBox) {
|
229
|
+
const selectionRect = this.selectionBox.region;
|
230
|
+
this.editor.dispatchNoAnnounce(this.editor.viewport.zoomTo(selectionRect, false), false);
|
231
|
+
}
|
232
|
+
}
|
233
|
+
|
223
234
|
private static handleableKeys = [
|
224
235
|
'a', 'h', 'ArrowLeft',
|
225
236
|
'd', 'l', 'ArrowRight',
|
@@ -393,7 +404,7 @@ export default class SelectionTool extends BaseTool {
|
|
393
404
|
return false;
|
394
405
|
}
|
395
406
|
|
396
|
-
const exportViewport = new Viewport(() => {});
|
407
|
+
const exportViewport = new Viewport(() => { });
|
397
408
|
exportViewport.updateScreenSize(Vec2.of(bbox.w, bbox.h));
|
398
409
|
exportViewport.resetTransform(Mat33.translation(bbox.topLeft.times(-1)));
|
399
410
|
|
@@ -421,6 +432,9 @@ export default class SelectionTool extends BaseTool {
|
|
421
432
|
super.setEnabled(enabled);
|
422
433
|
|
423
434
|
// Clear the selection
|
435
|
+
this.selectionBox?.cancelSelection();
|
436
|
+
this.onSelectionUpdated();
|
437
|
+
|
424
438
|
this.handleOverlay.replaceChildren();
|
425
439
|
this.selectionBox = null;
|
426
440
|
|
@@ -439,7 +453,7 @@ export default class SelectionTool extends BaseTool {
|
|
439
453
|
|
440
454
|
// Get the object responsible for displaying this' selection.
|
441
455
|
// @internal
|
442
|
-
public getSelection(): Selection|null {
|
456
|
+
public getSelection(): Selection | null {
|
443
457
|
return this.selectionBox;
|
444
458
|
}
|
445
459
|
|
@@ -464,7 +478,7 @@ export default class SelectionTool extends BaseTool {
|
|
464
478
|
return true;
|
465
479
|
});
|
466
480
|
|
467
|
-
let bbox: Rect2|null = null;
|
481
|
+
let bbox: Rect2 | null = null;
|
468
482
|
for (const object of objects) {
|
469
483
|
if (bbox) {
|
470
484
|
bbox = bbox.union(object.getBBox());
|
@@ -1,7 +1,5 @@
|
|
1
1
|
import Editor from '../../Editor';
|
2
|
-
import Mat33 from '
|
3
|
-
import { Point2, Vec2 } from '../../math/Vec2';
|
4
|
-
import Vec3 from '../../math/Vec3';
|
2
|
+
import { Vec3, Mat33, Vec2, Point2 } from '@js-draw/math';
|
5
3
|
import Viewport from '../../Viewport';
|
6
4
|
import Selection from './Selection';
|
7
5
|
import { ResizeMode } from './types';
|
package/src/tools/SoundUITool.ts
CHANGED
@@ -1,8 +1,6 @@
|
|
1
|
-
import Color4 from '../Color4';
|
2
1
|
import Editor from '../Editor';
|
3
|
-
import LineSegment2 from '
|
4
|
-
import {
|
5
|
-
import { PointerEvt } from '../types';
|
2
|
+
import { LineSegment2, Color4, Point2 } from '@js-draw/math';
|
3
|
+
import { KeyPressEvent, PointerEvt } from '../inputEvents';
|
6
4
|
import BaseTool from './BaseTool';
|
7
5
|
|
8
6
|
class SoundFeedback {
|
@@ -162,11 +160,22 @@ export default class SoundUITool extends BaseTool {
|
|
162
160
|
if (!enabled) {
|
163
161
|
this.soundFeedback?.close();
|
164
162
|
this.soundFeedback = null;
|
163
|
+
} else {
|
164
|
+
this.editor.announceForAccessibility(this.editor.localization.soundExplorerUsageAnnouncement);
|
165
165
|
}
|
166
166
|
|
167
167
|
this.updateToggleButtonText();
|
168
168
|
}
|
169
169
|
|
170
|
+
public override onKeyPress(event: KeyPressEvent): boolean {
|
171
|
+
if (event.code === 'Escape') {
|
172
|
+
this.setEnabled(false);
|
173
|
+
return true;
|
174
|
+
}
|
175
|
+
|
176
|
+
return false;
|
177
|
+
}
|
178
|
+
|
170
179
|
private lastPointerPos: Point2;
|
171
180
|
|
172
181
|
public override onPointerDown({ current, allPointers }: PointerEvt): boolean {
|
package/src/tools/TextTool.ts
CHANGED
@@ -1,20 +1,22 @@
|
|
1
|
-
import Color4 from '../Color4';
|
2
1
|
import TextComponent from '../components/TextComponent';
|
3
2
|
import Editor from '../Editor';
|
4
3
|
import EditorImage from '../EditorImage';
|
5
|
-
import Rect2 from '
|
6
|
-
import Mat33 from '../math/Mat33';
|
7
|
-
import { Vec2 } from '../math/Vec2';
|
4
|
+
import { Rect2, Mat33, Vec2, Color4 } from '@js-draw/math';
|
8
5
|
import { PointerDevice } from '../Pointer';
|
9
|
-
import { EditorEventType
|
6
|
+
import { EditorEventType } from '../types';
|
7
|
+
import { PointerEvt } from '../inputEvents';
|
10
8
|
import BaseTool from './BaseTool';
|
11
9
|
import { ToolLocalization } from './localization';
|
12
10
|
import Erase from '../commands/Erase';
|
13
11
|
import uniteCommands from '../commands/uniteCommands';
|
14
12
|
import TextRenderingStyle from '../rendering/TextRenderingStyle';
|
13
|
+
import { MutableReactiveValue, ReactiveValue } from '../util/ReactiveValue';
|
15
14
|
|
16
15
|
const overlayCSSClass = 'textEditorOverlay';
|
17
16
|
export default class TextTool extends BaseTool {
|
17
|
+
private textStyleValue: MutableReactiveValue<TextRenderingStyle>;
|
18
|
+
|
19
|
+
// A reference to the current value of `textStyleValue`.
|
18
20
|
private textStyle: TextRenderingStyle;
|
19
21
|
|
20
22
|
private textEditOverlay: HTMLElement;
|
@@ -28,13 +30,22 @@ export default class TextTool extends BaseTool {
|
|
28
30
|
|
29
31
|
public constructor(private editor: Editor, description: string, private localizationTable: ToolLocalization) {
|
30
32
|
super(editor.notifier, description);
|
31
|
-
this.
|
33
|
+
this.textStyleValue = ReactiveValue.fromInitialValue({
|
32
34
|
size: 32,
|
33
35
|
fontFamily: 'sans-serif',
|
34
36
|
renderingStyle: {
|
35
37
|
fill: Color4.purple,
|
36
38
|
},
|
37
|
-
};
|
39
|
+
});
|
40
|
+
this.textStyleValue.onUpdateAndNow(() => {
|
41
|
+
this.textStyle = this.textStyleValue.get();
|
42
|
+
|
43
|
+
this.updateTextInput();
|
44
|
+
this.editor.notifier.dispatch(EditorEventType.ToolUpdated, {
|
45
|
+
kind: EditorEventType.ToolUpdated,
|
46
|
+
tool: this,
|
47
|
+
});
|
48
|
+
});
|
38
49
|
|
39
50
|
this.textEditOverlay = document.createElement('div');
|
40
51
|
this.textEditOverlay.classList.add(overlayCSSClass);
|
@@ -284,47 +295,33 @@ export default class TextTool extends BaseTool {
|
|
284
295
|
this.editor.focus();
|
285
296
|
}
|
286
297
|
|
287
|
-
private dispatchUpdateEvent() {
|
288
|
-
this.updateTextInput();
|
289
|
-
this.editor.notifier.dispatch(EditorEventType.ToolUpdated, {
|
290
|
-
kind: EditorEventType.ToolUpdated,
|
291
|
-
tool: this,
|
292
|
-
});
|
293
|
-
}
|
294
|
-
|
295
298
|
public setFontFamily(fontFamily: string) {
|
296
299
|
if (fontFamily !== this.textStyle.fontFamily) {
|
297
|
-
this.
|
300
|
+
this.textStyleValue.set({
|
298
301
|
...this.textStyle,
|
299
302
|
fontFamily: fontFamily,
|
300
|
-
};
|
301
|
-
|
302
|
-
this.dispatchUpdateEvent();
|
303
|
+
});
|
303
304
|
}
|
304
305
|
}
|
305
306
|
|
306
307
|
public setColor(color: Color4) {
|
307
308
|
if (!color.eq(this.textStyle.renderingStyle.fill)) {
|
308
|
-
this.
|
309
|
+
this.textStyleValue.set({
|
309
310
|
...this.textStyle,
|
310
311
|
renderingStyle: {
|
311
312
|
...this.textStyle.renderingStyle,
|
312
313
|
fill: color,
|
313
314
|
},
|
314
|
-
};
|
315
|
-
|
316
|
-
this.dispatchUpdateEvent();
|
315
|
+
});
|
317
316
|
}
|
318
317
|
}
|
319
318
|
|
320
319
|
public setFontSize(size: number) {
|
321
320
|
if (size !== this.textStyle.size) {
|
322
|
-
this.
|
321
|
+
this.textStyleValue.set({
|
323
322
|
...this.textStyle,
|
324
323
|
size,
|
325
|
-
};
|
326
|
-
|
327
|
-
this.dispatchUpdateEvent();
|
324
|
+
});
|
328
325
|
}
|
329
326
|
}
|
330
327
|
|
@@ -332,9 +329,11 @@ export default class TextTool extends BaseTool {
|
|
332
329
|
return this.textStyle;
|
333
330
|
}
|
334
331
|
|
332
|
+
public getStyleValue(): MutableReactiveValue<TextRenderingStyle> {
|
333
|
+
return this.textStyleValue;
|
334
|
+
}
|
335
|
+
|
335
336
|
private setTextStyle(style: TextRenderingStyle) {
|
336
|
-
|
337
|
-
this.textStyle = { ...style, renderingStyle: { ...style.renderingStyle } };
|
338
|
-
this.dispatchUpdateEvent();
|
337
|
+
this.textStyleValue.set(style);
|
339
338
|
}
|
340
339
|
}
|