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,139 @@
|
|
1
|
+
import Color4 from '../Color4.mjs';
|
2
|
+
import { EditorImageEventType } from '../EditorImage.mjs';
|
3
|
+
import Rect2 from '../math/Rect2.mjs';
|
4
|
+
import AbstractComponent from './AbstractComponent.mjs';
|
5
|
+
import { createRestyleComponentCommand } from './RestylableComponent.mjs';
|
6
|
+
export var BackgroundType;
|
7
|
+
(function (BackgroundType) {
|
8
|
+
BackgroundType[BackgroundType["SolidColor"] = 0] = "SolidColor";
|
9
|
+
BackgroundType[BackgroundType["None"] = 1] = "None";
|
10
|
+
})(BackgroundType || (BackgroundType = {}));
|
11
|
+
export const imageBackgroundCSSClassName = 'js-draw-image-background';
|
12
|
+
// Represents the background of the editor's canvas.
|
13
|
+
export default class ImageBackground extends AbstractComponent {
|
14
|
+
constructor(backgroundType, mainColor) {
|
15
|
+
super('image-background', 0);
|
16
|
+
this.backgroundType = backgroundType;
|
17
|
+
this.mainColor = mainColor;
|
18
|
+
this.viewportSizeChangeListener = null;
|
19
|
+
// eslint-disable-next-line @typescript-eslint/prefer-as-const
|
20
|
+
this.isRestylableComponent = true;
|
21
|
+
this.contentBBox = Rect2.empty;
|
22
|
+
}
|
23
|
+
getStyle() {
|
24
|
+
let color = this.mainColor;
|
25
|
+
if (this.backgroundType === BackgroundType.None) {
|
26
|
+
color = undefined;
|
27
|
+
}
|
28
|
+
return {
|
29
|
+
color,
|
30
|
+
};
|
31
|
+
}
|
32
|
+
updateStyle(style) {
|
33
|
+
return createRestyleComponentCommand(this.getStyle(), style, this);
|
34
|
+
}
|
35
|
+
// @internal
|
36
|
+
forceStyle(style, editor) {
|
37
|
+
const fill = style.color;
|
38
|
+
if (!fill) {
|
39
|
+
return;
|
40
|
+
}
|
41
|
+
this.mainColor = fill;
|
42
|
+
if (fill.eq(Color4.transparent)) {
|
43
|
+
this.backgroundType = BackgroundType.None;
|
44
|
+
}
|
45
|
+
else {
|
46
|
+
this.backgroundType = BackgroundType.SolidColor;
|
47
|
+
}
|
48
|
+
if (editor) {
|
49
|
+
editor.image.queueRerenderOf(this);
|
50
|
+
editor.queueRerender();
|
51
|
+
}
|
52
|
+
}
|
53
|
+
onAddToImage(image) {
|
54
|
+
if (this.viewportSizeChangeListener) {
|
55
|
+
console.warn('onAddToImage called when background is already in an image');
|
56
|
+
this.onRemoveFromImage();
|
57
|
+
}
|
58
|
+
this.viewportSizeChangeListener = image.notifier.on(EditorImageEventType.ExportViewportChanged, () => {
|
59
|
+
this.recomputeBBox(image);
|
60
|
+
});
|
61
|
+
this.recomputeBBox(image);
|
62
|
+
}
|
63
|
+
onRemoveFromImage() {
|
64
|
+
var _a;
|
65
|
+
(_a = this.viewportSizeChangeListener) === null || _a === void 0 ? void 0 : _a.remove();
|
66
|
+
this.viewportSizeChangeListener = null;
|
67
|
+
}
|
68
|
+
recomputeBBox(image) {
|
69
|
+
const importExportRect = image.getImportExportViewport().visibleRect;
|
70
|
+
if (!this.contentBBox.eq(importExportRect)) {
|
71
|
+
this.contentBBox = importExportRect;
|
72
|
+
// Re-render this if already added to the EditorImage.
|
73
|
+
image.queueRerenderOf(this);
|
74
|
+
}
|
75
|
+
}
|
76
|
+
render(canvas, visibleRect) {
|
77
|
+
if (this.backgroundType === BackgroundType.None) {
|
78
|
+
return;
|
79
|
+
}
|
80
|
+
canvas.startObject(this.contentBBox);
|
81
|
+
if (this.backgroundType === BackgroundType.SolidColor) {
|
82
|
+
// If the rectangle for this region contains the visible rect,
|
83
|
+
// we can fill the entire visible rectangle (which may be more efficient than
|
84
|
+
// filling the entire region for this.)
|
85
|
+
if (visibleRect) {
|
86
|
+
const intersection = visibleRect.intersection(this.contentBBox);
|
87
|
+
if (intersection) {
|
88
|
+
canvas.fillRect(intersection, this.mainColor);
|
89
|
+
}
|
90
|
+
}
|
91
|
+
else {
|
92
|
+
canvas.fillRect(this.contentBBox, this.mainColor);
|
93
|
+
}
|
94
|
+
}
|
95
|
+
canvas.endObject(this.getLoadSaveData(), [imageBackgroundCSSClassName]);
|
96
|
+
}
|
97
|
+
intersects(lineSegment) {
|
98
|
+
return this.contentBBox.getEdges().some(edge => edge.intersects(lineSegment));
|
99
|
+
}
|
100
|
+
isSelectable() {
|
101
|
+
return false;
|
102
|
+
}
|
103
|
+
isBackground() {
|
104
|
+
return true;
|
105
|
+
}
|
106
|
+
serializeToJSON() {
|
107
|
+
return {
|
108
|
+
mainColor: this.mainColor.toHexString(),
|
109
|
+
backgroundType: this.backgroundType,
|
110
|
+
};
|
111
|
+
}
|
112
|
+
applyTransformation(_affineTransfm) {
|
113
|
+
// Do nothing — it doesn't make sense to transform the background.
|
114
|
+
}
|
115
|
+
description(localizationTable) {
|
116
|
+
if (this.backgroundType === BackgroundType.SolidColor) {
|
117
|
+
return localizationTable.filledBackgroundWithColor(this.mainColor.toString());
|
118
|
+
}
|
119
|
+
else {
|
120
|
+
return localizationTable.emptyBackground;
|
121
|
+
}
|
122
|
+
}
|
123
|
+
createClone() {
|
124
|
+
return new ImageBackground(this.backgroundType, this.mainColor);
|
125
|
+
}
|
126
|
+
// @internal
|
127
|
+
static deserializeFromJSON(json) {
|
128
|
+
if (typeof json === 'string') {
|
129
|
+
json = JSON.parse(json);
|
130
|
+
}
|
131
|
+
if (typeof json.mainColor !== 'string') {
|
132
|
+
throw new Error('Error deserializing — mainColor must be of type string.');
|
133
|
+
}
|
134
|
+
const backgroundType = json.backgroundType === BackgroundType.SolidColor ? BackgroundType.SolidColor : BackgroundType.None;
|
135
|
+
const mainColor = Color4.fromHex(json.mainColor);
|
136
|
+
return new ImageBackground(backgroundType, mainColor);
|
137
|
+
}
|
138
|
+
}
|
139
|
+
AbstractComponent.registerComponent('image-background', ImageBackground.deserializeFromJSON);
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import LineSegment2 from '../math/LineSegment2';
|
2
|
+
import Mat33, { Mat33Array } from '../math/Mat33';
|
3
|
+
import Rect2 from '../math/Rect2';
|
4
|
+
import AbstractRenderer, { RenderableImage } from '../rendering/renderers/AbstractRenderer';
|
5
|
+
import AbstractComponent from './AbstractComponent';
|
6
|
+
import { ImageComponentLocalization } from './localization';
|
7
|
+
export default class ImageComponent extends AbstractComponent {
|
8
|
+
protected contentBBox: Rect2;
|
9
|
+
private image;
|
10
|
+
constructor(image: RenderableImage);
|
11
|
+
private getImageRect;
|
12
|
+
private recomputeBBox;
|
13
|
+
static fromImage(elem: HTMLImageElement, transform: Mat33): Promise<ImageComponent>;
|
14
|
+
render(canvas: AbstractRenderer, _visibleRect?: Rect2): void;
|
15
|
+
getProportionalRenderingTime(): number;
|
16
|
+
intersects(lineSegment: LineSegment2): boolean;
|
17
|
+
protected serializeToJSON(): {
|
18
|
+
src: string;
|
19
|
+
label: string | undefined;
|
20
|
+
width: number;
|
21
|
+
height: number;
|
22
|
+
transform: Mat33Array;
|
23
|
+
};
|
24
|
+
protected applyTransformation(affineTransfm: Mat33): void;
|
25
|
+
description(localizationTable: ImageComponentLocalization): string;
|
26
|
+
getAltText(): string | undefined;
|
27
|
+
getURL(): string;
|
28
|
+
getTransformation(): Mat33;
|
29
|
+
protected createClone(): AbstractComponent;
|
30
|
+
static deserializeFromJSON(data: any): ImageComponent;
|
31
|
+
}
|
@@ -0,0 +1,146 @@
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
8
|
+
});
|
9
|
+
};
|
10
|
+
import Mat33 from '../math/Mat33.mjs';
|
11
|
+
import Rect2 from '../math/Rect2.mjs';
|
12
|
+
import AbstractComponent from './AbstractComponent.mjs';
|
13
|
+
// Represents a raster image.
|
14
|
+
export default class ImageComponent extends AbstractComponent {
|
15
|
+
constructor(image) {
|
16
|
+
var _a, _b, _c;
|
17
|
+
super('image-component');
|
18
|
+
this.image = Object.assign(Object.assign({}, image), { label: (_c = (_b = (_a = image.label) !== null && _a !== void 0 ? _a : image.image.getAttribute('alt')) !== null && _b !== void 0 ? _b : image.image.getAttribute('aria-label')) !== null && _c !== void 0 ? _c : undefined });
|
19
|
+
const isHTMLImageElem = (elem) => {
|
20
|
+
return elem.getAttribute('src') !== undefined;
|
21
|
+
};
|
22
|
+
if (isHTMLImageElem(image.image) && !image.image.complete) {
|
23
|
+
image.image.onload = () => this.recomputeBBox();
|
24
|
+
}
|
25
|
+
this.recomputeBBox();
|
26
|
+
}
|
27
|
+
getImageRect() {
|
28
|
+
return new Rect2(0, 0, this.image.image.width, this.image.image.height);
|
29
|
+
}
|
30
|
+
recomputeBBox() {
|
31
|
+
this.contentBBox = this.getImageRect();
|
32
|
+
this.contentBBox = this.contentBBox.transformedBoundingBox(this.image.transform);
|
33
|
+
}
|
34
|
+
// Load from an image. Waits for the image to load if incomplete.
|
35
|
+
static fromImage(elem, transform) {
|
36
|
+
var _a, _b, _c;
|
37
|
+
return __awaiter(this, void 0, void 0, function* () {
|
38
|
+
if (!elem.complete) {
|
39
|
+
yield new Promise((resolve, reject) => {
|
40
|
+
elem.onload = resolve;
|
41
|
+
elem.onerror = reject;
|
42
|
+
elem.onabort = reject;
|
43
|
+
});
|
44
|
+
}
|
45
|
+
let width, height;
|
46
|
+
if (typeof elem.width === 'number' && typeof elem.height === 'number'
|
47
|
+
&& elem.width !== 0 && elem.height !== 0) {
|
48
|
+
width = elem.width;
|
49
|
+
height = elem.height;
|
50
|
+
}
|
51
|
+
else {
|
52
|
+
width = elem.clientWidth;
|
53
|
+
height = elem.clientHeight;
|
54
|
+
}
|
55
|
+
let image;
|
56
|
+
let url = (_a = elem.src) !== null && _a !== void 0 ? _a : '';
|
57
|
+
if (!url.startsWith('data:image/')) {
|
58
|
+
// Convert to a data URL:
|
59
|
+
const canvas = document.createElement('canvas');
|
60
|
+
canvas.width = width;
|
61
|
+
canvas.height = height;
|
62
|
+
const ctx = canvas.getContext('2d');
|
63
|
+
ctx.drawImage(elem, 0, 0, canvas.width, canvas.height);
|
64
|
+
url = canvas.toDataURL();
|
65
|
+
image = canvas;
|
66
|
+
}
|
67
|
+
else {
|
68
|
+
image = new Image();
|
69
|
+
image.src = url;
|
70
|
+
image.width = width;
|
71
|
+
image.height = height;
|
72
|
+
}
|
73
|
+
image.setAttribute('alt', (_b = elem.getAttribute('alt')) !== null && _b !== void 0 ? _b : '');
|
74
|
+
image.setAttribute('aria-label', (_c = elem.getAttribute('aria-label')) !== null && _c !== void 0 ? _c : '');
|
75
|
+
return new ImageComponent({
|
76
|
+
image,
|
77
|
+
base64Url: url,
|
78
|
+
transform: transform,
|
79
|
+
});
|
80
|
+
});
|
81
|
+
}
|
82
|
+
render(canvas, _visibleRect) {
|
83
|
+
canvas.startObject(this.contentBBox);
|
84
|
+
canvas.drawImage(this.image);
|
85
|
+
canvas.endObject(this.getLoadSaveData());
|
86
|
+
}
|
87
|
+
getProportionalRenderingTime() {
|
88
|
+
// Estimate: Equivalent to a stroke with 10 segments.
|
89
|
+
return 10;
|
90
|
+
}
|
91
|
+
intersects(lineSegment) {
|
92
|
+
const rect = this.getImageRect();
|
93
|
+
const edges = rect.getEdges().map(edge => edge.transformedBy(this.image.transform));
|
94
|
+
for (const edge of edges) {
|
95
|
+
if (edge.intersects(lineSegment)) {
|
96
|
+
return true;
|
97
|
+
}
|
98
|
+
}
|
99
|
+
return false;
|
100
|
+
}
|
101
|
+
serializeToJSON() {
|
102
|
+
return {
|
103
|
+
src: this.image.base64Url,
|
104
|
+
label: this.image.label,
|
105
|
+
// Store the width and height for bounding box computations while the image is loading.
|
106
|
+
width: this.image.image.width,
|
107
|
+
height: this.image.image.height,
|
108
|
+
transform: this.image.transform.toArray(),
|
109
|
+
};
|
110
|
+
}
|
111
|
+
applyTransformation(affineTransfm) {
|
112
|
+
this.image.transform = affineTransfm.rightMul(this.image.transform);
|
113
|
+
this.recomputeBBox();
|
114
|
+
}
|
115
|
+
description(localizationTable) {
|
116
|
+
return this.image.label ? localizationTable.imageNode(this.image.label) : localizationTable.unlabeledImageNode;
|
117
|
+
}
|
118
|
+
getAltText() {
|
119
|
+
return this.image.label;
|
120
|
+
}
|
121
|
+
getURL() {
|
122
|
+
return this.image.base64Url;
|
123
|
+
}
|
124
|
+
getTransformation() {
|
125
|
+
return this.image.transform;
|
126
|
+
}
|
127
|
+
createClone() {
|
128
|
+
return new ImageComponent(Object.assign({}, this.image));
|
129
|
+
}
|
130
|
+
static deserializeFromJSON(data) {
|
131
|
+
if (!(typeof data.src === 'string')) {
|
132
|
+
throw new Error(`${data} has invalid format! Expected src property.`);
|
133
|
+
}
|
134
|
+
const image = new Image();
|
135
|
+
image.src = data.src;
|
136
|
+
image.width = data.width;
|
137
|
+
image.height = data.height;
|
138
|
+
return new ImageComponent({
|
139
|
+
image: image,
|
140
|
+
base64Url: image.src,
|
141
|
+
label: data.label,
|
142
|
+
transform: new Mat33(...data.transform),
|
143
|
+
});
|
144
|
+
}
|
145
|
+
}
|
146
|
+
AbstractComponent.registerComponent('image-component', ImageComponent.deserializeFromJSON);
|
@@ -0,0 +1,43 @@
|
|
1
|
+
import Color4 from '../Color4';
|
2
|
+
import SerializableCommand from '../commands/SerializableCommand';
|
3
|
+
import Editor from '../Editor';
|
4
|
+
import TextRenderingStyle from '../rendering/TextRenderingStyle';
|
5
|
+
import AbstractComponent from './AbstractComponent';
|
6
|
+
export interface ComponentStyle {
|
7
|
+
color?: Color4;
|
8
|
+
textStyle?: TextRenderingStyle;
|
9
|
+
}
|
10
|
+
export declare const createRestyleComponentCommand: (initialStyle: ComponentStyle, newStyle: ComponentStyle, component: RestyleableComponent) => SerializableCommand;
|
11
|
+
export declare const isRestylableComponent: (component: AbstractComponent) => component is RestyleableComponent;
|
12
|
+
/**
|
13
|
+
* An interface to be implemented by components with a changable color or {@link TextRenderingStyle}.
|
14
|
+
*
|
15
|
+
* All such classes must have a member variable, `isRestylableComponent` that is set to `true`
|
16
|
+
* to allow testing whether the class is a `RestylableComponent` (see {@link isRestylableComponent}).
|
17
|
+
*/
|
18
|
+
export interface RestyleableComponent extends AbstractComponent {
|
19
|
+
/**
|
20
|
+
* @returns a partial representation of this component's style.
|
21
|
+
*/
|
22
|
+
getStyle(): ComponentStyle;
|
23
|
+
/**
|
24
|
+
* Returns a {@link Command} that updates portions of this component's style
|
25
|
+
* to the given `style`.
|
26
|
+
*
|
27
|
+
* @example
|
28
|
+
* For some component and editor,
|
29
|
+
* ```ts
|
30
|
+
* editor.dispatch(component.updateStyle({ color: Color4.red }));
|
31
|
+
* ```
|
32
|
+
*/
|
33
|
+
updateStyle(style: ComponentStyle): SerializableCommand;
|
34
|
+
/**
|
35
|
+
* Set the style of this component in a way that can't be undone/redone
|
36
|
+
* (does not create a command).
|
37
|
+
*
|
38
|
+
* Prefer `updateStyle(style).apply(editor)`.
|
39
|
+
*/
|
40
|
+
forceStyle(style: ComponentStyle, editor: Editor | null): void;
|
41
|
+
isRestylableComponent: true;
|
42
|
+
}
|
43
|
+
export default RestyleableComponent;
|
@@ -0,0 +1,80 @@
|
|
1
|
+
import Color4 from '../Color4.mjs';
|
2
|
+
import SerializableCommand from '../commands/SerializableCommand.mjs';
|
3
|
+
import UnresolvedSerializableCommand from '../commands/UnresolvedCommand.mjs';
|
4
|
+
import { textStyleFromJSON, textStyleToJSON } from '../rendering/TextRenderingStyle.mjs';
|
5
|
+
const serializeComponentStyle = (style) => {
|
6
|
+
const result = {};
|
7
|
+
if (style.color) {
|
8
|
+
result.color = style.color.toHexString();
|
9
|
+
}
|
10
|
+
if (style.textStyle) {
|
11
|
+
result.textStyle = textStyleToJSON(style.textStyle);
|
12
|
+
}
|
13
|
+
return result;
|
14
|
+
};
|
15
|
+
const deserializeComponentStyle = (json) => {
|
16
|
+
const color = json.color ? Color4.fromHex(json.color) : undefined;
|
17
|
+
const textStyle = json.textStyle ? textStyleFromJSON(json.textStyle) : undefined;
|
18
|
+
return {
|
19
|
+
color,
|
20
|
+
textStyle,
|
21
|
+
};
|
22
|
+
};
|
23
|
+
// For internal use by Components implementing `updateStyle`:
|
24
|
+
export const createRestyleComponentCommand = (initialStyle, newStyle, component) => {
|
25
|
+
return new DefaultRestyleComponentCommand(initialStyle, newStyle, component.getId(), component);
|
26
|
+
};
|
27
|
+
// Returns true if `component` is a `RestylableComponent`.
|
28
|
+
export const isRestylableComponent = (component) => {
|
29
|
+
const hasMethods = 'getStyle' in component && 'updateStyle' in component && 'forceStyle' in component;
|
30
|
+
if (!hasMethods) {
|
31
|
+
return false;
|
32
|
+
}
|
33
|
+
if (!('isRestylableComponent' in component) || !component['isRestylableComponent']) {
|
34
|
+
return false;
|
35
|
+
}
|
36
|
+
return true;
|
37
|
+
};
|
38
|
+
const defaultRestyleComponentCommandId = 'default-restyle-element';
|
39
|
+
class DefaultRestyleComponentCommand extends UnresolvedSerializableCommand {
|
40
|
+
constructor(originalStyle, newStyle, componentID, component) {
|
41
|
+
super(defaultRestyleComponentCommandId, componentID, component);
|
42
|
+
this.originalStyle = originalStyle;
|
43
|
+
this.newStyle = newStyle;
|
44
|
+
}
|
45
|
+
getComponent(editor) {
|
46
|
+
this.resolveComponent(editor.image);
|
47
|
+
const component = this.component;
|
48
|
+
if (!component || !component['forceStyle'] || !component['updateStyle']) {
|
49
|
+
throw new Error('this.component is missing forceStyle and/or updateStyle methods!');
|
50
|
+
}
|
51
|
+
return component;
|
52
|
+
}
|
53
|
+
apply(editor) {
|
54
|
+
this.getComponent(editor).forceStyle(this.newStyle, editor);
|
55
|
+
}
|
56
|
+
unapply(editor) {
|
57
|
+
this.getComponent(editor).forceStyle(this.originalStyle, editor);
|
58
|
+
}
|
59
|
+
description(editor, localizationTable) {
|
60
|
+
return localizationTable.restyledElement(this.getComponent(editor).description(localizationTable));
|
61
|
+
}
|
62
|
+
serializeToJSON() {
|
63
|
+
return {
|
64
|
+
id: this.componentID,
|
65
|
+
originalStyle: serializeComponentStyle(this.originalStyle),
|
66
|
+
newStyle: serializeComponentStyle(this.newStyle),
|
67
|
+
};
|
68
|
+
}
|
69
|
+
}
|
70
|
+
(() => {
|
71
|
+
SerializableCommand.register(defaultRestyleComponentCommandId, (json, _editor) => {
|
72
|
+
const origStyle = deserializeComponentStyle(json.originalStyle);
|
73
|
+
const newStyle = deserializeComponentStyle(json.newStyle);
|
74
|
+
const id = json.id;
|
75
|
+
if (typeof json.id !== 'string') {
|
76
|
+
throw new Error(`json.id is of type ${(typeof json.id)}, not string.`);
|
77
|
+
}
|
78
|
+
return new DefaultRestyleComponentCommand(origStyle, newStyle, id);
|
79
|
+
});
|
80
|
+
})();
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import LineSegment2 from '../math/LineSegment2';
|
2
|
+
import Mat33 from '../math/Mat33';
|
3
|
+
import Rect2 from '../math/Rect2';
|
4
|
+
import AbstractRenderer from '../rendering/renderers/AbstractRenderer';
|
5
|
+
import AbstractComponent from './AbstractComponent';
|
6
|
+
import { ImageComponentLocalization } from './localization';
|
7
|
+
type GlobalAttrsList = Array<[string, string | null]>;
|
8
|
+
export default class SVGGlobalAttributesObject extends AbstractComponent {
|
9
|
+
private readonly attrs;
|
10
|
+
protected contentBBox: Rect2;
|
11
|
+
constructor(attrs: GlobalAttrsList);
|
12
|
+
render(canvas: AbstractRenderer, _visibleRect?: Rect2): void;
|
13
|
+
intersects(_lineSegment: LineSegment2): boolean;
|
14
|
+
protected applyTransformation(_affineTransfm: Mat33): void;
|
15
|
+
isSelectable(): boolean;
|
16
|
+
protected createClone(): SVGGlobalAttributesObject;
|
17
|
+
description(localization: ImageComponentLocalization): string;
|
18
|
+
protected serializeToJSON(): string | null;
|
19
|
+
static deserializeFromString(data: string): AbstractComponent;
|
20
|
+
}
|
21
|
+
export {};
|
@@ -0,0 +1,59 @@
|
|
1
|
+
//
|
2
|
+
// Used by `SVGLoader`s to store unrecognised global attributes
|
3
|
+
// (e.g. unrecognised XML namespace declarations).
|
4
|
+
// @internal
|
5
|
+
// @packageDocumentation
|
6
|
+
//
|
7
|
+
import Rect2 from '../math/Rect2.mjs';
|
8
|
+
import SVGRenderer from '../rendering/renderers/SVGRenderer.mjs';
|
9
|
+
import AbstractComponent from './AbstractComponent.mjs';
|
10
|
+
const componentKind = 'svg-global-attributes';
|
11
|
+
// Stores global SVG attributes (e.g. namespace identifiers.)
|
12
|
+
export default class SVGGlobalAttributesObject extends AbstractComponent {
|
13
|
+
constructor(attrs) {
|
14
|
+
super(componentKind);
|
15
|
+
this.attrs = attrs;
|
16
|
+
this.contentBBox = Rect2.empty;
|
17
|
+
}
|
18
|
+
render(canvas, _visibleRect) {
|
19
|
+
if (!(canvas instanceof SVGRenderer)) {
|
20
|
+
// Don't draw unrenderable objects if we can't
|
21
|
+
return;
|
22
|
+
}
|
23
|
+
for (const [attr, value] of this.attrs) {
|
24
|
+
canvas.setRootSVGAttribute(attr, value);
|
25
|
+
}
|
26
|
+
}
|
27
|
+
intersects(_lineSegment) {
|
28
|
+
return false;
|
29
|
+
}
|
30
|
+
applyTransformation(_affineTransfm) {
|
31
|
+
}
|
32
|
+
isSelectable() {
|
33
|
+
return false;
|
34
|
+
}
|
35
|
+
createClone() {
|
36
|
+
return new SVGGlobalAttributesObject(this.attrs);
|
37
|
+
}
|
38
|
+
description(localization) {
|
39
|
+
return localization.svgObject;
|
40
|
+
}
|
41
|
+
serializeToJSON() {
|
42
|
+
return JSON.stringify(this.attrs);
|
43
|
+
}
|
44
|
+
static deserializeFromString(data) {
|
45
|
+
const json = JSON.parse(data);
|
46
|
+
const attrs = [];
|
47
|
+
const numericAndSpaceContentExp = /^[ \t\n0-9.-eE]+$/;
|
48
|
+
// Don't deserialize all attributes, just those that should be safe.
|
49
|
+
for (const [key, val] of json) {
|
50
|
+
if (key === 'viewBox' || key === 'width' || key === 'height') {
|
51
|
+
if (val && numericAndSpaceContentExp.exec(val)) {
|
52
|
+
attrs.push([key, val]);
|
53
|
+
}
|
54
|
+
}
|
55
|
+
}
|
56
|
+
return new SVGGlobalAttributesObject(attrs);
|
57
|
+
}
|
58
|
+
}
|
59
|
+
AbstractComponent.registerComponent(componentKind, SVGGlobalAttributesObject.deserializeFromString);
|
@@ -0,0 +1,75 @@
|
|
1
|
+
import SerializableCommand from '../commands/SerializableCommand';
|
2
|
+
import LineSegment2 from '../math/LineSegment2';
|
3
|
+
import Mat33 from '../math/Mat33';
|
4
|
+
import Path from '../math/Path';
|
5
|
+
import Rect2 from '../math/Rect2';
|
6
|
+
import Editor from '../Editor';
|
7
|
+
import AbstractRenderer, { RenderablePathSpec } from '../rendering/renderers/AbstractRenderer';
|
8
|
+
import AbstractComponent from './AbstractComponent';
|
9
|
+
import { ImageComponentLocalization } from './localization';
|
10
|
+
import RestyleableComponent, { ComponentStyle } from './RestylableComponent';
|
11
|
+
/**
|
12
|
+
* Represents an {@link AbstractComponent} made up of one or more {@link Path}s.
|
13
|
+
*
|
14
|
+
* @example
|
15
|
+
* For some {@link Editor} editor and `Stroke` stroke,
|
16
|
+
*
|
17
|
+
* **Restyling**:
|
18
|
+
* ```ts
|
19
|
+
* editor.dispatch(stroke.updateStyle({ color: Color4.red }));
|
20
|
+
* ```
|
21
|
+
*
|
22
|
+
* **Transforming**:
|
23
|
+
* ```ts
|
24
|
+
* editor.dispatch(stroke.transformBy(Mat33.translation(Vec2.of(10, 0))));
|
25
|
+
* ```
|
26
|
+
*/
|
27
|
+
export default class Stroke extends AbstractComponent implements RestyleableComponent {
|
28
|
+
private parts;
|
29
|
+
protected contentBBox: Rect2;
|
30
|
+
readonly isRestylableComponent: true;
|
31
|
+
private approximateRenderingTime;
|
32
|
+
/**
|
33
|
+
* Creates a `Stroke` from the given `parts`. All parts should have the
|
34
|
+
* same color.
|
35
|
+
*
|
36
|
+
* @example
|
37
|
+
* ```ts
|
38
|
+
* // A path that starts at (1,1), moves to the right by (2, 0),
|
39
|
+
* // then moves down and right by (3, 3)
|
40
|
+
* const path = Path.fromString('m1,1 2,0 3,3');
|
41
|
+
*
|
42
|
+
* const stroke = new Stroke([
|
43
|
+
* // Fill with red
|
44
|
+
* path.toRenderable({ fill: Color4.red })
|
45
|
+
* ]);
|
46
|
+
* ```
|
47
|
+
*/
|
48
|
+
constructor(parts: RenderablePathSpec[]);
|
49
|
+
getStyle(): ComponentStyle;
|
50
|
+
updateStyle(style: ComponentStyle): SerializableCommand;
|
51
|
+
forceStyle(style: ComponentStyle, editor: Editor | null): void;
|
52
|
+
intersects(line: LineSegment2): boolean;
|
53
|
+
render(canvas: AbstractRenderer, visibleRect?: Rect2): void;
|
54
|
+
getProportionalRenderingTime(): number;
|
55
|
+
private bboxForPart;
|
56
|
+
protected applyTransformation(affineTransfm: Mat33): void;
|
57
|
+
/**
|
58
|
+
* @returns the {@link Path.union} of all paths that make up this stroke.
|
59
|
+
*/
|
60
|
+
getPath(): Path;
|
61
|
+
description(localization: ImageComponentLocalization): string;
|
62
|
+
protected createClone(): AbstractComponent;
|
63
|
+
protected serializeToJSON(): {
|
64
|
+
style: {
|
65
|
+
fill: string;
|
66
|
+
stroke: {
|
67
|
+
color: string;
|
68
|
+
width: number;
|
69
|
+
} | undefined;
|
70
|
+
};
|
71
|
+
path: string;
|
72
|
+
}[];
|
73
|
+
/** @internal */
|
74
|
+
static deserializeFromJSON(json: any): Stroke;
|
75
|
+
}
|