js-draw 0.23.0 → 0.24.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.
Files changed (1127) hide show
  1. package/build-config.json +23 -0
  2. package/dist/bundle.js +3 -3
  3. package/dist/bundledStyles.js +1 -1
  4. package/dist/cjs/Color4.js +263 -0
  5. package/dist/cjs/Editor.d.ts +328 -0
  6. package/dist/cjs/Editor.js +1058 -0
  7. package/dist/cjs/EditorImage.d.ts +97 -0
  8. package/dist/cjs/EditorImage.js +531 -0
  9. package/dist/cjs/EventDispatcher.d.ts +29 -0
  10. package/dist/cjs/EventDispatcher.js +58 -0
  11. package/dist/cjs/Pointer.d.ts +37 -0
  12. package/dist/cjs/Pointer.js +123 -0
  13. package/dist/cjs/SVGLoader.d.ts +48 -0
  14. package/dist/cjs/SVGLoader.js +667 -0
  15. package/dist/cjs/SVGLoader.test.d.ts +1 -0
  16. package/dist/cjs/UndoRedoHistory.js +105 -0
  17. package/dist/cjs/UndoRedoHistory.test.d.ts +1 -0
  18. package/dist/cjs/Viewport.d.ts +73 -0
  19. package/dist/cjs/Viewport.js +307 -0
  20. package/dist/cjs/bundle/bundled.js +21 -0
  21. package/dist/cjs/commands/Command.js +61 -0
  22. package/dist/cjs/commands/Duplicate.js +80 -0
  23. package/dist/cjs/commands/Erase.js +101 -0
  24. package/dist/cjs/commands/SerializableCommand.js +57 -0
  25. package/dist/cjs/commands/UnresolvedCommand.js +43 -0
  26. package/dist/cjs/commands/invertCommand.js +77 -0
  27. package/dist/cjs/commands/lib.js +15 -0
  28. package/dist/cjs/commands/localization.d.ts +23 -0
  29. package/dist/cjs/commands/localization.js +24 -0
  30. package/dist/cjs/commands/uniteCommands.js +152 -0
  31. package/dist/cjs/commands/uniteCommands.test.d.ts +1 -0
  32. package/dist/cjs/components/AbstractComponent.d.ts +85 -0
  33. package/dist/cjs/components/AbstractComponent.js +300 -0
  34. package/dist/cjs/components/AbstractComponent.transformBy.test.d.ts +1 -0
  35. package/dist/cjs/components/BackgroundComponent.d.ts +62 -0
  36. package/dist/cjs/components/BackgroundComponent.js +311 -0
  37. package/dist/cjs/components/BackgroundComponent.test.d.ts +1 -0
  38. package/dist/cjs/components/ImageComponent.d.ts +31 -0
  39. package/dist/cjs/components/ImageComponent.js +228 -0
  40. package/dist/cjs/components/RestylableComponent.js +103 -0
  41. package/dist/cjs/components/SVGGlobalAttributesObject.d.ts +21 -0
  42. package/dist/cjs/components/SVGGlobalAttributesObject.js +82 -0
  43. package/dist/cjs/components/Stroke.d.ts +76 -0
  44. package/dist/cjs/components/Stroke.js +271 -0
  45. package/dist/cjs/components/Stroke.test.d.ts +1 -0
  46. package/dist/cjs/components/TextComponent.d.ts +79 -0
  47. package/dist/cjs/components/TextComponent.js +411 -0
  48. package/dist/cjs/components/TextComponent.test.d.ts +1 -0
  49. package/dist/cjs/components/UnknownSVGObject.d.ts +18 -0
  50. package/dist/cjs/components/UnknownSVGObject.js +65 -0
  51. package/dist/cjs/components/UnknownSVGObject.test.d.ts +1 -0
  52. package/dist/cjs/components/builders/ArrowBuilder.d.ts +19 -0
  53. package/dist/cjs/components/builders/ArrowBuilder.js +93 -0
  54. package/dist/cjs/components/builders/CircleBuilder.d.ts +2 -0
  55. package/dist/cjs/components/builders/CircleBuilder.js +74 -0
  56. package/dist/cjs/components/builders/FreehandLineBuilder.d.ts +33 -0
  57. package/dist/cjs/components/builders/FreehandLineBuilder.js +183 -0
  58. package/dist/cjs/components/builders/FreehandLineBuilder.test.d.ts +1 -0
  59. package/dist/cjs/components/builders/LineBuilder.d.ts +18 -0
  60. package/dist/cjs/components/builders/LineBuilder.js +65 -0
  61. package/dist/cjs/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
  62. package/dist/cjs/components/builders/PressureSensitiveFreehandLineBuilder.js +351 -0
  63. package/dist/cjs/components/builders/RectangleBuilder.d.ts +20 -0
  64. package/dist/cjs/components/builders/RectangleBuilder.js +58 -0
  65. package/dist/cjs/components/builders/types.d.ts +12 -0
  66. package/dist/cjs/components/lib.d.ts +14 -0
  67. package/dist/cjs/components/lib.js +42 -0
  68. package/dist/cjs/components/localization.js +14 -0
  69. package/dist/cjs/components/util/StrokeSmoother.d.ts +35 -0
  70. package/dist/cjs/components/util/StrokeSmoother.js +225 -0
  71. package/dist/cjs/components/util/describeComponentList.d.ts +4 -0
  72. package/dist/cjs/components/util/describeComponentList.js +17 -0
  73. package/dist/cjs/lib.d.ts +66 -0
  74. package/dist/cjs/lib.js +94 -0
  75. package/dist/cjs/localization.js +24 -0
  76. package/dist/cjs/localizations/de.js +17 -0
  77. package/dist/cjs/localizations/en.js +17 -0
  78. package/dist/cjs/localizations/es.js +31 -0
  79. package/dist/cjs/localizations/getLocalizationTable.d.ts +17 -0
  80. package/dist/cjs/localizations/getLocalizationTable.js +65 -0
  81. package/dist/cjs/localizations/getLocalizationTable.test.d.ts +1 -0
  82. package/dist/cjs/math/Mat33.d.ts +123 -0
  83. package/dist/cjs/math/Mat33.js +340 -0
  84. package/dist/cjs/math/Mat33.test.d.ts +1 -0
  85. package/dist/cjs/math/Vec2.js +37 -0
  86. package/dist/cjs/math/Vec2.test.d.ts +1 -0
  87. package/dist/cjs/math/Vec3.js +183 -0
  88. package/dist/cjs/math/Vec3.test.d.ts +1 -0
  89. package/dist/cjs/math/lib.d.ts +7 -0
  90. package/dist/cjs/math/lib.js +15 -0
  91. package/dist/cjs/math/polynomial/solveQuadratic.d.ts +9 -0
  92. package/dist/cjs/math/polynomial/solveQuadratic.js +39 -0
  93. package/dist/cjs/math/polynomial/solveQuadratic.test.d.ts +1 -0
  94. package/dist/cjs/math/rounding.js +140 -0
  95. package/dist/cjs/math/rounding.test.d.ts +1 -0
  96. package/dist/cjs/math/shapes/Abstract2DShape.d.ts +49 -0
  97. package/dist/cjs/math/shapes/Abstract2DShape.js +42 -0
  98. package/dist/cjs/math/shapes/BezierJSWrapper.d.ts +36 -0
  99. package/dist/cjs/math/shapes/BezierJSWrapper.js +109 -0
  100. package/dist/cjs/math/shapes/CubicBezier.d.ts +17 -0
  101. package/dist/cjs/math/shapes/CubicBezier.js +50 -0
  102. package/dist/cjs/math/shapes/LineSegment2.d.ts +70 -0
  103. package/dist/cjs/math/shapes/LineSegment2.js +204 -0
  104. package/dist/cjs/math/shapes/LineSegment2.test.d.ts +1 -0
  105. package/dist/cjs/math/shapes/Path.d.ts +93 -0
  106. package/dist/cjs/math/shapes/Path.fromString.test.d.ts +1 -0
  107. package/dist/cjs/math/shapes/Path.js +865 -0
  108. package/dist/cjs/math/shapes/Path.test.d.ts +1 -0
  109. package/dist/cjs/math/shapes/Path.toString.test.d.ts +1 -0
  110. package/dist/cjs/math/shapes/PointShape2D.d.ts +18 -0
  111. package/dist/cjs/math/shapes/PointShape2D.js +46 -0
  112. package/dist/cjs/math/shapes/QuadraticBezier.d.ts +34 -0
  113. package/dist/cjs/math/shapes/QuadraticBezier.js +133 -0
  114. package/dist/cjs/math/shapes/QuadraticBezier.test.d.ts +1 -0
  115. package/dist/cjs/math/shapes/Rect2.d.ts +57 -0
  116. package/dist/cjs/math/shapes/Rect2.js +311 -0
  117. package/dist/cjs/math/shapes/Rect2.test.d.ts +1 -0
  118. package/dist/cjs/math/shapes/Triangle.d.ts +46 -0
  119. package/dist/cjs/math/shapes/Triangle.js +148 -0
  120. package/dist/cjs/math/shapes/Triangle.test.d.ts +1 -0
  121. package/dist/cjs/rendering/Display.js +222 -0
  122. package/dist/cjs/rendering/RenderingStyle.d.ts +31 -0
  123. package/dist/cjs/rendering/RenderingStyle.js +56 -0
  124. package/dist/cjs/rendering/RenderingStyle.test.d.ts +1 -0
  125. package/dist/cjs/rendering/TextRenderingStyle.d.ts +43 -0
  126. package/dist/cjs/rendering/TextRenderingStyle.js +40 -0
  127. package/dist/cjs/rendering/caching/CacheRecord.d.ts +20 -0
  128. package/dist/cjs/rendering/caching/CacheRecord.js +59 -0
  129. package/dist/cjs/rendering/caching/CacheRecord.test.d.ts +1 -0
  130. package/dist/cjs/rendering/caching/CacheRecordManager.d.ts +12 -0
  131. package/dist/cjs/rendering/caching/CacheRecordManager.js +48 -0
  132. package/dist/cjs/rendering/caching/RenderingCache.js +50 -0
  133. package/dist/cjs/rendering/caching/RenderingCache.test.d.ts +1 -0
  134. package/dist/cjs/rendering/caching/RenderingCacheNode.d.ts +29 -0
  135. package/dist/cjs/rendering/caching/RenderingCacheNode.js +340 -0
  136. package/dist/cjs/rendering/caching/testUtils.js +34 -0
  137. package/dist/cjs/rendering/lib.js +14 -0
  138. package/dist/cjs/rendering/localization.js +12 -0
  139. package/dist/cjs/rendering/renderers/AbstractRenderer.d.ts +85 -0
  140. package/dist/cjs/rendering/renderers/AbstractRenderer.js +168 -0
  141. package/dist/cjs/rendering/renderers/CanvasRenderer.d.ts +63 -0
  142. package/dist/cjs/rendering/renderers/CanvasRenderer.js +263 -0
  143. package/dist/cjs/rendering/renderers/DummyRenderer.d.ts +35 -0
  144. package/dist/cjs/rendering/renderers/DummyRenderer.js +132 -0
  145. package/dist/cjs/rendering/renderers/DummyRenderer.test.d.ts +1 -0
  146. package/dist/cjs/rendering/renderers/SVGRenderer.d.ts +57 -0
  147. package/dist/cjs/rendering/renderers/SVGRenderer.js +355 -0
  148. package/dist/cjs/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
  149. package/dist/cjs/rendering/renderers/TextOnlyRenderer.js +89 -0
  150. package/dist/cjs/rendering/renderers/TextOnlyRenderer.test.d.ts +1 -0
  151. package/dist/cjs/shortcuts/KeyBinding.d.ts +46 -0
  152. package/dist/cjs/shortcuts/KeyBinding.js +157 -0
  153. package/dist/cjs/shortcuts/KeyBinding.test.d.ts +1 -0
  154. package/dist/cjs/shortcuts/KeyboardShortcutManager.d.ts +77 -0
  155. package/dist/cjs/shortcuts/KeyboardShortcutManager.js +148 -0
  156. package/dist/cjs/shortcuts/KeyboardShortcutManager.test.d.ts +1 -0
  157. package/dist/cjs/shortcuts/lib.d.ts +2 -0
  158. package/dist/cjs/shortcuts/lib.js +7 -0
  159. package/dist/cjs/testing/createEditor.js +11 -0
  160. package/dist/cjs/testing/lib.js +7 -0
  161. package/dist/cjs/testing/sendPenEvent.js +21 -0
  162. package/dist/cjs/testing/sendTouchEvent.js +73 -0
  163. package/dist/cjs/toolbar/HTMLToolbar.js +465 -0
  164. package/dist/cjs/toolbar/IconProvider.js +274 -0
  165. package/dist/cjs/toolbar/lib.js +21 -0
  166. package/dist/cjs/toolbar/localization.d.ts +52 -0
  167. package/dist/cjs/toolbar/localization.js +54 -0
  168. package/dist/cjs/toolbar/makeColorInput.js +125 -0
  169. package/dist/cjs/toolbar/widgets/ActionButtonWidget.js +47 -0
  170. package/dist/cjs/toolbar/widgets/BaseToolWidget.js +64 -0
  171. package/dist/cjs/toolbar/widgets/BaseWidget.d.ts +78 -0
  172. package/dist/cjs/toolbar/widgets/BaseWidget.js +359 -0
  173. package/dist/cjs/toolbar/widgets/DocumentPropertiesWidget.js +196 -0
  174. package/dist/cjs/toolbar/widgets/EraserToolWidget.js +90 -0
  175. package/dist/cjs/toolbar/widgets/HandToolWidget.js +211 -0
  176. package/dist/cjs/toolbar/widgets/InsertImageWidget.js +246 -0
  177. package/dist/cjs/toolbar/widgets/OverflowWidget.js +103 -0
  178. package/dist/cjs/toolbar/widgets/PenToolWidget.js +264 -0
  179. package/dist/cjs/toolbar/widgets/SelectionToolWidget.js +213 -0
  180. package/dist/cjs/toolbar/widgets/TextToolWidget.js +142 -0
  181. package/dist/cjs/toolbar/widgets/keybindings.d.ts +2 -0
  182. package/dist/cjs/toolbar/widgets/keybindings.js +13 -0
  183. package/dist/cjs/toolbar/widgets/lib.js +23 -0
  184. package/dist/cjs/tools/BaseTool.js +67 -0
  185. package/dist/cjs/tools/Eraser.d.ts +24 -0
  186. package/dist/cjs/tools/Eraser.js +148 -0
  187. package/dist/cjs/tools/Eraser.test.d.ts +1 -0
  188. package/dist/cjs/tools/FindTool.d.ts +20 -0
  189. package/dist/cjs/tools/FindTool.js +137 -0
  190. package/dist/cjs/tools/PanZoom.d.ts +52 -0
  191. package/dist/cjs/tools/PanZoom.js +471 -0
  192. package/dist/cjs/tools/PanZoom.test.d.ts +1 -0
  193. package/dist/cjs/tools/PasteHandler.js +179 -0
  194. package/dist/cjs/tools/Pen.d.ts +41 -0
  195. package/dist/cjs/tools/Pen.js +238 -0
  196. package/dist/cjs/tools/Pen.test.d.ts +1 -0
  197. package/dist/cjs/tools/PipetteTool.js +63 -0
  198. package/dist/cjs/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
  199. package/dist/cjs/tools/SelectionTool/SelectAllShortcutHandler.js +44 -0
  200. package/dist/cjs/tools/SelectionTool/Selection.d.ts +64 -0
  201. package/dist/cjs/tools/SelectionTool/Selection.js +602 -0
  202. package/dist/cjs/tools/SelectionTool/SelectionHandle.js +86 -0
  203. package/dist/cjs/tools/SelectionTool/SelectionTool.d.ts +37 -0
  204. package/dist/cjs/tools/SelectionTool/SelectionTool.js +441 -0
  205. package/dist/cjs/tools/SelectionTool/SelectionTool.test.d.ts +1 -0
  206. package/dist/cjs/tools/SelectionTool/TransformMode.js +107 -0
  207. package/dist/cjs/tools/SelectionTool/types.js +14 -0
  208. package/dist/cjs/tools/SoundUITool.js +182 -0
  209. package/dist/cjs/tools/TextTool.d.ts +34 -0
  210. package/dist/cjs/tools/TextTool.js +284 -0
  211. package/dist/cjs/tools/ToolController.js +179 -0
  212. package/dist/cjs/tools/ToolEnabledGroup.js +16 -0
  213. package/dist/cjs/tools/ToolSwitcherShortcut.js +54 -0
  214. package/dist/cjs/tools/ToolbarShortcutHandler.js +50 -0
  215. package/dist/cjs/tools/UndoRedoShortcut.d.ts +8 -0
  216. package/dist/cjs/tools/UndoRedoShortcut.js +42 -0
  217. package/dist/cjs/tools/UndoRedoShortcut.test.d.ts +1 -0
  218. package/dist/cjs/tools/keybindings.d.ts +17 -0
  219. package/dist/cjs/tools/keybindings.js +44 -0
  220. package/dist/cjs/tools/lib.js +35 -0
  221. package/dist/cjs/tools/localization.js +33 -0
  222. package/dist/cjs/types.d.ts +154 -0
  223. package/dist/cjs/types.js +38 -0
  224. package/dist/cjs/util/assertions.js +54 -0
  225. package/dist/cjs/util/fileToBase64.js +15 -0
  226. package/dist/cjs/util/untilNextAnimationFrame.js +9 -0
  227. package/dist/cjs/util/waitForAll.js +17 -0
  228. package/dist/cjs/util/waitForTimeout.js +9 -0
  229. package/dist/mjs/Color4.mjs +260 -0
  230. package/dist/mjs/Color4.test.d.ts +1 -0
  231. package/dist/mjs/Editor.d.ts +328 -0
  232. package/dist/mjs/Editor.loadFrom.test.d.ts +1 -0
  233. package/dist/mjs/Editor.mjs +1055 -0
  234. package/dist/mjs/Editor.toSVG.test.d.ts +1 -0
  235. package/dist/mjs/EditorImage.d.ts +97 -0
  236. package/dist/mjs/EditorImage.mjs +527 -0
  237. package/dist/mjs/EditorImage.test.d.ts +1 -0
  238. package/dist/mjs/EventDispatcher.d.ts +29 -0
  239. package/dist/mjs/EventDispatcher.mjs +56 -0
  240. package/dist/mjs/EventDispatcher.test.d.ts +1 -0
  241. package/dist/mjs/Pointer.d.ts +37 -0
  242. package/dist/mjs/Pointer.mjs +120 -0
  243. package/dist/mjs/SVGLoader.d.ts +48 -0
  244. package/dist/mjs/SVGLoader.mjs +664 -0
  245. package/dist/mjs/SVGLoader.test.d.ts +1 -0
  246. package/dist/mjs/UndoRedoHistory.mjs +103 -0
  247. package/dist/mjs/UndoRedoHistory.test.d.ts +1 -0
  248. package/dist/mjs/Viewport.d.ts +73 -0
  249. package/dist/mjs/Viewport.mjs +304 -0
  250. package/dist/mjs/commands/Command.mjs +58 -0
  251. package/dist/mjs/commands/Duplicate.mjs +78 -0
  252. package/dist/mjs/commands/Erase.mjs +99 -0
  253. package/dist/mjs/commands/SerializableCommand.mjs +55 -0
  254. package/dist/mjs/commands/UnresolvedCommand.mjs +41 -0
  255. package/dist/mjs/commands/invertCommand.mjs +75 -0
  256. package/dist/mjs/commands/localization.d.ts +23 -0
  257. package/dist/mjs/commands/localization.mjs +21 -0
  258. package/dist/mjs/commands/uniteCommands.mjs +150 -0
  259. package/dist/mjs/commands/uniteCommands.test.d.ts +1 -0
  260. package/dist/mjs/components/AbstractComponent.d.ts +85 -0
  261. package/dist/mjs/components/AbstractComponent.mjs +298 -0
  262. package/dist/mjs/components/AbstractComponent.transformBy.test.d.ts +1 -0
  263. package/dist/mjs/components/BackgroundComponent.d.ts +62 -0
  264. package/dist/mjs/components/BackgroundComponent.mjs +308 -0
  265. package/dist/mjs/components/BackgroundComponent.test.d.ts +1 -0
  266. package/dist/mjs/components/ImageComponent.d.ts +31 -0
  267. package/dist/mjs/components/ImageComponent.mjs +226 -0
  268. package/dist/mjs/components/RestylableComponent.mjs +98 -0
  269. package/dist/mjs/components/SVGGlobalAttributesObject.d.ts +21 -0
  270. package/dist/mjs/components/SVGGlobalAttributesObject.mjs +80 -0
  271. package/dist/mjs/components/Stroke.d.ts +76 -0
  272. package/dist/mjs/components/Stroke.mjs +269 -0
  273. package/dist/mjs/components/Stroke.test.d.ts +1 -0
  274. package/dist/mjs/components/TextComponent.d.ts +79 -0
  275. package/dist/mjs/components/TextComponent.mjs +408 -0
  276. package/dist/mjs/components/TextComponent.test.d.ts +1 -0
  277. package/dist/mjs/components/UnknownSVGObject.d.ts +18 -0
  278. package/dist/mjs/components/UnknownSVGObject.mjs +63 -0
  279. package/dist/mjs/components/UnknownSVGObject.test.d.ts +1 -0
  280. package/dist/mjs/components/builders/ArrowBuilder.d.ts +19 -0
  281. package/dist/mjs/components/builders/ArrowBuilder.mjs +89 -0
  282. package/dist/mjs/components/builders/CircleBuilder.d.ts +2 -0
  283. package/dist/mjs/components/builders/CircleBuilder.mjs +70 -0
  284. package/dist/mjs/components/builders/FreehandLineBuilder.d.ts +33 -0
  285. package/dist/mjs/components/builders/FreehandLineBuilder.mjs +179 -0
  286. package/dist/mjs/components/builders/FreehandLineBuilder.test.d.ts +1 -0
  287. package/dist/mjs/components/builders/LineBuilder.d.ts +18 -0
  288. package/dist/mjs/components/builders/LineBuilder.mjs +61 -0
  289. package/dist/mjs/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
  290. package/dist/mjs/components/builders/PressureSensitiveFreehandLineBuilder.mjs +347 -0
  291. package/dist/mjs/components/builders/RectangleBuilder.d.ts +20 -0
  292. package/dist/mjs/components/builders/RectangleBuilder.mjs +53 -0
  293. package/dist/mjs/components/builders/types.d.ts +12 -0
  294. package/dist/mjs/components/builders/types.mjs +1 -0
  295. package/dist/mjs/components/lib.d.ts +14 -0
  296. package/dist/mjs/components/lib.mjs +15 -0
  297. package/dist/mjs/components/localization.mjs +11 -0
  298. package/dist/mjs/components/util/StrokeSmoother.d.ts +35 -0
  299. package/dist/mjs/components/util/StrokeSmoother.mjs +222 -0
  300. package/dist/mjs/components/util/describeComponentList.d.ts +4 -0
  301. package/dist/mjs/components/util/describeComponentList.mjs +15 -0
  302. package/dist/mjs/lib.d.ts +66 -0
  303. package/dist/mjs/lib.mjs +66 -0
  304. package/dist/mjs/localization.mjs +21 -0
  305. package/dist/mjs/localizations/de.mjs +15 -0
  306. package/dist/mjs/localizations/en.mjs +15 -0
  307. package/dist/mjs/localizations/es.mjs +29 -0
  308. package/dist/mjs/localizations/getLocalizationTable.d.ts +17 -0
  309. package/dist/mjs/localizations/getLocalizationTable.mjs +61 -0
  310. package/dist/mjs/localizations/getLocalizationTable.test.d.ts +1 -0
  311. package/dist/mjs/math/Mat33.d.ts +123 -0
  312. package/dist/mjs/math/Mat33.mjs +338 -0
  313. package/dist/mjs/math/Mat33.test.d.ts +1 -0
  314. package/dist/mjs/math/Vec2.mjs +34 -0
  315. package/dist/mjs/math/Vec2.test.d.ts +1 -0
  316. package/dist/mjs/math/Vec3.mjs +181 -0
  317. package/dist/mjs/math/Vec3.test.d.ts +1 -0
  318. package/dist/mjs/math/lib.d.ts +7 -0
  319. package/dist/mjs/math/lib.mjs +7 -0
  320. package/dist/mjs/math/polynomial/solveQuadratic.d.ts +9 -0
  321. package/dist/mjs/math/polynomial/solveQuadratic.mjs +37 -0
  322. package/dist/mjs/math/polynomial/solveQuadratic.test.d.ts +1 -0
  323. package/dist/mjs/math/rounding.mjs +133 -0
  324. package/dist/mjs/math/rounding.test.d.ts +1 -0
  325. package/dist/mjs/math/shapes/Abstract2DShape.d.ts +49 -0
  326. package/dist/mjs/math/shapes/Abstract2DShape.mjs +40 -0
  327. package/dist/mjs/math/shapes/BezierJSWrapper.d.ts +36 -0
  328. package/dist/mjs/math/shapes/BezierJSWrapper.mjs +107 -0
  329. package/dist/mjs/math/shapes/CubicBezier.d.ts +17 -0
  330. package/dist/mjs/math/shapes/CubicBezier.mjs +48 -0
  331. package/dist/mjs/math/shapes/LineSegment2.d.ts +70 -0
  332. package/dist/mjs/math/shapes/LineSegment2.mjs +202 -0
  333. package/dist/mjs/math/shapes/LineSegment2.test.d.ts +1 -0
  334. package/dist/mjs/math/shapes/Path.d.ts +93 -0
  335. package/dist/mjs/math/shapes/Path.fromString.test.d.ts +1 -0
  336. package/dist/mjs/math/shapes/Path.mjs +862 -0
  337. package/dist/mjs/math/shapes/Path.test.d.ts +1 -0
  338. package/dist/mjs/math/shapes/Path.toString.test.d.ts +1 -0
  339. package/dist/mjs/math/shapes/PointShape2D.d.ts +18 -0
  340. package/dist/mjs/math/shapes/PointShape2D.mjs +44 -0
  341. package/dist/mjs/math/shapes/QuadraticBezier.d.ts +34 -0
  342. package/dist/mjs/math/shapes/QuadraticBezier.mjs +131 -0
  343. package/dist/mjs/math/shapes/QuadraticBezier.test.d.ts +1 -0
  344. package/dist/mjs/math/shapes/Rect2.d.ts +57 -0
  345. package/dist/mjs/math/shapes/Rect2.mjs +309 -0
  346. package/dist/mjs/math/shapes/Rect2.test.d.ts +1 -0
  347. package/dist/mjs/math/shapes/Triangle.d.ts +46 -0
  348. package/dist/mjs/math/shapes/Triangle.mjs +146 -0
  349. package/dist/mjs/math/shapes/Triangle.test.d.ts +1 -0
  350. package/dist/mjs/rendering/Display.mjs +219 -0
  351. package/dist/mjs/rendering/RenderingStyle.d.ts +31 -0
  352. package/dist/mjs/rendering/RenderingStyle.mjs +49 -0
  353. package/dist/mjs/rendering/RenderingStyle.test.d.ts +1 -0
  354. package/dist/mjs/rendering/TextRenderingStyle.d.ts +43 -0
  355. package/dist/mjs/rendering/TextRenderingStyle.mjs +34 -0
  356. package/dist/mjs/rendering/caching/CacheRecord.d.ts +20 -0
  357. package/dist/mjs/rendering/caching/CacheRecord.mjs +57 -0
  358. package/dist/mjs/rendering/caching/CacheRecord.test.d.ts +1 -0
  359. package/dist/mjs/rendering/caching/CacheRecordManager.d.ts +12 -0
  360. package/dist/mjs/rendering/caching/CacheRecordManager.mjs +45 -0
  361. package/dist/mjs/rendering/caching/RenderingCache.mjs +48 -0
  362. package/dist/mjs/rendering/caching/RenderingCache.test.d.ts +1 -0
  363. package/dist/mjs/rendering/caching/RenderingCacheNode.d.ts +29 -0
  364. package/dist/mjs/rendering/caching/RenderingCacheNode.mjs +338 -0
  365. package/dist/mjs/rendering/caching/testUtils.mjs +30 -0
  366. package/dist/mjs/rendering/caching/types.mjs +1 -0
  367. package/dist/mjs/rendering/localization.mjs +9 -0
  368. package/dist/mjs/rendering/renderers/AbstractRenderer.d.ts +85 -0
  369. package/dist/mjs/rendering/renderers/AbstractRenderer.mjs +166 -0
  370. package/dist/mjs/rendering/renderers/CanvasRenderer.d.ts +63 -0
  371. package/dist/mjs/rendering/renderers/CanvasRenderer.mjs +261 -0
  372. package/dist/mjs/rendering/renderers/DummyRenderer.d.ts +35 -0
  373. package/dist/mjs/rendering/renderers/DummyRenderer.mjs +130 -0
  374. package/dist/mjs/rendering/renderers/DummyRenderer.test.d.ts +1 -0
  375. package/dist/mjs/rendering/renderers/SVGRenderer.d.ts +57 -0
  376. package/dist/mjs/rendering/renderers/SVGRenderer.mjs +352 -0
  377. package/dist/mjs/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
  378. package/dist/mjs/rendering/renderers/TextOnlyRenderer.mjs +87 -0
  379. package/dist/mjs/rendering/renderers/TextOnlyRenderer.test.d.ts +1 -0
  380. package/dist/mjs/shortcuts/KeyBinding.d.ts +46 -0
  381. package/dist/mjs/shortcuts/KeyBinding.mjs +155 -0
  382. package/dist/mjs/shortcuts/KeyBinding.test.d.ts +1 -0
  383. package/dist/mjs/shortcuts/KeyboardShortcutManager.d.ts +77 -0
  384. package/dist/mjs/shortcuts/KeyboardShortcutManager.mjs +146 -0
  385. package/dist/mjs/shortcuts/KeyboardShortcutManager.test.d.ts +1 -0
  386. package/dist/mjs/shortcuts/lib.d.ts +2 -0
  387. package/dist/mjs/shortcuts/lib.mjs +2 -0
  388. package/dist/mjs/testing/createEditor.mjs +9 -0
  389. package/dist/mjs/testing/sendPenEvent.mjs +19 -0
  390. package/dist/mjs/testing/sendTouchEvent.mjs +71 -0
  391. package/dist/mjs/toolbar/HTMLToolbar.mjs +462 -0
  392. package/dist/mjs/toolbar/IconProvider.mjs +272 -0
  393. package/dist/mjs/toolbar/localization.d.ts +52 -0
  394. package/dist/mjs/toolbar/localization.mjs +51 -0
  395. package/dist/mjs/toolbar/makeColorInput.mjs +121 -0
  396. package/dist/mjs/toolbar/types.mjs +1 -0
  397. package/dist/mjs/toolbar/widgets/ActionButtonWidget.mjs +45 -0
  398. package/dist/mjs/toolbar/widgets/BaseToolWidget.mjs +62 -0
  399. package/dist/mjs/toolbar/widgets/BaseWidget.d.ts +78 -0
  400. package/dist/mjs/toolbar/widgets/BaseWidget.mjs +357 -0
  401. package/dist/mjs/toolbar/widgets/DocumentPropertiesWidget.mjs +194 -0
  402. package/dist/mjs/toolbar/widgets/EraserToolWidget.mjs +88 -0
  403. package/dist/mjs/toolbar/widgets/HandToolWidget.mjs +209 -0
  404. package/dist/mjs/toolbar/widgets/InsertImageWidget.mjs +244 -0
  405. package/dist/mjs/toolbar/widgets/OverflowWidget.mjs +101 -0
  406. package/dist/mjs/toolbar/widgets/PenToolWidget.mjs +262 -0
  407. package/dist/mjs/toolbar/widgets/SelectionToolWidget.mjs +211 -0
  408. package/dist/mjs/toolbar/widgets/TextToolWidget.mjs +140 -0
  409. package/dist/mjs/toolbar/widgets/keybindings.d.ts +2 -0
  410. package/dist/mjs/toolbar/widgets/keybindings.mjs +10 -0
  411. package/dist/mjs/tools/BaseTool.mjs +65 -0
  412. package/dist/mjs/tools/Eraser.d.ts +24 -0
  413. package/dist/mjs/tools/Eraser.mjs +146 -0
  414. package/dist/mjs/tools/Eraser.test.d.ts +1 -0
  415. package/dist/mjs/tools/FindTool.d.ts +20 -0
  416. package/dist/mjs/tools/FindTool.mjs +135 -0
  417. package/dist/mjs/tools/PanZoom.d.ts +52 -0
  418. package/dist/mjs/tools/PanZoom.mjs +468 -0
  419. package/dist/mjs/tools/PanZoom.test.d.ts +1 -0
  420. package/dist/mjs/tools/PasteHandler.mjs +177 -0
  421. package/dist/mjs/tools/Pen.d.ts +41 -0
  422. package/dist/mjs/tools/Pen.mjs +236 -0
  423. package/dist/mjs/tools/Pen.test.d.ts +1 -0
  424. package/dist/mjs/tools/PipetteTool.mjs +61 -0
  425. package/dist/mjs/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
  426. package/dist/mjs/tools/SelectionTool/SelectAllShortcutHandler.mjs +42 -0
  427. package/dist/mjs/tools/SelectionTool/Selection.d.ts +64 -0
  428. package/dist/mjs/tools/SelectionTool/Selection.mjs +600 -0
  429. package/dist/mjs/tools/SelectionTool/SelectionHandle.mjs +83 -0
  430. package/dist/mjs/tools/SelectionTool/SelectionTool.d.ts +37 -0
  431. package/dist/mjs/tools/SelectionTool/SelectionTool.mjs +438 -0
  432. package/dist/mjs/tools/SelectionTool/SelectionTool.test.d.ts +1 -0
  433. package/dist/mjs/tools/SelectionTool/TransformMode.mjs +104 -0
  434. package/dist/mjs/tools/SoundUITool.mjs +180 -0
  435. package/dist/mjs/tools/TextTool.d.ts +34 -0
  436. package/dist/mjs/tools/TextTool.mjs +282 -0
  437. package/dist/mjs/tools/ToolController.mjs +177 -0
  438. package/dist/mjs/tools/ToolEnabledGroup.mjs +14 -0
  439. package/dist/mjs/tools/ToolSwitcherShortcut.mjs +52 -0
  440. package/dist/mjs/tools/ToolbarShortcutHandler.mjs +48 -0
  441. package/dist/mjs/tools/UndoRedoShortcut.d.ts +8 -0
  442. package/dist/mjs/tools/UndoRedoShortcut.mjs +40 -0
  443. package/dist/mjs/tools/UndoRedoShortcut.test.d.ts +1 -0
  444. package/dist/mjs/tools/keybindings.d.ts +17 -0
  445. package/dist/mjs/tools/keybindings.mjs +41 -0
  446. package/dist/mjs/tools/localization.mjs +30 -0
  447. package/dist/mjs/types.d.ts +154 -0
  448. package/dist/mjs/util/assertions.mjs +48 -0
  449. package/dist/mjs/util/fileToBase64.mjs +13 -0
  450. package/dist/mjs/util/untilNextAnimationFrame.mjs +7 -0
  451. package/dist/mjs/util/waitForAll.mjs +15 -0
  452. package/dist/mjs/util/waitForTimeout.mjs +7 -0
  453. package/dist-test/test_imports/package-lock.json +13 -0
  454. package/dist-test/test_imports/package.json +12 -0
  455. package/dist-test/test_imports/test-imports.js +17 -0
  456. package/dist-test/test_imports/test-require.cjs +19 -0
  457. package/package.json +98 -124
  458. package/src/Color4.test.ts +47 -0
  459. package/src/Color4.ts +304 -0
  460. package/src/Editor.loadFrom.test.ts +24 -0
  461. package/src/Editor.toSVG.test.ts +111 -0
  462. package/src/Editor.ts +1171 -0
  463. package/src/EditorImage.test.ts +120 -0
  464. package/src/EditorImage.ts +603 -0
  465. package/src/EventDispatcher.test.ts +123 -0
  466. package/src/EventDispatcher.ts +72 -0
  467. package/src/Pointer.ts +167 -0
  468. package/src/SVGLoader.test.ts +114 -0
  469. package/src/SVGLoader.ts +610 -0
  470. package/src/UndoRedoHistory.test.ts +33 -0
  471. package/src/UndoRedoHistory.ts +102 -0
  472. package/src/Viewport.ts +325 -0
  473. package/src/bundle/bundled.ts +7 -0
  474. package/src/commands/Command.ts +45 -0
  475. package/src/commands/Duplicate.ts +75 -0
  476. package/src/commands/Erase.ts +94 -0
  477. package/src/commands/SerializableCommand.ts +49 -0
  478. package/src/commands/UnresolvedCommand.ts +37 -0
  479. package/src/commands/invertCommand.ts +58 -0
  480. package/src/commands/lib.ts +16 -0
  481. package/src/commands/localization.ts +47 -0
  482. package/src/commands/uniteCommands.test.ts +23 -0
  483. package/src/commands/uniteCommands.ts +140 -0
  484. package/src/components/AbstractComponent.transformBy.test.ts +22 -0
  485. package/src/components/AbstractComponent.ts +374 -0
  486. package/src/components/BackgroundComponent.test.ts +45 -0
  487. package/src/components/BackgroundComponent.ts +353 -0
  488. package/src/components/ImageComponent.ts +178 -0
  489. package/src/components/RestylableComponent.ts +161 -0
  490. package/src/components/SVGGlobalAttributesObject.ts +81 -0
  491. package/src/components/Stroke.test.ts +139 -0
  492. package/src/components/Stroke.ts +296 -0
  493. package/src/components/TextComponent.test.ts +204 -0
  494. package/src/components/TextComponent.ts +432 -0
  495. package/src/components/UnknownSVGObject.test.ts +10 -0
  496. package/src/components/UnknownSVGObject.ts +60 -0
  497. package/src/components/builders/ArrowBuilder.ts +107 -0
  498. package/src/components/builders/CircleBuilder.ts +102 -0
  499. package/src/components/builders/FreehandLineBuilder.test.ts +25 -0
  500. package/src/components/builders/FreehandLineBuilder.ts +212 -0
  501. package/src/components/builders/LineBuilder.ts +77 -0
  502. package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +454 -0
  503. package/src/components/builders/RectangleBuilder.ts +74 -0
  504. package/src/components/builders/types.ts +15 -0
  505. package/src/components/lib.ts +31 -0
  506. package/src/components/localization.ts +24 -0
  507. package/src/components/util/StrokeSmoother.ts +302 -0
  508. package/src/components/util/describeComponentList.ts +18 -0
  509. package/src/lib.ts +69 -0
  510. package/src/localization.ts +34 -0
  511. package/src/localizations/de.ts +146 -0
  512. package/src/localizations/en.ts +8 -0
  513. package/src/localizations/es.ts +74 -0
  514. package/src/localizations/getLocalizationTable.test.ts +27 -0
  515. package/src/localizations/getLocalizationTable.ts +74 -0
  516. package/src/math/Mat33.test.ts +244 -0
  517. package/src/math/Mat33.ts +442 -0
  518. package/src/math/Vec2.test.ts +30 -0
  519. package/src/math/Vec2.ts +40 -0
  520. package/src/math/Vec3.test.ts +44 -0
  521. package/src/math/Vec3.ts +218 -0
  522. package/src/math/lib.ts +15 -0
  523. package/src/math/polynomial/solveQuadratic.test.ts +39 -0
  524. package/src/math/polynomial/solveQuadratic.ts +43 -0
  525. package/src/math/rounding.test.ts +65 -0
  526. package/src/math/rounding.ts +156 -0
  527. package/src/math/shapes/Abstract2DShape.ts +63 -0
  528. package/src/math/shapes/BezierJSWrapper.ts +93 -0
  529. package/src/math/shapes/CubicBezier.ts +35 -0
  530. package/src/math/shapes/LineSegment2.test.ts +99 -0
  531. package/src/math/shapes/LineSegment2.ts +231 -0
  532. package/src/math/shapes/Path.fromString.test.ts +223 -0
  533. package/src/math/shapes/Path.test.ts +309 -0
  534. package/src/math/shapes/Path.toString.test.ts +77 -0
  535. package/src/math/shapes/Path.ts +1027 -0
  536. package/src/math/shapes/PointShape2D.ts +33 -0
  537. package/src/math/shapes/QuadraticBezier.test.ts +31 -0
  538. package/src/math/shapes/QuadraticBezier.ts +141 -0
  539. package/src/math/shapes/Rect2.test.ts +209 -0
  540. package/src/math/shapes/Rect2.ts +344 -0
  541. package/src/math/shapes/Triangle.test.ts +61 -0
  542. package/src/math/shapes/Triangle.ts +139 -0
  543. package/src/rendering/Display.ts +248 -0
  544. package/src/rendering/RenderingStyle.test.ts +68 -0
  545. package/src/rendering/RenderingStyle.ts +55 -0
  546. package/src/rendering/TextRenderingStyle.ts +55 -0
  547. package/src/rendering/caching/CacheRecord.test.ts +49 -0
  548. package/src/rendering/caching/CacheRecord.ts +77 -0
  549. package/src/rendering/caching/CacheRecordManager.ts +71 -0
  550. package/src/rendering/caching/RenderingCache.test.ts +44 -0
  551. package/src/rendering/caching/RenderingCache.ts +66 -0
  552. package/src/rendering/caching/RenderingCacheNode.ts +405 -0
  553. package/src/rendering/caching/testUtils.ts +35 -0
  554. package/src/rendering/caching/types.ts +34 -0
  555. package/src/rendering/lib.ts +8 -0
  556. package/src/rendering/localization.ts +20 -0
  557. package/src/rendering/renderers/AbstractRenderer.ts +242 -0
  558. package/src/rendering/renderers/CanvasRenderer.ts +305 -0
  559. package/src/rendering/renderers/DummyRenderer.test.ts +42 -0
  560. package/src/rendering/renderers/DummyRenderer.ts +145 -0
  561. package/src/rendering/renderers/SVGRenderer.ts +374 -0
  562. package/src/rendering/renderers/TextOnlyRenderer.test.ts +34 -0
  563. package/src/rendering/renderers/TextOnlyRenderer.ts +71 -0
  564. package/src/shortcuts/KeyBinding.test.ts +51 -0
  565. package/src/shortcuts/KeyBinding.ts +218 -0
  566. package/src/shortcuts/KeyboardShortcutManager.test.ts +95 -0
  567. package/src/shortcuts/KeyboardShortcutManager.ts +163 -0
  568. package/src/shortcuts/lib.ts +3 -0
  569. package/src/testing/createEditor.ts +11 -0
  570. package/src/testing/lib.ts +3 -0
  571. package/src/testing/sendPenEvent.ts +31 -0
  572. package/src/testing/sendTouchEvent.ts +78 -0
  573. package/src/toolbar/HTMLToolbar.ts +567 -0
  574. package/src/toolbar/IconProvider.ts +736 -0
  575. package/src/toolbar/lib.ts +4 -0
  576. package/src/toolbar/localization.ts +114 -0
  577. package/src/toolbar/makeColorInput.ts +159 -0
  578. package/src/toolbar/toolbar.css +22 -0
  579. package/src/toolbar/types.ts +5 -0
  580. package/src/toolbar/widgets/ActionButtonWidget.ts +39 -0
  581. package/src/toolbar/widgets/BaseToolWidget.ts +56 -0
  582. package/src/toolbar/widgets/BaseWidget.ts +428 -0
  583. package/src/toolbar/widgets/DocumentPropertiesWidget.ts +234 -0
  584. package/src/toolbar/widgets/EraserToolWidget.ts +85 -0
  585. package/src/toolbar/widgets/HandToolWidget.ts +250 -0
  586. package/src/toolbar/widgets/InsertImageWidget.ts +223 -0
  587. package/src/toolbar/widgets/OverflowWidget.css +7 -2
  588. package/src/toolbar/widgets/OverflowWidget.ts +92 -0
  589. package/src/toolbar/widgets/PenToolWidget.ts +297 -0
  590. package/src/toolbar/widgets/SelectionToolWidget.ts +193 -0
  591. package/src/toolbar/widgets/TextToolWidget.ts +145 -0
  592. package/src/toolbar/widgets/keybindings.ts +21 -0
  593. package/src/toolbar/widgets/lib.ts +13 -0
  594. package/src/tools/BaseTool.ts +76 -0
  595. package/src/tools/Eraser.test.ts +103 -0
  596. package/src/tools/Eraser.ts +160 -0
  597. package/src/tools/FindTool.ts +153 -0
  598. package/src/tools/PanZoom.test.ts +310 -0
  599. package/src/tools/PanZoom.ts +502 -0
  600. package/src/tools/PasteHandler.ts +95 -0
  601. package/src/tools/Pen.test.ts +194 -0
  602. package/src/tools/Pen.ts +262 -0
  603. package/src/tools/PipetteTool.ts +55 -0
  604. package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +29 -0
  605. package/src/tools/SelectionTool/Selection.ts +611 -0
  606. package/src/tools/SelectionTool/SelectionHandle.ts +108 -0
  607. package/src/tools/SelectionTool/SelectionTool.test.ts +261 -0
  608. package/src/tools/SelectionTool/SelectionTool.ts +496 -0
  609. package/src/tools/SelectionTool/TransformMode.ts +114 -0
  610. package/src/tools/SelectionTool/types.ts +11 -0
  611. package/src/tools/SoundUITool.ts +212 -0
  612. package/src/tools/TextTool.ts +340 -0
  613. package/src/tools/ToolController.ts +185 -0
  614. package/src/tools/ToolEnabledGroup.ts +14 -0
  615. package/src/tools/ToolSwitcherShortcut.ts +39 -0
  616. package/src/tools/ToolbarShortcutHandler.ts +39 -0
  617. package/src/tools/UndoRedoShortcut.test.ts +56 -0
  618. package/src/tools/UndoRedoShortcut.ts +24 -0
  619. package/src/tools/keybindings.ts +85 -0
  620. package/src/tools/lib.ts +22 -0
  621. package/src/tools/localization.ts +74 -0
  622. package/src/types.ts +239 -0
  623. package/src/util/assertions.ts +55 -0
  624. package/src/util/fileToBase64.ts +18 -0
  625. package/src/util/untilNextAnimationFrame.ts +9 -0
  626. package/src/util/waitForAll.ts +18 -0
  627. package/src/util/waitForTimeout.ts +9 -0
  628. package/tools/allLocales.js +4 -0
  629. package/tsconfig.json +2 -32
  630. package/.eslintrc.js +0 -60
  631. package/.firebaserc +0 -5
  632. package/CHANGELOG.md +0 -384
  633. package/CONTRIBUTING.md +0 -75
  634. package/LICENSE +0 -21
  635. package/README.md +0 -217
  636. package/__mocks__/coloris.ts +0 -8
  637. package/__mocks__/styleMock.js +0 -1
  638. package/dist/cjs/src/Color4.js +0 -264
  639. package/dist/cjs/src/Editor.d.ts +0 -309
  640. package/dist/cjs/src/Editor.js +0 -922
  641. package/dist/cjs/src/EditorImage.d.ts +0 -97
  642. package/dist/cjs/src/EditorImage.js +0 -492
  643. package/dist/cjs/src/EventDispatcher.d.ts +0 -30
  644. package/dist/cjs/src/EventDispatcher.js +0 -57
  645. package/dist/cjs/src/Pointer.d.ts +0 -26
  646. package/dist/cjs/src/Pointer.js +0 -109
  647. package/dist/cjs/src/SVGLoader.d.ts +0 -48
  648. package/dist/cjs/src/SVGLoader.js +0 -537
  649. package/dist/cjs/src/UndoRedoHistory.js +0 -93
  650. package/dist/cjs/src/Viewport.d.ts +0 -73
  651. package/dist/cjs/src/Viewport.js +0 -268
  652. package/dist/cjs/src/bundle/bundled.js +0 -24
  653. package/dist/cjs/src/commands/Command.js +0 -34
  654. package/dist/cjs/src/commands/Duplicate.js +0 -65
  655. package/dist/cjs/src/commands/Erase.js +0 -83
  656. package/dist/cjs/src/commands/SerializableCommand.js +0 -42
  657. package/dist/cjs/src/commands/UnresolvedCommand.js +0 -28
  658. package/dist/cjs/src/commands/invertCommand.js +0 -55
  659. package/dist/cjs/src/commands/lib.js +0 -18
  660. package/dist/cjs/src/commands/localization.d.ts +0 -23
  661. package/dist/cjs/src/commands/localization.js +0 -24
  662. package/dist/cjs/src/commands/uniteCommands.js +0 -122
  663. package/dist/cjs/src/components/AbstractComponent.d.ts +0 -85
  664. package/dist/cjs/src/components/AbstractComponent.js +0 -273
  665. package/dist/cjs/src/components/BackgroundComponent.d.ts +0 -62
  666. package/dist/cjs/src/components/BackgroundComponent.js +0 -316
  667. package/dist/cjs/src/components/ImageComponent.d.ts +0 -31
  668. package/dist/cjs/src/components/ImageComponent.js +0 -157
  669. package/dist/cjs/src/components/RestylableComponent.js +0 -88
  670. package/dist/cjs/src/components/SVGGlobalAttributesObject.d.ts +0 -21
  671. package/dist/cjs/src/components/SVGGlobalAttributesObject.js +0 -65
  672. package/dist/cjs/src/components/Stroke.d.ts +0 -76
  673. package/dist/cjs/src/components/Stroke.js +0 -238
  674. package/dist/cjs/src/components/TextComponent.d.ts +0 -63
  675. package/dist/cjs/src/components/TextComponent.js +0 -280
  676. package/dist/cjs/src/components/UnknownSVGObject.d.ts +0 -18
  677. package/dist/cjs/src/components/UnknownSVGObject.js +0 -50
  678. package/dist/cjs/src/components/builders/ArrowBuilder.d.ts +0 -19
  679. package/dist/cjs/src/components/builders/ArrowBuilder.js +0 -117
  680. package/dist/cjs/src/components/builders/FreehandLineBuilder.d.ts +0 -33
  681. package/dist/cjs/src/components/builders/FreehandLineBuilder.js +0 -173
  682. package/dist/cjs/src/components/builders/LineBuilder.d.ts +0 -18
  683. package/dist/cjs/src/components/builders/LineBuilder.js +0 -89
  684. package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +0 -36
  685. package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.js +0 -347
  686. package/dist/cjs/src/components/builders/RectangleBuilder.d.ts +0 -20
  687. package/dist/cjs/src/components/builders/RectangleBuilder.js +0 -59
  688. package/dist/cjs/src/components/builders/types.d.ts +0 -12
  689. package/dist/cjs/src/components/lib.d.ts +0 -13
  690. package/dist/cjs/src/components/lib.js +0 -43
  691. package/dist/cjs/src/components/localization.js +0 -14
  692. package/dist/cjs/src/components/util/StrokeSmoother.d.ts +0 -35
  693. package/dist/cjs/src/components/util/StrokeSmoother.js +0 -225
  694. package/dist/cjs/src/components/util/describeComponentList.d.ts +0 -4
  695. package/dist/cjs/src/components/util/describeComponentList.js +0 -16
  696. package/dist/cjs/src/lib.d.ts +0 -64
  697. package/dist/cjs/src/lib.js +0 -93
  698. package/dist/cjs/src/localization.js +0 -13
  699. package/dist/cjs/src/localizations/de.js +0 -6
  700. package/dist/cjs/src/localizations/en.js +0 -6
  701. package/dist/cjs/src/localizations/es.js +0 -20
  702. package/dist/cjs/src/localizations/getLocalizationTable.d.ts +0 -3
  703. package/dist/cjs/src/localizations/getLocalizationTable.js +0 -50
  704. package/dist/cjs/src/math/LineSegment2.d.ts +0 -26
  705. package/dist/cjs/src/math/LineSegment2.js +0 -135
  706. package/dist/cjs/src/math/Mat33.d.ts +0 -118
  707. package/dist/cjs/src/math/Mat33.js +0 -332
  708. package/dist/cjs/src/math/Path.d.ts +0 -92
  709. package/dist/cjs/src/math/Path.js +0 -876
  710. package/dist/cjs/src/math/Rect2.d.ts +0 -52
  711. package/dist/cjs/src/math/Rect2.js +0 -235
  712. package/dist/cjs/src/math/Triangle.d.ts +0 -11
  713. package/dist/cjs/src/math/Triangle.js +0 -22
  714. package/dist/cjs/src/math/Vec2.js +0 -39
  715. package/dist/cjs/src/math/Vec3.js +0 -177
  716. package/dist/cjs/src/math/lib.d.ts +0 -7
  717. package/dist/cjs/src/math/lib.js +0 -18
  718. package/dist/cjs/src/math/polynomial/QuadraticBezier.d.ts +0 -28
  719. package/dist/cjs/src/math/polynomial/QuadraticBezier.js +0 -114
  720. package/dist/cjs/src/math/polynomial/solveQuadratic.d.ts +0 -6
  721. package/dist/cjs/src/math/polynomial/solveQuadratic.js +0 -36
  722. package/dist/cjs/src/math/rounding.js +0 -135
  723. package/dist/cjs/src/rendering/Display.js +0 -213
  724. package/dist/cjs/src/rendering/RenderingStyle.d.ts +0 -31
  725. package/dist/cjs/src/rendering/RenderingStyle.js +0 -48
  726. package/dist/cjs/src/rendering/TextRenderingStyle.d.ts +0 -36
  727. package/dist/cjs/src/rendering/TextRenderingStyle.js +0 -29
  728. package/dist/cjs/src/rendering/caching/CacheRecord.d.ts +0 -20
  729. package/dist/cjs/src/rendering/caching/CacheRecord.js +0 -61
  730. package/dist/cjs/src/rendering/caching/CacheRecordManager.d.ts +0 -12
  731. package/dist/cjs/src/rendering/caching/CacheRecordManager.js +0 -50
  732. package/dist/cjs/src/rendering/caching/RenderingCache.js +0 -51
  733. package/dist/cjs/src/rendering/caching/RenderingCacheNode.d.ts +0 -29
  734. package/dist/cjs/src/rendering/caching/RenderingCacheNode.js +0 -326
  735. package/dist/cjs/src/rendering/caching/testUtils.js +0 -27
  736. package/dist/cjs/src/rendering/lib.js +0 -17
  737. package/dist/cjs/src/rendering/localization.js +0 -12
  738. package/dist/cjs/src/rendering/renderers/AbstractRenderer.d.ts +0 -85
  739. package/dist/cjs/src/rendering/renderers/AbstractRenderer.js +0 -188
  740. package/dist/cjs/src/rendering/renderers/CanvasRenderer.d.ts +0 -63
  741. package/dist/cjs/src/rendering/renderers/CanvasRenderer.js +0 -243
  742. package/dist/cjs/src/rendering/renderers/DummyRenderer.d.ts +0 -35
  743. package/dist/cjs/src/rendering/renderers/DummyRenderer.js +0 -112
  744. package/dist/cjs/src/rendering/renderers/SVGRenderer.d.ts +0 -57
  745. package/dist/cjs/src/rendering/renderers/SVGRenderer.js +0 -320
  746. package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.d.ts +0 -29
  747. package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.js +0 -63
  748. package/dist/cjs/src/testing/beforeEachFile.js +0 -12
  749. package/dist/cjs/src/testing/createEditor.js +0 -14
  750. package/dist/cjs/src/testing/lib.js +0 -10
  751. package/dist/cjs/src/testing/loadExpectExtensions.d.ts +0 -2
  752. package/dist/cjs/src/testing/loadExpectExtensions.js +0 -28
  753. package/dist/cjs/src/testing/sendPenEvent.js +0 -24
  754. package/dist/cjs/src/testing/sendTouchEvent.js +0 -87
  755. package/dist/cjs/src/toolbar/HTMLToolbar.js +0 -449
  756. package/dist/cjs/src/toolbar/IconProvider.js +0 -660
  757. package/dist/cjs/src/toolbar/lib.js +0 -24
  758. package/dist/cjs/src/toolbar/localization.d.ts +0 -51
  759. package/dist/cjs/src/toolbar/localization.js +0 -53
  760. package/dist/cjs/src/toolbar/makeColorInput.js +0 -128
  761. package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.js +0 -31
  762. package/dist/cjs/src/toolbar/widgets/BaseToolWidget.js +0 -49
  763. package/dist/cjs/src/toolbar/widgets/BaseWidget.d.ts +0 -78
  764. package/dist/cjs/src/toolbar/widgets/BaseWidget.js +0 -348
  765. package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.js +0 -201
  766. package/dist/cjs/src/toolbar/widgets/EraserToolWidget.js +0 -63
  767. package/dist/cjs/src/toolbar/widgets/HandToolWidget.js +0 -201
  768. package/dist/cjs/src/toolbar/widgets/InsertImageWidget.js +0 -176
  769. package/dist/cjs/src/toolbar/widgets/OverflowWidget.js +0 -77
  770. package/dist/cjs/src/toolbar/widgets/PenToolWidget.js +0 -226
  771. package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.js +0 -153
  772. package/dist/cjs/src/toolbar/widgets/TextToolWidget.js +0 -115
  773. package/dist/cjs/src/toolbar/widgets/lib.js +0 -26
  774. package/dist/cjs/src/tools/BaseTool.js +0 -66
  775. package/dist/cjs/src/tools/Eraser.d.ts +0 -23
  776. package/dist/cjs/src/tools/Eraser.js +0 -112
  777. package/dist/cjs/src/tools/FindTool.d.ts +0 -21
  778. package/dist/cjs/src/tools/FindTool.js +0 -121
  779. package/dist/cjs/src/tools/PanZoom.d.ts +0 -52
  780. package/dist/cjs/src/tools/PanZoom.js +0 -421
  781. package/dist/cjs/src/tools/PasteHandler.js +0 -99
  782. package/dist/cjs/src/tools/Pen.d.ts +0 -43
  783. package/dist/cjs/src/tools/Pen.js +0 -202
  784. package/dist/cjs/src/tools/PipetteTool.js +0 -45
  785. package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +0 -8
  786. package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.js +0 -28
  787. package/dist/cjs/src/tools/SelectionTool/Selection.d.ts +0 -64
  788. package/dist/cjs/src/tools/SelectionTool/Selection.js +0 -491
  789. package/dist/cjs/src/tools/SelectionTool/SelectionHandle.js +0 -85
  790. package/dist/cjs/src/tools/SelectionTool/SelectionTool.d.ts +0 -37
  791. package/dist/cjs/src/tools/SelectionTool/SelectionTool.js +0 -413
  792. package/dist/cjs/src/tools/SelectionTool/TransformMode.js +0 -107
  793. package/dist/cjs/src/tools/SelectionTool/types.js +0 -14
  794. package/dist/cjs/src/tools/SoundUITool.js +0 -164
  795. package/dist/cjs/src/tools/TextTool.d.ts +0 -33
  796. package/dist/cjs/src/tools/TextTool.js +0 -262
  797. package/dist/cjs/src/tools/ToolController.js +0 -192
  798. package/dist/cjs/src/tools/ToolEnabledGroup.js +0 -14
  799. package/dist/cjs/src/tools/ToolSwitcherShortcut.js +0 -38
  800. package/dist/cjs/src/tools/ToolbarShortcutHandler.js +0 -29
  801. package/dist/cjs/src/tools/UndoRedoShortcut.d.ts +0 -8
  802. package/dist/cjs/src/tools/UndoRedoShortcut.js +0 -28
  803. package/dist/cjs/src/tools/lib.js +0 -38
  804. package/dist/cjs/src/tools/localization.js +0 -33
  805. package/dist/cjs/src/types.d.ts +0 -153
  806. package/dist/cjs/src/types.js +0 -38
  807. package/dist/cjs/src/util/assertions.js +0 -51
  808. package/dist/cjs/src/util/fileToBase64.js +0 -15
  809. package/dist/cjs/src/util/untilNextAnimationFrame.js +0 -9
  810. package/dist/cjs/src/util/waitForAll.js +0 -17
  811. package/dist/cjs/src/util/waitForTimeout.js +0 -9
  812. package/dist/mjs/src/Color4.mjs +0 -258
  813. package/dist/mjs/src/Editor.d.ts +0 -309
  814. package/dist/mjs/src/Editor.mjs +0 -892
  815. package/dist/mjs/src/EditorImage.d.ts +0 -97
  816. package/dist/mjs/src/EditorImage.mjs +0 -485
  817. package/dist/mjs/src/EventDispatcher.d.ts +0 -30
  818. package/dist/mjs/src/EventDispatcher.mjs +0 -54
  819. package/dist/mjs/src/Pointer.d.ts +0 -26
  820. package/dist/mjs/src/Pointer.mjs +0 -105
  821. package/dist/mjs/src/SVGLoader.d.ts +0 -48
  822. package/dist/mjs/src/SVGLoader.mjs +0 -507
  823. package/dist/mjs/src/UndoRedoHistory.mjs +0 -91
  824. package/dist/mjs/src/Viewport.d.ts +0 -73
  825. package/dist/mjs/src/Viewport.mjs +0 -261
  826. package/dist/mjs/src/commands/Command.mjs +0 -31
  827. package/dist/mjs/src/commands/Duplicate.mjs +0 -59
  828. package/dist/mjs/src/commands/Erase.mjs +0 -77
  829. package/dist/mjs/src/commands/SerializableCommand.mjs +0 -37
  830. package/dist/mjs/src/commands/UnresolvedCommand.mjs +0 -22
  831. package/dist/mjs/src/commands/invertCommand.mjs +0 -50
  832. package/dist/mjs/src/commands/localization.d.ts +0 -23
  833. package/dist/mjs/src/commands/localization.mjs +0 -21
  834. package/dist/mjs/src/commands/uniteCommands.mjs +0 -117
  835. package/dist/mjs/src/components/AbstractComponent.d.ts +0 -85
  836. package/dist/mjs/src/components/AbstractComponent.mjs +0 -268
  837. package/dist/mjs/src/components/BackgroundComponent.d.ts +0 -62
  838. package/dist/mjs/src/components/BackgroundComponent.mjs +0 -286
  839. package/dist/mjs/src/components/ImageComponent.d.ts +0 -31
  840. package/dist/mjs/src/components/ImageComponent.mjs +0 -151
  841. package/dist/mjs/src/components/RestylableComponent.mjs +0 -80
  842. package/dist/mjs/src/components/SVGGlobalAttributesObject.d.ts +0 -21
  843. package/dist/mjs/src/components/SVGGlobalAttributesObject.mjs +0 -59
  844. package/dist/mjs/src/components/Stroke.d.ts +0 -76
  845. package/dist/mjs/src/components/Stroke.mjs +0 -232
  846. package/dist/mjs/src/components/TextComponent.d.ts +0 -63
  847. package/dist/mjs/src/components/TextComponent.mjs +0 -275
  848. package/dist/mjs/src/components/UnknownSVGObject.d.ts +0 -18
  849. package/dist/mjs/src/components/UnknownSVGObject.mjs +0 -44
  850. package/dist/mjs/src/components/builders/ArrowBuilder.d.ts +0 -19
  851. package/dist/mjs/src/components/builders/ArrowBuilder.mjs +0 -86
  852. package/dist/mjs/src/components/builders/FreehandLineBuilder.d.ts +0 -33
  853. package/dist/mjs/src/components/builders/FreehandLineBuilder.mjs +0 -165
  854. package/dist/mjs/src/components/builders/LineBuilder.d.ts +0 -18
  855. package/dist/mjs/src/components/builders/LineBuilder.mjs +0 -58
  856. package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +0 -36
  857. package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.mjs +0 -339
  858. package/dist/mjs/src/components/builders/RectangleBuilder.d.ts +0 -20
  859. package/dist/mjs/src/components/builders/RectangleBuilder.mjs +0 -50
  860. package/dist/mjs/src/components/builders/types.d.ts +0 -12
  861. package/dist/mjs/src/components/lib.d.ts +0 -13
  862. package/dist/mjs/src/components/lib.mjs +0 -14
  863. package/dist/mjs/src/components/localization.mjs +0 -11
  864. package/dist/mjs/src/components/util/StrokeSmoother.d.ts +0 -35
  865. package/dist/mjs/src/components/util/StrokeSmoother.mjs +0 -218
  866. package/dist/mjs/src/components/util/describeComponentList.d.ts +0 -4
  867. package/dist/mjs/src/components/util/describeComponentList.mjs +0 -14
  868. package/dist/mjs/src/lib.d.ts +0 -64
  869. package/dist/mjs/src/lib.mjs +0 -64
  870. package/dist/mjs/src/localization.mjs +0 -10
  871. package/dist/mjs/src/localizations/de.mjs +0 -4
  872. package/dist/mjs/src/localizations/en.mjs +0 -4
  873. package/dist/mjs/src/localizations/es.mjs +0 -18
  874. package/dist/mjs/src/localizations/getLocalizationTable.d.ts +0 -3
  875. package/dist/mjs/src/localizations/getLocalizationTable.mjs +0 -45
  876. package/dist/mjs/src/math/LineSegment2.d.ts +0 -26
  877. package/dist/mjs/src/math/LineSegment2.mjs +0 -129
  878. package/dist/mjs/src/math/Mat33.d.ts +0 -118
  879. package/dist/mjs/src/math/Mat33.mjs +0 -327
  880. package/dist/mjs/src/math/Path.d.ts +0 -92
  881. package/dist/mjs/src/math/Path.mjs +0 -870
  882. package/dist/mjs/src/math/Rect2.d.ts +0 -52
  883. package/dist/mjs/src/math/Rect2.mjs +0 -230
  884. package/dist/mjs/src/math/Triangle.d.ts +0 -11
  885. package/dist/mjs/src/math/Triangle.mjs +0 -19
  886. package/dist/mjs/src/math/Vec2.mjs +0 -33
  887. package/dist/mjs/src/math/Vec3.mjs +0 -175
  888. package/dist/mjs/src/math/lib.d.ts +0 -7
  889. package/dist/mjs/src/math/lib.mjs +0 -7
  890. package/dist/mjs/src/math/polynomial/QuadraticBezier.d.ts +0 -28
  891. package/dist/mjs/src/math/polynomial/QuadraticBezier.mjs +0 -108
  892. package/dist/mjs/src/math/polynomial/solveQuadratic.d.ts +0 -6
  893. package/dist/mjs/src/math/polynomial/solveQuadratic.mjs +0 -34
  894. package/dist/mjs/src/math/rounding.mjs +0 -128
  895. package/dist/mjs/src/rendering/Display.mjs +0 -206
  896. package/dist/mjs/src/rendering/RenderingStyle.d.ts +0 -31
  897. package/dist/mjs/src/rendering/RenderingStyle.mjs +0 -38
  898. package/dist/mjs/src/rendering/TextRenderingStyle.d.ts +0 -36
  899. package/dist/mjs/src/rendering/TextRenderingStyle.mjs +0 -23
  900. package/dist/mjs/src/rendering/caching/CacheRecord.d.ts +0 -20
  901. package/dist/mjs/src/rendering/caching/CacheRecord.mjs +0 -55
  902. package/dist/mjs/src/rendering/caching/CacheRecordManager.d.ts +0 -12
  903. package/dist/mjs/src/rendering/caching/CacheRecordManager.mjs +0 -43
  904. package/dist/mjs/src/rendering/caching/RenderingCache.mjs +0 -45
  905. package/dist/mjs/src/rendering/caching/RenderingCacheNode.d.ts +0 -29
  906. package/dist/mjs/src/rendering/caching/RenderingCacheNode.mjs +0 -320
  907. package/dist/mjs/src/rendering/caching/testUtils.mjs +0 -20
  908. package/dist/mjs/src/rendering/localization.mjs +0 -9
  909. package/dist/mjs/src/rendering/renderers/AbstractRenderer.d.ts +0 -85
  910. package/dist/mjs/src/rendering/renderers/AbstractRenderer.mjs +0 -162
  911. package/dist/mjs/src/rendering/renderers/CanvasRenderer.d.ts +0 -63
  912. package/dist/mjs/src/rendering/renderers/CanvasRenderer.mjs +0 -237
  913. package/dist/mjs/src/rendering/renderers/DummyRenderer.d.ts +0 -35
  914. package/dist/mjs/src/rendering/renderers/DummyRenderer.mjs +0 -106
  915. package/dist/mjs/src/rendering/renderers/SVGRenderer.d.ts +0 -57
  916. package/dist/mjs/src/rendering/renderers/SVGRenderer.mjs +0 -313
  917. package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.d.ts +0 -29
  918. package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.mjs +0 -57
  919. package/dist/mjs/src/testing/beforeEachFile.mjs +0 -7
  920. package/dist/mjs/src/testing/createEditor.mjs +0 -9
  921. package/dist/mjs/src/testing/loadExpectExtensions.d.ts +0 -2
  922. package/dist/mjs/src/testing/loadExpectExtensions.mjs +0 -24
  923. package/dist/mjs/src/testing/sendPenEvent.mjs +0 -19
  924. package/dist/mjs/src/testing/sendTouchEvent.mjs +0 -62
  925. package/dist/mjs/src/toolbar/HTMLToolbar.mjs +0 -443
  926. package/dist/mjs/src/toolbar/IconProvider.mjs +0 -654
  927. package/dist/mjs/src/toolbar/localization.d.ts +0 -51
  928. package/dist/mjs/src/toolbar/localization.mjs +0 -50
  929. package/dist/mjs/src/toolbar/makeColorInput.mjs +0 -121
  930. package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.mjs +0 -25
  931. package/dist/mjs/src/toolbar/widgets/BaseToolWidget.mjs +0 -43
  932. package/dist/mjs/src/toolbar/widgets/BaseWidget.d.ts +0 -78
  933. package/dist/mjs/src/toolbar/widgets/BaseWidget.mjs +0 -342
  934. package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.mjs +0 -173
  935. package/dist/mjs/src/toolbar/widgets/EraserToolWidget.mjs +0 -58
  936. package/dist/mjs/src/toolbar/widgets/HandToolWidget.mjs +0 -172
  937. package/dist/mjs/src/toolbar/widgets/InsertImageWidget.mjs +0 -171
  938. package/dist/mjs/src/toolbar/widgets/OverflowWidget.mjs +0 -71
  939. package/dist/mjs/src/toolbar/widgets/PenToolWidget.mjs +0 -221
  940. package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.mjs +0 -147
  941. package/dist/mjs/src/toolbar/widgets/TextToolWidget.mjs +0 -110
  942. package/dist/mjs/src/tools/BaseTool.mjs +0 -63
  943. package/dist/mjs/src/tools/Eraser.d.ts +0 -23
  944. package/dist/mjs/src/tools/Eraser.mjs +0 -106
  945. package/dist/mjs/src/tools/FindTool.d.ts +0 -21
  946. package/dist/mjs/src/tools/FindTool.mjs +0 -114
  947. package/dist/mjs/src/tools/PanZoom.d.ts +0 -52
  948. package/dist/mjs/src/tools/PanZoom.mjs +0 -414
  949. package/dist/mjs/src/tools/PasteHandler.mjs +0 -93
  950. package/dist/mjs/src/tools/Pen.d.ts +0 -43
  951. package/dist/mjs/src/tools/Pen.mjs +0 -196
  952. package/dist/mjs/src/tools/PipetteTool.mjs +0 -39
  953. package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +0 -8
  954. package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.mjs +0 -22
  955. package/dist/mjs/src/tools/SelectionTool/Selection.d.ts +0 -64
  956. package/dist/mjs/src/tools/SelectionTool/Selection.mjs +0 -463
  957. package/dist/mjs/src/tools/SelectionTool/SelectionHandle.mjs +0 -81
  958. package/dist/mjs/src/tools/SelectionTool/SelectionTool.d.ts +0 -37
  959. package/dist/mjs/src/tools/SelectionTool/SelectionTool.mjs +0 -407
  960. package/dist/mjs/src/tools/SelectionTool/TransformMode.mjs +0 -98
  961. package/dist/mjs/src/tools/SoundUITool.mjs +0 -158
  962. package/dist/mjs/src/tools/TextTool.d.ts +0 -33
  963. package/dist/mjs/src/tools/TextTool.mjs +0 -256
  964. package/dist/mjs/src/tools/ToolController.mjs +0 -163
  965. package/dist/mjs/src/tools/ToolEnabledGroup.mjs +0 -11
  966. package/dist/mjs/src/tools/ToolSwitcherShortcut.mjs +0 -32
  967. package/dist/mjs/src/tools/ToolbarShortcutHandler.mjs +0 -23
  968. package/dist/mjs/src/tools/UndoRedoShortcut.d.ts +0 -8
  969. package/dist/mjs/src/tools/UndoRedoShortcut.mjs +0 -22
  970. package/dist/mjs/src/tools/localization.mjs +0 -30
  971. package/dist/mjs/src/types.d.ts +0 -153
  972. package/dist/mjs/src/util/assertions.mjs +0 -45
  973. package/dist/mjs/src/util/fileToBase64.mjs +0 -13
  974. package/dist/mjs/src/util/untilNextAnimationFrame.mjs +0 -7
  975. package/dist/mjs/src/util/waitForAll.mjs +0 -15
  976. package/dist/mjs/src/util/waitForTimeout.mjs +0 -7
  977. package/firebase.json +0 -16
  978. package/jest.config.js +0 -29
  979. package/lint-staged.config.js +0 -6
  980. package/tsconfig-typedoc.json +0 -7
  981. package/tsconfig.mjs.json +0 -9
  982. package/typedoc.json +0 -25
  983. /package/dist/cjs/{src/Color4.d.ts → Color4.d.ts} +0 -0
  984. /package/dist/cjs/{src/testing/beforeEachFile.d.ts → Color4.test.d.ts} +0 -0
  985. /package/dist/{mjs/src/components/builders/types.mjs → cjs/Editor.loadFrom.test.d.ts} +0 -0
  986. /package/dist/{mjs/src/rendering/caching/types.mjs → cjs/Editor.toSVG.test.d.ts} +0 -0
  987. /package/dist/{mjs/src/testing/beforeEachFile.d.ts → cjs/EditorImage.test.d.ts} +0 -0
  988. /package/dist/{mjs/src/toolbar/types.mjs → cjs/EventDispatcher.test.d.ts} +0 -0
  989. /package/dist/cjs/{src/UndoRedoHistory.d.ts → UndoRedoHistory.d.ts} +0 -0
  990. /package/dist/cjs/{src/bundle → bundle}/bundled.d.ts +0 -0
  991. /package/dist/cjs/{src/commands → commands}/Command.d.ts +0 -0
  992. /package/dist/cjs/{src/commands → commands}/Duplicate.d.ts +0 -0
  993. /package/dist/cjs/{src/commands → commands}/Erase.d.ts +0 -0
  994. /package/dist/cjs/{src/commands → commands}/SerializableCommand.d.ts +0 -0
  995. /package/dist/cjs/{src/commands → commands}/UnresolvedCommand.d.ts +0 -0
  996. /package/dist/cjs/{src/commands → commands}/invertCommand.d.ts +0 -0
  997. /package/dist/cjs/{src/commands → commands}/lib.d.ts +0 -0
  998. /package/dist/cjs/{src/commands → commands}/uniteCommands.d.ts +0 -0
  999. /package/dist/cjs/{src/components → components}/RestylableComponent.d.ts +0 -0
  1000. /package/dist/cjs/{src/components → components}/builders/types.js +0 -0
  1001. /package/dist/cjs/{src/components → components}/localization.d.ts +0 -0
  1002. /package/dist/cjs/{src/localization.d.ts → localization.d.ts} +0 -0
  1003. /package/dist/cjs/{src/localizations → localizations}/de.d.ts +0 -0
  1004. /package/dist/cjs/{src/localizations → localizations}/en.d.ts +0 -0
  1005. /package/dist/cjs/{src/localizations → localizations}/es.d.ts +0 -0
  1006. /package/dist/cjs/{src/math → math}/Vec2.d.ts +0 -0
  1007. /package/dist/cjs/{src/math → math}/Vec3.d.ts +0 -0
  1008. /package/dist/cjs/{src/math → math}/rounding.d.ts +0 -0
  1009. /package/dist/cjs/{src/rendering → rendering}/Display.d.ts +0 -0
  1010. /package/dist/cjs/{src/rendering → rendering}/caching/RenderingCache.d.ts +0 -0
  1011. /package/dist/cjs/{src/rendering → rendering}/caching/testUtils.d.ts +0 -0
  1012. /package/dist/cjs/{src/rendering → rendering}/caching/types.d.ts +0 -0
  1013. /package/dist/cjs/{src/rendering → rendering}/caching/types.js +0 -0
  1014. /package/dist/cjs/{src/rendering → rendering}/lib.d.ts +0 -0
  1015. /package/dist/cjs/{src/rendering → rendering}/localization.d.ts +0 -0
  1016. /package/dist/cjs/{src/testing → testing}/createEditor.d.ts +0 -0
  1017. /package/dist/cjs/{src/testing → testing}/lib.d.ts +0 -0
  1018. /package/dist/cjs/{src/testing → testing}/sendPenEvent.d.ts +0 -0
  1019. /package/dist/cjs/{src/testing → testing}/sendTouchEvent.d.ts +0 -0
  1020. /package/dist/cjs/{src/toolbar → toolbar}/HTMLToolbar.d.ts +0 -0
  1021. /package/dist/cjs/{src/toolbar → toolbar}/IconProvider.d.ts +0 -0
  1022. /package/dist/cjs/{src/toolbar → toolbar}/lib.d.ts +0 -0
  1023. /package/dist/cjs/{src/toolbar → toolbar}/makeColorInput.d.ts +0 -0
  1024. /package/dist/cjs/{src/toolbar → toolbar}/types.d.ts +0 -0
  1025. /package/dist/cjs/{src/toolbar → toolbar}/types.js +0 -0
  1026. /package/dist/cjs/{src/toolbar → toolbar}/widgets/ActionButtonWidget.d.ts +0 -0
  1027. /package/dist/cjs/{src/toolbar → toolbar}/widgets/BaseToolWidget.d.ts +0 -0
  1028. /package/dist/cjs/{src/toolbar → toolbar}/widgets/DocumentPropertiesWidget.d.ts +0 -0
  1029. /package/dist/cjs/{src/toolbar → toolbar}/widgets/EraserToolWidget.d.ts +0 -0
  1030. /package/dist/cjs/{src/toolbar → toolbar}/widgets/HandToolWidget.d.ts +0 -0
  1031. /package/dist/cjs/{src/toolbar → toolbar}/widgets/InsertImageWidget.d.ts +0 -0
  1032. /package/dist/cjs/{src/toolbar → toolbar}/widgets/OverflowWidget.d.ts +0 -0
  1033. /package/dist/cjs/{src/toolbar → toolbar}/widgets/PenToolWidget.d.ts +0 -0
  1034. /package/dist/cjs/{src/toolbar → toolbar}/widgets/SelectionToolWidget.d.ts +0 -0
  1035. /package/dist/cjs/{src/toolbar → toolbar}/widgets/TextToolWidget.d.ts +0 -0
  1036. /package/dist/cjs/{src/toolbar → toolbar}/widgets/lib.d.ts +0 -0
  1037. /package/dist/cjs/{src/tools → tools}/BaseTool.d.ts +0 -0
  1038. /package/dist/cjs/{src/tools → tools}/PasteHandler.d.ts +0 -0
  1039. /package/dist/cjs/{src/tools → tools}/PipetteTool.d.ts +0 -0
  1040. /package/dist/cjs/{src/tools → tools}/SelectionTool/SelectionHandle.d.ts +0 -0
  1041. /package/dist/cjs/{src/tools → tools}/SelectionTool/TransformMode.d.ts +0 -0
  1042. /package/dist/cjs/{src/tools → tools}/SelectionTool/types.d.ts +0 -0
  1043. /package/dist/cjs/{src/tools → tools}/SoundUITool.d.ts +0 -0
  1044. /package/dist/cjs/{src/tools → tools}/ToolController.d.ts +0 -0
  1045. /package/dist/cjs/{src/tools → tools}/ToolEnabledGroup.d.ts +0 -0
  1046. /package/dist/cjs/{src/tools → tools}/ToolSwitcherShortcut.d.ts +0 -0
  1047. /package/dist/cjs/{src/tools → tools}/ToolbarShortcutHandler.d.ts +0 -0
  1048. /package/dist/cjs/{src/tools → tools}/lib.d.ts +0 -0
  1049. /package/dist/cjs/{src/tools → tools}/localization.d.ts +0 -0
  1050. /package/dist/cjs/{src/util → util}/assertions.d.ts +0 -0
  1051. /package/dist/cjs/{src/util → util}/fileToBase64.d.ts +0 -0
  1052. /package/dist/cjs/{src/util → util}/untilNextAnimationFrame.d.ts +0 -0
  1053. /package/dist/cjs/{src/util → util}/waitForAll.d.ts +0 -0
  1054. /package/dist/cjs/{src/util → util}/waitForTimeout.d.ts +0 -0
  1055. /package/dist/mjs/{src/Color4.d.ts → Color4.d.ts} +0 -0
  1056. /package/dist/mjs/{src/UndoRedoHistory.d.ts → UndoRedoHistory.d.ts} +0 -0
  1057. /package/dist/mjs/{src/bundle → bundle}/bundled.d.ts +0 -0
  1058. /package/dist/mjs/{src/bundle → bundle}/bundled.mjs +0 -0
  1059. /package/dist/mjs/{src/commands → commands}/Command.d.ts +0 -0
  1060. /package/dist/mjs/{src/commands → commands}/Duplicate.d.ts +0 -0
  1061. /package/dist/mjs/{src/commands → commands}/Erase.d.ts +0 -0
  1062. /package/dist/mjs/{src/commands → commands}/SerializableCommand.d.ts +0 -0
  1063. /package/dist/mjs/{src/commands → commands}/UnresolvedCommand.d.ts +0 -0
  1064. /package/dist/mjs/{src/commands → commands}/invertCommand.d.ts +0 -0
  1065. /package/dist/mjs/{src/commands → commands}/lib.d.ts +0 -0
  1066. /package/dist/mjs/{src/commands → commands}/lib.mjs +0 -0
  1067. /package/dist/mjs/{src/commands → commands}/uniteCommands.d.ts +0 -0
  1068. /package/dist/mjs/{src/components → components}/RestylableComponent.d.ts +0 -0
  1069. /package/dist/mjs/{src/components → components}/localization.d.ts +0 -0
  1070. /package/dist/mjs/{src/localization.d.ts → localization.d.ts} +0 -0
  1071. /package/dist/mjs/{src/localizations → localizations}/de.d.ts +0 -0
  1072. /package/dist/mjs/{src/localizations → localizations}/en.d.ts +0 -0
  1073. /package/dist/mjs/{src/localizations → localizations}/es.d.ts +0 -0
  1074. /package/dist/mjs/{src/math → math}/Vec2.d.ts +0 -0
  1075. /package/dist/mjs/{src/math → math}/Vec3.d.ts +0 -0
  1076. /package/dist/mjs/{src/math → math}/rounding.d.ts +0 -0
  1077. /package/dist/mjs/{src/rendering → rendering}/Display.d.ts +0 -0
  1078. /package/dist/mjs/{src/rendering → rendering}/caching/RenderingCache.d.ts +0 -0
  1079. /package/dist/mjs/{src/rendering → rendering}/caching/testUtils.d.ts +0 -0
  1080. /package/dist/mjs/{src/rendering → rendering}/caching/types.d.ts +0 -0
  1081. /package/dist/mjs/{src/rendering → rendering}/lib.d.ts +0 -0
  1082. /package/dist/mjs/{src/rendering → rendering}/lib.mjs +0 -0
  1083. /package/dist/mjs/{src/rendering → rendering}/localization.d.ts +0 -0
  1084. /package/dist/mjs/{src/testing → testing}/createEditor.d.ts +0 -0
  1085. /package/dist/mjs/{src/testing → testing}/lib.d.ts +0 -0
  1086. /package/dist/mjs/{src/testing → testing}/lib.mjs +0 -0
  1087. /package/dist/mjs/{src/testing → testing}/sendPenEvent.d.ts +0 -0
  1088. /package/dist/mjs/{src/testing → testing}/sendTouchEvent.d.ts +0 -0
  1089. /package/dist/mjs/{src/toolbar → toolbar}/HTMLToolbar.d.ts +0 -0
  1090. /package/dist/mjs/{src/toolbar → toolbar}/IconProvider.d.ts +0 -0
  1091. /package/dist/mjs/{src/toolbar → toolbar}/lib.d.ts +0 -0
  1092. /package/dist/mjs/{src/toolbar → toolbar}/lib.mjs +0 -0
  1093. /package/dist/mjs/{src/toolbar → toolbar}/makeColorInput.d.ts +0 -0
  1094. /package/dist/mjs/{src/toolbar → toolbar}/types.d.ts +0 -0
  1095. /package/dist/mjs/{src/toolbar → toolbar}/widgets/ActionButtonWidget.d.ts +0 -0
  1096. /package/dist/mjs/{src/toolbar → toolbar}/widgets/BaseToolWidget.d.ts +0 -0
  1097. /package/dist/mjs/{src/toolbar → toolbar}/widgets/DocumentPropertiesWidget.d.ts +0 -0
  1098. /package/dist/mjs/{src/toolbar → toolbar}/widgets/EraserToolWidget.d.ts +0 -0
  1099. /package/dist/mjs/{src/toolbar → toolbar}/widgets/HandToolWidget.d.ts +0 -0
  1100. /package/dist/mjs/{src/toolbar → toolbar}/widgets/InsertImageWidget.d.ts +0 -0
  1101. /package/dist/mjs/{src/toolbar → toolbar}/widgets/OverflowWidget.d.ts +0 -0
  1102. /package/dist/mjs/{src/toolbar → toolbar}/widgets/PenToolWidget.d.ts +0 -0
  1103. /package/dist/mjs/{src/toolbar → toolbar}/widgets/SelectionToolWidget.d.ts +0 -0
  1104. /package/dist/mjs/{src/toolbar → toolbar}/widgets/TextToolWidget.d.ts +0 -0
  1105. /package/dist/mjs/{src/toolbar → toolbar}/widgets/lib.d.ts +0 -0
  1106. /package/dist/mjs/{src/toolbar → toolbar}/widgets/lib.mjs +0 -0
  1107. /package/dist/mjs/{src/tools → tools}/BaseTool.d.ts +0 -0
  1108. /package/dist/mjs/{src/tools → tools}/PasteHandler.d.ts +0 -0
  1109. /package/dist/mjs/{src/tools → tools}/PipetteTool.d.ts +0 -0
  1110. /package/dist/mjs/{src/tools → tools}/SelectionTool/SelectionHandle.d.ts +0 -0
  1111. /package/dist/mjs/{src/tools → tools}/SelectionTool/TransformMode.d.ts +0 -0
  1112. /package/dist/mjs/{src/tools → tools}/SelectionTool/types.d.ts +0 -0
  1113. /package/dist/mjs/{src/tools → tools}/SelectionTool/types.mjs +0 -0
  1114. /package/dist/mjs/{src/tools → tools}/SoundUITool.d.ts +0 -0
  1115. /package/dist/mjs/{src/tools → tools}/ToolController.d.ts +0 -0
  1116. /package/dist/mjs/{src/tools → tools}/ToolEnabledGroup.d.ts +0 -0
  1117. /package/dist/mjs/{src/tools → tools}/ToolSwitcherShortcut.d.ts +0 -0
  1118. /package/dist/mjs/{src/tools → tools}/ToolbarShortcutHandler.d.ts +0 -0
  1119. /package/dist/mjs/{src/tools → tools}/lib.d.ts +0 -0
  1120. /package/dist/mjs/{src/tools → tools}/lib.mjs +0 -0
  1121. /package/dist/mjs/{src/tools → tools}/localization.d.ts +0 -0
  1122. /package/dist/mjs/{src/types.mjs → types.mjs} +0 -0
  1123. /package/dist/mjs/{src/util → util}/assertions.d.ts +0 -0
  1124. /package/dist/mjs/{src/util → util}/fileToBase64.d.ts +0 -0
  1125. /package/dist/mjs/{src/util → util}/untilNextAnimationFrame.d.ts +0 -0
  1126. /package/dist/mjs/{src/util → util}/waitForAll.d.ts +0 -0
  1127. /package/dist/mjs/{src/util → util}/waitForTimeout.d.ts +0 -0
package/src/Editor.ts ADDED
@@ -0,0 +1,1171 @@
1
+ import EditorImage from './EditorImage';
2
+ import ToolController from './tools/ToolController';
3
+ import { InputEvtType, PointerEvt, EditorNotifier, EditorEventType, ImageLoader, HTMLPointerEventName, HTMLPointerEventFilter } from './types';
4
+ import Command from './commands/Command';
5
+ import UndoRedoHistory from './UndoRedoHistory';
6
+ import Viewport from './Viewport';
7
+ import EventDispatcher from './EventDispatcher';
8
+ import { Point2, Vec2 } from './math/Vec2';
9
+ import Vec3 from './math/Vec3';
10
+ import HTMLToolbar from './toolbar/HTMLToolbar';
11
+ import { RenderablePathSpec } from './rendering/renderers/AbstractRenderer';
12
+ import Display, { RenderingMode } from './rendering/Display';
13
+ import SVGRenderer from './rendering/renderers/SVGRenderer';
14
+ import Color4 from './Color4';
15
+ import SVGLoader from './SVGLoader';
16
+ import Pointer from './Pointer';
17
+ import Mat33 from './math/Mat33';
18
+ import Rect2 from './math/shapes/Rect2';
19
+ import { EditorLocalization } from './localization';
20
+ import getLocalizationTable from './localizations/getLocalizationTable';
21
+ import IconProvider from './toolbar/IconProvider';
22
+ import { toRoundedString } from './math/rounding';
23
+ import CanvasRenderer from './rendering/renderers/CanvasRenderer';
24
+ import untilNextAnimationFrame from './util/untilNextAnimationFrame';
25
+ import fileToBase64 from './util/fileToBase64';
26
+ import uniteCommands from './commands/uniteCommands';
27
+ import SelectionTool from './tools/SelectionTool/SelectionTool';
28
+ import AbstractComponent from './components/AbstractComponent';
29
+ import Erase from './commands/Erase';
30
+ import BackgroundComponent, { BackgroundType } from './components/BackgroundComponent';
31
+ import sendPenEvent from './testing/sendPenEvent';
32
+ import KeyboardShortcutManager from './shortcuts/KeyboardShortcutManager';
33
+ import KeyBinding from './shortcuts/KeyBinding';
34
+
35
+ export interface EditorSettings {
36
+ /** Defaults to `RenderingMode.CanvasRenderer` */
37
+ renderingMode: RenderingMode,
38
+
39
+ /** Uses a default English localization if a translation is not given. */
40
+ localization: Partial<EditorLocalization>,
41
+
42
+ /**
43
+ * `true` if touchpad/mousewheel scrolling should scroll the editor instead of the document.
44
+ * This does not include pinch-zoom events.
45
+ * Defaults to true.
46
+ */
47
+ wheelEventsEnabled: boolean|'only-if-focused';
48
+
49
+ /** Minimum zoom fraction (e.g. 0.5 → 50% zoom). */
50
+ minZoom: number,
51
+ maxZoom: number,
52
+
53
+ /**
54
+ * Overrides for keyboard shortcuts. For example,
55
+ * ```ts
56
+ * {
57
+ * 'some.shortcut.id': [ ShortcutManager.keyboardShortcutFromString('ctrl+a') ],
58
+ * 'another.shortcut.id': [ ]
59
+ * }
60
+ * ```
61
+ * where shortcut IDs map to lists of associated keybindings.
62
+ */
63
+ keyboardShortcutOverrides: Record<string, Array<KeyBinding>>,
64
+
65
+ iconProvider: IconProvider,
66
+ }
67
+
68
+ /**
69
+ * The main entrypoint for the full editor.
70
+ *
71
+ * @example
72
+ * To create an editor with a toolbar,
73
+ * ```
74
+ * const editor = new Editor(document.body);
75
+ *
76
+ * const toolbar = editor.addToolbar();
77
+ * toolbar.addActionButton('Save', () => {
78
+ * const saveData = editor.toSVG().outerHTML;
79
+ * // Do something with saveData...
80
+ * });
81
+ * ```
82
+ *
83
+ * See also
84
+ * [`docs/example/example.ts`](https://github.com/personalizedrefrigerator/js-draw/blob/main/docs/demo/example.ts#L15).
85
+ */
86
+ export class Editor {
87
+ // Wrapper around the viewport and toolbar
88
+ private container: HTMLElement;
89
+ private renderingRegion: HTMLElement;
90
+
91
+ /** Manages drawing surfaces/{@link AbstractRenderer}s. */
92
+ public display: Display;
93
+
94
+ /**
95
+ * Handles undo/redo.
96
+ *
97
+ * @example
98
+ * ```
99
+ * const editor = new Editor(document.body);
100
+ *
101
+ * // Do something undoable.
102
+ * // ...
103
+ *
104
+ * // Undo the last action
105
+ * editor.history.undo();
106
+ * ```
107
+ */
108
+ public history: UndoRedoHistory;
109
+
110
+ /**
111
+ * Data structure for adding/removing/querying objects in the image.
112
+ *
113
+ * @example
114
+ * ```
115
+ * const editor = new Editor(document.body);
116
+ *
117
+ * // Create a path.
118
+ * const stroke = new Stroke([
119
+ * Path.fromString('M0,0 L30,30 z').toRenderable({ fill: Color4.black }),
120
+ * ]);
121
+ * const addElementCommand = editor.image.addElement(stroke);
122
+ *
123
+ * // Add the stroke to the editor
124
+ * editor.dispatch(addElementCommand);
125
+ * ```
126
+ */
127
+ public readonly image: EditorImage;
128
+
129
+ /**
130
+ * Allows transforming the view and querying information about
131
+ * what is currently visible.
132
+ */
133
+ public readonly viewport: Viewport;
134
+
135
+ /** @internal */
136
+ public readonly localization: EditorLocalization;
137
+
138
+ /** {@link EditorSettings.iconProvider} */
139
+ public readonly icons: IconProvider;
140
+
141
+ /**
142
+ * Manages and allows overriding of keyboard shortcuts.
143
+ *
144
+ * @internal
145
+ */
146
+ public readonly shortcuts: KeyboardShortcutManager;
147
+
148
+ /**
149
+ * Controls the list of tools. See
150
+ * [the custom tool example](https://github.com/personalizedrefrigerator/js-draw/tree/main/docs/examples/example-custom-tools)
151
+ * for more.
152
+ */
153
+ public readonly toolController: ToolController;
154
+
155
+ /**
156
+ * Global event dispatcher/subscriber.
157
+ */
158
+ public readonly notifier: EditorNotifier;
159
+
160
+ private loadingWarning: HTMLElement;
161
+ private accessibilityAnnounceArea: HTMLElement;
162
+ private accessibilityControlArea: HTMLTextAreaElement;
163
+ private eventListenerTargets: HTMLElement[] = [];
164
+
165
+ private settings: EditorSettings;
166
+
167
+ /**
168
+ * @example
169
+ * ```
170
+ * const container = document.body;
171
+ *
172
+ * // Create an editor
173
+ * const editor = new Editor(container, {
174
+ * // 2e-10 and 1e12 are the default values for minimum/maximum zoom.
175
+ * minZoom: 2e-10,
176
+ * maxZoom: 1e12,
177
+ * });
178
+ *
179
+ * // Add the default toolbar
180
+ * const toolbar = editor.addToolbar();
181
+ *
182
+ * // Add a save button
183
+ * toolbar.addActionButton({
184
+ * label: 'Save'
185
+ * icon: createSaveIcon(),
186
+ * }, () => {
187
+ * const saveData = editor.toSVG().outerHTML;
188
+ * // Do something with saveData
189
+ * });
190
+ * ```
191
+ */
192
+ public constructor(
193
+ parent: HTMLElement,
194
+ settings: Partial<EditorSettings> = {},
195
+ ) {
196
+ this.localization = {
197
+ ...getLocalizationTable(),
198
+ ...settings.localization,
199
+ };
200
+
201
+ // Fill default settings.
202
+ this.settings = {
203
+ wheelEventsEnabled: settings.wheelEventsEnabled ?? true,
204
+ renderingMode: settings.renderingMode ?? RenderingMode.CanvasRenderer,
205
+ localization: this.localization,
206
+ minZoom: settings.minZoom ?? 2e-10,
207
+ maxZoom: settings.maxZoom ?? 1e12,
208
+ keyboardShortcutOverrides: settings.keyboardShortcutOverrides ?? {},
209
+ iconProvider: settings.iconProvider ?? new IconProvider(),
210
+ };
211
+ this.icons = this.settings.iconProvider;
212
+
213
+ this.shortcuts = new KeyboardShortcutManager(this.settings.keyboardShortcutOverrides);
214
+
215
+ this.container = document.createElement('div');
216
+ this.renderingRegion = document.createElement('div');
217
+ this.container.appendChild(this.renderingRegion);
218
+ this.container.className = 'imageEditorContainer';
219
+
220
+ this.loadingWarning = document.createElement('div');
221
+ this.loadingWarning.classList.add('loadingMessage');
222
+ this.loadingWarning.ariaLive = 'polite';
223
+ this.container.appendChild(this.loadingWarning);
224
+
225
+ this.accessibilityControlArea = document.createElement('textarea');
226
+ this.accessibilityControlArea.setAttribute('placeholder', this.localization.accessibilityInputInstructions);
227
+ this.accessibilityControlArea.style.opacity = '0';
228
+ this.accessibilityControlArea.style.width = '0';
229
+ this.accessibilityControlArea.style.height = '0';
230
+ this.accessibilityControlArea.style.position = 'absolute';
231
+
232
+ this.accessibilityAnnounceArea = document.createElement('div');
233
+ this.accessibilityAnnounceArea.setAttribute('aria-live', 'assertive');
234
+ this.accessibilityAnnounceArea.className = 'accessibilityAnnouncement';
235
+ this.container.appendChild(this.accessibilityAnnounceArea);
236
+
237
+ this.renderingRegion.style.touchAction = 'none';
238
+ this.renderingRegion.className = 'imageEditorRenderArea';
239
+ this.renderingRegion.appendChild(this.accessibilityControlArea);
240
+ this.renderingRegion.setAttribute('tabIndex', '0');
241
+ this.renderingRegion.setAttribute('alt', '');
242
+
243
+ this.notifier = new EventDispatcher();
244
+ this.viewport = new Viewport((oldTransform, newTransform) => {
245
+ this.notifier.dispatch(EditorEventType.ViewportChanged, {
246
+ kind: EditorEventType.ViewportChanged,
247
+ newTransform,
248
+ oldTransform,
249
+ });
250
+ });
251
+ this.display = new Display(this, this.settings.renderingMode, this.renderingRegion);
252
+ this.image = new EditorImage();
253
+ this.history = new UndoRedoHistory(this, this.announceRedoCallback, this.announceUndoCallback);
254
+ this.toolController = new ToolController(this, this.localization);
255
+
256
+ parent.appendChild(this.container);
257
+
258
+ this.viewport.updateScreenSize(
259
+ Vec2.of(this.display.width, this.display.height)
260
+ );
261
+
262
+ this.registerListeners();
263
+ this.queueRerender();
264
+ this.hideLoadingWarning();
265
+
266
+
267
+ // Enforce zoom limits.
268
+ this.notifier.on(EditorEventType.ViewportChanged, evt => {
269
+ if (evt.kind === EditorEventType.ViewportChanged) {
270
+ const zoom = evt.newTransform.transformVec3(Vec2.unitX).length();
271
+ if (zoom > this.settings.maxZoom || zoom < this.settings.minZoom) {
272
+ const oldZoom = evt.oldTransform.transformVec3(Vec2.unitX).length();
273
+ let resetTransform = Mat33.identity;
274
+
275
+ if (oldZoom <= this.settings.maxZoom && oldZoom >= this.settings.minZoom) {
276
+ resetTransform = evt.oldTransform;
277
+ }
278
+
279
+ this.viewport.resetTransform(resetTransform);
280
+ }
281
+ }
282
+ });
283
+ }
284
+
285
+ /**
286
+ * @returns a reference to the editor's container.
287
+ *
288
+ * @example
289
+ * ```
290
+ * // Set the editor's height to 500px
291
+ * editor.getRootElement().style.height = '500px';
292
+ * ```
293
+ */
294
+ public getRootElement(): HTMLElement {
295
+ return this.container;
296
+ }
297
+
298
+ /** @param fractionLoaded - should be a number from 0 to 1, where 1 represents completely loaded. */
299
+ public showLoadingWarning(fractionLoaded: number) {
300
+ const loadingPercent = Math.round(fractionLoaded * 100);
301
+ this.loadingWarning.innerText = this.localization.loading(loadingPercent);
302
+ this.loadingWarning.style.display = 'block';
303
+ }
304
+
305
+ public hideLoadingWarning() {
306
+ this.loadingWarning.style.display = 'none';
307
+
308
+ this.announceForAccessibility(this.localization.doneLoading);
309
+ }
310
+
311
+ private previousAccessibilityAnnouncement: string = '';
312
+
313
+ /**
314
+ * Announce `message` for screen readers. If `message` is the same as the previous
315
+ * message, it is re-announced.
316
+ */
317
+ public announceForAccessibility(message: string) {
318
+ // Force re-announcing an announcement if announced again.
319
+ if (message === this.previousAccessibilityAnnouncement) {
320
+ message = message + '. ';
321
+ }
322
+ this.accessibilityAnnounceArea.innerText = message;
323
+ this.previousAccessibilityAnnouncement = message;
324
+ }
325
+
326
+ /**
327
+ * Creates a toolbar. If `defaultLayout` is true, default buttons are used.
328
+ * @returns a reference to the toolbar.
329
+ */
330
+ public addToolbar(defaultLayout: boolean = true): HTMLToolbar {
331
+ const toolbar = new HTMLToolbar(this, this.container, this.localization);
332
+
333
+ if (defaultLayout) {
334
+ toolbar.addDefaults();
335
+ }
336
+
337
+ return toolbar;
338
+ }
339
+
340
+ private registerListeners() {
341
+ this.handlePointerEventsFrom(this.renderingRegion);
342
+ this.handleKeyEventsFrom(this.renderingRegion);
343
+
344
+ this.container.addEventListener('wheel', evt => {
345
+ let delta = Vec3.of(evt.deltaX, evt.deltaY, evt.deltaZ);
346
+
347
+ // Process wheel events if the ctrl key is down, even if disabled -- we do want to handle
348
+ // pinch-zooming.
349
+ if (!evt.ctrlKey && !evt.metaKey) {
350
+ if (!this.settings.wheelEventsEnabled) {
351
+ return;
352
+ } else if (this.settings.wheelEventsEnabled === 'only-if-focused') {
353
+ const focusedChild = this.container.querySelector(':focus');
354
+
355
+ if (!focusedChild) {
356
+ return;
357
+ }
358
+ }
359
+ }
360
+
361
+ if (evt.deltaMode === WheelEvent.DOM_DELTA_LINE) {
362
+ delta = delta.times(15);
363
+ } else if (evt.deltaMode === WheelEvent.DOM_DELTA_PAGE) {
364
+ delta = delta.times(100);
365
+ }
366
+
367
+ if (evt.ctrlKey || evt.metaKey) {
368
+ delta = Vec3.of(0, 0, evt.deltaY);
369
+ }
370
+
371
+ // Ensure that `pos` is relative to `this.renderingRegion`
372
+ const bbox = this.renderingRegion.getBoundingClientRect();
373
+ const pos = Vec2.of(evt.clientX, evt.clientY).minus(Vec2.of(bbox.left, bbox.top));
374
+
375
+ if (this.toolController.dispatchInputEvent({
376
+ kind: InputEvtType.WheelEvt,
377
+ delta,
378
+ screenPos: pos,
379
+ })) {
380
+ evt.preventDefault();
381
+ return true;
382
+ }
383
+ return false;
384
+ });
385
+
386
+ this.notifier.on(EditorEventType.DisplayResized, _event => {
387
+ this.viewport.updateScreenSize(
388
+ Vec2.of(this.display.width, this.display.height)
389
+ );
390
+ this.queueRerender();
391
+ });
392
+
393
+ const handleResize = () => {
394
+ this.notifier.dispatch(EditorEventType.DisplayResized, {
395
+ kind: EditorEventType.DisplayResized,
396
+ newSize: Vec2.of(
397
+ this.display.width,
398
+ this.display.height
399
+ ),
400
+ });
401
+ };
402
+
403
+ if ('ResizeObserver' in (window as any)) {
404
+ const resizeObserver = new ResizeObserver(handleResize);
405
+ resizeObserver.observe(this.container);
406
+ } else {
407
+ addEventListener('resize', handleResize);
408
+ }
409
+
410
+ this.accessibilityControlArea.addEventListener('input', () => {
411
+ this.accessibilityControlArea.value = '';
412
+ });
413
+
414
+ document.addEventListener('copy', evt => {
415
+ if (!this.isEventSink(document.querySelector(':focus'))) {
416
+ return;
417
+ }
418
+
419
+ const clipboardData = evt.clipboardData;
420
+
421
+ if (this.toolController.dispatchInputEvent({
422
+ kind: InputEvtType.CopyEvent,
423
+ setData: (mime, data) => {
424
+ clipboardData?.setData(mime, data);
425
+ },
426
+ })) {
427
+ evt.preventDefault();
428
+ }
429
+ });
430
+
431
+ document.addEventListener('paste', evt => {
432
+ this.handlePaste(evt);
433
+ });
434
+ }
435
+
436
+ private pointers: Record<number, Pointer> = {};
437
+ private getPointerList() {
438
+ const nowTime = (new Date()).getTime();
439
+
440
+ const res: Pointer[] = [];
441
+ for (const id in this.pointers) {
442
+ const maxUnupdatedTime = 2000; // Maximum time without a pointer update (ms)
443
+ if (this.pointers[id] && (nowTime - this.pointers[id].timeStamp) < maxUnupdatedTime) {
444
+ res.push(this.pointers[id]);
445
+ }
446
+ }
447
+ return res;
448
+ }
449
+
450
+ /**
451
+ * Dispatches a `PointerEvent` to the editor. The target element for `evt` must have the same top left
452
+ * as the content of the editor.
453
+ */
454
+ public handleHTMLPointerEvent(eventType: 'pointerdown'|'pointermove'|'pointerup'|'pointercancel', evt: PointerEvent): boolean {
455
+ const eventsRelativeTo = this.renderingRegion;
456
+ const eventTarget = (evt.target as HTMLElement|null) ?? this.renderingRegion;
457
+
458
+ if (eventType === 'pointerdown') {
459
+ const pointer = Pointer.ofEvent(evt, true, this.viewport, eventsRelativeTo);
460
+ this.pointers[pointer.id] = pointer;
461
+
462
+ eventTarget.setPointerCapture(pointer.id);
463
+ const event: PointerEvt = {
464
+ kind: InputEvtType.PointerDownEvt,
465
+ current: pointer,
466
+ allPointers: this.getPointerList(),
467
+ };
468
+ this.toolController.dispatchInputEvent(event);
469
+
470
+ return true;
471
+ }
472
+ else if (eventType === 'pointermove') {
473
+ const pointer = Pointer.ofEvent(
474
+ evt, this.pointers[evt.pointerId]?.down ?? false, this.viewport, eventsRelativeTo
475
+ );
476
+ if (pointer.down) {
477
+ const prevData = this.pointers[pointer.id];
478
+
479
+ if (prevData) {
480
+ const distanceMoved = pointer.screenPos.minus(prevData.screenPos).magnitude();
481
+
482
+ // If the pointer moved less than two pixels, don't send a new event.
483
+ if (distanceMoved < 2) {
484
+ return false;
485
+ }
486
+ }
487
+
488
+ this.pointers[pointer.id] = pointer;
489
+ if (this.toolController.dispatchInputEvent({
490
+ kind: InputEvtType.PointerMoveEvt,
491
+ current: pointer,
492
+ allPointers: this.getPointerList(),
493
+ })) {
494
+ evt.preventDefault();
495
+ }
496
+ }
497
+ return true;
498
+ }
499
+ else if (eventType === 'pointercancel' || eventType === 'pointerup') {
500
+ const pointer = Pointer.ofEvent(evt, false, this.viewport, eventsRelativeTo);
501
+ if (!this.pointers[pointer.id]) {
502
+ return false;
503
+ }
504
+
505
+ this.pointers[pointer.id] = pointer;
506
+ eventTarget.releasePointerCapture(pointer.id);
507
+ if (this.toolController.dispatchInputEvent({
508
+ kind: InputEvtType.PointerUpEvt,
509
+ current: pointer,
510
+ allPointers: this.getPointerList(),
511
+ })) {
512
+ evt.preventDefault();
513
+ }
514
+ delete this.pointers[pointer.id];
515
+ return true;
516
+ }
517
+
518
+ return eventType;
519
+ }
520
+
521
+ private isEventSink(evtTarget: Element|EventTarget|null) {
522
+ let currentElem: Element|null = evtTarget as Element|null;
523
+ while (currentElem !== null) {
524
+ for (const elem of this.eventListenerTargets) {
525
+ if (elem === currentElem) {
526
+ return true;
527
+ }
528
+ }
529
+
530
+ currentElem = (currentElem as Element).parentElement;
531
+ }
532
+ return false;
533
+ }
534
+
535
+ private async handlePaste(evt: DragEvent|ClipboardEvent) {
536
+ const target = document.querySelector(':focus') ?? evt.target;
537
+ if (!this.isEventSink(target)) {
538
+ return;
539
+ }
540
+
541
+ const clipboardData: DataTransfer = (evt as any).dataTransfer ?? (evt as any).clipboardData;
542
+ if (!clipboardData) {
543
+ return;
544
+ }
545
+
546
+ // Handle SVG files (prefer to PNG/JPEG)
547
+ for (const file of clipboardData.files) {
548
+ if (file.type.toLowerCase() === 'image/svg+xml') {
549
+ const text = await file.text();
550
+ if (this.toolController.dispatchInputEvent({
551
+ kind: InputEvtType.PasteEvent,
552
+ mime: file.type,
553
+ data: text,
554
+ })) {
555
+ evt.preventDefault();
556
+ return;
557
+ }
558
+ }
559
+ }
560
+
561
+ // Handle image files.
562
+ for (const file of clipboardData.files) {
563
+ const fileType = file.type.toLowerCase();
564
+ if (fileType === 'image/png' || fileType === 'image/jpg') {
565
+ this.showLoadingWarning(0);
566
+ const onprogress = (evt: ProgressEvent<FileReader>) => {
567
+ this.showLoadingWarning(evt.loaded / evt.total);
568
+ };
569
+
570
+ try {
571
+ const data = await fileToBase64(file, onprogress);
572
+
573
+ if (data && this.toolController.dispatchInputEvent({
574
+ kind: InputEvtType.PasteEvent,
575
+ mime: fileType,
576
+ data: data,
577
+ })) {
578
+ evt.preventDefault();
579
+ this.hideLoadingWarning();
580
+ return;
581
+ }
582
+ } catch (e) {
583
+ console.error('Error reading image:', e);
584
+ }
585
+ this.hideLoadingWarning();
586
+ }
587
+ }
588
+
589
+ // Supported MIMEs for text data, in order of preference
590
+ const supportedMIMEs = [
591
+ 'image/svg+xml',
592
+ 'text/plain',
593
+ ];
594
+
595
+ for (const mime of supportedMIMEs) {
596
+ const data = clipboardData.getData(mime);
597
+
598
+ if (data && this.toolController.dispatchInputEvent({
599
+ kind: InputEvtType.PasteEvent,
600
+ mime,
601
+ data,
602
+ })) {
603
+ evt.preventDefault();
604
+ return;
605
+ }
606
+ }
607
+ }
608
+
609
+ /**
610
+ * Forward pointer events from `elem` to this editor. Such that right-click/right-click drag
611
+ * events are also forwarded, `elem`'s contextmenu is disabled.
612
+ *
613
+ * @example
614
+ * ```ts
615
+ * const overlay = document.createElement('div');
616
+ * editor.createHTMLOverlay(overlay);
617
+ *
618
+ * // Send all pointer events that don't have the control key pressed
619
+ * // to the editor.
620
+ * editor.handlePointerEventsFrom(overlay, (event) => {
621
+ * if (event.ctrlKey) {
622
+ * return false;
623
+ * }
624
+ * return true;
625
+ * });
626
+ * ```
627
+ */
628
+ public handlePointerEventsFrom(elem: HTMLElement, filter?: HTMLPointerEventFilter) {
629
+ // May be required to prevent text selection on iOS/Safari:
630
+ // See https://stackoverflow.com/a/70992717/17055750
631
+ const touchstartListener = (evt: Event) => evt.preventDefault();
632
+ const contextmenuListener = (evt: Event) => {
633
+ // Don't show a context menu
634
+ evt.preventDefault();
635
+ };
636
+
637
+ const listeners: Record<string, (event: Event)=>void> = {
638
+ 'touchstart': touchstartListener,
639
+ 'contextmenu': contextmenuListener,
640
+ };
641
+
642
+ const eventNames: HTMLPointerEventName[] = ['pointerdown', 'pointermove', 'pointerup', 'pointercancel'];
643
+ for (const eventName of eventNames) {
644
+ listeners[eventName] = (evt: Event) => {
645
+ // This listener will only be called in the context of PointerEvents.
646
+ const event = evt as PointerEvent;
647
+
648
+ if (filter && !filter(eventName, event)) {
649
+ return true;
650
+ }
651
+
652
+ return this.handleHTMLPointerEvent(eventName, event);
653
+ };
654
+ }
655
+
656
+ // Add all listeners.
657
+ for (const eventName in listeners) {
658
+ elem.addEventListener(eventName, listeners[eventName]);
659
+ }
660
+
661
+ return {
662
+ /** Remove all event listeners registered by this function. */
663
+ remove: () => {
664
+ for (const eventName in listeners) {
665
+ elem.removeEventListener(eventName, listeners[eventName]);
666
+ }
667
+ },
668
+ };
669
+ }
670
+
671
+ /** Adds event listners for keypresses to `elem` and forwards those events to the editor. */
672
+ public handleKeyEventsFrom(elem: HTMLElement) {
673
+ elem.addEventListener('keydown', evt => {
674
+ if (evt.key === 't' || evt.key === 'T') {
675
+ evt.preventDefault();
676
+ this.display.rerenderAsText();
677
+ } else if (this.toolController.dispatchInputEvent({
678
+ kind: InputEvtType.KeyPressEvent,
679
+ key: evt.key,
680
+ ctrlKey: evt.ctrlKey || evt.metaKey,
681
+ altKey: evt.altKey,
682
+ })) {
683
+ evt.preventDefault();
684
+ } else if (evt.key === 'Escape') {
685
+ this.renderingRegion.blur();
686
+ }
687
+ });
688
+
689
+ elem.addEventListener('keyup', evt => {
690
+ if (this.toolController.dispatchInputEvent({
691
+ kind: InputEvtType.KeyUpEvent,
692
+ key: evt.key,
693
+ ctrlKey: evt.ctrlKey || evt.metaKey,
694
+ altKey: evt.altKey,
695
+ })) {
696
+ evt.preventDefault();
697
+ }
698
+ });
699
+
700
+ // Allow drop.
701
+ elem.ondragover = evt => {
702
+ evt.preventDefault();
703
+ };
704
+
705
+ elem.ondrop = evt => {
706
+ evt.preventDefault();
707
+ this.handlePaste(evt);
708
+ };
709
+
710
+ this.eventListenerTargets.push(elem);
711
+ }
712
+
713
+ /** `apply` a command. `command` will be announced for accessibility. */
714
+ public dispatch(command: Command, addToHistory: boolean = true) {
715
+ const dispatchResult = this.dispatchNoAnnounce(command, addToHistory);
716
+ this.announceForAccessibility(command.description(this, this.localization));
717
+
718
+ return dispatchResult;
719
+ }
720
+
721
+ /**
722
+ * Dispatches a command without announcing it. By default, does not add to history.
723
+ * Use this to show finalized commands that don't need to have `announceForAccessibility`
724
+ * called.
725
+ *
726
+ * Prefer `command.apply(editor)` for incomplete commands. `dispatchNoAnnounce` may allow
727
+ * clients to listen for the application of commands (e.g. `SerializableCommand`s so they can
728
+ * be sent across the network), while `apply` does not.
729
+ *
730
+ * @example
731
+ * ```
732
+ * const addToHistory = false;
733
+ * editor.dispatchNoAnnounce(editor.viewport.zoomTo(someRectangle), addToHistory);
734
+ * ```
735
+ */
736
+ public dispatchNoAnnounce(command: Command, addToHistory: boolean = false) {
737
+ const result = command.apply(this);
738
+
739
+ if (addToHistory) {
740
+ const apply = false; // Don't double-apply
741
+ this.history.push(command, apply);
742
+ }
743
+
744
+ return result;
745
+ }
746
+
747
+ /**
748
+ * Apply a large transformation in chunks.
749
+ * If `apply` is `false`, the commands are unapplied.
750
+ * Triggers a re-render after each `updateChunkSize`-sized group of commands
751
+ * has been applied.
752
+ */
753
+ public async asyncApplyOrUnapplyCommands(
754
+ commands: Command[], apply: boolean, updateChunkSize: number
755
+ ) {
756
+ console.assert(updateChunkSize > 0);
757
+ this.display.setDraftMode(true);
758
+ for (let i = 0; i < commands.length; i += updateChunkSize) {
759
+ this.showLoadingWarning(i / commands.length);
760
+
761
+ for (let j = i; j < commands.length && j < i + updateChunkSize; j++) {
762
+ const cmd = commands[j];
763
+
764
+ if (apply) {
765
+ cmd.apply(this);
766
+ } else {
767
+ cmd.unapply(this);
768
+ }
769
+ }
770
+
771
+ // Re-render to show progress, but only if we're not done.
772
+ if (i + updateChunkSize < commands.length) {
773
+ await new Promise(resolve => {
774
+ this.rerender();
775
+ requestAnimationFrame(resolve);
776
+ });
777
+ }
778
+ }
779
+ this.display.setDraftMode(false);
780
+ this.hideLoadingWarning();
781
+ }
782
+
783
+ // @see {@link #asyncApplyOrUnapplyCommands }
784
+ public asyncApplyCommands(commands: Command[], chunkSize: number) {
785
+ return this.asyncApplyOrUnapplyCommands(commands, true, chunkSize);
786
+ }
787
+
788
+ // If `unapplyInReverseOrder`, commands are reversed before unapplying.
789
+ // @see {@link #asyncApplyOrUnapplyCommands }
790
+ public asyncUnapplyCommands(commands: Command[], chunkSize: number, unapplyInReverseOrder: boolean = false) {
791
+ if (unapplyInReverseOrder) {
792
+ commands = [ ...commands ]; // copy
793
+ commands.reverse();
794
+ }
795
+
796
+ return this.asyncApplyOrUnapplyCommands(commands, false, chunkSize);
797
+ }
798
+
799
+ private announceUndoCallback = (command: Command) => {
800
+ this.announceForAccessibility(this.localization.undoAnnouncement(command.description(this, this.localization)));
801
+ };
802
+
803
+ private announceRedoCallback = (command: Command) => {
804
+ this.announceForAccessibility(this.localization.redoAnnouncement(command.description(this, this.localization)));
805
+ };
806
+
807
+ // Listeners to be called once at the end of the next re-render.
808
+ private nextRerenderListeners: Array<()=> void> = [];
809
+ private rerenderQueued: boolean = false;
810
+
811
+ /**
812
+ * Schedule a re-render for some time in the near future. Does not schedule an additional
813
+ * re-render if a re-render is already queued.
814
+ *
815
+ * @returns a promise that resolves when re-rendering has completed.
816
+ */
817
+ public queueRerender(): Promise<void> {
818
+ if (!this.rerenderQueued) {
819
+ this.rerenderQueued = true;
820
+ requestAnimationFrame(() => {
821
+ // If .rerender was called manually, we might not need to
822
+ // re-render.
823
+ if (this.rerenderQueued) {
824
+ this.rerender();
825
+ this.rerenderQueued = false;
826
+ }
827
+ });
828
+ }
829
+
830
+ return new Promise(resolve => {
831
+ this.nextRerenderListeners.push(() => resolve());
832
+ });
833
+ }
834
+
835
+ // @internal
836
+ public isRerenderQueued() {
837
+ return this.rerenderQueued;
838
+ }
839
+
840
+ /**
841
+ * Re-renders the entire image.
842
+ *
843
+ * @see {@link Editor.queueRerender}
844
+ */
845
+ public rerender(showImageBounds: boolean = true) {
846
+ this.display.startRerender();
847
+
848
+ // Don't render if the display has zero size.
849
+ if (this.display.width === 0 || this.display.height === 0) {
850
+ return;
851
+ }
852
+
853
+ // Draw a rectangle around the region that will be visible on save
854
+ const renderer = this.display.getDryInkRenderer();
855
+
856
+ this.image.renderWithCache(renderer, this.display.getCache(), this.viewport);
857
+
858
+ if (showImageBounds) {
859
+ const exportRectFill = { fill: Color4.fromHex('#44444455') };
860
+ const exportRectStrokeWidth = 5 * this.viewport.getSizeOfPixelOnCanvas();
861
+ renderer.drawRect(
862
+ this.getImportExportRect(),
863
+ exportRectStrokeWidth,
864
+ exportRectFill
865
+ );
866
+ }
867
+
868
+ this.rerenderQueued = false;
869
+ this.nextRerenderListeners.forEach(listener => listener());
870
+ this.nextRerenderListeners = [];
871
+ }
872
+
873
+ /**
874
+ * Draws the given path onto the wet ink renderer. The given path will
875
+ * be displayed on top of the main image.
876
+ *
877
+ * @see {@link Display.getWetInkRenderer} {@link Display.flatten}
878
+ */
879
+ public drawWetInk(...path: RenderablePathSpec[]) {
880
+ for (const part of path) {
881
+ this.display.getWetInkRenderer().drawPath(part);
882
+ }
883
+ }
884
+
885
+ /**
886
+ * Clears the wet ink display.
887
+ *
888
+ * @see {@link Display.getWetInkRenderer}
889
+ */
890
+ public clearWetInk() {
891
+ this.display.getWetInkRenderer().clear();
892
+ }
893
+
894
+ /**
895
+ * Focuses the region used for text input/key commands.
896
+ */
897
+ public focus() {
898
+ this.renderingRegion.focus();
899
+ }
900
+
901
+ /**
902
+ * Creates an element that will be positioned on top of the dry/wet ink
903
+ * renderers.
904
+ *
905
+ * This is useful for displaying content on top of the rendered content
906
+ * (e.g. a selection box).
907
+ */
908
+ public createHTMLOverlay(overlay: HTMLElement) {
909
+ overlay.classList.add('overlay');
910
+ this.container.appendChild(overlay);
911
+
912
+ return {
913
+ remove: () => overlay.remove(),
914
+ };
915
+ }
916
+
917
+ public addStyleSheet(content: string): HTMLStyleElement {
918
+ const styleSheet = document.createElement('style');
919
+ styleSheet.innerText = content;
920
+ this.container.appendChild(styleSheet);
921
+
922
+ return styleSheet;
923
+ }
924
+
925
+ // Dispatch a keyboard event to the currently selected tool.
926
+ // Intended for unit testing
927
+ public sendKeyboardEvent(
928
+ eventType: InputEvtType.KeyPressEvent|InputEvtType.KeyUpEvent,
929
+ key: string,
930
+ ctrlKey: boolean = false,
931
+ altKey: boolean = false,
932
+ ) {
933
+ this.toolController.dispatchInputEvent({
934
+ kind: eventType,
935
+ key,
936
+ ctrlKey,
937
+ altKey,
938
+ });
939
+ }
940
+
941
+ /**
942
+ * Dispatch a pen event to the currently selected tool.
943
+ * Intended primarially for unit tests.
944
+ *
945
+ * @deprecated
946
+ * @see {@link sendPenEvent} {@link sendTouchEvent}
947
+ */
948
+ public sendPenEvent(
949
+ eventType: InputEvtType.PointerDownEvt|InputEvtType.PointerMoveEvt|InputEvtType.PointerUpEvt,
950
+ point: Point2,
951
+
952
+ // @deprecated
953
+ allPointers?: Pointer[]
954
+ ) {
955
+ sendPenEvent(this, eventType, point, allPointers);
956
+ }
957
+
958
+ public async addAndCenterComponents(components: AbstractComponent[], selectComponents: boolean = true) {
959
+ let bbox: Rect2|null = null;
960
+ for (const component of components) {
961
+ if (bbox) {
962
+ bbox = bbox.union(component.getBBox());
963
+ } else {
964
+ bbox = component.getBBox();
965
+ }
966
+ }
967
+
968
+ if (!bbox) {
969
+ return;
970
+ }
971
+
972
+ // Find a transform that scales/moves bbox onto the screen.
973
+ const visibleRect = this.viewport.visibleRect;
974
+ const scaleRatioX = visibleRect.width / bbox.width;
975
+ const scaleRatioY = visibleRect.height / bbox.height;
976
+
977
+ let scaleRatio = scaleRatioX;
978
+ if (bbox.width * scaleRatio > visibleRect.width || bbox.height * scaleRatio > visibleRect.height) {
979
+ scaleRatio = scaleRatioY;
980
+ }
981
+ scaleRatio *= 2 / 3;
982
+
983
+ scaleRatio = Viewport.roundScaleRatio(scaleRatio);
984
+
985
+ const transfm = Mat33.translation(
986
+ visibleRect.center.minus(bbox.center)
987
+ ).rightMul(
988
+ Mat33.scaling2D(scaleRatio, bbox.center)
989
+ );
990
+
991
+ const commands: Command[] = [];
992
+ for (const component of components) {
993
+ // To allow deserialization, we need to add first, then transform.
994
+ commands.push(EditorImage.addElement(component));
995
+ commands.push(component.transformBy(transfm));
996
+ }
997
+
998
+ const applyChunkSize = 100;
999
+ await this.dispatch(uniteCommands(commands, applyChunkSize), true);
1000
+
1001
+ if (selectComponents) {
1002
+ for (const selectionTool of this.toolController.getMatchingTools(SelectionTool)) {
1003
+ selectionTool.setEnabled(true);
1004
+ selectionTool.setSelection(components);
1005
+ }
1006
+ }
1007
+ }
1008
+
1009
+ // Get a data URL (e.g. as produced by `HTMLCanvasElement::toDataURL`).
1010
+ // If `format` is not `image/png`, a PNG image URL may still be returned (as in the
1011
+ // case of `HTMLCanvasElement::toDataURL`).
1012
+ //
1013
+ // The export resolution is the same as the size of the drawing canvas.
1014
+ public toDataURL(format: 'image/png'|'image/jpeg'|'image/webp' = 'image/png', outputSize?: Vec2): string {
1015
+ const canvas = document.createElement('canvas');
1016
+
1017
+ const importExportViewport = this.image.getImportExportViewport();
1018
+ const exportRectSize = importExportViewport.getScreenRectSize();
1019
+ const resolution = outputSize ?? exportRectSize;
1020
+
1021
+ canvas.width = resolution.x;
1022
+ canvas.height = resolution.y;
1023
+
1024
+ const ctx = canvas.getContext('2d')!;
1025
+
1026
+ // Scale to ensure that the entire output is visible.
1027
+ const scaleFactor = Math.min(resolution.x / exportRectSize.x, resolution.y / exportRectSize.y);
1028
+ ctx.scale(scaleFactor, scaleFactor);
1029
+
1030
+ const renderer = new CanvasRenderer(ctx, importExportViewport);
1031
+
1032
+ this.image.renderAll(renderer);
1033
+
1034
+ const dataURL = canvas.toDataURL(format);
1035
+ return dataURL;
1036
+ }
1037
+
1038
+ public toSVG(): SVGElement {
1039
+ const importExportViewport = this.image.getImportExportViewport().getTemporaryClone();
1040
+
1041
+ const sanitize = false;
1042
+ const { element: result, renderer } = SVGRenderer.fromViewport(importExportViewport, sanitize);
1043
+
1044
+ const origTransform = importExportViewport.canvasToScreenTransform;
1045
+ // Render with (0,0) at (0,0) — we'll handle translation with
1046
+ // the viewBox property.
1047
+ importExportViewport.resetTransform(Mat33.identity);
1048
+
1049
+ this.image.renderAll(renderer);
1050
+
1051
+ importExportViewport.resetTransform(origTransform);
1052
+
1053
+
1054
+ // Just show the main region
1055
+ const rect = importExportViewport.visibleRect;
1056
+ result.setAttribute('viewBox', [rect.x, rect.y, rect.w, rect.h].map(part => toRoundedString(part)).join(' '));
1057
+ result.setAttribute('width', toRoundedString(rect.w));
1058
+ result.setAttribute('height', toRoundedString(rect.h));
1059
+
1060
+ return result;
1061
+ }
1062
+
1063
+ /**
1064
+ * Load editor data from an `ImageLoader` (e.g. an {@link SVGLoader}).
1065
+ *
1066
+ * @see loadFromSVG
1067
+ */
1068
+ public async loadFrom(loader: ImageLoader) {
1069
+ this.showLoadingWarning(0);
1070
+ this.display.setDraftMode(true);
1071
+
1072
+ const originalBackgrounds = this.image.getBackgroundComponents();
1073
+ const eraseBackgroundCommand = new Erase(originalBackgrounds);
1074
+
1075
+ await loader.start(async (component) => {
1076
+ await this.dispatchNoAnnounce(EditorImage.addElement(component));
1077
+ }, (countProcessed: number, totalToProcess: number) => {
1078
+ if (countProcessed % 500 === 0) {
1079
+ this.showLoadingWarning(countProcessed / totalToProcess);
1080
+ this.rerender();
1081
+ return untilNextAnimationFrame();
1082
+ }
1083
+
1084
+ return null;
1085
+ }, (importExportRect: Rect2) => {
1086
+ this.dispatchNoAnnounce(this.setImportExportRect(importExportRect), false);
1087
+ this.dispatchNoAnnounce(this.viewport.zoomTo(importExportRect), false);
1088
+ });
1089
+
1090
+ // Ensure that we don't have multiple overlapping BackgroundComponents. Remove
1091
+ // old BackgroundComponents.
1092
+ // Overlapping BackgroundComponents may cause changing the background color to
1093
+ // not work properly.
1094
+ if (this.image.getBackgroundComponents().length !== originalBackgrounds.length) {
1095
+ await this.dispatchNoAnnounce(eraseBackgroundCommand);
1096
+ }
1097
+
1098
+ this.hideLoadingWarning();
1099
+
1100
+ this.display.setDraftMode(false);
1101
+ this.queueRerender();
1102
+ }
1103
+
1104
+ private getTopmostBackgroundComponent(): BackgroundComponent|null {
1105
+ let background: BackgroundComponent|null = null;
1106
+
1107
+ // Find a background component, if one exists.
1108
+ // Use the last (topmost) background component if there are multiple.
1109
+ for (const component of this.image.getBackgroundComponents()) {
1110
+ if (component instanceof BackgroundComponent) {
1111
+ background = component;
1112
+ }
1113
+ }
1114
+
1115
+ return background;
1116
+ }
1117
+
1118
+ /**
1119
+ * Set the background color of the image.
1120
+ */
1121
+ public setBackgroundColor(color: Color4): Command {
1122
+ let background = this.getTopmostBackgroundComponent();
1123
+
1124
+ if (!background) {
1125
+ const backgroundType = color.eq(Color4.transparent) ? BackgroundType.None : BackgroundType.SolidColor;
1126
+ background = new BackgroundComponent(backgroundType, color);
1127
+ return this.image.addElement(background);
1128
+ } else {
1129
+ return background.updateStyle({ color });
1130
+ }
1131
+ }
1132
+
1133
+ /**
1134
+ * @returns the average of the colors of all background components. Use this to get the current background
1135
+ * color.
1136
+ */
1137
+ public estimateBackgroundColor(): Color4 {
1138
+ const backgroundColors = [];
1139
+
1140
+ for (const component of this.image.getBackgroundComponents()) {
1141
+ if (component instanceof BackgroundComponent) {
1142
+ backgroundColors.push(component.getStyle().color ?? Color4.transparent);
1143
+ }
1144
+ }
1145
+
1146
+ return Color4.average(backgroundColors);
1147
+ }
1148
+
1149
+ // Returns the size of the visible region of the output SVG
1150
+ public getImportExportRect(): Rect2 {
1151
+ return this.image.getImportExportViewport().visibleRect;
1152
+ }
1153
+
1154
+ // Resize the output SVG to match `imageRect`.
1155
+ public setImportExportRect(imageRect: Rect2): Command {
1156
+ return this.image.setImportExportRect(imageRect);
1157
+ }
1158
+
1159
+ /**
1160
+ * Alias for loadFrom(SVGLoader.fromString).
1161
+ *
1162
+ * This is particularly useful when accessing a bundled version of the editor,
1163
+ * where `SVGLoader.fromString` is unavailable.
1164
+ */
1165
+ public async loadFromSVG(svgData: string, sanitize: boolean = false) {
1166
+ const loader = SVGLoader.fromString(svgData, sanitize);
1167
+ await this.loadFrom(loader);
1168
+ }
1169
+ }
1170
+
1171
+ export default Editor;