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
@@ -1,892 +0,0 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- import EditorImage from './EditorImage.mjs';
11
- import ToolController from './tools/ToolController.mjs';
12
- import { InputEvtType, EditorEventType } from './types.mjs';
13
- import UndoRedoHistory from './UndoRedoHistory.mjs';
14
- import Viewport from './Viewport.mjs';
15
- import EventDispatcher from './EventDispatcher.mjs';
16
- import { Vec2 } from './math/Vec2.mjs';
17
- import Vec3 from './math/Vec3.mjs';
18
- import HTMLToolbar from './toolbar/HTMLToolbar.mjs';
19
- import Display, { RenderingMode } from './rendering/Display.mjs';
20
- import SVGRenderer from './rendering/renderers/SVGRenderer.mjs';
21
- import Color4 from './Color4.mjs';
22
- import SVGLoader from './SVGLoader.mjs';
23
- import Pointer from './Pointer.mjs';
24
- import Mat33 from './math/Mat33.mjs';
25
- import getLocalizationTable from './localizations/getLocalizationTable.mjs';
26
- import IconProvider from './toolbar/IconProvider.mjs';
27
- import { toRoundedString } from './math/rounding.mjs';
28
- import CanvasRenderer from './rendering/renderers/CanvasRenderer.mjs';
29
- import untilNextAnimationFrame from './util/untilNextAnimationFrame.mjs';
30
- import fileToBase64 from './util/fileToBase64.mjs';
31
- import uniteCommands from './commands/uniteCommands.mjs';
32
- import SelectionTool from './tools/SelectionTool/SelectionTool.mjs';
33
- import Erase from './commands/Erase.mjs';
34
- import BackgroundComponent, { BackgroundType } from './components/BackgroundComponent.mjs';
35
- import sendPenEvent from './testing/sendPenEvent.mjs';
36
- /**
37
- * The main entrypoint for the full editor.
38
- *
39
- * @example
40
- * To create an editor with a toolbar,
41
- * ```
42
- * const editor = new Editor(document.body);
43
- *
44
- * const toolbar = editor.addToolbar();
45
- * toolbar.addActionButton('Save', () => {
46
- * const saveData = editor.toSVG().outerHTML;
47
- * // Do something with saveData...
48
- * });
49
- * ```
50
- *
51
- * See also
52
- * [`docs/example/example.ts`](https://github.com/personalizedrefrigerator/js-draw/blob/main/docs/example/example.ts#L15).
53
- */
54
- export class Editor {
55
- /**
56
- * @example
57
- * ```
58
- * const container = document.body;
59
- *
60
- * // Create an editor
61
- * const editor = new Editor(container, {
62
- * // 2e-10 and 1e12 are the default values for minimum/maximum zoom.
63
- * minZoom: 2e-10,
64
- * maxZoom: 1e12,
65
- * });
66
- *
67
- * // Add the default toolbar
68
- * const toolbar = editor.addToolbar();
69
- *
70
- * // Add a save button
71
- * toolbar.addActionButton({
72
- * label: 'Save'
73
- * icon: createSaveIcon(),
74
- * }, () => {
75
- * const saveData = editor.toSVG().outerHTML;
76
- * // Do something with saveData
77
- * });
78
- * ```
79
- */
80
- constructor(parent, settings = {}) {
81
- var _a, _b, _c, _d, _e;
82
- this.eventListenerTargets = [];
83
- this.previousAccessibilityAnnouncement = '';
84
- this.pointers = {};
85
- this.announceUndoCallback = (command) => {
86
- this.announceForAccessibility(this.localization.undoAnnouncement(command.description(this, this.localization)));
87
- };
88
- this.announceRedoCallback = (command) => {
89
- this.announceForAccessibility(this.localization.redoAnnouncement(command.description(this, this.localization)));
90
- };
91
- // Listeners to be called once at the end of the next re-render.
92
- this.nextRerenderListeners = [];
93
- this.rerenderQueued = false;
94
- this.localization = Object.assign(Object.assign({}, getLocalizationTable()), settings.localization);
95
- // Fill default settings.
96
- this.settings = {
97
- wheelEventsEnabled: (_a = settings.wheelEventsEnabled) !== null && _a !== void 0 ? _a : true,
98
- renderingMode: (_b = settings.renderingMode) !== null && _b !== void 0 ? _b : RenderingMode.CanvasRenderer,
99
- localization: this.localization,
100
- minZoom: (_c = settings.minZoom) !== null && _c !== void 0 ? _c : 2e-10,
101
- maxZoom: (_d = settings.maxZoom) !== null && _d !== void 0 ? _d : 1e12,
102
- iconProvider: (_e = settings.iconProvider) !== null && _e !== void 0 ? _e : new IconProvider(),
103
- };
104
- this.icons = this.settings.iconProvider;
105
- this.container = document.createElement('div');
106
- this.renderingRegion = document.createElement('div');
107
- this.container.appendChild(this.renderingRegion);
108
- this.container.className = 'imageEditorContainer';
109
- this.loadingWarning = document.createElement('div');
110
- this.loadingWarning.classList.add('loadingMessage');
111
- this.loadingWarning.ariaLive = 'polite';
112
- this.container.appendChild(this.loadingWarning);
113
- this.accessibilityControlArea = document.createElement('textarea');
114
- this.accessibilityControlArea.setAttribute('placeholder', this.localization.accessibilityInputInstructions);
115
- this.accessibilityControlArea.style.opacity = '0';
116
- this.accessibilityControlArea.style.width = '0';
117
- this.accessibilityControlArea.style.height = '0';
118
- this.accessibilityControlArea.style.position = 'absolute';
119
- this.accessibilityAnnounceArea = document.createElement('div');
120
- this.accessibilityAnnounceArea.setAttribute('aria-live', 'assertive');
121
- this.accessibilityAnnounceArea.className = 'accessibilityAnnouncement';
122
- this.container.appendChild(this.accessibilityAnnounceArea);
123
- this.renderingRegion.style.touchAction = 'none';
124
- this.renderingRegion.className = 'imageEditorRenderArea';
125
- this.renderingRegion.appendChild(this.accessibilityControlArea);
126
- this.renderingRegion.setAttribute('tabIndex', '0');
127
- this.renderingRegion.setAttribute('alt', '');
128
- this.notifier = new EventDispatcher();
129
- this.viewport = new Viewport((oldTransform, newTransform) => {
130
- this.notifier.dispatch(EditorEventType.ViewportChanged, {
131
- kind: EditorEventType.ViewportChanged,
132
- newTransform,
133
- oldTransform,
134
- });
135
- });
136
- this.display = new Display(this, this.settings.renderingMode, this.renderingRegion);
137
- this.image = new EditorImage();
138
- this.history = new UndoRedoHistory(this, this.announceRedoCallback, this.announceUndoCallback);
139
- this.toolController = new ToolController(this, this.localization);
140
- parent.appendChild(this.container);
141
- this.viewport.updateScreenSize(Vec2.of(this.display.width, this.display.height));
142
- this.registerListeners();
143
- this.queueRerender();
144
- this.hideLoadingWarning();
145
- // Enforce zoom limits.
146
- this.notifier.on(EditorEventType.ViewportChanged, evt => {
147
- if (evt.kind === EditorEventType.ViewportChanged) {
148
- const zoom = evt.newTransform.transformVec3(Vec2.unitX).length();
149
- if (zoom > this.settings.maxZoom || zoom < this.settings.minZoom) {
150
- const oldZoom = evt.oldTransform.transformVec3(Vec2.unitX).length();
151
- let resetTransform = Mat33.identity;
152
- if (oldZoom <= this.settings.maxZoom && oldZoom >= this.settings.minZoom) {
153
- resetTransform = evt.oldTransform;
154
- }
155
- this.viewport.resetTransform(resetTransform);
156
- }
157
- }
158
- });
159
- }
160
- /**
161
- * @returns a reference to the editor's container.
162
- *
163
- * @example
164
- * ```
165
- * // Set the editor's height to 500px
166
- * editor.getRootElement().style.height = '500px';
167
- * ```
168
- */
169
- getRootElement() {
170
- return this.container;
171
- }
172
- /** @param fractionLoaded - should be a number from 0 to 1, where 1 represents completely loaded. */
173
- showLoadingWarning(fractionLoaded) {
174
- const loadingPercent = Math.round(fractionLoaded * 100);
175
- this.loadingWarning.innerText = this.localization.loading(loadingPercent);
176
- this.loadingWarning.style.display = 'block';
177
- }
178
- hideLoadingWarning() {
179
- this.loadingWarning.style.display = 'none';
180
- this.announceForAccessibility(this.localization.doneLoading);
181
- }
182
- /**
183
- * Announce `message` for screen readers. If `message` is the same as the previous
184
- * message, it is re-announced.
185
- */
186
- announceForAccessibility(message) {
187
- // Force re-announcing an announcement if announced again.
188
- if (message === this.previousAccessibilityAnnouncement) {
189
- message = message + '. ';
190
- }
191
- this.accessibilityAnnounceArea.innerText = message;
192
- this.previousAccessibilityAnnouncement = message;
193
- }
194
- /**
195
- * Creates a toolbar. If `defaultLayout` is true, default buttons are used.
196
- * @returns a reference to the toolbar.
197
- */
198
- addToolbar(defaultLayout = true) {
199
- const toolbar = new HTMLToolbar(this, this.container, this.localization);
200
- if (defaultLayout) {
201
- toolbar.addDefaults();
202
- }
203
- return toolbar;
204
- }
205
- registerListeners() {
206
- this.handlePointerEventsFrom(this.renderingRegion);
207
- this.handleKeyEventsFrom(this.renderingRegion);
208
- this.container.addEventListener('wheel', evt => {
209
- let delta = Vec3.of(evt.deltaX, evt.deltaY, evt.deltaZ);
210
- // Process wheel events if the ctrl key is down, even if disabled -- we do want to handle
211
- // pinch-zooming.
212
- if (!evt.ctrlKey && !evt.metaKey) {
213
- if (!this.settings.wheelEventsEnabled) {
214
- return;
215
- }
216
- else if (this.settings.wheelEventsEnabled === 'only-if-focused') {
217
- const focusedChild = this.container.querySelector(':focus');
218
- if (!focusedChild) {
219
- return;
220
- }
221
- }
222
- }
223
- if (evt.deltaMode === WheelEvent.DOM_DELTA_LINE) {
224
- delta = delta.times(15);
225
- }
226
- else if (evt.deltaMode === WheelEvent.DOM_DELTA_PAGE) {
227
- delta = delta.times(100);
228
- }
229
- if (evt.ctrlKey || evt.metaKey) {
230
- delta = Vec3.of(0, 0, evt.deltaY);
231
- }
232
- // Ensure that `pos` is relative to `this.renderingRegion`
233
- const bbox = this.renderingRegion.getBoundingClientRect();
234
- const pos = Vec2.of(evt.clientX, evt.clientY).minus(Vec2.of(bbox.left, bbox.top));
235
- if (this.toolController.dispatchInputEvent({
236
- kind: InputEvtType.WheelEvt,
237
- delta,
238
- screenPos: pos,
239
- })) {
240
- evt.preventDefault();
241
- return true;
242
- }
243
- return false;
244
- });
245
- this.notifier.on(EditorEventType.DisplayResized, _event => {
246
- this.viewport.updateScreenSize(Vec2.of(this.display.width, this.display.height));
247
- this.queueRerender();
248
- });
249
- const handleResize = () => {
250
- this.notifier.dispatch(EditorEventType.DisplayResized, {
251
- kind: EditorEventType.DisplayResized,
252
- newSize: Vec2.of(this.display.width, this.display.height),
253
- });
254
- };
255
- if ('ResizeObserver' in window) {
256
- const resizeObserver = new ResizeObserver(handleResize);
257
- resizeObserver.observe(this.container);
258
- }
259
- else {
260
- addEventListener('resize', handleResize);
261
- }
262
- this.accessibilityControlArea.addEventListener('input', () => {
263
- this.accessibilityControlArea.value = '';
264
- });
265
- document.addEventListener('copy', evt => {
266
- if (!this.isEventSink(document.querySelector(':focus'))) {
267
- return;
268
- }
269
- const clipboardData = evt.clipboardData;
270
- if (this.toolController.dispatchInputEvent({
271
- kind: InputEvtType.CopyEvent,
272
- setData: (mime, data) => {
273
- clipboardData === null || clipboardData === void 0 ? void 0 : clipboardData.setData(mime, data);
274
- },
275
- })) {
276
- evt.preventDefault();
277
- }
278
- });
279
- document.addEventListener('paste', evt => {
280
- this.handlePaste(evt);
281
- });
282
- }
283
- getPointerList() {
284
- const nowTime = (new Date()).getTime();
285
- const res = [];
286
- for (const id in this.pointers) {
287
- const maxUnupdatedTime = 2000; // Maximum time without a pointer update (ms)
288
- if (this.pointers[id] && (nowTime - this.pointers[id].timeStamp) < maxUnupdatedTime) {
289
- res.push(this.pointers[id]);
290
- }
291
- }
292
- return res;
293
- }
294
- /**
295
- * Dispatches a `PointerEvent` to the editor. The target element for `evt` must have the same top left
296
- * as the content of the editor.
297
- */
298
- handleHTMLPointerEvent(eventType, evt) {
299
- var _a, _b, _c;
300
- const eventsRelativeTo = this.renderingRegion;
301
- const eventTarget = (_a = evt.target) !== null && _a !== void 0 ? _a : this.renderingRegion;
302
- if (eventType === 'pointerdown') {
303
- const pointer = Pointer.ofEvent(evt, true, this.viewport, eventsRelativeTo);
304
- this.pointers[pointer.id] = pointer;
305
- eventTarget.setPointerCapture(pointer.id);
306
- const event = {
307
- kind: InputEvtType.PointerDownEvt,
308
- current: pointer,
309
- allPointers: this.getPointerList(),
310
- };
311
- this.toolController.dispatchInputEvent(event);
312
- return true;
313
- }
314
- else if (eventType === 'pointermove') {
315
- const pointer = Pointer.ofEvent(evt, (_c = (_b = this.pointers[evt.pointerId]) === null || _b === void 0 ? void 0 : _b.down) !== null && _c !== void 0 ? _c : false, this.viewport, eventsRelativeTo);
316
- if (pointer.down) {
317
- const prevData = this.pointers[pointer.id];
318
- if (prevData) {
319
- const distanceMoved = pointer.screenPos.minus(prevData.screenPos).magnitude();
320
- // If the pointer moved less than two pixels, don't send a new event.
321
- if (distanceMoved < 2) {
322
- return false;
323
- }
324
- }
325
- this.pointers[pointer.id] = pointer;
326
- if (this.toolController.dispatchInputEvent({
327
- kind: InputEvtType.PointerMoveEvt,
328
- current: pointer,
329
- allPointers: this.getPointerList(),
330
- })) {
331
- evt.preventDefault();
332
- }
333
- }
334
- return true;
335
- }
336
- else if (eventType === 'pointercancel' || eventType === 'pointerup') {
337
- const pointer = Pointer.ofEvent(evt, false, this.viewport, eventsRelativeTo);
338
- if (!this.pointers[pointer.id]) {
339
- return false;
340
- }
341
- this.pointers[pointer.id] = pointer;
342
- eventTarget.releasePointerCapture(pointer.id);
343
- if (this.toolController.dispatchInputEvent({
344
- kind: InputEvtType.PointerUpEvt,
345
- current: pointer,
346
- allPointers: this.getPointerList(),
347
- })) {
348
- evt.preventDefault();
349
- }
350
- delete this.pointers[pointer.id];
351
- return true;
352
- }
353
- return eventType;
354
- }
355
- isEventSink(evtTarget) {
356
- let currentElem = evtTarget;
357
- while (currentElem !== null) {
358
- for (const elem of this.eventListenerTargets) {
359
- if (elem === currentElem) {
360
- return true;
361
- }
362
- }
363
- currentElem = currentElem.parentElement;
364
- }
365
- return false;
366
- }
367
- handlePaste(evt) {
368
- var _a, _b;
369
- return __awaiter(this, void 0, void 0, function* () {
370
- const target = (_a = document.querySelector(':focus')) !== null && _a !== void 0 ? _a : evt.target;
371
- if (!this.isEventSink(target)) {
372
- return;
373
- }
374
- const clipboardData = (_b = evt.dataTransfer) !== null && _b !== void 0 ? _b : evt.clipboardData;
375
- if (!clipboardData) {
376
- return;
377
- }
378
- // Handle SVG files (prefer to PNG/JPEG)
379
- for (const file of clipboardData.files) {
380
- if (file.type.toLowerCase() === 'image/svg+xml') {
381
- const text = yield file.text();
382
- if (this.toolController.dispatchInputEvent({
383
- kind: InputEvtType.PasteEvent,
384
- mime: file.type,
385
- data: text,
386
- })) {
387
- evt.preventDefault();
388
- return;
389
- }
390
- }
391
- }
392
- // Handle image files.
393
- for (const file of clipboardData.files) {
394
- const fileType = file.type.toLowerCase();
395
- if (fileType === 'image/png' || fileType === 'image/jpg') {
396
- this.showLoadingWarning(0);
397
- const onprogress = (evt) => {
398
- this.showLoadingWarning(evt.loaded / evt.total);
399
- };
400
- try {
401
- const data = yield fileToBase64(file, onprogress);
402
- if (data && this.toolController.dispatchInputEvent({
403
- kind: InputEvtType.PasteEvent,
404
- mime: fileType,
405
- data: data,
406
- })) {
407
- evt.preventDefault();
408
- this.hideLoadingWarning();
409
- return;
410
- }
411
- }
412
- catch (e) {
413
- console.error('Error reading image:', e);
414
- }
415
- this.hideLoadingWarning();
416
- }
417
- }
418
- // Supported MIMEs for text data, in order of preference
419
- const supportedMIMEs = [
420
- 'image/svg+xml',
421
- 'text/plain',
422
- ];
423
- for (const mime of supportedMIMEs) {
424
- const data = clipboardData.getData(mime);
425
- if (data && this.toolController.dispatchInputEvent({
426
- kind: InputEvtType.PasteEvent,
427
- mime,
428
- data,
429
- })) {
430
- evt.preventDefault();
431
- return;
432
- }
433
- }
434
- });
435
- }
436
- /**
437
- * Forward pointer events from `elem` to this editor. Such that right-click/right-click drag
438
- * events are also forwarded, `elem`'s contextmenu is disabled.
439
- *
440
- * @example
441
- * ```ts
442
- * const overlay = document.createElement('div');
443
- * editor.createHTMLOverlay(overlay);
444
- *
445
- * // Send all pointer events that don't have the control key pressed
446
- * // to the editor.
447
- * editor.handlePointerEventsFrom(overlay, (event) => {
448
- * if (event.ctrlKey) {
449
- * return false;
450
- * }
451
- * return true;
452
- * });
453
- * ```
454
- */
455
- handlePointerEventsFrom(elem, filter) {
456
- // May be required to prevent text selection on iOS/Safari:
457
- // See https://stackoverflow.com/a/70992717/17055750
458
- const touchstartListener = (evt) => evt.preventDefault();
459
- const contextmenuListener = (evt) => {
460
- // Don't show a context menu
461
- evt.preventDefault();
462
- };
463
- const listeners = {
464
- 'touchstart': touchstartListener,
465
- 'contextmenu': contextmenuListener,
466
- };
467
- const eventNames = ['pointerdown', 'pointermove', 'pointerup', 'pointercancel'];
468
- for (const eventName of eventNames) {
469
- listeners[eventName] = (evt) => {
470
- // This listener will only be called in the context of PointerEvents.
471
- const event = evt;
472
- if (filter && !filter(eventName, event)) {
473
- return true;
474
- }
475
- return this.handleHTMLPointerEvent(eventName, event);
476
- };
477
- }
478
- // Add all listeners.
479
- for (const eventName in listeners) {
480
- elem.addEventListener(eventName, listeners[eventName]);
481
- }
482
- return {
483
- /** Remove all event listeners registered by this function. */
484
- remove: () => {
485
- for (const eventName in listeners) {
486
- elem.removeEventListener(eventName, listeners[eventName]);
487
- }
488
- },
489
- };
490
- }
491
- /** Adds event listners for keypresses to `elem` and forwards those events to the editor. */
492
- handleKeyEventsFrom(elem) {
493
- elem.addEventListener('keydown', evt => {
494
- if (evt.key === 't' || evt.key === 'T') {
495
- evt.preventDefault();
496
- this.display.rerenderAsText();
497
- }
498
- else if (this.toolController.dispatchInputEvent({
499
- kind: InputEvtType.KeyPressEvent,
500
- key: evt.key,
501
- ctrlKey: evt.ctrlKey || evt.metaKey,
502
- altKey: evt.altKey,
503
- })) {
504
- evt.preventDefault();
505
- }
506
- else if (evt.key === 'Escape') {
507
- this.renderingRegion.blur();
508
- }
509
- });
510
- elem.addEventListener('keyup', evt => {
511
- if (this.toolController.dispatchInputEvent({
512
- kind: InputEvtType.KeyUpEvent,
513
- key: evt.key,
514
- ctrlKey: evt.ctrlKey || evt.metaKey,
515
- altKey: evt.altKey,
516
- })) {
517
- evt.preventDefault();
518
- }
519
- });
520
- // Allow drop.
521
- elem.ondragover = evt => {
522
- evt.preventDefault();
523
- };
524
- elem.ondrop = evt => {
525
- evt.preventDefault();
526
- this.handlePaste(evt);
527
- };
528
- this.eventListenerTargets.push(elem);
529
- }
530
- /** `apply` a command. `command` will be announced for accessibility. */
531
- dispatch(command, addToHistory = true) {
532
- const dispatchResult = this.dispatchNoAnnounce(command, addToHistory);
533
- this.announceForAccessibility(command.description(this, this.localization));
534
- return dispatchResult;
535
- }
536
- /**
537
- * Dispatches a command without announcing it. By default, does not add to history.
538
- * Use this to show finalized commands that don't need to have `announceForAccessibility`
539
- * called.
540
- *
541
- * Prefer `command.apply(editor)` for incomplete commands. `dispatchNoAnnounce` may allow
542
- * clients to listen for the application of commands (e.g. `SerializableCommand`s so they can
543
- * be sent across the network), while `apply` does not.
544
- *
545
- * @example
546
- * ```
547
- * const addToHistory = false;
548
- * editor.dispatchNoAnnounce(editor.viewport.zoomTo(someRectangle), addToHistory);
549
- * ```
550
- */
551
- dispatchNoAnnounce(command, addToHistory = false) {
552
- const result = command.apply(this);
553
- if (addToHistory) {
554
- const apply = false; // Don't double-apply
555
- this.history.push(command, apply);
556
- }
557
- return result;
558
- }
559
- /**
560
- * Apply a large transformation in chunks.
561
- * If `apply` is `false`, the commands are unapplied.
562
- * Triggers a re-render after each `updateChunkSize`-sized group of commands
563
- * has been applied.
564
- */
565
- asyncApplyOrUnapplyCommands(commands, apply, updateChunkSize) {
566
- return __awaiter(this, void 0, void 0, function* () {
567
- console.assert(updateChunkSize > 0);
568
- this.display.setDraftMode(true);
569
- for (let i = 0; i < commands.length; i += updateChunkSize) {
570
- this.showLoadingWarning(i / commands.length);
571
- for (let j = i; j < commands.length && j < i + updateChunkSize; j++) {
572
- const cmd = commands[j];
573
- if (apply) {
574
- cmd.apply(this);
575
- }
576
- else {
577
- cmd.unapply(this);
578
- }
579
- }
580
- // Re-render to show progress, but only if we're not done.
581
- if (i + updateChunkSize < commands.length) {
582
- yield new Promise(resolve => {
583
- this.rerender();
584
- requestAnimationFrame(resolve);
585
- });
586
- }
587
- }
588
- this.display.setDraftMode(false);
589
- this.hideLoadingWarning();
590
- });
591
- }
592
- // @see {@link #asyncApplyOrUnapplyCommands }
593
- asyncApplyCommands(commands, chunkSize) {
594
- return this.asyncApplyOrUnapplyCommands(commands, true, chunkSize);
595
- }
596
- // If `unapplyInReverseOrder`, commands are reversed before unapplying.
597
- // @see {@link #asyncApplyOrUnapplyCommands }
598
- asyncUnapplyCommands(commands, chunkSize, unapplyInReverseOrder = false) {
599
- if (unapplyInReverseOrder) {
600
- commands = [...commands]; // copy
601
- commands.reverse();
602
- }
603
- return this.asyncApplyOrUnapplyCommands(commands, false, chunkSize);
604
- }
605
- /**
606
- * Schedule a re-render for some time in the near future. Does not schedule an additional
607
- * re-render if a re-render is already queued.
608
- *
609
- * @returns a promise that resolves when re-rendering has completed.
610
- */
611
- queueRerender() {
612
- if (!this.rerenderQueued) {
613
- this.rerenderQueued = true;
614
- requestAnimationFrame(() => {
615
- // If .rerender was called manually, we might not need to
616
- // re-render.
617
- if (this.rerenderQueued) {
618
- this.rerender();
619
- this.rerenderQueued = false;
620
- }
621
- });
622
- }
623
- return new Promise(resolve => {
624
- this.nextRerenderListeners.push(() => resolve());
625
- });
626
- }
627
- // @internal
628
- isRerenderQueued() {
629
- return this.rerenderQueued;
630
- }
631
- /**
632
- * Re-renders the entire image.
633
- *
634
- * @see {@link Editor.queueRerender}
635
- */
636
- rerender(showImageBounds = true) {
637
- this.display.startRerender();
638
- // Don't render if the display has zero size.
639
- if (this.display.width === 0 || this.display.height === 0) {
640
- return;
641
- }
642
- // Draw a rectangle around the region that will be visible on save
643
- const renderer = this.display.getDryInkRenderer();
644
- this.image.renderWithCache(renderer, this.display.getCache(), this.viewport);
645
- if (showImageBounds) {
646
- const exportRectFill = { fill: Color4.fromHex('#44444455') };
647
- const exportRectStrokeWidth = 5 * this.viewport.getSizeOfPixelOnCanvas();
648
- renderer.drawRect(this.getImportExportRect(), exportRectStrokeWidth, exportRectFill);
649
- }
650
- this.rerenderQueued = false;
651
- this.nextRerenderListeners.forEach(listener => listener());
652
- this.nextRerenderListeners = [];
653
- }
654
- /**
655
- * Draws the given path onto the wet ink renderer. The given path will
656
- * be displayed on top of the main image.
657
- *
658
- * @see {@link Display.getWetInkRenderer} {@link Display.flatten}
659
- */
660
- drawWetInk(...path) {
661
- for (const part of path) {
662
- this.display.getWetInkRenderer().drawPath(part);
663
- }
664
- }
665
- /**
666
- * Clears the wet ink display.
667
- *
668
- * @see {@link Display.getWetInkRenderer}
669
- */
670
- clearWetInk() {
671
- this.display.getWetInkRenderer().clear();
672
- }
673
- /**
674
- * Focuses the region used for text input/key commands.
675
- */
676
- focus() {
677
- this.renderingRegion.focus();
678
- }
679
- /**
680
- * Creates an element that will be positioned on top of the dry/wet ink
681
- * renderers.
682
- *
683
- * This is useful for displaying content on top of the rendered content
684
- * (e.g. a selection box).
685
- */
686
- createHTMLOverlay(overlay) {
687
- overlay.classList.add('overlay');
688
- this.container.appendChild(overlay);
689
- return {
690
- remove: () => overlay.remove(),
691
- };
692
- }
693
- addStyleSheet(content) {
694
- const styleSheet = document.createElement('style');
695
- styleSheet.innerText = content;
696
- this.container.appendChild(styleSheet);
697
- return styleSheet;
698
- }
699
- // Dispatch a keyboard event to the currently selected tool.
700
- // Intended for unit testing
701
- sendKeyboardEvent(eventType, key, ctrlKey = false, altKey = false) {
702
- this.toolController.dispatchInputEvent({
703
- kind: eventType,
704
- key,
705
- ctrlKey,
706
- altKey,
707
- });
708
- }
709
- /**
710
- * Dispatch a pen event to the currently selected tool.
711
- * Intended primarially for unit tests.
712
- *
713
- * @deprecated
714
- * @see {@link sendPenEvent} {@link sendTouchEvent}
715
- */
716
- sendPenEvent(eventType, point,
717
- // @deprecated
718
- allPointers) {
719
- sendPenEvent(this, eventType, point, allPointers);
720
- }
721
- addAndCenterComponents(components, selectComponents = true) {
722
- return __awaiter(this, void 0, void 0, function* () {
723
- let bbox = null;
724
- for (const component of components) {
725
- if (bbox) {
726
- bbox = bbox.union(component.getBBox());
727
- }
728
- else {
729
- bbox = component.getBBox();
730
- }
731
- }
732
- if (!bbox) {
733
- return;
734
- }
735
- // Find a transform that scales/moves bbox onto the screen.
736
- const visibleRect = this.viewport.visibleRect;
737
- const scaleRatioX = visibleRect.width / bbox.width;
738
- const scaleRatioY = visibleRect.height / bbox.height;
739
- let scaleRatio = scaleRatioX;
740
- if (bbox.width * scaleRatio > visibleRect.width || bbox.height * scaleRatio > visibleRect.height) {
741
- scaleRatio = scaleRatioY;
742
- }
743
- scaleRatio *= 2 / 3;
744
- scaleRatio = Viewport.roundScaleRatio(scaleRatio);
745
- const transfm = Mat33.translation(visibleRect.center.minus(bbox.center)).rightMul(Mat33.scaling2D(scaleRatio, bbox.center));
746
- const commands = [];
747
- for (const component of components) {
748
- // To allow deserialization, we need to add first, then transform.
749
- commands.push(EditorImage.addElement(component));
750
- commands.push(component.transformBy(transfm));
751
- }
752
- const applyChunkSize = 100;
753
- yield this.dispatch(uniteCommands(commands, applyChunkSize), true);
754
- if (selectComponents) {
755
- for (const selectionTool of this.toolController.getMatchingTools(SelectionTool)) {
756
- selectionTool.setEnabled(true);
757
- selectionTool.setSelection(components);
758
- }
759
- }
760
- });
761
- }
762
- // Get a data URL (e.g. as produced by `HTMLCanvasElement::toDataURL`).
763
- // If `format` is not `image/png`, a PNG image URL may still be returned (as in the
764
- // case of `HTMLCanvasElement::toDataURL`).
765
- //
766
- // The export resolution is the same as the size of the drawing canvas.
767
- toDataURL(format = 'image/png') {
768
- const canvas = document.createElement('canvas');
769
- const importExportViewport = this.image.getImportExportViewport();
770
- const resolution = importExportViewport.getScreenRectSize();
771
- canvas.width = resolution.x;
772
- canvas.height = resolution.y;
773
- const ctx = canvas.getContext('2d');
774
- const renderer = new CanvasRenderer(ctx, importExportViewport);
775
- this.image.renderAll(renderer);
776
- const dataURL = canvas.toDataURL(format);
777
- return dataURL;
778
- }
779
- toSVG() {
780
- const importExportViewport = this.image.getImportExportViewport().getTemporaryClone();
781
- const sanitize = false;
782
- const { element: result, renderer } = SVGRenderer.fromViewport(importExportViewport, sanitize);
783
- const origTransform = importExportViewport.canvasToScreenTransform;
784
- // Render with (0,0) at (0,0) — we'll handle translation with
785
- // the viewBox property.
786
- importExportViewport.resetTransform(Mat33.identity);
787
- this.image.renderAll(renderer);
788
- importExportViewport.resetTransform(origTransform);
789
- // Just show the main region
790
- const rect = importExportViewport.visibleRect;
791
- result.setAttribute('viewBox', [rect.x, rect.y, rect.w, rect.h].map(part => toRoundedString(part)).join(' '));
792
- result.setAttribute('width', toRoundedString(rect.w));
793
- result.setAttribute('height', toRoundedString(rect.h));
794
- return result;
795
- }
796
- /**
797
- * Load editor data from an `ImageLoader` (e.g. an {@link SVGLoader}).
798
- *
799
- * @see loadFromSVG
800
- */
801
- loadFrom(loader) {
802
- return __awaiter(this, void 0, void 0, function* () {
803
- this.showLoadingWarning(0);
804
- this.display.setDraftMode(true);
805
- const originalBackgrounds = this.image.getBackgroundComponents();
806
- const eraseBackgroundCommand = new Erase(originalBackgrounds);
807
- yield loader.start((component) => __awaiter(this, void 0, void 0, function* () {
808
- yield this.dispatchNoAnnounce(EditorImage.addElement(component));
809
- }), (countProcessed, totalToProcess) => {
810
- if (countProcessed % 500 === 0) {
811
- this.showLoadingWarning(countProcessed / totalToProcess);
812
- this.rerender();
813
- return untilNextAnimationFrame();
814
- }
815
- return null;
816
- }, (importExportRect) => {
817
- this.dispatchNoAnnounce(this.setImportExportRect(importExportRect), false);
818
- this.dispatchNoAnnounce(this.viewport.zoomTo(importExportRect), false);
819
- });
820
- // Ensure that we don't have multiple overlapping BackgroundComponents. Remove
821
- // old BackgroundComponents.
822
- // Overlapping BackgroundComponents may cause changing the background color to
823
- // not work properly.
824
- if (this.image.getBackgroundComponents().length !== originalBackgrounds.length) {
825
- yield this.dispatchNoAnnounce(eraseBackgroundCommand);
826
- }
827
- this.hideLoadingWarning();
828
- this.display.setDraftMode(false);
829
- this.queueRerender();
830
- });
831
- }
832
- getTopmostBackgroundComponent() {
833
- let background = null;
834
- // Find a background component, if one exists.
835
- // Use the last (topmost) background component if there are multiple.
836
- for (const component of this.image.getBackgroundComponents()) {
837
- if (component instanceof BackgroundComponent) {
838
- background = component;
839
- }
840
- }
841
- return background;
842
- }
843
- /**
844
- * Set the background color of the image.
845
- */
846
- setBackgroundColor(color) {
847
- let background = this.getTopmostBackgroundComponent();
848
- if (!background) {
849
- const backgroundType = color.eq(Color4.transparent) ? BackgroundType.None : BackgroundType.SolidColor;
850
- background = new BackgroundComponent(backgroundType, color);
851
- return this.image.addElement(background);
852
- }
853
- else {
854
- return background.updateStyle({ color });
855
- }
856
- }
857
- /**
858
- * @returns the average of the colors of all background components. Use this to get the current background
859
- * color.
860
- */
861
- estimateBackgroundColor() {
862
- var _a;
863
- const backgroundColors = [];
864
- for (const component of this.image.getBackgroundComponents()) {
865
- if (component instanceof BackgroundComponent) {
866
- backgroundColors.push((_a = component.getStyle().color) !== null && _a !== void 0 ? _a : Color4.transparent);
867
- }
868
- }
869
- return Color4.average(backgroundColors);
870
- }
871
- // Returns the size of the visible region of the output SVG
872
- getImportExportRect() {
873
- return this.image.getImportExportViewport().visibleRect;
874
- }
875
- // Resize the output SVG to match `imageRect`.
876
- setImportExportRect(imageRect) {
877
- return this.image.setImportExportRect(imageRect);
878
- }
879
- /**
880
- * Alias for loadFrom(SVGLoader.fromString).
881
- *
882
- * This is particularly useful when accessing a bundled version of the editor,
883
- * where `SVGLoader.fromString` is unavailable.
884
- */
885
- loadFromSVG(svgData, sanitize = false) {
886
- return __awaiter(this, void 0, void 0, function* () {
887
- const loader = SVGLoader.fromString(svgData, sanitize);
888
- yield this.loadFrom(loader);
889
- });
890
- }
891
- }
892
- export default Editor;