js-draw 0.23.1 → 0.24.1

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