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,257 @@
|
|
1
|
+
import Vec3 from './math/Vec3.mjs';
|
2
|
+
export default class Color4 {
|
3
|
+
constructor(
|
4
|
+
/** Red component. Should be in the range [0, 1]. */
|
5
|
+
r,
|
6
|
+
/** Green component. `g` ∈ [0, 1] */
|
7
|
+
g,
|
8
|
+
/** Blue component. `b` ∈ [0, 1] */
|
9
|
+
b,
|
10
|
+
/** Alpha/transparent component. `a` ∈ [0, 1]. 0 = transparent */
|
11
|
+
a) {
|
12
|
+
this.r = r;
|
13
|
+
this.g = g;
|
14
|
+
this.b = b;
|
15
|
+
this.a = a;
|
16
|
+
this.hexString = null;
|
17
|
+
}
|
18
|
+
/**
|
19
|
+
* Create a color from red, green, blue components. The color is fully opaque (`a = 1.0`).
|
20
|
+
*
|
21
|
+
* Each component should be in the range [0, 1].
|
22
|
+
*/
|
23
|
+
static ofRGB(red, green, blue) {
|
24
|
+
return Color4.ofRGBA(red, green, blue, 1.0);
|
25
|
+
}
|
26
|
+
static ofRGBA(red, green, blue, alpha) {
|
27
|
+
red = Math.max(0, Math.min(red, 1));
|
28
|
+
green = Math.max(0, Math.min(green, 1));
|
29
|
+
blue = Math.max(0, Math.min(blue, 1));
|
30
|
+
alpha = Math.max(0, Math.min(alpha, 1));
|
31
|
+
return new Color4(red, green, blue, alpha);
|
32
|
+
}
|
33
|
+
static fromHex(hexString) {
|
34
|
+
var _a;
|
35
|
+
// Remove starting '#' (if present)
|
36
|
+
hexString = ((_a = hexString.match(/^[#]?(.*)$/)) !== null && _a !== void 0 ? _a : [])[1];
|
37
|
+
hexString = hexString.toUpperCase();
|
38
|
+
if (!hexString.match(/^[0-9A-F]+$/)) {
|
39
|
+
throw new Error(`${hexString} is not in a valid format.`);
|
40
|
+
}
|
41
|
+
// RGBA or RGB
|
42
|
+
if (hexString.length === 3 || hexString.length === 4) {
|
43
|
+
// Each character is a component
|
44
|
+
const components = hexString.split('');
|
45
|
+
// Convert to RRGGBBAA or RRGGBB format
|
46
|
+
hexString = components.map(component => `${component}0`).join('');
|
47
|
+
}
|
48
|
+
if (hexString.length === 6) {
|
49
|
+
// Alpha component
|
50
|
+
hexString += 'FF';
|
51
|
+
}
|
52
|
+
const components = [];
|
53
|
+
for (let i = 2; i <= hexString.length; i += 2) {
|
54
|
+
const chunk = hexString.substring(i - 2, i);
|
55
|
+
components.push(parseInt(chunk, 16) / 255);
|
56
|
+
}
|
57
|
+
if (components.length !== 4) {
|
58
|
+
throw new Error(`Unable to parse ${hexString}: Wrong number of components.`);
|
59
|
+
}
|
60
|
+
return Color4.ofRGBA(components[0], components[1], components[2], components[3]);
|
61
|
+
}
|
62
|
+
/** Like fromHex, but can handle additional colors if an `HTMLCanvasElement` is available. */
|
63
|
+
static fromString(text) {
|
64
|
+
if (text.startsWith('#')) {
|
65
|
+
return Color4.fromHex(text);
|
66
|
+
}
|
67
|
+
if (text === 'none' || text === 'transparent') {
|
68
|
+
return Color4.transparent;
|
69
|
+
}
|
70
|
+
// rgba?: Match both rgb and rgba strings.
|
71
|
+
// ([,0-9.]+): Match any string of only numeric, '.' and ',' characters.
|
72
|
+
const rgbRegex = /^rgba?\(([,0-9.]+)\)$/i;
|
73
|
+
const rgbMatch = text.replace(/\s*/g, '').match(rgbRegex);
|
74
|
+
if (rgbMatch) {
|
75
|
+
const componentsListStr = rgbMatch[1];
|
76
|
+
const componentsList = JSON.parse(`[ ${componentsListStr} ]`);
|
77
|
+
if (componentsList.length === 3) {
|
78
|
+
return Color4.ofRGB(componentsList[0] / 255, componentsList[1] / 255, componentsList[2] / 255);
|
79
|
+
}
|
80
|
+
else if (componentsList.length === 4) {
|
81
|
+
return Color4.ofRGBA(componentsList[0] / 255, componentsList[1] / 255, componentsList[2] / 255, componentsList[3]);
|
82
|
+
}
|
83
|
+
else {
|
84
|
+
throw new Error(`RGB string, ${text}, has wrong number of components: ${componentsList.length}`);
|
85
|
+
}
|
86
|
+
}
|
87
|
+
// Otherwise, try to use an HTMLCanvasElement to determine the color.
|
88
|
+
// Note: We may be unable to create an HTMLCanvasElement if running as a unit test.
|
89
|
+
const canvas = document.createElement('canvas');
|
90
|
+
canvas.width = 1;
|
91
|
+
canvas.height = 1;
|
92
|
+
const ctx = canvas.getContext('2d');
|
93
|
+
ctx.fillStyle = text;
|
94
|
+
ctx.fillRect(0, 0, 1, 1);
|
95
|
+
const data = ctx.getImageData(0, 0, 1, 1);
|
96
|
+
const red = data.data[0] / 255;
|
97
|
+
const green = data.data[1] / 255;
|
98
|
+
const blue = data.data[2] / 255;
|
99
|
+
const alpha = data.data[3] / 255;
|
100
|
+
return Color4.ofRGBA(red, green, blue, alpha);
|
101
|
+
}
|
102
|
+
/** @returns true if `this` and `other` are approximately equal. */
|
103
|
+
eq(other) {
|
104
|
+
if (other == null) {
|
105
|
+
return false;
|
106
|
+
}
|
107
|
+
// If both completely transparent,
|
108
|
+
if (this.a === 0 && other.a === 0) {
|
109
|
+
return true;
|
110
|
+
}
|
111
|
+
return this.toHexString() === other.toHexString();
|
112
|
+
}
|
113
|
+
/**
|
114
|
+
* If `fractionTo` is not in the range [0, 1], it will be clamped to the nearest number
|
115
|
+
* in that range. For example, `a.mix(b, -1)` is equivalent to `a.mix(b, 0)`.
|
116
|
+
*
|
117
|
+
* @returns a color `fractionTo` of the way from this color to `other`.
|
118
|
+
*
|
119
|
+
* @example
|
120
|
+
* ```ts
|
121
|
+
* Color4.ofRGB(1, 0, 0).mix(Color4.ofRGB(0, 1, 0), 0.1) // -> Color4(0.9, 0.1, 0)
|
122
|
+
* ```
|
123
|
+
*/
|
124
|
+
mix(other, fractionTo) {
|
125
|
+
fractionTo = Math.min(Math.max(fractionTo, 0), 1);
|
126
|
+
const fractionOfThis = 1 - fractionTo;
|
127
|
+
return new Color4(this.r * fractionOfThis + other.r * fractionTo, this.g * fractionOfThis + other.g * fractionTo, this.b * fractionOfThis + other.b * fractionTo, this.a * fractionOfThis + other.a * fractionTo);
|
128
|
+
}
|
129
|
+
/**
|
130
|
+
* @returns the component-wise average of `colors`, or `Color4.transparent` if `colors` is empty.
|
131
|
+
*/
|
132
|
+
static average(colors) {
|
133
|
+
let averageA = 0;
|
134
|
+
let averageR = 0;
|
135
|
+
let averageG = 0;
|
136
|
+
let averageB = 0;
|
137
|
+
for (const color of colors) {
|
138
|
+
averageA += color.a;
|
139
|
+
averageR += color.r;
|
140
|
+
averageG += color.g;
|
141
|
+
averageB += color.b;
|
142
|
+
}
|
143
|
+
if (colors.length > 0) {
|
144
|
+
averageA /= colors.length;
|
145
|
+
averageR /= colors.length;
|
146
|
+
averageG /= colors.length;
|
147
|
+
averageB /= colors.length;
|
148
|
+
}
|
149
|
+
return new Color4(averageR, averageG, averageB, averageA);
|
150
|
+
}
|
151
|
+
/**
|
152
|
+
* Converts to (hue, saturation, value).
|
153
|
+
* See also https://en.wikipedia.org/wiki/HSL_and_HSV#General_approach
|
154
|
+
*
|
155
|
+
* The resultant hue is represented in radians and is thus in [0, 2pi].
|
156
|
+
*/
|
157
|
+
asHSV() {
|
158
|
+
// Ref: https://en.wikipedia.org/wiki/HSL_and_HSV#General_approach
|
159
|
+
//
|
160
|
+
// HUE:
|
161
|
+
// First, consider the unit cube. Rotate it such that one vertex is at the origin
|
162
|
+
// of a plane and its three neighboring vertices are equidistant from that plane:
|
163
|
+
//
|
164
|
+
// /\
|
165
|
+
// / | \
|
166
|
+
// 2 / 3 \ 1
|
167
|
+
// \ | /
|
168
|
+
// \ | /
|
169
|
+
// . \/ .
|
170
|
+
//
|
171
|
+
// .
|
172
|
+
//
|
173
|
+
// Let z be up and (x, y, 0) be in the plane.
|
174
|
+
//
|
175
|
+
// Label vectors 1,2,3 with R, G, and B, respectively. Let R's projection into the plane
|
176
|
+
// lie along the x axis.
|
177
|
+
//
|
178
|
+
// Because R is a unit vector and R, G, B are equidistant from the plane, they must
|
179
|
+
// form 30-60-90 triangles, which have side lengths proportional to (1, √3, 2)
|
180
|
+
//
|
181
|
+
// /|
|
182
|
+
// 1/ | (√3)/2
|
183
|
+
// / |
|
184
|
+
// 1/2
|
185
|
+
//
|
186
|
+
const minComponent = Math.min(this.r, this.g, this.b);
|
187
|
+
const maxComponent = Math.max(this.r, this.g, this.b);
|
188
|
+
const chroma = maxComponent - minComponent;
|
189
|
+
let hue;
|
190
|
+
// See https://en.wikipedia.org/wiki/HSL_and_HSV#General_approach
|
191
|
+
if (chroma === 0) {
|
192
|
+
hue = 0;
|
193
|
+
}
|
194
|
+
else if (this.r >= this.g && this.r >= this.b) {
|
195
|
+
hue = ((this.g - this.b) / chroma) % 6;
|
196
|
+
}
|
197
|
+
else if (this.g >= this.r && this.g >= this.b) {
|
198
|
+
hue = (this.b - this.r) / chroma + 2;
|
199
|
+
}
|
200
|
+
else {
|
201
|
+
hue = (this.r - this.g) / chroma + 4;
|
202
|
+
}
|
203
|
+
// Convert to degree representation, then to radians.
|
204
|
+
hue *= 60;
|
205
|
+
hue *= Math.PI / 180;
|
206
|
+
// Ensure positivity.
|
207
|
+
if (hue < 0) {
|
208
|
+
hue += Math.PI * 2;
|
209
|
+
}
|
210
|
+
const value = maxComponent;
|
211
|
+
const saturation = value > 0 ? chroma / value : 0;
|
212
|
+
return Vec3.of(hue, saturation, value);
|
213
|
+
}
|
214
|
+
/**
|
215
|
+
* @returns a hexadecimal color string representation of `this`, in the form `#rrggbbaa`.
|
216
|
+
*
|
217
|
+
* @example
|
218
|
+
* ```
|
219
|
+
* Color4.red.toHexString(); // -> #ff0000ff
|
220
|
+
* ```
|
221
|
+
*/
|
222
|
+
toHexString() {
|
223
|
+
if (this.hexString) {
|
224
|
+
return this.hexString;
|
225
|
+
}
|
226
|
+
const componentToHex = (component) => {
|
227
|
+
const res = Math.round(255 * component).toString(16);
|
228
|
+
if (res.length === 1) {
|
229
|
+
return `0${res}`;
|
230
|
+
}
|
231
|
+
return res;
|
232
|
+
};
|
233
|
+
const alpha = componentToHex(this.a);
|
234
|
+
const red = componentToHex(this.r);
|
235
|
+
const green = componentToHex(this.g);
|
236
|
+
const blue = componentToHex(this.b);
|
237
|
+
if (alpha === 'ff') {
|
238
|
+
return `#${red}${green}${blue}`;
|
239
|
+
}
|
240
|
+
this.hexString = `#${red}${green}${blue}${alpha}`;
|
241
|
+
return this.hexString;
|
242
|
+
}
|
243
|
+
toString() {
|
244
|
+
return this.toHexString();
|
245
|
+
}
|
246
|
+
}
|
247
|
+
Color4.transparent = Color4.ofRGBA(0, 0, 0, 0);
|
248
|
+
Color4.red = Color4.ofRGB(1.0, 0.0, 0.0);
|
249
|
+
Color4.green = Color4.ofRGB(0.0, 1.0, 0.0);
|
250
|
+
Color4.blue = Color4.ofRGB(0.0, 0.0, 1.0);
|
251
|
+
Color4.purple = Color4.ofRGB(0.5, 0.2, 0.5);
|
252
|
+
Color4.yellow = Color4.ofRGB(1, 1, 0.1);
|
253
|
+
Color4.clay = Color4.ofRGB(0.8, 0.4, 0.2);
|
254
|
+
Color4.black = Color4.ofRGB(0, 0, 0);
|
255
|
+
Color4.gray = Color4.ofRGB(0.5, 0.5, 0.5);
|
256
|
+
Color4.white = Color4.ofRGB(1, 1, 1);
|
257
|
+
export { Color4 };
|
@@ -0,0 +1,308 @@
|
|
1
|
+
import EditorImage from './EditorImage';
|
2
|
+
import ToolController from './tools/ToolController';
|
3
|
+
import { InputEvtType, EditorNotifier, ImageLoader } from './types';
|
4
|
+
import Command from './commands/Command';
|
5
|
+
import UndoRedoHistory from './UndoRedoHistory';
|
6
|
+
import Viewport from './Viewport';
|
7
|
+
import { Point2 } from './math/Vec2';
|
8
|
+
import HTMLToolbar from './toolbar/HTMLToolbar';
|
9
|
+
import { RenderablePathSpec } from './rendering/renderers/AbstractRenderer';
|
10
|
+
import Display, { RenderingMode } from './rendering/Display';
|
11
|
+
import Color4 from './Color4';
|
12
|
+
import Pointer from './Pointer';
|
13
|
+
import Rect2 from './math/Rect2';
|
14
|
+
import { EditorLocalization } from './localization';
|
15
|
+
import IconProvider from './toolbar/IconProvider';
|
16
|
+
import AbstractComponent from './components/AbstractComponent';
|
17
|
+
type HTMLPointerEventType = 'pointerdown' | 'pointermove' | 'pointerup' | 'pointercancel';
|
18
|
+
type HTMLPointerEventFilter = (eventName: HTMLPointerEventType, event: PointerEvent) => boolean;
|
19
|
+
export interface EditorSettings {
|
20
|
+
/** Defaults to `RenderingMode.CanvasRenderer` */
|
21
|
+
renderingMode: RenderingMode;
|
22
|
+
/** Uses a default English localization if a translation is not given. */
|
23
|
+
localization: Partial<EditorLocalization>;
|
24
|
+
/**
|
25
|
+
* `true` if touchpad/mousewheel scrolling should scroll the editor instead of the document.
|
26
|
+
* This does not include pinch-zoom events.
|
27
|
+
* Defaults to true.
|
28
|
+
*/
|
29
|
+
wheelEventsEnabled: boolean | 'only-if-focused';
|
30
|
+
/** Minimum zoom fraction (e.g. 0.5 → 50% zoom). */
|
31
|
+
minZoom: number;
|
32
|
+
maxZoom: number;
|
33
|
+
iconProvider: IconProvider;
|
34
|
+
}
|
35
|
+
/**
|
36
|
+
* The main entrypoint for the full editor.
|
37
|
+
*
|
38
|
+
* @example
|
39
|
+
* To create an editor with a toolbar,
|
40
|
+
* ```
|
41
|
+
* const editor = new Editor(document.body);
|
42
|
+
*
|
43
|
+
* const toolbar = editor.addToolbar();
|
44
|
+
* toolbar.addActionButton('Save', () => {
|
45
|
+
* const saveData = editor.toSVG().outerHTML;
|
46
|
+
* // Do something with saveData...
|
47
|
+
* });
|
48
|
+
* ```
|
49
|
+
*
|
50
|
+
* See also
|
51
|
+
* [`docs/example/example.ts`](https://github.com/personalizedrefrigerator/js-draw/blob/main/docs/example/example.ts#L15).
|
52
|
+
*/
|
53
|
+
export declare class Editor {
|
54
|
+
private container;
|
55
|
+
private renderingRegion;
|
56
|
+
/** Manages drawing surfaces/{@link AbstractRenderer}s. */
|
57
|
+
display: Display;
|
58
|
+
/**
|
59
|
+
* Handles undo/redo.
|
60
|
+
*
|
61
|
+
* @example
|
62
|
+
* ```
|
63
|
+
* const editor = new Editor(document.body);
|
64
|
+
*
|
65
|
+
* // Do something undoable.
|
66
|
+
* // ...
|
67
|
+
*
|
68
|
+
* // Undo the last action
|
69
|
+
* editor.history.undo();
|
70
|
+
* ```
|
71
|
+
*/
|
72
|
+
history: UndoRedoHistory;
|
73
|
+
/**
|
74
|
+
* Data structure for adding/removing/querying objects in the image.
|
75
|
+
*
|
76
|
+
* @example
|
77
|
+
* ```
|
78
|
+
* const editor = new Editor(document.body);
|
79
|
+
*
|
80
|
+
* // Create a path.
|
81
|
+
* const stroke = new Stroke([
|
82
|
+
* Path.fromString('M0,0 L30,30 z').toRenderable({ fill: Color4.black }),
|
83
|
+
* ]);
|
84
|
+
* const addElementCommand = editor.image.addElement(stroke);
|
85
|
+
*
|
86
|
+
* // Add the stroke to the editor
|
87
|
+
* editor.dispatch(addElementCommand);
|
88
|
+
* ```
|
89
|
+
*/
|
90
|
+
readonly image: EditorImage;
|
91
|
+
/**
|
92
|
+
* Allows transforming the view and querying information about
|
93
|
+
* what is currently visible.
|
94
|
+
*/
|
95
|
+
readonly viewport: Viewport;
|
96
|
+
/** @internal */
|
97
|
+
readonly localization: EditorLocalization;
|
98
|
+
/** {@link EditorSettings.iconProvider} */
|
99
|
+
readonly icons: IconProvider;
|
100
|
+
/**
|
101
|
+
* Controls the list of tools. See
|
102
|
+
* [the custom tool example](https://github.com/personalizedrefrigerator/js-draw/tree/main/docs/example-custom-tools)
|
103
|
+
* for more.
|
104
|
+
*/
|
105
|
+
readonly toolController: ToolController;
|
106
|
+
/**
|
107
|
+
* Global event dispatcher/subscriber.
|
108
|
+
*/
|
109
|
+
readonly notifier: EditorNotifier;
|
110
|
+
private loadingWarning;
|
111
|
+
private accessibilityAnnounceArea;
|
112
|
+
private accessibilityControlArea;
|
113
|
+
private eventListenerTargets;
|
114
|
+
private settings;
|
115
|
+
/**
|
116
|
+
* @example
|
117
|
+
* ```
|
118
|
+
* const container = document.body;
|
119
|
+
*
|
120
|
+
* // Create an editor
|
121
|
+
* const editor = new Editor(container, {
|
122
|
+
* // 2e-10 and 1e12 are the default values for minimum/maximum zoom.
|
123
|
+
* minZoom: 2e-10,
|
124
|
+
* maxZoom: 1e12,
|
125
|
+
* });
|
126
|
+
*
|
127
|
+
* // Add the default toolbar
|
128
|
+
* const toolbar = editor.addToolbar();
|
129
|
+
*
|
130
|
+
* // Add a save button
|
131
|
+
* toolbar.addActionButton({
|
132
|
+
* label: 'Save'
|
133
|
+
* icon: createSaveIcon(),
|
134
|
+
* }, () => {
|
135
|
+
* const saveData = editor.toSVG().outerHTML;
|
136
|
+
* // Do something with saveData
|
137
|
+
* });
|
138
|
+
* ```
|
139
|
+
*/
|
140
|
+
constructor(parent: HTMLElement, settings?: Partial<EditorSettings>);
|
141
|
+
/**
|
142
|
+
* @returns a reference to the editor's container.
|
143
|
+
*
|
144
|
+
* @example
|
145
|
+
* ```
|
146
|
+
* // Set the editor's height to 500px
|
147
|
+
* editor.getRootElement().style.height = '500px';
|
148
|
+
* ```
|
149
|
+
*/
|
150
|
+
getRootElement(): HTMLElement;
|
151
|
+
/** @param fractionLoaded - should be a number from 0 to 1, where 1 represents completely loaded. */
|
152
|
+
showLoadingWarning(fractionLoaded: number): void;
|
153
|
+
hideLoadingWarning(): void;
|
154
|
+
private previousAccessibilityAnnouncement;
|
155
|
+
/**
|
156
|
+
* Announce `message` for screen readers. If `message` is the same as the previous
|
157
|
+
* message, it is re-announced.
|
158
|
+
*/
|
159
|
+
announceForAccessibility(message: string): void;
|
160
|
+
/**
|
161
|
+
* Creates a toolbar. If `defaultLayout` is true, default buttons are used.
|
162
|
+
* @returns a reference to the toolbar.
|
163
|
+
*/
|
164
|
+
addToolbar(defaultLayout?: boolean): HTMLToolbar;
|
165
|
+
private registerListeners;
|
166
|
+
private pointers;
|
167
|
+
private getPointerList;
|
168
|
+
/**
|
169
|
+
* Dispatches a `PointerEvent` to the editor. The target element for `evt` must have the same top left
|
170
|
+
* as the content of the editor.
|
171
|
+
*/
|
172
|
+
handleHTMLPointerEvent(eventType: 'pointerdown' | 'pointermove' | 'pointerup' | 'pointercancel', evt: PointerEvent): boolean;
|
173
|
+
private isEventSink;
|
174
|
+
private handlePaste;
|
175
|
+
/**
|
176
|
+
* Forward pointer events from `elem` to this editor. Such that right-click/right-click drag
|
177
|
+
* events are also forwarded, `elem`'s contextmenu is disabled.
|
178
|
+
*
|
179
|
+
* @example
|
180
|
+
* ```ts
|
181
|
+
* const overlay = document.createElement('div');
|
182
|
+
* editor.createHTMLOverlay(overlay);
|
183
|
+
*
|
184
|
+
* // Send all pointer events that don't have the control key pressed
|
185
|
+
* // to the editor.
|
186
|
+
* editor.handlePointerEventsFrom(overlay, (event) => {
|
187
|
+
* if (event.ctrlKey) {
|
188
|
+
* return false;
|
189
|
+
* }
|
190
|
+
* return true;
|
191
|
+
* });
|
192
|
+
* ```
|
193
|
+
*/
|
194
|
+
handlePointerEventsFrom(elem: HTMLElement, filter?: HTMLPointerEventFilter): void;
|
195
|
+
/** Adds event listners for keypresses to `elem` and forwards those events to the editor. */
|
196
|
+
handleKeyEventsFrom(elem: HTMLElement): void;
|
197
|
+
/** `apply` a command. `command` will be announced for accessibility. */
|
198
|
+
dispatch(command: Command, addToHistory?: boolean): void | Promise<void>;
|
199
|
+
/**
|
200
|
+
* Dispatches a command without announcing it. By default, does not add to history.
|
201
|
+
* Use this to show finalized commands that don't need to have `announceForAccessibility`
|
202
|
+
* called.
|
203
|
+
*
|
204
|
+
* Prefer `command.apply(editor)` for incomplete commands. `dispatchNoAnnounce` may allow
|
205
|
+
* clients to listen for the application of commands (e.g. `SerializableCommand`s so they can
|
206
|
+
* be sent across the network), while `apply` does not.
|
207
|
+
*
|
208
|
+
* @example
|
209
|
+
* ```
|
210
|
+
* const addToHistory = false;
|
211
|
+
* editor.dispatchNoAnnounce(editor.viewport.zoomTo(someRectangle), addToHistory);
|
212
|
+
* ```
|
213
|
+
*/
|
214
|
+
dispatchNoAnnounce(command: Command, addToHistory?: boolean): void | Promise<void>;
|
215
|
+
/**
|
216
|
+
* Apply a large transformation in chunks.
|
217
|
+
* If `apply` is `false`, the commands are unapplied.
|
218
|
+
* Triggers a re-render after each `updateChunkSize`-sized group of commands
|
219
|
+
* has been applied.
|
220
|
+
*/
|
221
|
+
asyncApplyOrUnapplyCommands(commands: Command[], apply: boolean, updateChunkSize: number): Promise<void>;
|
222
|
+
asyncApplyCommands(commands: Command[], chunkSize: number): Promise<void>;
|
223
|
+
asyncUnapplyCommands(commands: Command[], chunkSize: number, unapplyInReverseOrder?: boolean): Promise<void>;
|
224
|
+
private announceUndoCallback;
|
225
|
+
private announceRedoCallback;
|
226
|
+
private nextRerenderListeners;
|
227
|
+
private rerenderQueued;
|
228
|
+
/**
|
229
|
+
* Schedule a re-render for some time in the near future. Does not schedule an additional
|
230
|
+
* re-render if a re-render is already queued.
|
231
|
+
*
|
232
|
+
* @returns a promise that resolves when re-rendering has completed.
|
233
|
+
*/
|
234
|
+
queueRerender(): Promise<void>;
|
235
|
+
isRerenderQueued(): boolean;
|
236
|
+
/**
|
237
|
+
* Re-renders the entire image.
|
238
|
+
*
|
239
|
+
* @see {@link Editor.queueRerender}
|
240
|
+
*/
|
241
|
+
rerender(showImageBounds?: boolean): void;
|
242
|
+
/**
|
243
|
+
* Draws the given path onto the wet ink renderer. The given path will
|
244
|
+
* be displayed on top of the main image.
|
245
|
+
*
|
246
|
+
* @see {@link Display.getWetInkRenderer} {@link Display.flatten}
|
247
|
+
*/
|
248
|
+
drawWetInk(...path: RenderablePathSpec[]): void;
|
249
|
+
/**
|
250
|
+
* Clears the wet ink display.
|
251
|
+
*
|
252
|
+
* @see {@link Display.getWetInkRenderer}
|
253
|
+
*/
|
254
|
+
clearWetInk(): void;
|
255
|
+
/**
|
256
|
+
* Focuses the region used for text input/key commands.
|
257
|
+
*/
|
258
|
+
focus(): void;
|
259
|
+
/**
|
260
|
+
* Creates an element that will be positioned on top of the dry/wet ink
|
261
|
+
* renderers.
|
262
|
+
*
|
263
|
+
* This is useful for displaying content on top of the rendered content
|
264
|
+
* (e.g. a selection box).
|
265
|
+
*/
|
266
|
+
createHTMLOverlay(overlay: HTMLElement): {
|
267
|
+
remove: () => void;
|
268
|
+
};
|
269
|
+
addStyleSheet(content: string): HTMLStyleElement;
|
270
|
+
sendKeyboardEvent(eventType: InputEvtType.KeyPressEvent | InputEvtType.KeyUpEvent, key: string, ctrlKey?: boolean, altKey?: boolean): void;
|
271
|
+
/**
|
272
|
+
* Dispatch a pen event to the currently selected tool.
|
273
|
+
* Intended primarially for unit tests.
|
274
|
+
*
|
275
|
+
* @deprecated
|
276
|
+
* @see {@link sendPenEvent} {@link sendTouchEvent}
|
277
|
+
*/
|
278
|
+
sendPenEvent(eventType: InputEvtType.PointerDownEvt | InputEvtType.PointerMoveEvt | InputEvtType.PointerUpEvt, point: Point2, allPointers?: Pointer[]): void;
|
279
|
+
addAndCenterComponents(components: AbstractComponent[], selectComponents?: boolean): Promise<void>;
|
280
|
+
toDataURL(format?: 'image/png' | 'image/jpeg' | 'image/webp'): string;
|
281
|
+
toSVG(): SVGElement;
|
282
|
+
/**
|
283
|
+
* Load editor data from an `ImageLoader` (e.g. an {@link SVGLoader}).
|
284
|
+
*
|
285
|
+
* @see loadFromSVG
|
286
|
+
*/
|
287
|
+
loadFrom(loader: ImageLoader): Promise<void>;
|
288
|
+
private getTopmostBackgroundComponent;
|
289
|
+
/**
|
290
|
+
* Set the background color of the image.
|
291
|
+
*/
|
292
|
+
setBackgroundColor(color: Color4): Command;
|
293
|
+
/**
|
294
|
+
* @returns the average of the colors of all background components. Use this to get the current background
|
295
|
+
* color.
|
296
|
+
*/
|
297
|
+
estimateBackgroundColor(): Color4;
|
298
|
+
getImportExportRect(): Rect2;
|
299
|
+
setImportExportRect(imageRect: Rect2): Command;
|
300
|
+
/**
|
301
|
+
* Alias for loadFrom(SVGLoader.fromString).
|
302
|
+
*
|
303
|
+
* This is particularly useful when accessing a bundled version of the editor,
|
304
|
+
* where `SVGLoader.fromString` is unavailable.
|
305
|
+
*/
|
306
|
+
loadFromSVG(svgData: string, sanitize?: boolean): Promise<void>;
|
307
|
+
}
|
308
|
+
export default Editor;
|