js-draw 0.18.1 → 0.18.2
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 +3 -0
- package/dist/cjs/src/Color4.d.ts +61 -0
- package/dist/cjs/src/Color4.js +197 -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 +472 -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 +24 -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 +40 -0
- package/dist/cjs/src/components/Stroke.js +191 -0
- package/dist/cjs/src/components/TextComponent.d.ts +53 -0
- package/dist/cjs/src/components/TextComponent.js +258 -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 +12 -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 +34 -0
- package/dist/cjs/src/lib.js +63 -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 +5 -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/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 +187 -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 +16 -0
- package/dist/cjs/src/tools/lib.js +36 -0
- package/dist/cjs/src/tools/localization.d.ts +28 -0
- package/dist/cjs/src/tools/localization.js +30 -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 +61 -0
- package/dist/mjs/src/Color4.mjs +193 -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 +442 -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 +24 -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 +40 -0
- package/dist/mjs/src/components/Stroke.mjs +185 -0
- package/dist/mjs/src/components/TextComponent.d.ts +53 -0
- package/dist/mjs/src/components/TextComponent.mjs +252 -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 +12 -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 +34 -0
- package/dist/mjs/src/lib.mjs +34 -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 +5 -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/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 +158 -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 +16 -0
- package/dist/mjs/src/tools/lib.mjs +16 -0
- package/dist/mjs/src/tools/localization.d.ts +28 -0
- package/dist/mjs/src/tools/localization.mjs +27 -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 +1 -1
- package/src/Color4.test.ts +40 -0
- package/src/Color4.ts +236 -0
- package/src/Editor.css +86 -0
- package/src/Editor.loadFrom.test.ts +24 -0
- package/src/Editor.toSVG.test.ts +111 -0
- package/src/Editor.ts +1122 -0
- package/src/EditorImage.test.ts +120 -0
- package/src/EditorImage.ts +603 -0
- package/src/EventDispatcher.test.ts +123 -0
- package/src/EventDispatcher.ts +71 -0
- package/src/Pointer.ts +127 -0
- package/src/SVGLoader.test.ts +114 -0
- package/src/SVGLoader.ts +511 -0
- package/src/UndoRedoHistory.test.ts +33 -0
- package/src/UndoRedoHistory.ts +102 -0
- package/src/Viewport.ts +319 -0
- package/src/bundle/bundled.ts +7 -0
- package/src/commands/Command.ts +45 -0
- package/src/commands/Duplicate.ts +48 -0
- package/src/commands/Erase.ts +74 -0
- package/src/commands/SerializableCommand.ts +49 -0
- package/src/commands/UnresolvedCommand.ts +37 -0
- package/src/commands/invertCommand.ts +51 -0
- package/src/commands/lib.ts +16 -0
- package/src/commands/localization.ts +47 -0
- package/src/commands/uniteCommands.test.ts +23 -0
- package/src/commands/uniteCommands.ts +135 -0
- package/src/components/AbstractComponent.transformBy.test.ts +22 -0
- package/src/components/AbstractComponent.ts +364 -0
- package/src/components/ImageBackground.test.ts +35 -0
- package/src/components/ImageBackground.ts +176 -0
- package/src/components/ImageComponent.ts +171 -0
- package/src/components/RestylableComponent.ts +142 -0
- package/src/components/SVGGlobalAttributesObject.ts +81 -0
- package/src/components/Stroke.test.ts +139 -0
- package/src/components/Stroke.ts +245 -0
- package/src/components/TextComponent.test.ts +99 -0
- package/src/components/TextComponent.ts +315 -0
- package/src/components/UnknownSVGObject.test.ts +10 -0
- package/src/components/UnknownSVGObject.ts +60 -0
- package/src/components/builders/ArrowBuilder.ts +107 -0
- package/src/components/builders/FreehandLineBuilder.ts +212 -0
- package/src/components/builders/LineBuilder.ts +77 -0
- package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +454 -0
- package/src/components/builders/RectangleBuilder.ts +74 -0
- package/src/components/builders/types.ts +15 -0
- package/src/components/lib.ts +25 -0
- package/src/components/localization.ts +22 -0
- package/src/components/util/StrokeSmoother.ts +293 -0
- package/src/components/util/describeComponentList.ts +18 -0
- package/src/lib.ts +37 -0
- package/src/localization.ts +34 -0
- package/src/localizations/de.ts +98 -0
- package/src/localizations/en.ts +8 -0
- package/src/localizations/es.ts +74 -0
- package/src/localizations/getLocalizationTable.test.ts +27 -0
- package/src/localizations/getLocalizationTable.ts +55 -0
- package/src/math/LineSegment2.test.ts +99 -0
- package/src/math/LineSegment2.ts +160 -0
- package/src/math/Mat33.test.ts +244 -0
- package/src/math/Mat33.ts +437 -0
- package/src/math/Path.fromString.test.ts +223 -0
- package/src/math/Path.test.ts +198 -0
- package/src/math/Path.toString.test.ts +77 -0
- package/src/math/Path.ts +790 -0
- package/src/math/Rect2.test.ts +204 -0
- package/src/math/Rect2.ts +315 -0
- package/src/math/Triangle.ts +29 -0
- package/src/math/Vec2.test.ts +30 -0
- package/src/math/Vec2.ts +18 -0
- package/src/math/Vec3.test.ts +44 -0
- package/src/math/Vec3.ts +218 -0
- package/src/math/lib.ts +15 -0
- package/src/math/rounding.test.ts +65 -0
- package/src/math/rounding.ts +156 -0
- package/src/rendering/Display.ts +249 -0
- package/src/rendering/RenderingStyle.test.ts +68 -0
- package/src/rendering/RenderingStyle.ts +55 -0
- package/src/rendering/TextRenderingStyle.ts +45 -0
- package/src/rendering/caching/CacheRecord.test.ts +49 -0
- package/src/rendering/caching/CacheRecord.ts +77 -0
- package/src/rendering/caching/CacheRecordManager.ts +71 -0
- package/src/rendering/caching/RenderingCache.test.ts +44 -0
- package/src/rendering/caching/RenderingCache.ts +66 -0
- package/src/rendering/caching/RenderingCacheNode.ts +405 -0
- package/src/rendering/caching/testUtils.ts +35 -0
- package/src/rendering/caching/types.ts +34 -0
- package/src/rendering/lib.ts +6 -0
- package/src/rendering/localization.ts +20 -0
- package/src/rendering/renderers/AbstractRenderer.ts +222 -0
- package/src/rendering/renderers/CanvasRenderer.ts +296 -0
- package/src/rendering/renderers/DummyRenderer.test.ts +42 -0
- package/src/rendering/renderers/DummyRenderer.ts +136 -0
- package/src/rendering/renderers/SVGRenderer.ts +354 -0
- package/src/rendering/renderers/TextOnlyRenderer.ts +70 -0
- package/src/styles.js +7 -0
- package/src/testing/beforeEachFile.ts +8 -0
- package/src/testing/createEditor.ts +11 -0
- package/src/testing/global.d.ts +17 -0
- package/src/testing/lib.ts +3 -0
- package/src/testing/loadExpectExtensions.ts +25 -0
- package/src/testing/sendPenEvent.ts +31 -0
- package/src/testing/sendTouchEvent.ts +78 -0
- package/src/toolbar/HTMLToolbar.ts +492 -0
- package/src/toolbar/IconProvider.ts +736 -0
- package/src/toolbar/lib.ts +4 -0
- package/src/toolbar/localization.ts +106 -0
- package/src/toolbar/makeColorInput.ts +145 -0
- package/src/toolbar/toolbar.css +213 -0
- package/src/toolbar/types.ts +5 -0
- package/src/toolbar/widgets/ActionButtonWidget.ts +39 -0
- package/src/toolbar/widgets/BaseToolWidget.ts +56 -0
- package/src/toolbar/widgets/BaseWidget.ts +377 -0
- package/src/toolbar/widgets/DocumentPropertiesWidget.ts +167 -0
- package/src/toolbar/widgets/EraserToolWidget.ts +85 -0
- package/src/toolbar/widgets/HandToolWidget.ts +250 -0
- package/src/toolbar/widgets/InsertImageWidget.css +44 -0
- package/src/toolbar/widgets/InsertImageWidget.ts +223 -0
- package/src/toolbar/widgets/OverflowWidget.css +27 -0
- package/src/toolbar/widgets/OverflowWidget.ts +92 -0
- package/src/toolbar/widgets/PenToolWidget.ts +288 -0
- package/src/toolbar/widgets/SelectionToolWidget.ts +190 -0
- package/src/toolbar/widgets/TextToolWidget.ts +145 -0
- package/src/toolbar/widgets/lib.ts +13 -0
- package/src/tools/BaseTool.ts +76 -0
- package/src/tools/Eraser.test.ts +103 -0
- package/src/tools/Eraser.ts +139 -0
- package/src/tools/FindTool.css +7 -0
- package/src/tools/FindTool.ts +152 -0
- package/src/tools/PanZoom.test.ts +310 -0
- package/src/tools/PanZoom.ts +520 -0
- package/src/tools/PasteHandler.ts +95 -0
- package/src/tools/Pen.test.ts +194 -0
- package/src/tools/Pen.ts +226 -0
- package/src/tools/PipetteTool.ts +55 -0
- package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +28 -0
- package/src/tools/SelectionTool/Selection.ts +607 -0
- package/src/tools/SelectionTool/SelectionHandle.ts +108 -0
- package/src/tools/SelectionTool/SelectionTool.css +23 -0
- package/src/tools/SelectionTool/SelectionTool.test.ts +261 -0
- package/src/tools/SelectionTool/SelectionTool.ts +480 -0
- package/src/tools/SelectionTool/TransformMode.ts +114 -0
- package/src/tools/SelectionTool/types.ts +11 -0
- package/src/tools/TextTool.ts +326 -0
- package/src/tools/ToolController.ts +178 -0
- package/src/tools/ToolEnabledGroup.ts +14 -0
- package/src/tools/ToolSwitcherShortcut.ts +39 -0
- package/src/tools/ToolbarShortcutHandler.ts +34 -0
- package/src/tools/UndoRedoShortcut.test.ts +56 -0
- package/src/tools/UndoRedoShortcut.ts +25 -0
- package/src/tools/lib.ts +21 -0
- package/src/tools/localization.ts +66 -0
- package/src/types.ts +234 -0
- package/src/util/assertions.ts +55 -0
- package/src/util/fileToBase64.ts +18 -0
- package/src/util/untilNextAnimationFrame.ts +9 -0
- package/src/util/waitForTimeout.ts +9 -0
@@ -0,0 +1,47 @@
|
|
1
|
+
import Rect2 from '../math/Rect2';
|
2
|
+
|
3
|
+
export interface CommandLocalization {
|
4
|
+
movedLeft: string;
|
5
|
+
movedUp: string;
|
6
|
+
movedDown: string;
|
7
|
+
movedRight: string;
|
8
|
+
rotatedBy: (degrees: number) => string;
|
9
|
+
zoomedOut: string;
|
10
|
+
zoomedIn: string;
|
11
|
+
erasedNoElements: string;
|
12
|
+
duplicatedNoElements: string;
|
13
|
+
elements: string;
|
14
|
+
updatedViewport: string;
|
15
|
+
transformedElements: (elemCount: number) => string;
|
16
|
+
resizeOutputCommand: (newSize: Rect2) => string;
|
17
|
+
addElementAction: (elemDescription: string) => string;
|
18
|
+
eraseAction: (elemDescription: string, numElems: number) => string;
|
19
|
+
duplicateAction: (elemDescription: string, count: number)=> string;
|
20
|
+
inverseOf: (actionDescription: string)=> string;
|
21
|
+
unionOf: (actionDescription: string, actionCount: number)=> string;
|
22
|
+
|
23
|
+
selectedElements: (count: number)=>string;
|
24
|
+
}
|
25
|
+
|
26
|
+
export const defaultCommandLocalization: CommandLocalization = {
|
27
|
+
updatedViewport: 'Transformed Viewport',
|
28
|
+
transformedElements: (elemCount) => `Transformed ${elemCount} element${elemCount === 1 ? '' : 's'}`,
|
29
|
+
resizeOutputCommand: (newSize: Rect2) => `Resized image to ${newSize.w}x${newSize.h}`,
|
30
|
+
addElementAction: (componentDescription: string) => `Added ${componentDescription}`,
|
31
|
+
eraseAction: (componentDescription: string, numElems: number) => `Erased ${numElems} ${componentDescription}`,
|
32
|
+
duplicateAction: (componentDescription: string, numElems: number) => `Duplicated ${numElems} ${componentDescription}`,
|
33
|
+
unionOf: (actionDescription: string, actionCount: number) => `Union: ${actionCount} ${actionDescription}`,
|
34
|
+
inverseOf: (actionDescription: string) => `Inverse of ${actionDescription}`,
|
35
|
+
elements: 'Elements',
|
36
|
+
erasedNoElements: 'Erased nothing',
|
37
|
+
duplicatedNoElements: 'Duplicated nothing',
|
38
|
+
|
39
|
+
rotatedBy: (degrees) => `Rotated by ${Math.abs(degrees)} degrees ${degrees < 0 ? 'clockwise' : 'counter-clockwise'}`,
|
40
|
+
movedLeft: 'Moved left',
|
41
|
+
movedUp: 'Moved up',
|
42
|
+
movedDown: 'Moved down',
|
43
|
+
movedRight: 'Moved right',
|
44
|
+
zoomedOut: 'Zoomed out',
|
45
|
+
zoomedIn: 'Zoomed in',
|
46
|
+
selectedElements: (count) => `Selected ${count} element${count === 1 ? '' : 's'}`,
|
47
|
+
};
|
@@ -0,0 +1,23 @@
|
|
1
|
+
|
2
|
+
import { Color4, EditorImage, Mat33, Path, SerializableCommand, StrokeComponent, Vec2 } from '../lib';
|
3
|
+
import uniteCommands from './uniteCommands';
|
4
|
+
import createEditor from '../testing/createEditor';
|
5
|
+
|
6
|
+
describe('uniteCommands', () => {
|
7
|
+
it('should be serializable and deserializable', () => {
|
8
|
+
const editor = createEditor();
|
9
|
+
const stroke = new StrokeComponent([ Path.fromString('m0,0 l10,10 h-2 z').toRenderable({ fill: Color4.red }) ]);
|
10
|
+
const union = uniteCommands([
|
11
|
+
EditorImage.addElement(stroke),
|
12
|
+
stroke.transformBy(Mat33.translation(Vec2.of(1, 10))),
|
13
|
+
]);
|
14
|
+
const deserialized = SerializableCommand.deserialize(union.serialize(), editor);
|
15
|
+
|
16
|
+
deserialized.apply(editor);
|
17
|
+
|
18
|
+
const lookupResult = editor.image.lookupElement(stroke.getId());
|
19
|
+
expect(lookupResult).not.toBeNull();
|
20
|
+
expect(lookupResult?.getBBox().topLeft).toMatchObject(Vec2.of(1, 10));
|
21
|
+
expect(lookupResult?.getBBox().bottomRight).toMatchObject(Vec2.of(11, 20));
|
22
|
+
});
|
23
|
+
});
|
@@ -0,0 +1,135 @@
|
|
1
|
+
import Editor from '../Editor';
|
2
|
+
import { EditorLocalization } from '../localization';
|
3
|
+
import Command from './Command';
|
4
|
+
import SerializableCommand from './SerializableCommand';
|
5
|
+
|
6
|
+
|
7
|
+
class NonSerializableUnion extends Command {
|
8
|
+
public constructor(private commands: Command[], private applyChunkSize: number|undefined) {
|
9
|
+
super();
|
10
|
+
}
|
11
|
+
|
12
|
+
private static waitForAll(commands: (Promise<void>|void)[]): Promise<void>|void {
|
13
|
+
// If any are Promises...
|
14
|
+
if (commands.some(command => command && command['then'])) {
|
15
|
+
console.log('waiting...');
|
16
|
+
// Wait for all commands to finish.
|
17
|
+
return Promise.all(commands)
|
18
|
+
// Ensure we return a Promise<void> and not a Promise<void[]>
|
19
|
+
.then(() => {});
|
20
|
+
}
|
21
|
+
|
22
|
+
return;
|
23
|
+
}
|
24
|
+
|
25
|
+
public apply(editor: Editor) {
|
26
|
+
if (this.applyChunkSize === undefined) {
|
27
|
+
const results = this.commands.map(cmd => cmd.apply(editor));
|
28
|
+
return NonSerializableUnion.waitForAll(results);
|
29
|
+
} else {
|
30
|
+
return editor.asyncApplyCommands(this.commands, this.applyChunkSize);
|
31
|
+
}
|
32
|
+
}
|
33
|
+
|
34
|
+
public unapply(editor: Editor) {
|
35
|
+
const commands = [ ...this.commands ];
|
36
|
+
commands.reverse();
|
37
|
+
|
38
|
+
if (this.applyChunkSize === undefined) {
|
39
|
+
const results = commands.map(cmd => cmd.unapply(editor));
|
40
|
+
return NonSerializableUnion.waitForAll(results);
|
41
|
+
} else {
|
42
|
+
return editor.asyncUnapplyCommands(commands, this.applyChunkSize, false);
|
43
|
+
}
|
44
|
+
}
|
45
|
+
|
46
|
+
public description(editor: Editor, localizationTable: EditorLocalization) {
|
47
|
+
const descriptions: string[] = [];
|
48
|
+
|
49
|
+
let lastDescription: string|null = null;
|
50
|
+
let duplicateDescriptionCount: number = 0;
|
51
|
+
for (const part of this.commands) {
|
52
|
+
const description = part.description(editor, localizationTable);
|
53
|
+
if (description !== lastDescription && lastDescription !== null) {
|
54
|
+
descriptions.push(localizationTable.unionOf(lastDescription, duplicateDescriptionCount));
|
55
|
+
lastDescription = null;
|
56
|
+
duplicateDescriptionCount = 0;
|
57
|
+
}
|
58
|
+
|
59
|
+
duplicateDescriptionCount ++;
|
60
|
+
lastDescription ??= description;
|
61
|
+
}
|
62
|
+
|
63
|
+
if (duplicateDescriptionCount > 1) {
|
64
|
+
descriptions.push(localizationTable.unionOf(lastDescription!, duplicateDescriptionCount));
|
65
|
+
} else if (duplicateDescriptionCount === 1) {
|
66
|
+
descriptions.push(lastDescription!);
|
67
|
+
}
|
68
|
+
|
69
|
+
return descriptions.join(', ');
|
70
|
+
}
|
71
|
+
}
|
72
|
+
|
73
|
+
class SerializableUnion extends SerializableCommand {
|
74
|
+
private nonserializableCommand: NonSerializableUnion;
|
75
|
+
public constructor(private commands: SerializableCommand[], private applyChunkSize: number|undefined) {
|
76
|
+
super('union');
|
77
|
+
this.nonserializableCommand = new NonSerializableUnion(commands, applyChunkSize);
|
78
|
+
}
|
79
|
+
|
80
|
+
protected serializeToJSON() {
|
81
|
+
return {
|
82
|
+
applyChunkSize: this.applyChunkSize,
|
83
|
+
data: this.commands.map(command => command.serialize()),
|
84
|
+
};
|
85
|
+
}
|
86
|
+
|
87
|
+
public apply(editor: Editor) {
|
88
|
+
return this.nonserializableCommand.apply(editor);
|
89
|
+
}
|
90
|
+
|
91
|
+
public unapply(editor: Editor) {
|
92
|
+
return this.nonserializableCommand.unapply(editor);
|
93
|
+
}
|
94
|
+
|
95
|
+
public description(editor: Editor, localizationTable: EditorLocalization): string {
|
96
|
+
return this.nonserializableCommand.description(editor, localizationTable);
|
97
|
+
}
|
98
|
+
}
|
99
|
+
|
100
|
+
const uniteCommands = <T extends Command> (commands: T[], applyChunkSize?: number): T extends SerializableCommand ? SerializableCommand : Command => {
|
101
|
+
let allSerializable = true;
|
102
|
+
for (const command of commands) {
|
103
|
+
if (!(command instanceof SerializableCommand)) {
|
104
|
+
allSerializable = false;
|
105
|
+
break;
|
106
|
+
}
|
107
|
+
}
|
108
|
+
|
109
|
+
if (!allSerializable) {
|
110
|
+
return new NonSerializableUnion(commands, applyChunkSize) as any;
|
111
|
+
} else {
|
112
|
+
const castedCommands = commands as any[] as SerializableCommand[];
|
113
|
+
return new SerializableUnion(castedCommands, applyChunkSize);
|
114
|
+
}
|
115
|
+
};
|
116
|
+
|
117
|
+
SerializableCommand.register('union', (data: any, editor) => {
|
118
|
+
if (typeof data.data.length !== 'number') {
|
119
|
+
throw new Error('Unions of commands must serialize to lists of serialization data.');
|
120
|
+
}
|
121
|
+
const applyChunkSize: number|undefined = data.applyChunkSize;
|
122
|
+
if (typeof applyChunkSize !== 'number' && applyChunkSize !== undefined) {
|
123
|
+
throw new Error('serialized applyChunkSize is neither undefined nor a number.');
|
124
|
+
}
|
125
|
+
|
126
|
+
const commands: SerializableCommand[] = [];
|
127
|
+
for (const part of data.data as any[]) {
|
128
|
+
commands.push(SerializableCommand.deserialize(part, editor));
|
129
|
+
}
|
130
|
+
|
131
|
+
return uniteCommands(commands, applyChunkSize);
|
132
|
+
});
|
133
|
+
|
134
|
+
|
135
|
+
export default uniteCommands;
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import { Color4, EditorImage, Mat33, Path, Rect2, Vec2 } from '../lib';
|
2
|
+
import createEditor from '../testing/createEditor';
|
3
|
+
import Stroke from './Stroke';
|
4
|
+
|
5
|
+
describe('AbstractComponent.transformBy', () => {
|
6
|
+
it('should restore the component\'s z-index on undo', () => {
|
7
|
+
const editor = createEditor();
|
8
|
+
const component = new Stroke([ Path.fromRect(Rect2.unitSquare).toRenderable({ fill: Color4.red }) ]);
|
9
|
+
EditorImage.addElement(component).apply(editor);
|
10
|
+
|
11
|
+
const origZIndex = component.getZIndex();
|
12
|
+
|
13
|
+
const transformCommand = component.transformBy(Mat33.translation(Vec2.unitX));
|
14
|
+
transformCommand.apply(editor);
|
15
|
+
|
16
|
+
// Should increase the z-index on applying a transform
|
17
|
+
expect(component.getZIndex()).toBeGreaterThan(origZIndex);
|
18
|
+
|
19
|
+
transformCommand.unapply(editor);
|
20
|
+
expect(component.getZIndex()).toBe(origZIndex);
|
21
|
+
});
|
22
|
+
});
|
@@ -0,0 +1,364 @@
|
|
1
|
+
import SerializableCommand from '../commands/SerializableCommand';
|
2
|
+
import Editor from '../Editor';
|
3
|
+
import EditorImage from '../EditorImage';
|
4
|
+
import LineSegment2 from '../math/LineSegment2';
|
5
|
+
import Mat33, { Mat33Array } from '../math/Mat33';
|
6
|
+
import Rect2 from '../math/Rect2';
|
7
|
+
import { EditorLocalization } from '../localization';
|
8
|
+
import AbstractRenderer from '../rendering/renderers/AbstractRenderer';
|
9
|
+
import { ImageComponentLocalization } from './localization';
|
10
|
+
import UnresolvedSerializableCommand from '../commands/UnresolvedCommand';
|
11
|
+
|
12
|
+
export type LoadSaveData = (string[]|Record<symbol, string|number>);
|
13
|
+
export type LoadSaveDataTable = Record<string, Array<LoadSaveData>>;
|
14
|
+
export type DeserializeCallback = (data: string)=>AbstractComponent;
|
15
|
+
type ComponentId = string;
|
16
|
+
|
17
|
+
/**
|
18
|
+
* A base class for everything that can be added to an {@link EditorImage}.
|
19
|
+
*/
|
20
|
+
export default abstract class AbstractComponent {
|
21
|
+
// The timestamp (milliseconds) at which the component was
|
22
|
+
// last changed (i.e. created/translated).
|
23
|
+
// @deprecated
|
24
|
+
protected lastChangedTime: number;
|
25
|
+
|
26
|
+
// The bounding box of this component.
|
27
|
+
// {@link getBBox}, by default, returns `contentBBox`.
|
28
|
+
// This must be set by components.
|
29
|
+
protected abstract contentBBox: Rect2;
|
30
|
+
|
31
|
+
private zIndex: number;
|
32
|
+
private id: string;
|
33
|
+
|
34
|
+
// Topmost z-index
|
35
|
+
private static zIndexCounter: number = 0;
|
36
|
+
|
37
|
+
protected constructor(
|
38
|
+
// A unique identifier for the type of component
|
39
|
+
private readonly componentKind: string,
|
40
|
+
initialZIndex?: number,
|
41
|
+
) {
|
42
|
+
this.lastChangedTime = (new Date()).getTime();
|
43
|
+
|
44
|
+
if (initialZIndex !== undefined) {
|
45
|
+
this.zIndex = initialZIndex;
|
46
|
+
} else {
|
47
|
+
this.zIndex = AbstractComponent.zIndexCounter++;
|
48
|
+
}
|
49
|
+
|
50
|
+
// Create a unique ID.
|
51
|
+
this.id = `${new Date().getTime()}-${Math.random()}`;
|
52
|
+
|
53
|
+
if (AbstractComponent.deserializationCallbacks[componentKind] === undefined) {
|
54
|
+
throw new Error(`Component ${componentKind} has not been registered using AbstractComponent.registerComponent`);
|
55
|
+
}
|
56
|
+
}
|
57
|
+
|
58
|
+
// Returns a unique ID for this element.
|
59
|
+
// @see { @link lib!EditorImage.lookupElement }
|
60
|
+
public getId() {
|
61
|
+
return this.id;
|
62
|
+
}
|
63
|
+
|
64
|
+
private static deserializationCallbacks: Record<ComponentId, DeserializeCallback|null> = {};
|
65
|
+
|
66
|
+
// Store the deserialization callback (or lack of it) for [componentKind].
|
67
|
+
// If components are registered multiple times (as may be done in automated tests),
|
68
|
+
// the most recent deserialization callback is used.
|
69
|
+
public static registerComponent(
|
70
|
+
componentKind: string,
|
71
|
+
deserialize: DeserializeCallback|null,
|
72
|
+
) {
|
73
|
+
this.deserializationCallbacks[componentKind] = deserialize ?? null;
|
74
|
+
}
|
75
|
+
|
76
|
+
// Stores data attached by a loader.
|
77
|
+
private loadSaveData: LoadSaveDataTable = {};
|
78
|
+
|
79
|
+
/**
|
80
|
+
* Attach data that can be used while exporting the component (e.g. to SVG).
|
81
|
+
*
|
82
|
+
* This is intended for use by a {@link ImageLoader}.
|
83
|
+
*/
|
84
|
+
public attachLoadSaveData(key: string, data: LoadSaveData) {
|
85
|
+
if (!this.loadSaveData[key]) {
|
86
|
+
this.loadSaveData[key] = [];
|
87
|
+
}
|
88
|
+
this.loadSaveData[key].push(data);
|
89
|
+
}
|
90
|
+
|
91
|
+
/** See {@link attachLoadSaveData} */
|
92
|
+
public getLoadSaveData(): LoadSaveDataTable {
|
93
|
+
return this.loadSaveData;
|
94
|
+
}
|
95
|
+
|
96
|
+
public getZIndex(): number {
|
97
|
+
return this.zIndex;
|
98
|
+
}
|
99
|
+
|
100
|
+
/** @returns the bounding box of */
|
101
|
+
public getBBox(): Rect2 {
|
102
|
+
return this.contentBBox;
|
103
|
+
}
|
104
|
+
|
105
|
+
/** Called when this component is added to the given image. */
|
106
|
+
public onAddToImage(_image: EditorImage): void { }
|
107
|
+
public onRemoveFromImage(): void { }
|
108
|
+
|
109
|
+
public abstract render(canvas: AbstractRenderer, visibleRect?: Rect2): void;
|
110
|
+
|
111
|
+
/** @return true if `lineSegment` intersects this component. */
|
112
|
+
public abstract intersects(lineSegment: LineSegment2): boolean;
|
113
|
+
|
114
|
+
/**
|
115
|
+
* @returns true if this component intersects `rect` -- it is entirely contained
|
116
|
+
* within the rectangle or one of the rectangle's edges intersects this component.
|
117
|
+
*/
|
118
|
+
public intersectsRect(rect: Rect2): boolean {
|
119
|
+
// If this component intersects rect,
|
120
|
+
// it is either contained entirely within rect or intersects one of rect's edges.
|
121
|
+
|
122
|
+
// If contained within,
|
123
|
+
if (rect.containsRect(this.getBBox())) {
|
124
|
+
return true;
|
125
|
+
}
|
126
|
+
|
127
|
+
// Calculated bounding boxes can be slightly larger than their actual contents' bounding box.
|
128
|
+
// As such, test with more lines than just the rect's edges.
|
129
|
+
const testLines = [];
|
130
|
+
for (const subregion of rect.divideIntoGrid(2, 2)) {
|
131
|
+
testLines.push(...subregion.getEdges());
|
132
|
+
}
|
133
|
+
|
134
|
+
return testLines.some(edge => this.intersects(edge));
|
135
|
+
}
|
136
|
+
|
137
|
+
// Return null iff this object cannot be safely serialized/deserialized.
|
138
|
+
protected abstract serializeToJSON(): any[]|Record<string, any>|number|string|null;
|
139
|
+
|
140
|
+
// Private helper for transformBy: Apply the given transformation to all points of this.
|
141
|
+
protected abstract applyTransformation(affineTransfm: Mat33): void;
|
142
|
+
|
143
|
+
// Returns a command that, when applied, transforms this by [affineTransfm] and
|
144
|
+
// updates the editor.
|
145
|
+
public transformBy(affineTransfm: Mat33): SerializableCommand {
|
146
|
+
return new AbstractComponent.TransformElementCommand(affineTransfm, this.getId(), this);
|
147
|
+
}
|
148
|
+
|
149
|
+
// Returns a command that updates this component's z-index.
|
150
|
+
public setZIndex(newZIndex: number): SerializableCommand {
|
151
|
+
return new AbstractComponent.TransformElementCommand(Mat33.identity, this.getId(), this, newZIndex, this.getZIndex());
|
152
|
+
}
|
153
|
+
|
154
|
+
// @returns true iff this component can be selected (e.g. by the selection tool.)
|
155
|
+
public isSelectable(): boolean {
|
156
|
+
return true;
|
157
|
+
}
|
158
|
+
|
159
|
+
// @returns true iff this component should be added to the background, rather than the
|
160
|
+
// foreground of the image.
|
161
|
+
public isBackground(): boolean {
|
162
|
+
return false;
|
163
|
+
}
|
164
|
+
|
165
|
+
// @returns an approximation of the proportional time it takes to render this component.
|
166
|
+
// This is intended to be a rough estimate, but, for example, a stroke with two points sould have
|
167
|
+
// a renderingWeight approximately twice that of a stroke with one point.
|
168
|
+
public getProportionalRenderingTime(): number {
|
169
|
+
return 1;
|
170
|
+
}
|
171
|
+
|
172
|
+
private static transformElementCommandId = 'transform-element';
|
173
|
+
|
174
|
+
private static TransformElementCommand = class extends UnresolvedSerializableCommand {
|
175
|
+
private targetZIndex: number;
|
176
|
+
|
177
|
+
// Construct a new TransformElementCommand. `component`, while optional, should
|
178
|
+
// be provided if available. If not provided, it will be fetched from the editor's
|
179
|
+
// document when the command is applied.
|
180
|
+
public constructor(
|
181
|
+
private affineTransfm: Mat33,
|
182
|
+
componentID: string,
|
183
|
+
component?: AbstractComponent,
|
184
|
+
targetZIndex?: number,
|
185
|
+
private origZIndex?: number,
|
186
|
+
) {
|
187
|
+
super(AbstractComponent.transformElementCommandId, componentID, component);
|
188
|
+
this.targetZIndex = targetZIndex ?? AbstractComponent.zIndexCounter++;
|
189
|
+
|
190
|
+
// Ensure that we keep drawing on top even after changing the z-index.
|
191
|
+
if (this.targetZIndex >= AbstractComponent.zIndexCounter) {
|
192
|
+
AbstractComponent.zIndexCounter = this.targetZIndex + 1;
|
193
|
+
}
|
194
|
+
|
195
|
+
if (component && origZIndex === undefined) {
|
196
|
+
this.origZIndex = component.getZIndex();
|
197
|
+
}
|
198
|
+
}
|
199
|
+
|
200
|
+
protected resolveComponent(image: EditorImage): void {
|
201
|
+
if (this.component) {
|
202
|
+
return;
|
203
|
+
}
|
204
|
+
|
205
|
+
super.resolveComponent(image);
|
206
|
+
this.origZIndex ??= this.component!.getZIndex();
|
207
|
+
}
|
208
|
+
|
209
|
+
private updateTransform(editor: Editor, newTransfm: Mat33) {
|
210
|
+
if (!this.component) {
|
211
|
+
throw new Error('this.component is undefined or null!');
|
212
|
+
}
|
213
|
+
|
214
|
+
// Any parent should have only one direct child.
|
215
|
+
const parent = editor.image.findParent(this.component);
|
216
|
+
let hadParent = false;
|
217
|
+
if (parent) {
|
218
|
+
parent.remove();
|
219
|
+
hadParent = true;
|
220
|
+
}
|
221
|
+
|
222
|
+
this.component.applyTransformation(newTransfm);
|
223
|
+
this.component.lastChangedTime = (new Date()).getTime();
|
224
|
+
|
225
|
+
// Add the element back to the document.
|
226
|
+
if (hadParent) {
|
227
|
+
EditorImage.addElement(this.component).apply(editor);
|
228
|
+
}
|
229
|
+
}
|
230
|
+
|
231
|
+
public apply(editor: Editor) {
|
232
|
+
this.resolveComponent(editor.image);
|
233
|
+
|
234
|
+
this.component!.zIndex = this.targetZIndex;
|
235
|
+
this.updateTransform(editor, this.affineTransfm);
|
236
|
+
editor.queueRerender();
|
237
|
+
}
|
238
|
+
|
239
|
+
public unapply(editor: Editor) {
|
240
|
+
this.resolveComponent(editor.image);
|
241
|
+
|
242
|
+
this.component!.zIndex = this.origZIndex!;
|
243
|
+
this.updateTransform(editor, this.affineTransfm.inverse());
|
244
|
+
editor.queueRerender();
|
245
|
+
}
|
246
|
+
|
247
|
+
public description(_editor: Editor, localizationTable: EditorLocalization) {
|
248
|
+
return localizationTable.transformedElements(1);
|
249
|
+
}
|
250
|
+
|
251
|
+
static {
|
252
|
+
SerializableCommand.register(AbstractComponent.transformElementCommandId, (json: any, editor: Editor) => {
|
253
|
+
const elem = editor.image.lookupElement(json.id) ?? undefined;
|
254
|
+
const transform = new Mat33(...(json.transfm as Mat33Array));
|
255
|
+
const targetZIndex = json.targetZIndex;
|
256
|
+
const origZIndex = json.origZIndex ?? undefined;
|
257
|
+
|
258
|
+
return new AbstractComponent.TransformElementCommand(
|
259
|
+
transform,
|
260
|
+
json.id,
|
261
|
+
elem,
|
262
|
+
targetZIndex,
|
263
|
+
origZIndex,
|
264
|
+
);
|
265
|
+
});
|
266
|
+
}
|
267
|
+
|
268
|
+
protected serializeToJSON() {
|
269
|
+
return {
|
270
|
+
id: this.componentID,
|
271
|
+
transfm: this.affineTransfm.toArray(),
|
272
|
+
targetZIndex: this.targetZIndex,
|
273
|
+
origZIndex: this.origZIndex,
|
274
|
+
};
|
275
|
+
}
|
276
|
+
};
|
277
|
+
|
278
|
+
/**
|
279
|
+
* @return a description that could be read by a screen reader
|
280
|
+
* (e.g. when adding/erasing the component)
|
281
|
+
*/
|
282
|
+
public abstract description(localizationTable: ImageComponentLocalization): string;
|
283
|
+
|
284
|
+
// Component-specific implementation of {@link clone}.
|
285
|
+
protected abstract createClone(): AbstractComponent;
|
286
|
+
|
287
|
+
// Returns a copy of this component.
|
288
|
+
public clone() {
|
289
|
+
const clone = this.createClone();
|
290
|
+
|
291
|
+
for (const attachmentKey in this.loadSaveData) {
|
292
|
+
for (const val of this.loadSaveData[attachmentKey]) {
|
293
|
+
clone.attachLoadSaveData(attachmentKey, val);
|
294
|
+
}
|
295
|
+
}
|
296
|
+
|
297
|
+
return clone;
|
298
|
+
}
|
299
|
+
|
300
|
+
// Convert the component to an object that can be passed to
|
301
|
+
// `JSON.stringify`.
|
302
|
+
//
|
303
|
+
// Do not rely on the output of this function to take a particular form —
|
304
|
+
// this function's output can change form without a major version increase.
|
305
|
+
public serialize() {
|
306
|
+
const data = this.serializeToJSON();
|
307
|
+
|
308
|
+
if (data === null) {
|
309
|
+
throw new Error(`${this} cannot be serialized.`);
|
310
|
+
}
|
311
|
+
|
312
|
+
return {
|
313
|
+
name: this.componentKind,
|
314
|
+
zIndex: this.zIndex,
|
315
|
+
id: this.id,
|
316
|
+
loadSaveData: this.loadSaveData,
|
317
|
+
data,
|
318
|
+
};
|
319
|
+
}
|
320
|
+
|
321
|
+
// Returns true if `data` is not deserializable. May return false even if [data]
|
322
|
+
// is not deserializable.
|
323
|
+
private static isNotDeserializable(json: any|string) {
|
324
|
+
if (typeof json === 'string') {
|
325
|
+
json = JSON.parse(json);
|
326
|
+
}
|
327
|
+
|
328
|
+
if (typeof json !== 'object') {
|
329
|
+
return true;
|
330
|
+
}
|
331
|
+
|
332
|
+
if (!this.deserializationCallbacks[json?.name]) {
|
333
|
+
return true;
|
334
|
+
}
|
335
|
+
|
336
|
+
if (!json.data) {
|
337
|
+
return true;
|
338
|
+
}
|
339
|
+
|
340
|
+
return false;
|
341
|
+
}
|
342
|
+
|
343
|
+
// Convert a string or an object produced by `JSON.parse` into an `AbstractComponent`.
|
344
|
+
public static deserialize(json: string|any): AbstractComponent {
|
345
|
+
if (typeof json === 'string') {
|
346
|
+
json = JSON.parse(json);
|
347
|
+
}
|
348
|
+
|
349
|
+
if (AbstractComponent.isNotDeserializable(json)) {
|
350
|
+
throw new Error(`Element with data ${json} cannot be deserialized.`);
|
351
|
+
}
|
352
|
+
|
353
|
+
const instance = this.deserializationCallbacks[json.name]!(json.data);
|
354
|
+
instance.zIndex = json.zIndex;
|
355
|
+
instance.id = json.id;
|
356
|
+
|
357
|
+
// TODO: What should we do with json.loadSaveData?
|
358
|
+
// If we attach it to [instance], we create a potential security risk — loadSaveData
|
359
|
+
// is often used to store unrecognised attributes so they can be preserved on output.
|
360
|
+
// ...but what if we're deserializing data sent across the network?
|
361
|
+
|
362
|
+
return instance;
|
363
|
+
}
|
364
|
+
}
|
@@ -0,0 +1,35 @@
|
|
1
|
+
import Color4 from '../Color4';
|
2
|
+
import { Path, Rect2 } from '../math/lib';
|
3
|
+
import createEditor from '../testing/createEditor';
|
4
|
+
import ImageBackground, { BackgroundType, imageBackgroundCSSClassName } from './ImageBackground';
|
5
|
+
|
6
|
+
describe('ImageBackground', () => {
|
7
|
+
it('should render to fill exported SVG', () => {
|
8
|
+
const editor = createEditor();
|
9
|
+
const background = new ImageBackground(BackgroundType.SolidColor, Color4.green);
|
10
|
+
editor.image.addElement(
|
11
|
+
background
|
12
|
+
).apply(editor);
|
13
|
+
|
14
|
+
const expectedImportExportRect = new Rect2(-10, 10, 15, 20);
|
15
|
+
editor.setImportExportRect(expectedImportExportRect).apply(editor);
|
16
|
+
expect(editor.getImportExportRect()).objEq(expectedImportExportRect);
|
17
|
+
|
18
|
+
expect(background.getBBox()).objEq(expectedImportExportRect);
|
19
|
+
|
20
|
+
const rendered = editor.toSVG();
|
21
|
+
const renderedBackground = rendered.querySelector(`.${imageBackgroundCSSClassName}`);
|
22
|
+
|
23
|
+
if (renderedBackground === null) {
|
24
|
+
throw new Error('ImageBackground did not render in exported SVG');
|
25
|
+
}
|
26
|
+
|
27
|
+
expect(renderedBackground.tagName.toLowerCase()).toBe('path');
|
28
|
+
|
29
|
+
const pathString = renderedBackground.getAttribute('d')!;
|
30
|
+
expect(pathString).not.toBeNull();
|
31
|
+
|
32
|
+
const path = Path.fromString(pathString);
|
33
|
+
expect(path.bbox).objEq(editor.getImportExportRect());
|
34
|
+
});
|
35
|
+
});
|