js-draw 0.25.1 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +60 -20
- 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/package.json +11 -22
- package/src/Coloris.css +8 -8
- package/src/Editor.scss +148 -0
- package/src/dialogs/dialogs.scss +36 -0
- package/src/dialogs/makeAboutDialog.scss +41 -0
- package/src/styles.js +1 -1
- package/src/toolbar/{toolbar.css → AbstractToolbar.scss} +47 -85
- package/src/toolbar/DropdownToolbar.scss +46 -0
- package/src/toolbar/EdgeToolbar.scss +511 -0
- package/src/toolbar/toolbar.scss +11 -0
- package/src/toolbar/widgets/DocumentPropertiesWidget.scss +7 -0
- package/src/toolbar/widgets/HandToolWidget.scss +14 -0
- package/src/toolbar/widgets/InsertImageWidget.scss +41 -0
- package/src/toolbar/widgets/PenToolWidget.css +0 -51
- package/src/toolbar/widgets/SelectionToolWidget.scss +6 -0
- package/src/toolbar/widgets/components/components.scss +5 -0
- package/src/toolbar/widgets/components/makeColorInput.scss +82 -0
- package/src/toolbar/widgets/components/makeFileInput.scss +77 -0
- package/src/toolbar/widgets/components/makeGridSelector.scss +60 -0
- package/src/toolbar/widgets/components/makeSeparator.scss +14 -0
- package/src/toolbar/widgets/components/makeThicknessSlider.scss +9 -0
- package/src/tools/FindTool.css +3 -3
- package/src/tools/SelectionTool/SelectionTool.css +23 -11
- package/src/tools/tools.scss +4 -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/Editor.loadFrom.test.d.ts +0 -1
- package/dist/cjs/Editor.toSVG.test.d.ts +0 -1
- package/dist/cjs/EditorImage.test.d.ts +0 -1
- package/dist/cjs/EventDispatcher.test.d.ts +0 -1
- package/dist/cjs/SVGLoader.test.d.ts +0 -1
- package/dist/cjs/UndoRedoHistory.test.d.ts +0 -1
- package/dist/cjs/commands/uniteCommands.test.d.ts +0 -1
- package/dist/cjs/components/AbstractComponent.transformBy.test.d.ts +0 -1
- package/dist/cjs/components/BackgroundComponent.test.d.ts +0 -1
- package/dist/cjs/components/Stroke.test.d.ts +0 -1
- package/dist/cjs/components/TextComponent.test.d.ts +0 -1
- package/dist/cjs/components/UnknownSVGObject.test.d.ts +0 -1
- package/dist/cjs/components/builders/FreehandLineBuilder.test.d.ts +0 -1
- package/dist/cjs/localizations/getLocalizationTable.test.d.ts +0 -1
- package/dist/cjs/math/Mat33.d.ts +0 -123
- package/dist/cjs/math/Mat33.js +0 -340
- package/dist/cjs/math/Mat33.test.d.ts +0 -1
- package/dist/cjs/math/Vec2.d.ts +0 -33
- package/dist/cjs/math/Vec2.js +0 -37
- package/dist/cjs/math/Vec2.test.d.ts +0 -1
- package/dist/cjs/math/Vec3.d.ts +0 -106
- package/dist/cjs/math/Vec3.js +0 -183
- package/dist/cjs/math/Vec3.test.d.ts +0 -1
- 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/polynomial/solveQuadratic.test.d.ts +0 -1
- package/dist/cjs/math/rounding.d.ts +0 -4
- package/dist/cjs/math/rounding.js +0 -140
- package/dist/cjs/math/rounding.test.d.ts +0 -1
- 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/LineSegment2.test.d.ts +0 -1
- package/dist/cjs/math/shapes/Path.d.ts +0 -93
- package/dist/cjs/math/shapes/Path.fromString.test.d.ts +0 -1
- package/dist/cjs/math/shapes/Path.js +0 -865
- package/dist/cjs/math/shapes/Path.test.d.ts +0 -1
- package/dist/cjs/math/shapes/Path.toString.test.d.ts +0 -1
- 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/QuadraticBezier.test.d.ts +0 -1
- package/dist/cjs/math/shapes/Rect2.d.ts +0 -57
- package/dist/cjs/math/shapes/Rect2.js +0 -311
- package/dist/cjs/math/shapes/Rect2.test.d.ts +0 -1
- package/dist/cjs/math/shapes/Triangle.d.ts +0 -46
- package/dist/cjs/math/shapes/Triangle.js +0 -148
- package/dist/cjs/math/shapes/Triangle.test.d.ts +0 -1
- package/dist/cjs/rendering/RenderingStyle.test.d.ts +0 -1
- package/dist/cjs/rendering/caching/CacheRecord.test.d.ts +0 -1
- package/dist/cjs/rendering/caching/RenderingCache.test.d.ts +0 -1
- package/dist/cjs/rendering/renderers/DummyRenderer.test.d.ts +0 -1
- package/dist/cjs/rendering/renderers/TextOnlyRenderer.test.d.ts +0 -1
- package/dist/cjs/shortcuts/KeyBinding.test.d.ts +0 -1
- package/dist/cjs/shortcuts/KeyboardShortcutManager.test.d.ts +0 -1
- 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/cjs/tools/Eraser.test.d.ts +0 -1
- package/dist/cjs/tools/PanZoom.test.d.ts +0 -1
- package/dist/cjs/tools/Pen.test.d.ts +0 -1
- package/dist/cjs/tools/SelectionTool/SelectionTool.test.d.ts +0 -1
- package/dist/cjs/tools/UndoRedoShortcut.test.d.ts +0 -1
- 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/Editor.loadFrom.test.d.ts +0 -1
- package/dist/mjs/Editor.toSVG.test.d.ts +0 -1
- package/dist/mjs/EditorImage.test.d.ts +0 -1
- package/dist/mjs/EventDispatcher.test.d.ts +0 -1
- package/dist/mjs/SVGLoader.test.d.ts +0 -1
- package/dist/mjs/UndoRedoHistory.test.d.ts +0 -1
- package/dist/mjs/commands/uniteCommands.test.d.ts +0 -1
- package/dist/mjs/components/AbstractComponent.transformBy.test.d.ts +0 -1
- package/dist/mjs/components/BackgroundComponent.test.d.ts +0 -1
- package/dist/mjs/components/Stroke.test.d.ts +0 -1
- package/dist/mjs/components/TextComponent.test.d.ts +0 -1
- package/dist/mjs/components/UnknownSVGObject.test.d.ts +0 -1
- package/dist/mjs/components/builders/FreehandLineBuilder.test.d.ts +0 -1
- package/dist/mjs/localizations/getLocalizationTable.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/rendering/RenderingStyle.test.d.ts +0 -1
- package/dist/mjs/rendering/caching/CacheRecord.test.d.ts +0 -1
- package/dist/mjs/rendering/caching/RenderingCache.test.d.ts +0 -1
- package/dist/mjs/rendering/renderers/DummyRenderer.test.d.ts +0 -1
- package/dist/mjs/rendering/renderers/TextOnlyRenderer.test.d.ts +0 -1
- package/dist/mjs/shortcuts/KeyBinding.test.d.ts +0 -1
- package/dist/mjs/shortcuts/KeyboardShortcutManager.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/dist/mjs/tools/Eraser.test.d.ts +0 -1
- package/dist/mjs/tools/PanZoom.test.d.ts +0 -1
- package/dist/mjs/tools/Pen.test.d.ts +0 -1
- package/dist/mjs/tools/SelectionTool/SelectionTool.test.d.ts +0 -1
- package/dist/mjs/tools/UndoRedoShortcut.test.d.ts +0 -1
- package/dist-test/test_imports/package-lock.json +0 -13
- package/dist-test/test_imports/package.json +0 -12
- package/dist-test/test_imports/test-imports.js +0 -17
- package/dist-test/test_imports/test-require.cjs +0 -19
- package/src/Color4.test.ts +0 -47
- package/src/Color4.ts +0 -304
- package/src/Editor.css +0 -98
- package/src/Editor.loadFrom.test.ts +0 -24
- package/src/Editor.toSVG.test.ts +0 -111
- package/src/Editor.ts +0 -1171
- package/src/EditorImage.test.ts +0 -120
- package/src/EditorImage.ts +0 -603
- package/src/EventDispatcher.test.ts +0 -123
- package/src/EventDispatcher.ts +0 -72
- package/src/Pointer.ts +0 -170
- package/src/SVGLoader.test.ts +0 -114
- package/src/SVGLoader.ts +0 -610
- package/src/UndoRedoHistory.test.ts +0 -33
- package/src/UndoRedoHistory.ts +0 -102
- package/src/Viewport.ts +0 -325
- package/src/bundle/bundled.ts +0 -7
- package/src/commands/Command.ts +0 -45
- package/src/commands/Duplicate.ts +0 -75
- package/src/commands/Erase.ts +0 -94
- package/src/commands/SerializableCommand.ts +0 -49
- package/src/commands/UnresolvedCommand.ts +0 -37
- package/src/commands/invertCommand.ts +0 -58
- package/src/commands/lib.ts +0 -16
- package/src/commands/localization.ts +0 -47
- package/src/commands/uniteCommands.test.ts +0 -23
- package/src/commands/uniteCommands.ts +0 -140
- package/src/components/AbstractComponent.transformBy.test.ts +0 -22
- package/src/components/AbstractComponent.ts +0 -374
- package/src/components/BackgroundComponent.test.ts +0 -45
- package/src/components/BackgroundComponent.ts +0 -353
- package/src/components/ImageComponent.ts +0 -178
- package/src/components/RestylableComponent.ts +0 -161
- package/src/components/SVGGlobalAttributesObject.ts +0 -81
- package/src/components/Stroke.test.ts +0 -139
- package/src/components/Stroke.ts +0 -296
- package/src/components/TextComponent.test.ts +0 -204
- package/src/components/TextComponent.ts +0 -432
- package/src/components/UnknownSVGObject.test.ts +0 -10
- package/src/components/UnknownSVGObject.ts +0 -60
- package/src/components/builders/ArrowBuilder.ts +0 -107
- package/src/components/builders/CircleBuilder.ts +0 -102
- package/src/components/builders/FreehandLineBuilder.test.ts +0 -25
- package/src/components/builders/FreehandLineBuilder.ts +0 -212
- package/src/components/builders/LineBuilder.ts +0 -77
- package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +0 -454
- package/src/components/builders/RectangleBuilder.ts +0 -74
- package/src/components/builders/types.ts +0 -15
- package/src/components/lib.ts +0 -31
- package/src/components/localization.ts +0 -24
- package/src/components/util/StrokeSmoother.ts +0 -302
- package/src/components/util/describeComponentList.ts +0 -18
- package/src/lib.ts +0 -69
- package/src/localization.ts +0 -34
- package/src/localizations/de.ts +0 -146
- package/src/localizations/en.ts +0 -8
- package/src/localizations/es.ts +0 -74
- package/src/localizations/getLocalizationTable.test.ts +0 -27
- package/src/localizations/getLocalizationTable.ts +0 -74
- 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/rendering/Display.ts +0 -248
- package/src/rendering/RenderingStyle.test.ts +0 -68
- package/src/rendering/RenderingStyle.ts +0 -55
- package/src/rendering/TextRenderingStyle.ts +0 -55
- package/src/rendering/caching/CacheRecord.test.ts +0 -49
- package/src/rendering/caching/CacheRecord.ts +0 -77
- package/src/rendering/caching/CacheRecordManager.ts +0 -71
- package/src/rendering/caching/RenderingCache.test.ts +0 -44
- package/src/rendering/caching/RenderingCache.ts +0 -66
- package/src/rendering/caching/RenderingCacheNode.ts +0 -405
- package/src/rendering/caching/testUtils.ts +0 -35
- package/src/rendering/caching/types.ts +0 -34
- package/src/rendering/lib.ts +0 -8
- package/src/rendering/localization.ts +0 -20
- package/src/rendering/renderers/AbstractRenderer.ts +0 -242
- package/src/rendering/renderers/CanvasRenderer.ts +0 -307
- package/src/rendering/renderers/DummyRenderer.test.ts +0 -42
- package/src/rendering/renderers/DummyRenderer.ts +0 -145
- package/src/rendering/renderers/SVGRenderer.ts +0 -377
- package/src/rendering/renderers/TextOnlyRenderer.test.ts +0 -34
- package/src/rendering/renderers/TextOnlyRenderer.ts +0 -71
- package/src/shortcuts/KeyBinding.test.ts +0 -51
- package/src/shortcuts/KeyBinding.ts +0 -218
- package/src/shortcuts/KeyboardShortcutManager.test.ts +0 -95
- package/src/shortcuts/KeyboardShortcutManager.ts +0 -163
- package/src/shortcuts/lib.ts +0 -3
- package/src/testing/createEditor.ts +0 -11
- package/src/testing/getUniquePointerId.ts +0 -18
- package/src/testing/lib.ts +0 -3
- package/src/testing/sendPenEvent.ts +0 -36
- package/src/testing/sendTouchEvent.ts +0 -71
- package/src/toolbar/HTMLToolbar.ts +0 -567
- package/src/toolbar/IconProvider.ts +0 -805
- package/src/toolbar/lib.ts +0 -4
- package/src/toolbar/localization.ts +0 -114
- package/src/toolbar/makeColorInput.ts +0 -159
- package/src/toolbar/types.ts +0 -5
- package/src/toolbar/widgets/ActionButtonWidget.ts +0 -39
- package/src/toolbar/widgets/BaseToolWidget.ts +0 -65
- package/src/toolbar/widgets/BaseWidget.ts +0 -428
- package/src/toolbar/widgets/DocumentPropertiesWidget.ts +0 -234
- package/src/toolbar/widgets/EraserToolWidget.ts +0 -85
- package/src/toolbar/widgets/HandToolWidget.ts +0 -250
- package/src/toolbar/widgets/InsertImageWidget.css +0 -44
- package/src/toolbar/widgets/InsertImageWidget.ts +0 -223
- package/src/toolbar/widgets/OverflowWidget.ts +0 -92
- package/src/toolbar/widgets/PenToolWidget.ts +0 -409
- package/src/toolbar/widgets/SelectionToolWidget.ts +0 -197
- package/src/toolbar/widgets/TextToolWidget.ts +0 -145
- package/src/toolbar/widgets/keybindings.ts +0 -21
- package/src/toolbar/widgets/lib.ts +0 -13
- package/src/tools/BaseTool.ts +0 -97
- package/src/tools/Eraser.test.ts +0 -103
- package/src/tools/Eraser.ts +0 -160
- package/src/tools/FindTool.ts +0 -153
- package/src/tools/PanZoom.test.ts +0 -349
- package/src/tools/PanZoom.ts +0 -502
- package/src/tools/PasteHandler.ts +0 -95
- package/src/tools/Pen.test.ts +0 -262
- package/src/tools/Pen.ts +0 -300
- package/src/tools/PipetteTool.ts +0 -55
- package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +0 -29
- package/src/tools/SelectionTool/Selection.ts +0 -611
- package/src/tools/SelectionTool/SelectionHandle.ts +0 -108
- package/src/tools/SelectionTool/SelectionTool.test.ts +0 -261
- package/src/tools/SelectionTool/SelectionTool.ts +0 -496
- package/src/tools/SelectionTool/TransformMode.ts +0 -114
- package/src/tools/SelectionTool/types.ts +0 -11
- package/src/tools/SoundUITool.ts +0 -212
- package/src/tools/TextTool.ts +0 -340
- package/src/tools/ToolController.ts +0 -200
- package/src/tools/ToolEnabledGroup.ts +0 -14
- package/src/tools/ToolSwitcherShortcut.ts +0 -39
- package/src/tools/ToolbarShortcutHandler.ts +0 -39
- package/src/tools/UndoRedoShortcut.test.ts +0 -56
- package/src/tools/UndoRedoShortcut.ts +0 -24
- package/src/tools/keybindings.ts +0 -85
- package/src/tools/lib.ts +0 -22
- package/src/tools/localization.ts +0 -74
- package/src/tools/tools.css +0 -4
- package/src/types.ts +0 -239
- package/src/util/assertions.ts +0 -55
- package/src/util/fileToBase64.ts +0 -18
- package/src/util/untilNextAnimationFrame.ts +0 -9
- package/src/util/waitForAll.ts +0 -18
- package/src/util/waitForTimeout.ts +0 -9
- /package/dist/{cjs/Color4.test.d.ts → mjs/toolbar/widgets/layout/types.mjs} +0 -0
@@ -1,14 +1,5 @@
|
|
1
|
-
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
2
|
-
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
3
|
-
if (ar || !(i in from)) {
|
4
|
-
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
5
|
-
ar[i] = from[i];
|
6
|
-
}
|
7
|
-
}
|
8
|
-
return to.concat(ar || Array.prototype.slice.call(from));
|
9
|
-
};
|
10
1
|
import Pointer, { PointerDevice } from '../Pointer.mjs';
|
11
|
-
import { InputEvtType } from '../
|
2
|
+
import { InputEvtType } from '../inputEvents.mjs';
|
12
3
|
import getUniquePointerId from './getUniquePointerId.mjs';
|
13
4
|
/**
|
14
5
|
* Dispatch a touch event to the currently selected tool. Intended for unit tests.
|
@@ -46,17 +37,18 @@ import getUniquePointerId from './getUniquePointerId.mjs';
|
|
46
37
|
* }
|
47
38
|
* ```
|
48
39
|
*/
|
49
|
-
|
50
|
-
|
40
|
+
const sendTouchEvent = (editor, eventType, screenPos, allOtherPointers) => {
|
41
|
+
const canvasPos = editor.viewport.screenToCanvas(screenPos);
|
51
42
|
// Get a unique ID for the main pointer
|
52
43
|
// (try to use id=0, but don't use it if it's already in use).
|
53
|
-
|
54
|
-
|
44
|
+
const ptrId = getUniquePointerId(allOtherPointers ?? []);
|
45
|
+
const mainPointer = Pointer.ofCanvasPoint(canvasPos, eventType !== InputEvtType.PointerUpEvt, editor.viewport, ptrId, PointerDevice.Touch);
|
55
46
|
editor.toolController.dispatchInputEvent({
|
56
47
|
kind: eventType,
|
57
|
-
allPointers:
|
48
|
+
allPointers: [
|
49
|
+
...(allOtherPointers ?? []),
|
58
50
|
mainPointer,
|
59
|
-
],
|
51
|
+
],
|
60
52
|
current: mainPointer,
|
61
53
|
});
|
62
54
|
return mainPointer;
|
@@ -0,0 +1,166 @@
|
|
1
|
+
import Editor from '../Editor';
|
2
|
+
import { ToolbarLocalization } from './localization';
|
3
|
+
import { ActionButtonIcon } from './types';
|
4
|
+
import BaseWidget, { ToolbarWidgetTag } from './widgets/BaseWidget';
|
5
|
+
import { DispatcherEventListener } from '../EventDispatcher';
|
6
|
+
export interface SpacerOptions {
|
7
|
+
grow: number;
|
8
|
+
minSize: string;
|
9
|
+
maxSize: string;
|
10
|
+
}
|
11
|
+
export default abstract class AbstractToolbar {
|
12
|
+
#private;
|
13
|
+
protected editor: Editor;
|
14
|
+
protected localizationTable: ToolbarLocalization;
|
15
|
+
private static colorisStarted;
|
16
|
+
/** @internal */
|
17
|
+
constructor(editor: Editor, localizationTable?: ToolbarLocalization);
|
18
|
+
private closeColorPickerOverlay;
|
19
|
+
private setupCloseColorPickerOverlay;
|
20
|
+
setupColorPickers(): void;
|
21
|
+
protected closeColorPickers(): void;
|
22
|
+
protected getWidgetUniqueId(widget: BaseWidget): string;
|
23
|
+
protected getWidgetFromId(id: string): BaseWidget | undefined;
|
24
|
+
/** Do **not** modify the return value. */
|
25
|
+
protected getAllWidgets(): Array<BaseWidget>;
|
26
|
+
/**
|
27
|
+
* Adds a spacer.
|
28
|
+
*
|
29
|
+
* **Toolbars can choose to ignore calls to `addSpacer`**.
|
30
|
+
*
|
31
|
+
* @example
|
32
|
+
* Adding a save button that moves to the very right edge of the toolbar
|
33
|
+
* while keeping the other buttons centered:
|
34
|
+
* ```ts
|
35
|
+
* const toolbar = editor.addToolbar(false);
|
36
|
+
*
|
37
|
+
* toolbar.addSpacer({ grow: 1 });
|
38
|
+
* toolbar.addDefaults();
|
39
|
+
* toolbar.addSpacer({ grow: 1 });
|
40
|
+
*
|
41
|
+
* toolbar.addActionButton({
|
42
|
+
* label: 'Save',
|
43
|
+
* icon: editor.icons.makeSaveIcon(),
|
44
|
+
* }, () => {
|
45
|
+
* saveCallback();
|
46
|
+
* });
|
47
|
+
* ```
|
48
|
+
*/
|
49
|
+
abstract addSpacer(options?: Partial<SpacerOptions>): void;
|
50
|
+
/**
|
51
|
+
* Adds an `ActionButtonWidget` or `BaseToolWidget`. The widget should not have already have a parent
|
52
|
+
* (i.e. its `addTo` method should not have been called).
|
53
|
+
*
|
54
|
+
* @example
|
55
|
+
* ```ts
|
56
|
+
* const toolbar = editor.addToolbar();
|
57
|
+
* const insertImageWidget = new InsertImageWidget(editor);
|
58
|
+
* toolbar.addWidget(insertImageWidget);
|
59
|
+
* ```
|
60
|
+
*/
|
61
|
+
addWidget(widget: BaseWidget): void;
|
62
|
+
/** Called by `addWidget`. Implement this to add a new widget to the toolbar. */
|
63
|
+
protected abstract addWidgetInternal(widget: BaseWidget): void;
|
64
|
+
/** Removes the given `widget` from this toolbar. */
|
65
|
+
removeWidget(widget: BaseWidget): void;
|
66
|
+
/** Called by `removeWidget`. Implement this to remove a new widget from the toolbar. */
|
67
|
+
protected abstract removeWidgetInternal(widget: BaseWidget): void;
|
68
|
+
private static rootToolbarId;
|
69
|
+
/** Returns a snapshot of the state of widgets in the toolbar. */
|
70
|
+
serializeState(): string;
|
71
|
+
/**
|
72
|
+
* Deserialize toolbar widgets from the given state.
|
73
|
+
* Assumes that toolbar widgets are in the same order as when state was serialized.
|
74
|
+
*/
|
75
|
+
deserializeState(state: string): void;
|
76
|
+
/**
|
77
|
+
* Called by `serializeState` to attach any additional JSONifyable data
|
78
|
+
* to the serialized result.
|
79
|
+
*
|
80
|
+
* @reutrns an object that can be converted to JSON with `JSON.stringify`.
|
81
|
+
*/
|
82
|
+
protected serializeInternal(): any;
|
83
|
+
/**
|
84
|
+
* Called by `deserializeState` with a version of the JSON outputted
|
85
|
+
* previously by `serializeInternal`.
|
86
|
+
*/
|
87
|
+
protected deserializeInternal(_json: any): void;
|
88
|
+
/**
|
89
|
+
* Creates, but does not add, an action button to this container.
|
90
|
+
*
|
91
|
+
* @see
|
92
|
+
* {@link addActionButton}
|
93
|
+
*/
|
94
|
+
protected makeActionButton(title: string | ActionButtonIcon, command: () => void, mustBeToplevel?: boolean): BaseWidget;
|
95
|
+
/**
|
96
|
+
* Adds an action button with `title` to this toolbar (or to the given `parent` element).
|
97
|
+
*
|
98
|
+
* @return The added button.
|
99
|
+
*/
|
100
|
+
addActionButton(title: string | ActionButtonIcon, command: () => void, mustBeToplevel?: boolean): BaseWidget;
|
101
|
+
/**
|
102
|
+
* Like {@link addActionButton}, except associates `tags` with the button that allow
|
103
|
+
* different toolbar styles to give the button tag-dependent styles.
|
104
|
+
*/
|
105
|
+
addTaggedActionButton(tags: (ToolbarWidgetTag | string)[], title: string | ActionButtonIcon, command: () => void, mustBeToplevel?: boolean): BaseWidget;
|
106
|
+
/**
|
107
|
+
* Adds a save button that, when clicked, calls `saveCallback`.
|
108
|
+
*
|
109
|
+
* **Note**: This is equivalent to
|
110
|
+
* ```ts
|
111
|
+
* const tags = [
|
112
|
+
* ToolbarWidgetTag.Save,
|
113
|
+
* ];
|
114
|
+
* toolbar.addTaggedActionButton(tags, {
|
115
|
+
* label: editor.localization.save,
|
116
|
+
* icon: editor.icons.makeSaveIcon(),
|
117
|
+
* }, () => {
|
118
|
+
* saveCallback();
|
119
|
+
* });
|
120
|
+
* ```
|
121
|
+
*
|
122
|
+
* @final
|
123
|
+
*/
|
124
|
+
addSaveButton(saveCallback: () => void): BaseWidget;
|
125
|
+
/**
|
126
|
+
* Adds an "Exit" button that, when clicked, calls `exitCallback`.
|
127
|
+
*
|
128
|
+
* **Note**: This is equivalent to
|
129
|
+
* ```ts
|
130
|
+
* toolbar.addTaggedActionButton([ ToolbarWidgetTag.Exit ], {
|
131
|
+
* label: this.editor.localization.exit,
|
132
|
+
* icon: this.editor.icons.makeCloseIcon(),
|
133
|
+
* }, () => {
|
134
|
+
* exitCallback();
|
135
|
+
* });
|
136
|
+
* ```
|
137
|
+
*
|
138
|
+
* @final
|
139
|
+
*/
|
140
|
+
addExitButton(exitCallback: () => void): BaseWidget;
|
141
|
+
/**
|
142
|
+
* Adds undo and redo buttons that trigger the editor's built-in undo and redo
|
143
|
+
* functionality.
|
144
|
+
*/
|
145
|
+
addUndoRedoButtons(undoFirst?: boolean): void;
|
146
|
+
/**
|
147
|
+
* Adds toolbar widgets based on the enabled tools.
|
148
|
+
*/
|
149
|
+
addDefaultToolWidgets(): void;
|
150
|
+
addDefaultActionButtons(): void;
|
151
|
+
/**
|
152
|
+
* Adds both the default tool widgets and action buttons.
|
153
|
+
*/
|
154
|
+
abstract addDefaults(): void;
|
155
|
+
/** Remove this toolbar from its container and clean up listeners. */
|
156
|
+
remove(): void;
|
157
|
+
/**
|
158
|
+
* Removes `listener` when {@link remove} is called.
|
159
|
+
*/
|
160
|
+
protected manageListener(listener: DispatcherEventListener): void;
|
161
|
+
/**
|
162
|
+
* Internal logic for {@link remove}. Implementers should remove the toolbar
|
163
|
+
* from its container.
|
164
|
+
*/
|
165
|
+
protected abstract onRemove(): void;
|
166
|
+
}
|
@@ -0,0 +1,405 @@
|
|
1
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
2
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
3
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
4
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
5
|
+
};
|
6
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
7
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
8
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
9
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
10
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
11
|
+
};
|
12
|
+
var _AbstractToolbar_listeners, _AbstractToolbar_widgetsById, _AbstractToolbar_widgetList, _AbstractToolbar_updateColoris;
|
13
|
+
import { EditorEventType } from '../types.mjs';
|
14
|
+
import { coloris, close as closeColoris, init as colorisInit } from '@melloware/coloris';
|
15
|
+
import { defaultToolbarLocalization } from './localization.mjs';
|
16
|
+
import SelectionTool from '../tools/SelectionTool/SelectionTool.mjs';
|
17
|
+
import PanZoomTool from '../tools/PanZoom.mjs';
|
18
|
+
import TextTool from '../tools/TextTool.mjs';
|
19
|
+
import EraserTool from '../tools/Eraser.mjs';
|
20
|
+
import PenTool from '../tools/Pen.mjs';
|
21
|
+
import PenToolWidget from './widgets/PenToolWidget.mjs';
|
22
|
+
import EraserWidget from './widgets/EraserToolWidget.mjs';
|
23
|
+
import SelectionToolWidget from './widgets/SelectionToolWidget.mjs';
|
24
|
+
import TextToolWidget from './widgets/TextToolWidget.mjs';
|
25
|
+
import HandToolWidget from './widgets/HandToolWidget.mjs';
|
26
|
+
import { ToolbarWidgetTag } from './widgets/BaseWidget.mjs';
|
27
|
+
import ActionButtonWidget from './widgets/ActionButtonWidget.mjs';
|
28
|
+
import InsertImageWidget from './widgets/InsertImageWidget.mjs';
|
29
|
+
import DocumentPropertiesWidget from './widgets/DocumentPropertiesWidget.mjs';
|
30
|
+
import { Color4 } from '@js-draw/math';
|
31
|
+
import { toolbarCSSPrefix } from './constants.mjs';
|
32
|
+
class AbstractToolbar {
|
33
|
+
/** @internal */
|
34
|
+
constructor(editor, localizationTable = defaultToolbarLocalization) {
|
35
|
+
this.editor = editor;
|
36
|
+
this.localizationTable = localizationTable;
|
37
|
+
_AbstractToolbar_listeners.set(this, []);
|
38
|
+
_AbstractToolbar_widgetsById.set(this, {});
|
39
|
+
_AbstractToolbar_widgetList.set(this, []);
|
40
|
+
_AbstractToolbar_updateColoris.set(this, null);
|
41
|
+
this.closeColorPickerOverlay = null;
|
42
|
+
if (!AbstractToolbar.colorisStarted) {
|
43
|
+
colorisInit();
|
44
|
+
AbstractToolbar.colorisStarted = true;
|
45
|
+
}
|
46
|
+
this.setupColorPickers();
|
47
|
+
}
|
48
|
+
setupCloseColorPickerOverlay() {
|
49
|
+
if (this.closeColorPickerOverlay)
|
50
|
+
return;
|
51
|
+
this.closeColorPickerOverlay = document.createElement('div');
|
52
|
+
this.closeColorPickerOverlay.className = `${toolbarCSSPrefix}closeColorPickerOverlay`;
|
53
|
+
this.editor.createHTMLOverlay(this.closeColorPickerOverlay);
|
54
|
+
// Hide the color picker when attempting to draw on the overlay.
|
55
|
+
__classPrivateFieldGet(this, _AbstractToolbar_listeners, "f").push(this.editor.handlePointerEventsExceptClicksFrom(this.closeColorPickerOverlay, (eventName) => {
|
56
|
+
if (eventName === 'pointerdown') {
|
57
|
+
closeColoris();
|
58
|
+
}
|
59
|
+
// Transfer focus to the editor to allow keyboard events to be handled.
|
60
|
+
if (eventName === 'pointerup') {
|
61
|
+
this.editor.focus();
|
62
|
+
}
|
63
|
+
// Send the event to the editor
|
64
|
+
return true;
|
65
|
+
}));
|
66
|
+
}
|
67
|
+
// @internal
|
68
|
+
setupColorPickers() {
|
69
|
+
// Much of the setup only needs to be done once.
|
70
|
+
if (__classPrivateFieldGet(this, _AbstractToolbar_updateColoris, "f")) {
|
71
|
+
__classPrivateFieldGet(this, _AbstractToolbar_updateColoris, "f").call(this);
|
72
|
+
return;
|
73
|
+
}
|
74
|
+
this.setupCloseColorPickerOverlay();
|
75
|
+
const maxSwatchLen = 12;
|
76
|
+
const swatches = [
|
77
|
+
Color4.red.toHexString(),
|
78
|
+
Color4.purple.toHexString(),
|
79
|
+
Color4.blue.toHexString(),
|
80
|
+
Color4.clay.toHexString(),
|
81
|
+
Color4.black.toHexString(),
|
82
|
+
Color4.white.toHexString(),
|
83
|
+
];
|
84
|
+
const presetColorEnd = swatches.length;
|
85
|
+
// Keeps track of whether a Coloris initialization is scheduled.
|
86
|
+
let colorisInitScheduled = false;
|
87
|
+
// (Re)init Coloris -- update the swatches list.
|
88
|
+
const initColoris = () => {
|
89
|
+
try {
|
90
|
+
coloris({
|
91
|
+
el: '.coloris_input',
|
92
|
+
format: 'hex',
|
93
|
+
selectInput: false,
|
94
|
+
focusInput: false,
|
95
|
+
themeMode: 'auto',
|
96
|
+
swatches,
|
97
|
+
});
|
98
|
+
}
|
99
|
+
catch (err) {
|
100
|
+
console.warn('Failed to initialize Coloris. Error: ', err);
|
101
|
+
// Try again --- a known issue is that Coloris fails to load if the document
|
102
|
+
// isn't ready.
|
103
|
+
if (!colorisInitScheduled) {
|
104
|
+
colorisInitScheduled = true;
|
105
|
+
// Wait to initialize after the document has loaded
|
106
|
+
document.addEventListener('load', () => {
|
107
|
+
initColoris();
|
108
|
+
}, { once: true });
|
109
|
+
}
|
110
|
+
}
|
111
|
+
};
|
112
|
+
initColoris();
|
113
|
+
__classPrivateFieldSet(this, _AbstractToolbar_updateColoris, initColoris, "f");
|
114
|
+
const addColorToSwatch = (newColor) => {
|
115
|
+
let alreadyPresent = false;
|
116
|
+
for (const color of swatches) {
|
117
|
+
if (color === newColor) {
|
118
|
+
alreadyPresent = true;
|
119
|
+
}
|
120
|
+
}
|
121
|
+
if (!alreadyPresent) {
|
122
|
+
swatches.push(newColor);
|
123
|
+
if (swatches.length > maxSwatchLen) {
|
124
|
+
swatches.splice(presetColorEnd, 1);
|
125
|
+
}
|
126
|
+
initColoris();
|
127
|
+
}
|
128
|
+
};
|
129
|
+
__classPrivateFieldGet(this, _AbstractToolbar_listeners, "f").push(this.editor.notifier.on(EditorEventType.ColorPickerToggled, event => {
|
130
|
+
if (event.kind !== EditorEventType.ColorPickerToggled) {
|
131
|
+
return;
|
132
|
+
}
|
133
|
+
// Show/hide the overlay. Making the overlay visible gives users a surface to click
|
134
|
+
// on that shows/hides the color picker.
|
135
|
+
if (this.closeColorPickerOverlay) {
|
136
|
+
this.closeColorPickerOverlay.style.display = event.open ? 'block' : 'none';
|
137
|
+
}
|
138
|
+
}));
|
139
|
+
// Add newly-selected colors to the swatch.
|
140
|
+
__classPrivateFieldGet(this, _AbstractToolbar_listeners, "f").push(this.editor.notifier.on(EditorEventType.ColorPickerColorSelected, event => {
|
141
|
+
if (event.kind === EditorEventType.ColorPickerColorSelected) {
|
142
|
+
addColorToSwatch(event.color.toHexString());
|
143
|
+
}
|
144
|
+
}));
|
145
|
+
}
|
146
|
+
closeColorPickers() {
|
147
|
+
closeColoris?.();
|
148
|
+
}
|
149
|
+
getWidgetUniqueId(widget) {
|
150
|
+
return widget.getUniqueIdIn(__classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f"));
|
151
|
+
}
|
152
|
+
getWidgetFromId(id) {
|
153
|
+
return __classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f")[id];
|
154
|
+
}
|
155
|
+
/** Do **not** modify the return value. */
|
156
|
+
getAllWidgets() {
|
157
|
+
return __classPrivateFieldGet(this, _AbstractToolbar_widgetList, "f");
|
158
|
+
}
|
159
|
+
/**
|
160
|
+
* Adds an `ActionButtonWidget` or `BaseToolWidget`. The widget should not have already have a parent
|
161
|
+
* (i.e. its `addTo` method should not have been called).
|
162
|
+
*
|
163
|
+
* @example
|
164
|
+
* ```ts
|
165
|
+
* const toolbar = editor.addToolbar();
|
166
|
+
* const insertImageWidget = new InsertImageWidget(editor);
|
167
|
+
* toolbar.addWidget(insertImageWidget);
|
168
|
+
* ```
|
169
|
+
*/
|
170
|
+
addWidget(widget) {
|
171
|
+
// Prevent name collisions
|
172
|
+
const id = widget.getUniqueIdIn(__classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f"));
|
173
|
+
// Add the widget
|
174
|
+
__classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f")[id] = widget;
|
175
|
+
__classPrivateFieldGet(this, _AbstractToolbar_widgetList, "f").push(widget);
|
176
|
+
this.addWidgetInternal(widget);
|
177
|
+
this.setupColorPickers();
|
178
|
+
}
|
179
|
+
/** Removes the given `widget` from this toolbar. */
|
180
|
+
removeWidget(widget) {
|
181
|
+
const id = widget.getUniqueIdIn(__classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f"));
|
182
|
+
this.removeWidgetInternal(widget);
|
183
|
+
delete __classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f")[id];
|
184
|
+
__classPrivateFieldSet(this, _AbstractToolbar_widgetList, __classPrivateFieldGet(this, _AbstractToolbar_widgetList, "f").filter(otherWidget => otherWidget !== widget), "f");
|
185
|
+
}
|
186
|
+
/** Returns a snapshot of the state of widgets in the toolbar. */
|
187
|
+
serializeState() {
|
188
|
+
const result = {};
|
189
|
+
for (const widgetId in __classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f")) {
|
190
|
+
result[widgetId] = __classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f")[widgetId].serializeState();
|
191
|
+
}
|
192
|
+
result[AbstractToolbar.rootToolbarId] = this.serializeInternal();
|
193
|
+
return JSON.stringify(result);
|
194
|
+
}
|
195
|
+
/**
|
196
|
+
* Deserialize toolbar widgets from the given state.
|
197
|
+
* Assumes that toolbar widgets are in the same order as when state was serialized.
|
198
|
+
*/
|
199
|
+
deserializeState(state) {
|
200
|
+
const data = JSON.parse(state);
|
201
|
+
const rootId = AbstractToolbar.rootToolbarId;
|
202
|
+
this.deserializeInternal(data[rootId]);
|
203
|
+
for (const widgetId in data) {
|
204
|
+
if (widgetId === rootId) {
|
205
|
+
continue;
|
206
|
+
}
|
207
|
+
if (!(widgetId in __classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f"))) {
|
208
|
+
console.warn(`Unable to deserialize widget ${widgetId} — no such widget.`);
|
209
|
+
continue;
|
210
|
+
}
|
211
|
+
__classPrivateFieldGet(this, _AbstractToolbar_widgetsById, "f")[widgetId].deserializeFrom(data[widgetId]);
|
212
|
+
}
|
213
|
+
}
|
214
|
+
/**
|
215
|
+
* Called by `serializeState` to attach any additional JSONifyable data
|
216
|
+
* to the serialized result.
|
217
|
+
*
|
218
|
+
* @reutrns an object that can be converted to JSON with `JSON.stringify`.
|
219
|
+
*/
|
220
|
+
serializeInternal() { }
|
221
|
+
/**
|
222
|
+
* Called by `deserializeState` with a version of the JSON outputted
|
223
|
+
* previously by `serializeInternal`.
|
224
|
+
*/
|
225
|
+
deserializeInternal(_json) { }
|
226
|
+
/**
|
227
|
+
* Creates, but does not add, an action button to this container.
|
228
|
+
*
|
229
|
+
* @see
|
230
|
+
* {@link addActionButton}
|
231
|
+
*/
|
232
|
+
makeActionButton(title, command, mustBeToplevel = true) {
|
233
|
+
const titleString = typeof title === 'string' ? title : title.label;
|
234
|
+
const widgetId = 'action-button';
|
235
|
+
const makeIcon = () => {
|
236
|
+
if (typeof title === 'string') {
|
237
|
+
return null;
|
238
|
+
}
|
239
|
+
return title.icon;
|
240
|
+
};
|
241
|
+
const widget = new ActionButtonWidget(this.editor, widgetId, makeIcon, titleString, command, this.editor.localization, mustBeToplevel);
|
242
|
+
return widget;
|
243
|
+
}
|
244
|
+
/**
|
245
|
+
* Adds an action button with `title` to this toolbar (or to the given `parent` element).
|
246
|
+
*
|
247
|
+
* @return The added button.
|
248
|
+
*/
|
249
|
+
addActionButton(title, command, mustBeToplevel = true) {
|
250
|
+
const widget = this.makeActionButton(title, command, mustBeToplevel);
|
251
|
+
this.addWidget(widget);
|
252
|
+
return widget;
|
253
|
+
}
|
254
|
+
/**
|
255
|
+
* Like {@link addActionButton}, except associates `tags` with the button that allow
|
256
|
+
* different toolbar styles to give the button tag-dependent styles.
|
257
|
+
*/
|
258
|
+
addTaggedActionButton(tags, title, command, mustBeToplevel = true) {
|
259
|
+
const widget = this.makeActionButton(title, command, mustBeToplevel);
|
260
|
+
widget.setTags(tags);
|
261
|
+
this.addWidget(widget);
|
262
|
+
return widget;
|
263
|
+
}
|
264
|
+
/**
|
265
|
+
* Adds a save button that, when clicked, calls `saveCallback`.
|
266
|
+
*
|
267
|
+
* **Note**: This is equivalent to
|
268
|
+
* ```ts
|
269
|
+
* const tags = [
|
270
|
+
* ToolbarWidgetTag.Save,
|
271
|
+
* ];
|
272
|
+
* toolbar.addTaggedActionButton(tags, {
|
273
|
+
* label: editor.localization.save,
|
274
|
+
* icon: editor.icons.makeSaveIcon(),
|
275
|
+
* }, () => {
|
276
|
+
* saveCallback();
|
277
|
+
* });
|
278
|
+
* ```
|
279
|
+
*
|
280
|
+
* @final
|
281
|
+
*/
|
282
|
+
addSaveButton(saveCallback) {
|
283
|
+
return this.addTaggedActionButton([ToolbarWidgetTag.Save], {
|
284
|
+
label: this.editor.localization.save,
|
285
|
+
icon: this.editor.icons.makeSaveIcon(),
|
286
|
+
}, () => {
|
287
|
+
saveCallback();
|
288
|
+
});
|
289
|
+
}
|
290
|
+
/**
|
291
|
+
* Adds an "Exit" button that, when clicked, calls `exitCallback`.
|
292
|
+
*
|
293
|
+
* **Note**: This is equivalent to
|
294
|
+
* ```ts
|
295
|
+
* toolbar.addTaggedActionButton([ ToolbarWidgetTag.Exit ], {
|
296
|
+
* label: this.editor.localization.exit,
|
297
|
+
* icon: this.editor.icons.makeCloseIcon(),
|
298
|
+
* }, () => {
|
299
|
+
* exitCallback();
|
300
|
+
* });
|
301
|
+
* ```
|
302
|
+
*
|
303
|
+
* @final
|
304
|
+
*/
|
305
|
+
addExitButton(exitCallback) {
|
306
|
+
return this.addTaggedActionButton([ToolbarWidgetTag.Exit], {
|
307
|
+
label: this.editor.localization.exit,
|
308
|
+
icon: this.editor.icons.makeCloseIcon(),
|
309
|
+
}, () => {
|
310
|
+
exitCallback();
|
311
|
+
});
|
312
|
+
}
|
313
|
+
/**
|
314
|
+
* Adds undo and redo buttons that trigger the editor's built-in undo and redo
|
315
|
+
* functionality.
|
316
|
+
*/
|
317
|
+
addUndoRedoButtons(undoFirst = true) {
|
318
|
+
const makeUndo = () => {
|
319
|
+
return this.addTaggedActionButton([
|
320
|
+
ToolbarWidgetTag.Undo,
|
321
|
+
], {
|
322
|
+
label: this.localizationTable.undo,
|
323
|
+
icon: this.editor.icons.makeUndoIcon()
|
324
|
+
}, () => {
|
325
|
+
this.editor.history.undo();
|
326
|
+
});
|
327
|
+
};
|
328
|
+
const makeRedo = () => {
|
329
|
+
return this.addTaggedActionButton([
|
330
|
+
ToolbarWidgetTag.Redo,
|
331
|
+
], {
|
332
|
+
label: this.localizationTable.redo,
|
333
|
+
icon: this.editor.icons.makeRedoIcon(),
|
334
|
+
}, () => {
|
335
|
+
this.editor.history.redo();
|
336
|
+
});
|
337
|
+
};
|
338
|
+
let undoButton;
|
339
|
+
let redoButton;
|
340
|
+
if (undoFirst) {
|
341
|
+
undoButton = makeUndo();
|
342
|
+
redoButton = makeRedo();
|
343
|
+
}
|
344
|
+
else {
|
345
|
+
redoButton = makeRedo();
|
346
|
+
undoButton = makeUndo();
|
347
|
+
}
|
348
|
+
undoButton.setDisabled(true);
|
349
|
+
redoButton.setDisabled(true);
|
350
|
+
this.editor.notifier.on(EditorEventType.UndoRedoStackUpdated, event => {
|
351
|
+
if (event.kind !== EditorEventType.UndoRedoStackUpdated) {
|
352
|
+
throw new Error('Wrong event type!');
|
353
|
+
}
|
354
|
+
undoButton.setDisabled(event.undoStackSize === 0);
|
355
|
+
redoButton.setDisabled(event.redoStackSize === 0);
|
356
|
+
});
|
357
|
+
}
|
358
|
+
/**
|
359
|
+
* Adds toolbar widgets based on the enabled tools.
|
360
|
+
*/
|
361
|
+
addDefaultToolWidgets() {
|
362
|
+
const toolController = this.editor.toolController;
|
363
|
+
for (const tool of toolController.getMatchingTools(PenTool)) {
|
364
|
+
const widget = new PenToolWidget(this.editor, tool, this.localizationTable);
|
365
|
+
this.addWidget(widget);
|
366
|
+
}
|
367
|
+
for (const tool of toolController.getMatchingTools(EraserTool)) {
|
368
|
+
this.addWidget(new EraserWidget(this.editor, tool, this.localizationTable));
|
369
|
+
}
|
370
|
+
for (const tool of toolController.getMatchingTools(SelectionTool)) {
|
371
|
+
this.addWidget(new SelectionToolWidget(this.editor, tool, this.localizationTable));
|
372
|
+
}
|
373
|
+
for (const tool of toolController.getMatchingTools(TextTool)) {
|
374
|
+
this.addWidget(new TextToolWidget(this.editor, tool, this.localizationTable));
|
375
|
+
}
|
376
|
+
const panZoomTool = toolController.getMatchingTools(PanZoomTool)[0];
|
377
|
+
if (panZoomTool) {
|
378
|
+
this.addWidget(new HandToolWidget(this.editor, panZoomTool, this.localizationTable));
|
379
|
+
}
|
380
|
+
this.addWidget(new DocumentPropertiesWidget(this.editor, this.localizationTable));
|
381
|
+
this.addWidget(new InsertImageWidget(this.editor, this.localizationTable));
|
382
|
+
}
|
383
|
+
addDefaultActionButtons() {
|
384
|
+
this.addUndoRedoButtons();
|
385
|
+
}
|
386
|
+
/** Remove this toolbar from its container and clean up listeners. */
|
387
|
+
remove() {
|
388
|
+
this.closeColorPickerOverlay?.remove();
|
389
|
+
for (const listener of __classPrivateFieldGet(this, _AbstractToolbar_listeners, "f")) {
|
390
|
+
listener.remove();
|
391
|
+
}
|
392
|
+
__classPrivateFieldSet(this, _AbstractToolbar_listeners, [], "f");
|
393
|
+
this.onRemove();
|
394
|
+
}
|
395
|
+
/**
|
396
|
+
* Removes `listener` when {@link remove} is called.
|
397
|
+
*/
|
398
|
+
manageListener(listener) {
|
399
|
+
__classPrivateFieldGet(this, _AbstractToolbar_listeners, "f").push(listener);
|
400
|
+
}
|
401
|
+
}
|
402
|
+
_AbstractToolbar_listeners = new WeakMap(), _AbstractToolbar_widgetsById = new WeakMap(), _AbstractToolbar_widgetList = new WeakMap(), _AbstractToolbar_updateColoris = new WeakMap();
|
403
|
+
AbstractToolbar.colorisStarted = false;
|
404
|
+
AbstractToolbar.rootToolbarId = 'root-toolbar--';
|
405
|
+
export default AbstractToolbar;
|
@@ -0,0 +1,43 @@
|
|
1
|
+
import Editor from '../Editor';
|
2
|
+
import { ToolbarLocalization } from './localization';
|
3
|
+
import BaseWidget from './widgets/BaseWidget';
|
4
|
+
import AbstractToolbar, { SpacerOptions } from './AbstractToolbar';
|
5
|
+
export declare const makeDropdownToolbar: (editor: Editor) => AbstractToolbar;
|
6
|
+
export default class DropdownToolbar extends AbstractToolbar {
|
7
|
+
protected container: HTMLElement;
|
8
|
+
private resizeObserver;
|
9
|
+
private widgetOrderCounter;
|
10
|
+
private overflowWidget;
|
11
|
+
/** @internal */
|
12
|
+
constructor(editor: Editor, parent: HTMLElement, localizationTable?: ToolbarLocalization);
|
13
|
+
private reLayoutQueued;
|
14
|
+
private queueReLayout;
|
15
|
+
private reLayout;
|
16
|
+
protected addWidgetInternal(widget: BaseWidget): void;
|
17
|
+
protected removeWidgetInternal(widget: BaseWidget): void;
|
18
|
+
addSpacer(options?: Partial<SpacerOptions>): void;
|
19
|
+
/**
|
20
|
+
* Adds a widget that toggles the overflow menu. Call `addOverflowWidget` to ensure
|
21
|
+
* that this widget is in the correct space (if shown).
|
22
|
+
*
|
23
|
+
* @example
|
24
|
+
* ```ts
|
25
|
+
* toolbar.addDefaultToolWidgets();
|
26
|
+
* toolbar.addOverflowWidget();
|
27
|
+
* toolbar.addDefaultActionButtons();
|
28
|
+
* ```
|
29
|
+
* shows the overflow widget between the default tool widgets and the default action buttons,
|
30
|
+
* if shown.
|
31
|
+
*/
|
32
|
+
addOverflowWidget(): void;
|
33
|
+
/**
|
34
|
+
* Adds both the default tool widgets and action buttons. Equivalent to
|
35
|
+
* ```ts
|
36
|
+
* toolbar.addDefaultToolWidgets();
|
37
|
+
* toolbar.addOverflowWidget();
|
38
|
+
* toolbar.addDefaultActionButtons();
|
39
|
+
* ```
|
40
|
+
*/
|
41
|
+
addDefaults(): void;
|
42
|
+
protected onRemove(): void;
|
43
|
+
}
|