js-draw 0.18.1 → 0.19.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/CHANGELOG.md +10 -0
- package/dist/bundle.js +2 -2
- package/dist/bundledStyles.js +1 -0
- package/dist/cjs/src/Color4.d.ts +69 -0
- package/dist/cjs/src/Color4.js +264 -0
- package/dist/cjs/src/Editor.d.ts +308 -0
- package/dist/cjs/src/Editor.js +904 -0
- package/dist/cjs/src/EditorImage.d.ts +97 -0
- package/dist/cjs/src/EditorImage.js +486 -0
- package/dist/cjs/src/EventDispatcher.d.ts +30 -0
- package/dist/cjs/src/EventDispatcher.js +57 -0
- package/dist/cjs/src/Pointer.d.ts +24 -0
- package/dist/cjs/src/Pointer.js +84 -0
- package/dist/cjs/src/SVGLoader.d.ts +48 -0
- package/dist/cjs/src/SVGLoader.js +475 -0
- package/dist/cjs/src/UndoRedoHistory.d.ts +19 -0
- package/dist/cjs/src/UndoRedoHistory.js +93 -0
- package/dist/cjs/src/Viewport.d.ts +71 -0
- package/dist/cjs/src/Viewport.js +264 -0
- package/dist/cjs/src/bundle/bundled.d.ts +4 -0
- package/dist/cjs/src/bundle/bundled.js +24 -0
- package/dist/cjs/src/commands/Command.d.ts +16 -0
- package/dist/cjs/src/commands/Command.js +34 -0
- package/dist/cjs/src/commands/Duplicate.d.ts +14 -0
- package/dist/cjs/src/commands/Duplicate.js +39 -0
- package/dist/cjs/src/commands/Erase.d.ts +14 -0
- package/dist/cjs/src/commands/Erase.js +63 -0
- package/dist/cjs/src/commands/SerializableCommand.d.ts +12 -0
- package/dist/cjs/src/commands/SerializableCommand.js +42 -0
- package/dist/cjs/src/commands/UnresolvedCommand.d.ts +14 -0
- package/dist/cjs/src/commands/UnresolvedCommand.js +28 -0
- package/dist/cjs/src/commands/invertCommand.d.ts +4 -0
- package/dist/cjs/src/commands/invertCommand.js +49 -0
- package/dist/cjs/src/commands/lib.d.ts +7 -0
- package/dist/cjs/src/commands/lib.js +18 -0
- package/dist/cjs/src/commands/localization.d.ts +23 -0
- package/dist/cjs/src/commands/localization.js +24 -0
- package/dist/cjs/src/commands/uniteCommands.d.ts +4 -0
- package/dist/cjs/src/commands/uniteCommands.js +121 -0
- package/dist/cjs/src/components/AbstractComponent.d.ts +73 -0
- package/dist/cjs/src/components/AbstractComponent.js +258 -0
- package/dist/cjs/src/components/ImageBackground.d.ts +42 -0
- package/dist/cjs/src/components/ImageBackground.js +146 -0
- package/dist/cjs/src/components/ImageComponent.d.ts +31 -0
- package/dist/cjs/src/components/ImageComponent.js +152 -0
- package/dist/cjs/src/components/RestylableComponent.d.ts +43 -0
- package/dist/cjs/src/components/RestylableComponent.js +88 -0
- package/dist/cjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
- package/dist/cjs/src/components/SVGGlobalAttributesObject.js +65 -0
- package/dist/cjs/src/components/Stroke.d.ts +75 -0
- package/dist/cjs/src/components/Stroke.js +225 -0
- package/dist/cjs/src/components/TextComponent.d.ts +75 -0
- package/dist/cjs/src/components/TextComponent.js +280 -0
- package/dist/cjs/src/components/UnknownSVGObject.d.ts +18 -0
- package/dist/cjs/src/components/UnknownSVGObject.js +50 -0
- package/dist/cjs/src/components/builders/ArrowBuilder.d.ts +19 -0
- package/dist/cjs/src/components/builders/ArrowBuilder.js +117 -0
- package/dist/cjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
- package/dist/cjs/src/components/builders/FreehandLineBuilder.js +173 -0
- package/dist/cjs/src/components/builders/LineBuilder.d.ts +18 -0
- package/dist/cjs/src/components/builders/LineBuilder.js +89 -0
- package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
- package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.js +347 -0
- package/dist/cjs/src/components/builders/RectangleBuilder.d.ts +20 -0
- package/dist/cjs/src/components/builders/RectangleBuilder.js +59 -0
- package/dist/cjs/src/components/builders/types.d.ts +12 -0
- package/dist/cjs/src/components/builders/types.js +2 -0
- package/dist/cjs/src/components/lib.d.ts +13 -0
- package/dist/cjs/src/components/lib.js +43 -0
- package/dist/cjs/src/components/localization.d.ts +11 -0
- package/dist/cjs/src/components/localization.js +13 -0
- package/dist/cjs/src/components/util/StrokeSmoother.d.ts +35 -0
- package/dist/cjs/src/components/util/StrokeSmoother.js +217 -0
- package/dist/cjs/src/components/util/describeComponentList.d.ts +4 -0
- package/dist/cjs/src/components/util/describeComponentList.js +16 -0
- package/dist/cjs/src/lib.d.ts +64 -0
- package/dist/cjs/src/lib.js +93 -0
- package/dist/cjs/src/localization.d.ts +14 -0
- package/dist/cjs/src/localization.js +13 -0
- package/dist/cjs/src/localizations/de.d.ts +3 -0
- package/dist/cjs/src/localizations/de.js +6 -0
- package/dist/cjs/src/localizations/en.d.ts +3 -0
- package/dist/cjs/src/localizations/en.js +6 -0
- package/dist/cjs/src/localizations/es.d.ts +3 -0
- package/dist/cjs/src/localizations/es.js +20 -0
- package/dist/cjs/src/localizations/getLocalizationTable.d.ts +3 -0
- package/dist/cjs/src/localizations/getLocalizationTable.js +50 -0
- package/dist/cjs/src/math/LineSegment2.d.ts +24 -0
- package/dist/cjs/src/math/LineSegment2.js +131 -0
- package/dist/cjs/src/math/Mat33.d.ts +118 -0
- package/dist/cjs/src/math/Mat33.js +332 -0
- package/dist/cjs/src/math/Path.d.ts +71 -0
- package/dist/cjs/src/math/Path.js +655 -0
- package/dist/cjs/src/math/Rect2.d.ts +52 -0
- package/dist/cjs/src/math/Rect2.js +234 -0
- package/dist/cjs/src/math/Triangle.d.ts +11 -0
- package/dist/cjs/src/math/Triangle.js +22 -0
- package/dist/cjs/src/math/Vec2.d.ts +13 -0
- package/dist/cjs/src/math/Vec2.js +19 -0
- package/dist/cjs/src/math/Vec3.d.ts +106 -0
- package/dist/cjs/src/math/Vec3.js +177 -0
- package/dist/cjs/src/math/lib.d.ts +7 -0
- package/dist/cjs/src/math/lib.js +18 -0
- package/dist/cjs/src/math/rounding.d.ts +4 -0
- package/dist/cjs/src/math/rounding.js +135 -0
- package/dist/cjs/src/rendering/Display.d.ts +75 -0
- package/dist/cjs/src/rendering/Display.js +214 -0
- package/dist/cjs/src/rendering/RenderingStyle.d.ts +31 -0
- package/dist/cjs/src/rendering/RenderingStyle.js +48 -0
- package/dist/cjs/src/rendering/TextRenderingStyle.d.ts +36 -0
- package/dist/cjs/src/rendering/TextRenderingStyle.js +29 -0
- package/dist/cjs/src/rendering/caching/CacheRecord.d.ts +20 -0
- package/dist/cjs/src/rendering/caching/CacheRecord.js +61 -0
- package/dist/cjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
- package/dist/cjs/src/rendering/caching/CacheRecordManager.js +50 -0
- package/dist/cjs/src/rendering/caching/RenderingCache.d.ts +11 -0
- package/dist/cjs/src/rendering/caching/RenderingCache.js +51 -0
- package/dist/cjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
- package/dist/cjs/src/rendering/caching/RenderingCacheNode.js +326 -0
- package/dist/cjs/src/rendering/caching/testUtils.d.ts +9 -0
- package/dist/cjs/src/rendering/caching/testUtils.js +27 -0
- package/dist/cjs/src/rendering/caching/types.d.ts +19 -0
- package/dist/cjs/src/rendering/caching/types.js +2 -0
- package/dist/cjs/src/rendering/lib.d.ts +7 -0
- package/dist/cjs/src/rendering/lib.js +17 -0
- package/dist/cjs/src/rendering/localization.d.ts +10 -0
- package/dist/cjs/src/rendering/localization.js +12 -0
- package/dist/cjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
- package/dist/cjs/src/rendering/renderers/AbstractRenderer.js +170 -0
- package/dist/cjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
- package/dist/cjs/src/rendering/renderers/CanvasRenderer.js +236 -0
- package/dist/cjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
- package/dist/cjs/src/rendering/renderers/DummyRenderer.js +112 -0
- package/dist/cjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
- package/dist/cjs/src/rendering/renderers/SVGRenderer.js +311 -0
- package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
- package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.js +63 -0
- package/dist/cjs/src/testing/beforeEachFile.d.ts +1 -0
- package/dist/cjs/src/testing/beforeEachFile.js +12 -0
- package/dist/cjs/src/testing/createEditor.d.ts +4 -0
- package/dist/cjs/src/testing/createEditor.js +14 -0
- package/dist/cjs/src/testing/lib.d.ts +2 -0
- package/dist/cjs/src/testing/lib.js +10 -0
- package/dist/cjs/src/testing/loadExpectExtensions.d.ts +2 -0
- package/dist/cjs/src/testing/loadExpectExtensions.js +28 -0
- package/dist/cjs/src/testing/sendPenEvent.d.ts +12 -0
- package/dist/cjs/src/testing/sendPenEvent.js +24 -0
- package/dist/cjs/src/testing/sendTouchEvent.d.ts +42 -0
- package/dist/cjs/src/testing/sendTouchEvent.js +87 -0
- package/dist/cjs/src/toolbar/HTMLToolbar.d.ts +103 -0
- package/dist/cjs/src/toolbar/HTMLToolbar.js +383 -0
- package/dist/cjs/src/toolbar/IconProvider.d.ts +62 -0
- package/dist/cjs/src/toolbar/IconProvider.js +660 -0
- package/dist/cjs/src/toolbar/lib.d.ts +3 -0
- package/dist/cjs/src/toolbar/lib.js +24 -0
- package/dist/cjs/src/toolbar/localization.d.ts +49 -0
- package/dist/cjs/src/toolbar/localization.js +51 -0
- package/dist/cjs/src/toolbar/makeColorInput.d.ts +6 -0
- package/dist/cjs/src/toolbar/makeColorInput.js +120 -0
- package/dist/cjs/src/toolbar/types.d.ts +4 -0
- package/dist/cjs/src/toolbar/types.js +2 -0
- package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
- package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.js +31 -0
- package/dist/cjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
- package/dist/cjs/src/toolbar/widgets/BaseToolWidget.js +50 -0
- package/dist/cjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
- package/dist/cjs/src/toolbar/widgets/BaseWidget.js +313 -0
- package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
- package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.js +126 -0
- package/dist/cjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
- package/dist/cjs/src/toolbar/widgets/EraserToolWidget.js +63 -0
- package/dist/cjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
- package/dist/cjs/src/toolbar/widgets/HandToolWidget.js +201 -0
- package/dist/cjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
- package/dist/cjs/src/toolbar/widgets/InsertImageWidget.js +176 -0
- package/dist/cjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
- package/dist/cjs/src/toolbar/widgets/OverflowWidget.js +77 -0
- package/dist/cjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
- package/dist/cjs/src/toolbar/widgets/PenToolWidget.js +226 -0
- package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
- package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.js +153 -0
- package/dist/cjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
- package/dist/cjs/src/toolbar/widgets/TextToolWidget.js +115 -0
- package/dist/cjs/src/toolbar/widgets/lib.d.ts +10 -0
- package/dist/cjs/src/toolbar/widgets/lib.js +26 -0
- package/dist/cjs/src/tools/BaseTool.d.ts +22 -0
- package/dist/cjs/src/tools/BaseTool.js +66 -0
- package/dist/cjs/src/tools/Eraser.d.ts +23 -0
- package/dist/cjs/src/tools/Eraser.js +112 -0
- package/dist/cjs/src/tools/FindTool.d.ts +21 -0
- package/dist/cjs/src/tools/FindTool.js +121 -0
- package/dist/cjs/src/tools/PanZoom.d.ts +52 -0
- package/dist/cjs/src/tools/PanZoom.js +421 -0
- package/dist/cjs/src/tools/PasteHandler.d.ts +23 -0
- package/dist/cjs/src/tools/PasteHandler.js +99 -0
- package/dist/cjs/src/tools/Pen.d.ts +39 -0
- package/dist/cjs/src/tools/Pen.js +179 -0
- package/dist/cjs/src/tools/PipetteTool.d.ts +18 -0
- package/dist/cjs/src/tools/PipetteTool.js +45 -0
- package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
- package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.js +28 -0
- package/dist/cjs/src/tools/SelectionTool/Selection.d.ts +64 -0
- package/dist/cjs/src/tools/SelectionTool/Selection.js +488 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionHandle.js +85 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionTool.js +405 -0
- package/dist/cjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
- package/dist/cjs/src/tools/SelectionTool/TransformMode.js +107 -0
- package/dist/cjs/src/tools/SelectionTool/types.d.ts +9 -0
- package/dist/cjs/src/tools/SelectionTool/types.js +14 -0
- package/dist/cjs/src/tools/SoundUITool.d.ts +24 -0
- package/dist/cjs/src/tools/SoundUITool.js +164 -0
- package/dist/cjs/src/tools/TextTool.d.ts +33 -0
- package/dist/cjs/src/tools/TextTool.js +262 -0
- package/dist/cjs/src/tools/ToolController.d.ts +18 -0
- package/dist/cjs/src/tools/ToolController.js +192 -0
- package/dist/cjs/src/tools/ToolEnabledGroup.d.ts +6 -0
- package/dist/cjs/src/tools/ToolEnabledGroup.js +14 -0
- package/dist/cjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
- package/dist/cjs/src/tools/ToolSwitcherShortcut.js +38 -0
- package/dist/cjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
- package/dist/cjs/src/tools/ToolbarShortcutHandler.js +29 -0
- package/dist/cjs/src/tools/UndoRedoShortcut.d.ts +8 -0
- package/dist/cjs/src/tools/UndoRedoShortcut.js +28 -0
- package/dist/cjs/src/tools/lib.d.ts +17 -0
- package/dist/cjs/src/tools/lib.js +38 -0
- package/dist/cjs/src/tools/localization.d.ts +31 -0
- package/dist/cjs/src/tools/localization.js +33 -0
- package/dist/cjs/src/types.d.ts +151 -0
- package/dist/cjs/src/types.js +38 -0
- package/dist/cjs/src/util/assertions.d.ts +23 -0
- package/dist/cjs/src/util/assertions.js +51 -0
- package/dist/cjs/src/util/fileToBase64.d.ts +3 -0
- package/dist/cjs/src/util/fileToBase64.js +15 -0
- package/dist/cjs/src/util/untilNextAnimationFrame.d.ts +3 -0
- package/dist/cjs/src/util/untilNextAnimationFrame.js +9 -0
- package/dist/cjs/src/util/waitForTimeout.d.ts +2 -0
- package/dist/cjs/src/util/waitForTimeout.js +9 -0
- package/dist/mjs/src/Color4.d.ts +69 -0
- package/dist/mjs/src/Color4.mjs +257 -0
- package/dist/mjs/src/Editor.d.ts +308 -0
- package/dist/mjs/src/Editor.mjs +874 -0
- package/dist/mjs/src/EditorImage.d.ts +97 -0
- package/dist/mjs/src/EditorImage.mjs +477 -0
- package/dist/mjs/src/EventDispatcher.d.ts +30 -0
- package/dist/mjs/src/EventDispatcher.mjs +54 -0
- package/dist/mjs/src/Pointer.d.ts +24 -0
- package/dist/mjs/src/Pointer.mjs +80 -0
- package/dist/mjs/src/SVGLoader.d.ts +48 -0
- package/dist/mjs/src/SVGLoader.mjs +445 -0
- package/dist/mjs/src/UndoRedoHistory.d.ts +19 -0
- package/dist/mjs/src/UndoRedoHistory.mjs +91 -0
- package/dist/mjs/src/Viewport.d.ts +71 -0
- package/dist/mjs/src/Viewport.mjs +256 -0
- package/dist/mjs/src/bundle/bundled.d.ts +4 -0
- package/dist/mjs/src/bundle/bundled.mjs +5 -0
- package/dist/mjs/src/commands/Command.d.ts +16 -0
- package/dist/mjs/src/commands/Command.mjs +30 -0
- package/dist/mjs/src/commands/Duplicate.d.ts +14 -0
- package/dist/mjs/src/commands/Duplicate.mjs +33 -0
- package/dist/mjs/src/commands/Erase.d.ts +14 -0
- package/dist/mjs/src/commands/Erase.mjs +57 -0
- package/dist/mjs/src/commands/SerializableCommand.d.ts +12 -0
- package/dist/mjs/src/commands/SerializableCommand.mjs +36 -0
- package/dist/mjs/src/commands/UnresolvedCommand.d.ts +14 -0
- package/dist/mjs/src/commands/UnresolvedCommand.mjs +22 -0
- package/dist/mjs/src/commands/invertCommand.d.ts +4 -0
- package/dist/mjs/src/commands/invertCommand.mjs +44 -0
- package/dist/mjs/src/commands/lib.d.ts +7 -0
- package/dist/mjs/src/commands/lib.mjs +7 -0
- package/dist/mjs/src/commands/localization.d.ts +23 -0
- package/dist/mjs/src/commands/localization.mjs +21 -0
- package/dist/mjs/src/commands/uniteCommands.d.ts +4 -0
- package/dist/mjs/src/commands/uniteCommands.mjs +116 -0
- package/dist/mjs/src/components/AbstractComponent.d.ts +73 -0
- package/dist/mjs/src/components/AbstractComponent.mjs +252 -0
- package/dist/mjs/src/components/ImageBackground.d.ts +42 -0
- package/dist/mjs/src/components/ImageBackground.mjs +139 -0
- package/dist/mjs/src/components/ImageComponent.d.ts +31 -0
- package/dist/mjs/src/components/ImageComponent.mjs +146 -0
- package/dist/mjs/src/components/RestylableComponent.d.ts +43 -0
- package/dist/mjs/src/components/RestylableComponent.mjs +80 -0
- package/dist/mjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
- package/dist/mjs/src/components/SVGGlobalAttributesObject.mjs +59 -0
- package/dist/mjs/src/components/Stroke.d.ts +75 -0
- package/dist/mjs/src/components/Stroke.mjs +219 -0
- package/dist/mjs/src/components/TextComponent.d.ts +75 -0
- package/dist/mjs/src/components/TextComponent.mjs +274 -0
- package/dist/mjs/src/components/UnknownSVGObject.d.ts +18 -0
- package/dist/mjs/src/components/UnknownSVGObject.mjs +44 -0
- package/dist/mjs/src/components/builders/ArrowBuilder.d.ts +19 -0
- package/dist/mjs/src/components/builders/ArrowBuilder.mjs +86 -0
- package/dist/mjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
- package/dist/mjs/src/components/builders/FreehandLineBuilder.mjs +165 -0
- package/dist/mjs/src/components/builders/LineBuilder.d.ts +18 -0
- package/dist/mjs/src/components/builders/LineBuilder.mjs +58 -0
- package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
- package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.mjs +339 -0
- package/dist/mjs/src/components/builders/RectangleBuilder.d.ts +20 -0
- package/dist/mjs/src/components/builders/RectangleBuilder.mjs +50 -0
- package/dist/mjs/src/components/builders/types.d.ts +12 -0
- package/dist/mjs/src/components/builders/types.mjs +1 -0
- package/dist/mjs/src/components/lib.d.ts +13 -0
- package/dist/mjs/src/components/lib.mjs +12 -0
- package/dist/mjs/src/components/localization.d.ts +11 -0
- package/dist/mjs/src/components/localization.mjs +10 -0
- package/dist/mjs/src/components/util/StrokeSmoother.d.ts +35 -0
- package/dist/mjs/src/components/util/StrokeSmoother.mjs +210 -0
- package/dist/mjs/src/components/util/describeComponentList.d.ts +4 -0
- package/dist/mjs/src/components/util/describeComponentList.mjs +14 -0
- package/dist/mjs/src/lib.d.ts +64 -0
- package/dist/mjs/src/lib.mjs +64 -0
- package/dist/mjs/src/localization.d.ts +14 -0
- package/dist/mjs/src/localization.mjs +10 -0
- package/dist/mjs/src/localizations/de.d.ts +3 -0
- package/dist/mjs/src/localizations/de.mjs +4 -0
- package/dist/mjs/src/localizations/en.d.ts +3 -0
- package/dist/mjs/src/localizations/en.mjs +4 -0
- package/dist/mjs/src/localizations/es.d.ts +3 -0
- package/dist/mjs/src/localizations/es.mjs +18 -0
- package/dist/mjs/src/localizations/getLocalizationTable.d.ts +3 -0
- package/dist/mjs/src/localizations/getLocalizationTable.mjs +45 -0
- package/dist/mjs/src/math/LineSegment2.d.ts +24 -0
- package/dist/mjs/src/math/LineSegment2.mjs +125 -0
- package/dist/mjs/src/math/Mat33.d.ts +118 -0
- package/dist/mjs/src/math/Mat33.mjs +326 -0
- package/dist/mjs/src/math/Path.d.ts +71 -0
- package/dist/mjs/src/math/Path.mjs +648 -0
- package/dist/mjs/src/math/Rect2.d.ts +52 -0
- package/dist/mjs/src/math/Rect2.mjs +228 -0
- package/dist/mjs/src/math/Triangle.d.ts +11 -0
- package/dist/mjs/src/math/Triangle.mjs +19 -0
- package/dist/mjs/src/math/Vec2.d.ts +13 -0
- package/dist/mjs/src/math/Vec2.mjs +13 -0
- package/dist/mjs/src/math/Vec3.d.ts +106 -0
- package/dist/mjs/src/math/Vec3.mjs +174 -0
- package/dist/mjs/src/math/lib.d.ts +7 -0
- package/dist/mjs/src/math/lib.mjs +7 -0
- package/dist/mjs/src/math/rounding.d.ts +4 -0
- package/dist/mjs/src/math/rounding.mjs +128 -0
- package/dist/mjs/src/rendering/Display.d.ts +75 -0
- package/dist/mjs/src/rendering/Display.mjs +207 -0
- package/dist/mjs/src/rendering/RenderingStyle.d.ts +31 -0
- package/dist/mjs/src/rendering/RenderingStyle.mjs +38 -0
- package/dist/mjs/src/rendering/TextRenderingStyle.d.ts +36 -0
- package/dist/mjs/src/rendering/TextRenderingStyle.mjs +23 -0
- package/dist/mjs/src/rendering/caching/CacheRecord.d.ts +20 -0
- package/dist/mjs/src/rendering/caching/CacheRecord.mjs +55 -0
- package/dist/mjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
- package/dist/mjs/src/rendering/caching/CacheRecordManager.mjs +43 -0
- package/dist/mjs/src/rendering/caching/RenderingCache.d.ts +11 -0
- package/dist/mjs/src/rendering/caching/RenderingCache.mjs +45 -0
- package/dist/mjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
- package/dist/mjs/src/rendering/caching/RenderingCacheNode.mjs +320 -0
- package/dist/mjs/src/rendering/caching/testUtils.d.ts +9 -0
- package/dist/mjs/src/rendering/caching/testUtils.mjs +20 -0
- package/dist/mjs/src/rendering/caching/types.d.ts +19 -0
- package/dist/mjs/src/rendering/caching/types.mjs +1 -0
- package/dist/mjs/src/rendering/lib.d.ts +7 -0
- package/dist/mjs/src/rendering/lib.mjs +5 -0
- package/dist/mjs/src/rendering/localization.d.ts +10 -0
- package/dist/mjs/src/rendering/localization.mjs +9 -0
- package/dist/mjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
- package/dist/mjs/src/rendering/renderers/AbstractRenderer.mjs +144 -0
- package/dist/mjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
- package/dist/mjs/src/rendering/renderers/CanvasRenderer.mjs +230 -0
- package/dist/mjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
- package/dist/mjs/src/rendering/renderers/DummyRenderer.mjs +106 -0
- package/dist/mjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
- package/dist/mjs/src/rendering/renderers/SVGRenderer.mjs +304 -0
- package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
- package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.mjs +57 -0
- package/dist/mjs/src/testing/beforeEachFile.d.ts +1 -0
- package/dist/mjs/src/testing/beforeEachFile.mjs +7 -0
- package/dist/mjs/src/testing/createEditor.d.ts +4 -0
- package/dist/mjs/src/testing/createEditor.mjs +9 -0
- package/dist/mjs/src/testing/lib.d.ts +2 -0
- package/dist/mjs/src/testing/lib.mjs +2 -0
- package/dist/mjs/src/testing/loadExpectExtensions.d.ts +2 -0
- package/dist/mjs/src/testing/loadExpectExtensions.mjs +24 -0
- package/dist/mjs/src/testing/sendPenEvent.d.ts +12 -0
- package/dist/mjs/src/testing/sendPenEvent.mjs +19 -0
- package/dist/mjs/src/testing/sendTouchEvent.d.ts +42 -0
- package/dist/mjs/src/testing/sendTouchEvent.mjs +62 -0
- package/dist/mjs/src/toolbar/HTMLToolbar.d.ts +103 -0
- package/dist/mjs/src/toolbar/HTMLToolbar.mjs +376 -0
- package/dist/mjs/src/toolbar/IconProvider.d.ts +62 -0
- package/dist/mjs/src/toolbar/IconProvider.mjs +654 -0
- package/dist/mjs/src/toolbar/lib.d.ts +3 -0
- package/dist/mjs/src/toolbar/lib.mjs +3 -0
- package/dist/mjs/src/toolbar/localization.d.ts +49 -0
- package/dist/mjs/src/toolbar/localization.mjs +48 -0
- package/dist/mjs/src/toolbar/makeColorInput.d.ts +6 -0
- package/dist/mjs/src/toolbar/makeColorInput.mjs +113 -0
- package/dist/mjs/src/toolbar/types.d.ts +4 -0
- package/dist/mjs/src/toolbar/types.mjs +1 -0
- package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
- package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.mjs +25 -0
- package/dist/mjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
- package/dist/mjs/src/toolbar/widgets/BaseToolWidget.mjs +44 -0
- package/dist/mjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
- package/dist/mjs/src/toolbar/widgets/BaseWidget.mjs +307 -0
- package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
- package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.mjs +120 -0
- package/dist/mjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
- package/dist/mjs/src/toolbar/widgets/EraserToolWidget.mjs +57 -0
- package/dist/mjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
- package/dist/mjs/src/toolbar/widgets/HandToolWidget.mjs +172 -0
- package/dist/mjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
- package/dist/mjs/src/toolbar/widgets/InsertImageWidget.mjs +170 -0
- package/dist/mjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
- package/dist/mjs/src/toolbar/widgets/OverflowWidget.mjs +71 -0
- package/dist/mjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
- package/dist/mjs/src/toolbar/widgets/PenToolWidget.mjs +220 -0
- package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
- package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.mjs +147 -0
- package/dist/mjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
- package/dist/mjs/src/toolbar/widgets/TextToolWidget.mjs +109 -0
- package/dist/mjs/src/toolbar/widgets/lib.d.ts +10 -0
- package/dist/mjs/src/toolbar/widgets/lib.mjs +10 -0
- package/dist/mjs/src/tools/BaseTool.d.ts +22 -0
- package/dist/mjs/src/tools/BaseTool.mjs +63 -0
- package/dist/mjs/src/tools/Eraser.d.ts +23 -0
- package/dist/mjs/src/tools/Eraser.mjs +106 -0
- package/dist/mjs/src/tools/FindTool.d.ts +21 -0
- package/dist/mjs/src/tools/FindTool.mjs +114 -0
- package/dist/mjs/src/tools/PanZoom.d.ts +52 -0
- package/dist/mjs/src/tools/PanZoom.mjs +414 -0
- package/dist/mjs/src/tools/PasteHandler.d.ts +23 -0
- package/dist/mjs/src/tools/PasteHandler.mjs +93 -0
- package/dist/mjs/src/tools/Pen.d.ts +39 -0
- package/dist/mjs/src/tools/Pen.mjs +173 -0
- package/dist/mjs/src/tools/PipetteTool.d.ts +18 -0
- package/dist/mjs/src/tools/PipetteTool.mjs +39 -0
- package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
- package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.mjs +22 -0
- package/dist/mjs/src/tools/SelectionTool/Selection.d.ts +64 -0
- package/dist/mjs/src/tools/SelectionTool/Selection.mjs +459 -0
- package/dist/mjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
- package/dist/mjs/src/tools/SelectionTool/SelectionHandle.mjs +81 -0
- package/dist/mjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
- package/dist/mjs/src/tools/SelectionTool/SelectionTool.mjs +398 -0
- package/dist/mjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
- package/dist/mjs/src/tools/SelectionTool/TransformMode.mjs +98 -0
- package/dist/mjs/src/tools/SelectionTool/types.d.ts +9 -0
- package/dist/mjs/src/tools/SelectionTool/types.mjs +11 -0
- package/dist/mjs/src/tools/SoundUITool.d.ts +24 -0
- package/dist/mjs/src/tools/SoundUITool.mjs +158 -0
- package/dist/mjs/src/tools/TextTool.d.ts +33 -0
- package/dist/mjs/src/tools/TextTool.mjs +256 -0
- package/dist/mjs/src/tools/ToolController.d.ts +18 -0
- package/dist/mjs/src/tools/ToolController.mjs +163 -0
- package/dist/mjs/src/tools/ToolEnabledGroup.d.ts +6 -0
- package/dist/mjs/src/tools/ToolEnabledGroup.mjs +11 -0
- package/dist/mjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
- package/dist/mjs/src/tools/ToolSwitcherShortcut.mjs +32 -0
- package/dist/mjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
- package/dist/mjs/src/tools/ToolbarShortcutHandler.mjs +23 -0
- package/dist/mjs/src/tools/UndoRedoShortcut.d.ts +8 -0
- package/dist/mjs/src/tools/UndoRedoShortcut.mjs +22 -0
- package/dist/mjs/src/tools/lib.d.ts +17 -0
- package/dist/mjs/src/tools/lib.mjs +17 -0
- package/dist/mjs/src/tools/localization.d.ts +31 -0
- package/dist/mjs/src/tools/localization.mjs +30 -0
- package/dist/mjs/src/types.d.ts +151 -0
- package/dist/mjs/src/types.mjs +35 -0
- package/dist/mjs/src/util/assertions.d.ts +23 -0
- package/dist/mjs/src/util/assertions.mjs +45 -0
- package/dist/mjs/src/util/fileToBase64.d.ts +3 -0
- package/dist/mjs/src/util/fileToBase64.mjs +13 -0
- package/dist/mjs/src/util/untilNextAnimationFrame.d.ts +3 -0
- package/dist/mjs/src/util/untilNextAnimationFrame.mjs +7 -0
- package/dist/mjs/src/util/waitForTimeout.d.ts +2 -0
- package/dist/mjs/src/util/waitForTimeout.mjs +7 -0
- package/package.json +6 -4
- package/src/Editor.css +86 -0
- package/src/styles.js +7 -0
- package/src/toolbar/toolbar.css +213 -0
- package/src/toolbar/widgets/InsertImageWidget.css +44 -0
- package/src/toolbar/widgets/OverflowWidget.css +27 -0
- package/src/tools/FindTool.css +7 -0
- package/src/tools/SelectionTool/SelectionTool.css +23 -0
- package/src/tools/SoundUITool.css +15 -0
- package/src/tools/tools.css +4 -0
@@ -0,0 +1,32 @@
|
|
1
|
+
import BaseTool from './BaseTool.mjs';
|
2
|
+
/**
|
3
|
+
* Handles keyboard events used, by default, to select tools. By default,
|
4
|
+
* 1 maps to the first primary tool, 2 to the second primary tool, ... .
|
5
|
+
*
|
6
|
+
* This is in the default set of {@link ToolController} tools.
|
7
|
+
*
|
8
|
+
* @deprecated This may be replaced in the future.
|
9
|
+
*/
|
10
|
+
export default class ToolSwitcherShortcut extends BaseTool {
|
11
|
+
constructor(editor) {
|
12
|
+
super(editor.notifier, editor.localization.changeTool);
|
13
|
+
this.editor = editor;
|
14
|
+
}
|
15
|
+
// @internal
|
16
|
+
onKeyPress({ key }) {
|
17
|
+
const toolController = this.editor.toolController;
|
18
|
+
const primaryTools = toolController.getPrimaryTools();
|
19
|
+
// Map keys 0-9 to primary tools.
|
20
|
+
const keyMatch = /^[0-9]$/.exec(key);
|
21
|
+
let targetTool;
|
22
|
+
if (keyMatch) {
|
23
|
+
const targetIdx = parseInt(keyMatch[0], 10) - 1;
|
24
|
+
targetTool = primaryTools[targetIdx];
|
25
|
+
}
|
26
|
+
if (targetTool) {
|
27
|
+
targetTool.setEnabled(true);
|
28
|
+
return true;
|
29
|
+
}
|
30
|
+
return false;
|
31
|
+
}
|
32
|
+
}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import Editor from '../Editor';
|
2
|
+
import { KeyPressEvent } from '../types';
|
3
|
+
import BaseTool from './BaseTool';
|
4
|
+
type KeyPressListener = (event: KeyPressEvent) => boolean;
|
5
|
+
export default class ToolbarShortcutHandler extends BaseTool {
|
6
|
+
private listeners;
|
7
|
+
constructor(editor: Editor);
|
8
|
+
registerListener(listener: KeyPressListener): void;
|
9
|
+
removeListener(listener: KeyPressListener): void;
|
10
|
+
onKeyPress(event: KeyPressEvent): boolean;
|
11
|
+
}
|
12
|
+
export {};
|
@@ -0,0 +1,23 @@
|
|
1
|
+
// Allows the toolbar to register keyboard events.
|
2
|
+
// @packageDocumentation
|
3
|
+
import BaseTool from './BaseTool.mjs';
|
4
|
+
export default class ToolbarShortcutHandler extends BaseTool {
|
5
|
+
constructor(editor) {
|
6
|
+
super(editor.notifier, editor.localization.changeTool);
|
7
|
+
this.listeners = new Set([]);
|
8
|
+
}
|
9
|
+
registerListener(listener) {
|
10
|
+
this.listeners.add(listener);
|
11
|
+
}
|
12
|
+
removeListener(listener) {
|
13
|
+
this.listeners.delete(listener);
|
14
|
+
}
|
15
|
+
onKeyPress(event) {
|
16
|
+
for (const listener of this.listeners) {
|
17
|
+
if (listener(event)) {
|
18
|
+
return true;
|
19
|
+
}
|
20
|
+
}
|
21
|
+
return false;
|
22
|
+
}
|
23
|
+
}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import Editor from '../Editor';
|
2
|
+
import { KeyPressEvent } from '../types';
|
3
|
+
import BaseTool from './BaseTool';
|
4
|
+
export default class UndoRedoShortcut extends BaseTool {
|
5
|
+
private editor;
|
6
|
+
constructor(editor: Editor);
|
7
|
+
onKeyPress({ key, ctrlKey }: KeyPressEvent): boolean;
|
8
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import BaseTool from './BaseTool.mjs';
|
2
|
+
// Handles ctrl+Z, ctrl+Shift+Z keyboard shortcuts.
|
3
|
+
export default class UndoRedoShortcut extends BaseTool {
|
4
|
+
constructor(editor) {
|
5
|
+
super(editor.notifier, editor.localization.undoRedoTool);
|
6
|
+
this.editor = editor;
|
7
|
+
}
|
8
|
+
// @internal
|
9
|
+
onKeyPress({ key, ctrlKey }) {
|
10
|
+
if (ctrlKey) {
|
11
|
+
if (key === 'z') {
|
12
|
+
this.editor.history.undo();
|
13
|
+
return true;
|
14
|
+
}
|
15
|
+
else if (key === 'Z') {
|
16
|
+
this.editor.history.redo();
|
17
|
+
return true;
|
18
|
+
}
|
19
|
+
}
|
20
|
+
return false;
|
21
|
+
}
|
22
|
+
}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
/**
|
2
|
+
* @packageDocumentation
|
3
|
+
*/
|
4
|
+
export { default as BaseTool } from './BaseTool';
|
5
|
+
export { default as ToolController } from './ToolController';
|
6
|
+
export { default as ToolEnabledGroup } from './ToolEnabledGroup';
|
7
|
+
export { default as UndoRedoShortcut } from './UndoRedoShortcut';
|
8
|
+
export { default as ToolSwitcherShortcut } from './ToolSwitcherShortcut';
|
9
|
+
export { default as PanZoomTool, PanZoomMode } from './PanZoom';
|
10
|
+
export { default as PenTool, PenStyle } from './Pen';
|
11
|
+
export { default as TextTool } from './TextTool';
|
12
|
+
export { default as SelectionTool } from './SelectionTool/SelectionTool';
|
13
|
+
export { default as SelectAllShortcutHandler } from './SelectionTool/SelectAllShortcutHandler';
|
14
|
+
export { default as EraserTool } from './Eraser';
|
15
|
+
export { default as PasteHandler } from './PasteHandler';
|
16
|
+
export { default as SoundUITool } from './SoundUITool';
|
17
|
+
export { default as ToolbarShortcutHandler } from './ToolbarShortcutHandler';
|
@@ -0,0 +1,17 @@
|
|
1
|
+
/**
|
2
|
+
* @packageDocumentation
|
3
|
+
*/
|
4
|
+
export { default as BaseTool } from './BaseTool.mjs';
|
5
|
+
export { default as ToolController } from './ToolController.mjs';
|
6
|
+
export { default as ToolEnabledGroup } from './ToolEnabledGroup.mjs';
|
7
|
+
export { default as UndoRedoShortcut } from './UndoRedoShortcut.mjs';
|
8
|
+
export { default as ToolSwitcherShortcut } from './ToolSwitcherShortcut.mjs';
|
9
|
+
export { default as PanZoomTool, PanZoomMode } from './PanZoom.mjs';
|
10
|
+
export { default as PenTool } from './Pen.mjs';
|
11
|
+
export { default as TextTool } from './TextTool.mjs';
|
12
|
+
export { default as SelectionTool } from './SelectionTool/SelectionTool.mjs';
|
13
|
+
export { default as SelectAllShortcutHandler } from './SelectionTool/SelectAllShortcutHandler.mjs';
|
14
|
+
export { default as EraserTool } from './Eraser.mjs';
|
15
|
+
export { default as PasteHandler } from './PasteHandler.mjs';
|
16
|
+
export { default as SoundUITool } from './SoundUITool.mjs';
|
17
|
+
export { default as ToolbarShortcutHandler } from './ToolbarShortcutHandler.mjs';
|
@@ -0,0 +1,31 @@
|
|
1
|
+
export interface ToolLocalization {
|
2
|
+
keyboardPanZoom: string;
|
3
|
+
penTool: (penId: number) => string;
|
4
|
+
selectionTool: string;
|
5
|
+
selectAllTool: string;
|
6
|
+
eraserTool: string;
|
7
|
+
touchPanTool: string;
|
8
|
+
twoFingerPanZoomTool: string;
|
9
|
+
undoRedoTool: string;
|
10
|
+
pipetteTool: string;
|
11
|
+
rightClickDragPanTool: string;
|
12
|
+
textTool: string;
|
13
|
+
enterTextToInsert: string;
|
14
|
+
changeTool: string;
|
15
|
+
pasteHandler: string;
|
16
|
+
soundExplorer: string;
|
17
|
+
disableAccessibilityExploreTool: string;
|
18
|
+
enableAccessibilityExploreTool: string;
|
19
|
+
findLabel: string;
|
20
|
+
toNextMatch: string;
|
21
|
+
closeFindDialog: string;
|
22
|
+
findDialogShown: string;
|
23
|
+
findDialogHidden: string;
|
24
|
+
focusedFoundText: (currentMatchNumber: number, totalMatches: number) => string;
|
25
|
+
anyDevicePanning: string;
|
26
|
+
copied: (count: number, description: string) => string;
|
27
|
+
pasted: (count: number, description: string) => string;
|
28
|
+
toolEnabledAnnouncement: (toolName: string) => string;
|
29
|
+
toolDisabledAnnouncement: (toolName: string) => string;
|
30
|
+
}
|
31
|
+
export declare const defaultToolLocalization: ToolLocalization;
|
@@ -0,0 +1,30 @@
|
|
1
|
+
export const defaultToolLocalization = {
|
2
|
+
penTool: (penId) => `Pen ${penId}`,
|
3
|
+
selectionTool: 'Selection',
|
4
|
+
selectAllTool: 'Select all shortcut',
|
5
|
+
eraserTool: 'Eraser',
|
6
|
+
touchPanTool: 'Touch panning',
|
7
|
+
twoFingerPanZoomTool: 'Panning and zooming',
|
8
|
+
undoRedoTool: 'Undo/Redo',
|
9
|
+
rightClickDragPanTool: 'Right-click drag',
|
10
|
+
pipetteTool: 'Pick color from screen',
|
11
|
+
keyboardPanZoom: 'Keyboard pan/zoom shortcuts',
|
12
|
+
textTool: 'Text',
|
13
|
+
enterTextToInsert: 'Text to insert',
|
14
|
+
changeTool: 'Change tool',
|
15
|
+
pasteHandler: 'Copy paste handler',
|
16
|
+
soundExplorer: 'Sound-based image exploration',
|
17
|
+
disableAccessibilityExploreTool: 'Disable sound-based exploration',
|
18
|
+
enableAccessibilityExploreTool: 'Enable sound-based exploration',
|
19
|
+
findLabel: 'Find',
|
20
|
+
toNextMatch: 'Next',
|
21
|
+
closeFindDialog: 'Close',
|
22
|
+
findDialogShown: 'Find dialog shown',
|
23
|
+
findDialogHidden: 'Find dialog hidden',
|
24
|
+
focusedFoundText: (matchIdx, totalMatches) => `Viewing match ${matchIdx} of ${totalMatches}`,
|
25
|
+
anyDevicePanning: 'Any device panning',
|
26
|
+
copied: (count, description) => `Copied ${count} ${description}`,
|
27
|
+
pasted: (count, description) => `Pasted ${count} ${description}`,
|
28
|
+
toolEnabledAnnouncement: (toolName) => `${toolName} enabled`,
|
29
|
+
toolDisabledAnnouncement: (toolName) => `${toolName} disabled`,
|
30
|
+
};
|
@@ -0,0 +1,151 @@
|
|
1
|
+
import EventDispatcher from './EventDispatcher';
|
2
|
+
import Mat33 from './math/Mat33';
|
3
|
+
import { Point2, Vec2 } from './math/Vec2';
|
4
|
+
import Vec3 from './math/Vec3';
|
5
|
+
import BaseTool from './tools/BaseTool';
|
6
|
+
import AbstractComponent from './components/AbstractComponent';
|
7
|
+
import Rect2 from './math/Rect2';
|
8
|
+
import Pointer from './Pointer';
|
9
|
+
import Color4 from './Color4';
|
10
|
+
import Command from './commands/Command';
|
11
|
+
import BaseWidget from './toolbar/widgets/BaseWidget';
|
12
|
+
export interface PointerEvtListener {
|
13
|
+
onPointerDown(event: PointerEvt): boolean;
|
14
|
+
onPointerMove(event: PointerEvt): void;
|
15
|
+
onPointerUp(event: PointerEvt): void;
|
16
|
+
onGestureCancel(): void;
|
17
|
+
}
|
18
|
+
export declare enum InputEvtType {
|
19
|
+
PointerDownEvt = 0,
|
20
|
+
PointerMoveEvt = 1,
|
21
|
+
PointerUpEvt = 2,
|
22
|
+
GestureCancelEvt = 3,
|
23
|
+
WheelEvt = 4,
|
24
|
+
KeyPressEvent = 5,
|
25
|
+
KeyUpEvent = 6,
|
26
|
+
CopyEvent = 7,
|
27
|
+
PasteEvent = 8
|
28
|
+
}
|
29
|
+
export interface WheelEvt {
|
30
|
+
readonly kind: InputEvtType.WheelEvt;
|
31
|
+
readonly delta: Vec3;
|
32
|
+
readonly screenPos: Point2;
|
33
|
+
}
|
34
|
+
export interface KeyPressEvent {
|
35
|
+
readonly kind: InputEvtType.KeyPressEvent;
|
36
|
+
readonly key: string;
|
37
|
+
readonly ctrlKey: boolean | undefined;
|
38
|
+
readonly altKey: boolean | undefined;
|
39
|
+
}
|
40
|
+
export interface KeyUpEvent {
|
41
|
+
readonly kind: InputEvtType.KeyUpEvent;
|
42
|
+
readonly key: string;
|
43
|
+
readonly ctrlKey: boolean | undefined;
|
44
|
+
readonly altKey: boolean | undefined;
|
45
|
+
}
|
46
|
+
export interface CopyEvent {
|
47
|
+
readonly kind: InputEvtType.CopyEvent;
|
48
|
+
setData(mime: string, data: string): void;
|
49
|
+
}
|
50
|
+
export interface PasteEvent {
|
51
|
+
readonly kind: InputEvtType.PasteEvent;
|
52
|
+
readonly data: string;
|
53
|
+
readonly mime: string;
|
54
|
+
}
|
55
|
+
export interface GestureCancelEvt {
|
56
|
+
readonly kind: InputEvtType.GestureCancelEvt;
|
57
|
+
}
|
58
|
+
interface PointerEvtBase {
|
59
|
+
readonly current: Pointer;
|
60
|
+
readonly allPointers: Pointer[];
|
61
|
+
}
|
62
|
+
export interface PointerDownEvt extends PointerEvtBase {
|
63
|
+
readonly kind: InputEvtType.PointerDownEvt;
|
64
|
+
}
|
65
|
+
export interface PointerMoveEvt extends PointerEvtBase {
|
66
|
+
readonly kind: InputEvtType.PointerMoveEvt;
|
67
|
+
}
|
68
|
+
export interface PointerUpEvt extends PointerEvtBase {
|
69
|
+
readonly kind: InputEvtType.PointerUpEvt;
|
70
|
+
}
|
71
|
+
export type PointerEvt = PointerDownEvt | PointerMoveEvt | PointerUpEvt;
|
72
|
+
export type InputEvt = KeyPressEvent | KeyUpEvent | WheelEvt | GestureCancelEvt | PointerEvt | CopyEvent | PasteEvent;
|
73
|
+
export type EditorNotifier = EventDispatcher<EditorEventType, EditorEventDataType>;
|
74
|
+
export declare enum EditorEventType {
|
75
|
+
ToolEnabled = 0,
|
76
|
+
ToolDisabled = 1,
|
77
|
+
ToolUpdated = 2,
|
78
|
+
UndoRedoStackUpdated = 3,
|
79
|
+
CommandDone = 4,
|
80
|
+
CommandUndone = 5,
|
81
|
+
ObjectAdded = 6,
|
82
|
+
ViewportChanged = 7,
|
83
|
+
DisplayResized = 8,
|
84
|
+
ColorPickerToggled = 9,
|
85
|
+
ColorPickerColorSelected = 10,
|
86
|
+
ToolbarDropdownShown = 11
|
87
|
+
}
|
88
|
+
export declare enum UndoEventType {
|
89
|
+
CommandDone = 0,
|
90
|
+
CommandUndone = 1,
|
91
|
+
CommandRedone = 2
|
92
|
+
}
|
93
|
+
type EditorToolEventType = EditorEventType.ToolEnabled | EditorEventType.ToolDisabled | EditorEventType.ToolUpdated;
|
94
|
+
export interface EditorToolEvent {
|
95
|
+
readonly kind: EditorToolEventType;
|
96
|
+
readonly tool: BaseTool;
|
97
|
+
}
|
98
|
+
export interface EditorObjectEvent {
|
99
|
+
readonly kind: EditorEventType.ObjectAdded;
|
100
|
+
readonly object: AbstractComponent;
|
101
|
+
}
|
102
|
+
export interface EditorViewportChangedEvent {
|
103
|
+
readonly kind: EditorEventType.ViewportChanged;
|
104
|
+
readonly newTransform: Mat33;
|
105
|
+
readonly oldTransform: Mat33;
|
106
|
+
}
|
107
|
+
export interface DisplayResizedEvent {
|
108
|
+
readonly kind: EditorEventType.DisplayResized;
|
109
|
+
readonly newSize: Vec2;
|
110
|
+
}
|
111
|
+
export interface EditorUndoStackUpdated {
|
112
|
+
readonly kind: EditorEventType.UndoRedoStackUpdated;
|
113
|
+
readonly undoStackSize: number;
|
114
|
+
readonly redoStackSize: number;
|
115
|
+
readonly command?: Command;
|
116
|
+
readonly stackUpdateType: UndoEventType;
|
117
|
+
}
|
118
|
+
export interface CommandDoneEvent {
|
119
|
+
readonly kind: EditorEventType.CommandDone;
|
120
|
+
readonly command: Command;
|
121
|
+
}
|
122
|
+
export interface CommandUndoneEvent {
|
123
|
+
readonly kind: EditorEventType.CommandUndone;
|
124
|
+
readonly command: Command;
|
125
|
+
}
|
126
|
+
export interface ColorPickerToggled {
|
127
|
+
readonly kind: EditorEventType.ColorPickerToggled;
|
128
|
+
readonly open: boolean;
|
129
|
+
}
|
130
|
+
export interface ColorPickerColorSelected {
|
131
|
+
readonly kind: EditorEventType.ColorPickerColorSelected;
|
132
|
+
readonly color: Color4;
|
133
|
+
}
|
134
|
+
export interface ToolbarDropdownShownEvent {
|
135
|
+
readonly kind: EditorEventType.ToolbarDropdownShown;
|
136
|
+
readonly parentWidget: BaseWidget;
|
137
|
+
}
|
138
|
+
export type EditorEventDataType = EditorToolEvent | EditorObjectEvent | EditorViewportChangedEvent | DisplayResizedEvent | EditorUndoStackUpdated | CommandDoneEvent | CommandUndoneEvent | ColorPickerToggled | ColorPickerColorSelected | ToolbarDropdownShownEvent;
|
139
|
+
export type OnProgressListener = (amountProcessed: number, totalToProcess: number) => Promise<void> | null | void;
|
140
|
+
export type ComponentAddedListener = (component: AbstractComponent) => Promise<void> | void;
|
141
|
+
export type OnDetermineExportRectListener = (exportRect: Rect2) => void;
|
142
|
+
export interface ImageLoader {
|
143
|
+
start(onAddComponent: ComponentAddedListener, onProgressListener: OnProgressListener, onDetermineExportRect?: OnDetermineExportRectListener): Promise<void>;
|
144
|
+
}
|
145
|
+
export interface StrokeDataPoint {
|
146
|
+
pos: Point2;
|
147
|
+
width: number;
|
148
|
+
time: number;
|
149
|
+
color: Color4;
|
150
|
+
}
|
151
|
+
export {};
|
@@ -0,0 +1,35 @@
|
|
1
|
+
// Types related to the image editor
|
2
|
+
export var InputEvtType;
|
3
|
+
(function (InputEvtType) {
|
4
|
+
InputEvtType[InputEvtType["PointerDownEvt"] = 0] = "PointerDownEvt";
|
5
|
+
InputEvtType[InputEvtType["PointerMoveEvt"] = 1] = "PointerMoveEvt";
|
6
|
+
InputEvtType[InputEvtType["PointerUpEvt"] = 2] = "PointerUpEvt";
|
7
|
+
InputEvtType[InputEvtType["GestureCancelEvt"] = 3] = "GestureCancelEvt";
|
8
|
+
InputEvtType[InputEvtType["WheelEvt"] = 4] = "WheelEvt";
|
9
|
+
InputEvtType[InputEvtType["KeyPressEvent"] = 5] = "KeyPressEvent";
|
10
|
+
InputEvtType[InputEvtType["KeyUpEvent"] = 6] = "KeyUpEvent";
|
11
|
+
InputEvtType[InputEvtType["CopyEvent"] = 7] = "CopyEvent";
|
12
|
+
InputEvtType[InputEvtType["PasteEvent"] = 8] = "PasteEvent";
|
13
|
+
})(InputEvtType || (InputEvtType = {}));
|
14
|
+
export var EditorEventType;
|
15
|
+
(function (EditorEventType) {
|
16
|
+
EditorEventType[EditorEventType["ToolEnabled"] = 0] = "ToolEnabled";
|
17
|
+
EditorEventType[EditorEventType["ToolDisabled"] = 1] = "ToolDisabled";
|
18
|
+
EditorEventType[EditorEventType["ToolUpdated"] = 2] = "ToolUpdated";
|
19
|
+
EditorEventType[EditorEventType["UndoRedoStackUpdated"] = 3] = "UndoRedoStackUpdated";
|
20
|
+
EditorEventType[EditorEventType["CommandDone"] = 4] = "CommandDone";
|
21
|
+
EditorEventType[EditorEventType["CommandUndone"] = 5] = "CommandUndone";
|
22
|
+
EditorEventType[EditorEventType["ObjectAdded"] = 6] = "ObjectAdded";
|
23
|
+
EditorEventType[EditorEventType["ViewportChanged"] = 7] = "ViewportChanged";
|
24
|
+
EditorEventType[EditorEventType["DisplayResized"] = 8] = "DisplayResized";
|
25
|
+
EditorEventType[EditorEventType["ColorPickerToggled"] = 9] = "ColorPickerToggled";
|
26
|
+
EditorEventType[EditorEventType["ColorPickerColorSelected"] = 10] = "ColorPickerColorSelected";
|
27
|
+
EditorEventType[EditorEventType["ToolbarDropdownShown"] = 11] = "ToolbarDropdownShown";
|
28
|
+
})(EditorEventType || (EditorEventType = {}));
|
29
|
+
// Types of `EditorUndoStackUpdated` events.
|
30
|
+
export var UndoEventType;
|
31
|
+
(function (UndoEventType) {
|
32
|
+
UndoEventType[UndoEventType["CommandDone"] = 0] = "CommandDone";
|
33
|
+
UndoEventType[UndoEventType["CommandUndone"] = 1] = "CommandUndone";
|
34
|
+
UndoEventType[UndoEventType["CommandRedone"] = 2] = "CommandRedone";
|
35
|
+
})(UndoEventType || (UndoEventType = {}));
|
@@ -0,0 +1,23 @@
|
|
1
|
+
/**
|
2
|
+
* Compile-time assertion that a branch of code is unreachable.
|
3
|
+
* @internal
|
4
|
+
*/
|
5
|
+
export declare const assertUnreachable: (key: never) => never;
|
6
|
+
/**
|
7
|
+
* Throws an exception if the typeof given value is not a number or `value` is NaN.
|
8
|
+
*
|
9
|
+
* @example
|
10
|
+
* ```ts
|
11
|
+
* const foo: unknown = 3;
|
12
|
+
* assertIsNumber(foo);
|
13
|
+
*
|
14
|
+
* assertIsNumber('hello, world'); // throws an Error.
|
15
|
+
* ```
|
16
|
+
*
|
17
|
+
*
|
18
|
+
*/
|
19
|
+
export declare const assertIsNumber: (value: any, allowNaN?: boolean) => value is number;
|
20
|
+
/**
|
21
|
+
* Throws if any of `values` is not of type number.
|
22
|
+
*/
|
23
|
+
export declare const assertIsNumberArray: (values: any[], allowNaN?: boolean) => values is number[];
|
@@ -0,0 +1,45 @@
|
|
1
|
+
/**
|
2
|
+
* Compile-time assertion that a branch of code is unreachable.
|
3
|
+
* @internal
|
4
|
+
*/
|
5
|
+
export const assertUnreachable = (key) => {
|
6
|
+
// See https://stackoverflow.com/a/39419171/17055750
|
7
|
+
throw new Error(`Should be unreachable. Key: ${key}.`);
|
8
|
+
};
|
9
|
+
/**
|
10
|
+
* Throws an exception if the typeof given value is not a number or `value` is NaN.
|
11
|
+
*
|
12
|
+
* @example
|
13
|
+
* ```ts
|
14
|
+
* const foo: unknown = 3;
|
15
|
+
* assertIsNumber(foo);
|
16
|
+
*
|
17
|
+
* assertIsNumber('hello, world'); // throws an Error.
|
18
|
+
* ```
|
19
|
+
*
|
20
|
+
*
|
21
|
+
*/
|
22
|
+
export const assertIsNumber = (value, allowNaN = false) => {
|
23
|
+
if (typeof value !== 'number' || (!allowNaN && isNaN(value))) {
|
24
|
+
throw new Error('Given value is not a number');
|
25
|
+
// return false;
|
26
|
+
}
|
27
|
+
return true;
|
28
|
+
};
|
29
|
+
/**
|
30
|
+
* Throws if any of `values` is not of type number.
|
31
|
+
*/
|
32
|
+
export const assertIsNumberArray = (values, allowNaN = false) => {
|
33
|
+
if (typeof values !== 'object') {
|
34
|
+
throw new Error('Asserting isNumberArray: Given entity is not an array');
|
35
|
+
}
|
36
|
+
if (!assertIsNumber(values['length'])) {
|
37
|
+
return false;
|
38
|
+
}
|
39
|
+
for (const value of values) {
|
40
|
+
if (!assertIsNumber(value, allowNaN)) {
|
41
|
+
return false;
|
42
|
+
}
|
43
|
+
}
|
44
|
+
return true;
|
45
|
+
};
|
@@ -0,0 +1,13 @@
|
|
1
|
+
const fileToBase64 = (file, onprogress) => {
|
2
|
+
const reader = new FileReader();
|
3
|
+
return new Promise((resolve, reject) => {
|
4
|
+
reader.onload = () => resolve(reader.result);
|
5
|
+
reader.onerror = reject;
|
6
|
+
reader.onabort = reject;
|
7
|
+
reader.onprogress = (evt) => {
|
8
|
+
onprogress === null || onprogress === void 0 ? void 0 : onprogress(evt);
|
9
|
+
};
|
10
|
+
reader.readAsDataURL(file);
|
11
|
+
});
|
12
|
+
};
|
13
|
+
export default fileToBase64;
|
package/package.json
CHANGED
@@ -1,12 +1,12 @@
|
|
1
1
|
{
|
2
2
|
"name": "js-draw",
|
3
|
-
"version": "0.
|
3
|
+
"version": "0.19.0",
|
4
4
|
"description": "Draw pictures using a pen, touchscreen, or mouse! JS-draw is a drawing library for JavaScript and TypeScript. ",
|
5
|
-
"types": "./dist/
|
5
|
+
"types": "./dist/mjs/src/lib.d.ts",
|
6
6
|
"main": "./dist/cjs/src/lib.js",
|
7
7
|
"exports": {
|
8
8
|
".": {
|
9
|
-
"types": "./dist/
|
9
|
+
"types": "./dist/mjs/src/lib.d.ts",
|
10
10
|
"import": "./dist/mjs/src/lib.mjs",
|
11
11
|
"require": "./dist/cjs/src/lib.js"
|
12
12
|
},
|
@@ -20,6 +20,9 @@
|
|
20
20
|
"types": "./dist/mjs/src/bundle/bundled.d.ts",
|
21
21
|
"default": "./dist/bundle.js"
|
22
22
|
},
|
23
|
+
"./bundledStyles": {
|
24
|
+
"default": "./dist/bundledStyles.js"
|
25
|
+
},
|
23
26
|
"./Editor": {
|
24
27
|
"types": "./dist/mjs/src/Editor.d.ts",
|
25
28
|
"default": "./dist/mjs/src/Editor.mjs"
|
@@ -79,7 +82,6 @@
|
|
79
82
|
"postpack": "pinst --enable"
|
80
83
|
},
|
81
84
|
"dependencies": {
|
82
|
-
"@babel/runtime": "^7.21.0",
|
83
85
|
"@melloware/coloris": "^0.18.0",
|
84
86
|
"bezier-js": "^6.1.3"
|
85
87
|
},
|
package/src/Editor.css
ADDED
@@ -0,0 +1,86 @@
|
|
1
|
+
|
2
|
+
@import url('./toolbar/toolbar.css');
|
3
|
+
@import url('./tools/tools.css');
|
4
|
+
|
5
|
+
.imageEditorContainer {
|
6
|
+
/* Deafult colors for the editor */
|
7
|
+
--primary-background-color: white;
|
8
|
+
--primary-background-color-transparent: rgba(255, 255, 255, 0.5);
|
9
|
+
--secondary-background-color: #faf;
|
10
|
+
--primary-foreground-color: black;
|
11
|
+
--secondary-foreground-color: black;
|
12
|
+
--primary-shadow-color: rgba(0, 0, 0, 0.5);
|
13
|
+
}
|
14
|
+
|
15
|
+
@media (prefers-color-scheme: dark) {
|
16
|
+
.imageEditorContainer {
|
17
|
+
--primary-background-color: #151515;
|
18
|
+
--primary-background-color-transparent: rgba(50, 50, 50, 0.5);
|
19
|
+
--secondary-background-color: #607;
|
20
|
+
--primary-foreground-color: white;
|
21
|
+
--secondary-foreground-color: white;
|
22
|
+
--primary-shadow-color: rgba(250, 250, 250, 0.5);
|
23
|
+
}
|
24
|
+
}
|
25
|
+
|
26
|
+
.imageEditorContainer {
|
27
|
+
color: var(--primary-foreground-color);
|
28
|
+
font-family: system-ui, -apple-system, sans-serif;
|
29
|
+
background-color: var(--primary-background-color);
|
30
|
+
|
31
|
+
display: flex;
|
32
|
+
flex-direction: column-reverse;
|
33
|
+
}
|
34
|
+
|
35
|
+
.imageEditorContainer .imageEditorRenderArea {
|
36
|
+
display: grid;
|
37
|
+
grid-template-columns: 1fr;
|
38
|
+
flex-grow: 2;
|
39
|
+
flex-shrink: 1;
|
40
|
+
min-height: 100px;
|
41
|
+
}
|
42
|
+
|
43
|
+
.imageEditorContainer .imageEditorRenderArea canvas {
|
44
|
+
/* Stack all canvases on top of each other */
|
45
|
+
grid-row: 1 / 1;
|
46
|
+
grid-column: 1 / 1;
|
47
|
+
touch-action: none;
|
48
|
+
|
49
|
+
/* Fill the container */
|
50
|
+
box-sizing: border-box;
|
51
|
+
width: 100%;
|
52
|
+
height: 100%;
|
53
|
+
|
54
|
+
/* Allow the canvas to shrink (needed in Chrome) */
|
55
|
+
min-height: 0px;
|
56
|
+
max-height: inherit;
|
57
|
+
}
|
58
|
+
|
59
|
+
.imageEditorContainer .loadingMessage {
|
60
|
+
position: fixed;
|
61
|
+
text-align: center;
|
62
|
+
font-size: 2em;
|
63
|
+
|
64
|
+
bottom: 0;
|
65
|
+
left: 0;
|
66
|
+
right: 0;
|
67
|
+
}
|
68
|
+
|
69
|
+
.imageEditorContainer .accessibilityAnnouncement {
|
70
|
+
opacity: 0;
|
71
|
+
width: 0;
|
72
|
+
height: 0;
|
73
|
+
overflow: hidden;
|
74
|
+
pointer-events: none;
|
75
|
+
}
|
76
|
+
|
77
|
+
.imageEditorContainer .textRendererOutputContainer {
|
78
|
+
width: 1px;
|
79
|
+
height: 1px;
|
80
|
+
overflow: hidden;
|
81
|
+
}
|
82
|
+
|
83
|
+
.imageEditorContainer .textRendererOutputContainer:focus-within {
|
84
|
+
overflow: visible;
|
85
|
+
z-index: 5;
|
86
|
+
}
|