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