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,7 +0,0 @@
1
- import Command from './Command';
2
- import Duplicate from './Duplicate';
3
- import Erase from './Erase';
4
- import invertCommand from './invertCommand';
5
- import SerializableCommand from './SerializableCommand';
6
- import uniteCommands from './uniteCommands';
7
- export { Command, Duplicate, Erase, SerializableCommand, invertCommand, uniteCommands, };
@@ -1,23 +0,0 @@
1
- import Rect2 from '../math/Rect2';
2
- export interface CommandLocalization {
3
- movedLeft: string;
4
- movedUp: string;
5
- movedDown: string;
6
- movedRight: string;
7
- rotatedBy: (degrees: number) => string;
8
- zoomedOut: string;
9
- zoomedIn: string;
10
- erasedNoElements: string;
11
- duplicatedNoElements: string;
12
- elements: string;
13
- updatedViewport: string;
14
- transformedElements: (elemCount: number) => string;
15
- resizeOutputCommand: (newSize: Rect2) => string;
16
- addElementAction: (elemDescription: string) => string;
17
- eraseAction: (elemDescription: string, numElems: number) => string;
18
- duplicateAction: (elemDescription: string, count: number) => string;
19
- inverseOf: (actionDescription: string) => string;
20
- unionOf: (actionDescription: string, actionCount: number) => string;
21
- selectedElements: (count: number) => string;
22
- }
23
- export declare const defaultCommandLocalization: CommandLocalization;
@@ -1,21 +0,0 @@
1
- export const defaultCommandLocalization = {
2
- updatedViewport: 'Transformed Viewport',
3
- transformedElements: (elemCount) => `Transformed ${elemCount} element${elemCount === 1 ? '' : 's'}`,
4
- resizeOutputCommand: (newSize) => `Resized image to ${newSize.w}x${newSize.h}`,
5
- addElementAction: (componentDescription) => `Added ${componentDescription}`,
6
- eraseAction: (componentDescription, numElems) => `Erased ${numElems} ${componentDescription}`,
7
- duplicateAction: (componentDescription, numElems) => `Duplicated ${numElems} ${componentDescription}`,
8
- unionOf: (actionDescription, actionCount) => `Union: ${actionCount} ${actionDescription}`,
9
- inverseOf: (actionDescription) => `Inverse of ${actionDescription}`,
10
- elements: 'Elements',
11
- erasedNoElements: 'Erased nothing',
12
- duplicatedNoElements: 'Duplicated nothing',
13
- rotatedBy: (degrees) => `Rotated by ${Math.abs(degrees)} degrees ${degrees < 0 ? 'clockwise' : 'counter-clockwise'}`,
14
- movedLeft: 'Moved left',
15
- movedUp: 'Moved up',
16
- movedDown: 'Moved down',
17
- movedRight: 'Moved right',
18
- zoomedOut: 'Zoomed out',
19
- zoomedIn: 'Zoomed in',
20
- selectedElements: (count) => `Selected ${count} element${count === 1 ? '' : 's'}`,
21
- };
@@ -1,4 +0,0 @@
1
- import Command from './Command';
2
- import SerializableCommand from './SerializableCommand';
3
- declare const uniteCommands: <T extends Command>(commands: T[], applyChunkSize?: number) => T extends SerializableCommand ? SerializableCommand : Command;
4
- export default uniteCommands;
@@ -1,116 +0,0 @@
1
- import Command from './Command';
2
- import SerializableCommand from './SerializableCommand';
3
- class NonSerializableUnion extends Command {
4
- constructor(commands, applyChunkSize) {
5
- super();
6
- this.commands = commands;
7
- this.applyChunkSize = applyChunkSize;
8
- }
9
- static waitForAll(commands) {
10
- // If any are Promises...
11
- if (commands.some(command => command && command['then'])) {
12
- console.log('waiting...');
13
- // Wait for all commands to finish.
14
- return Promise.all(commands)
15
- // Ensure we return a Promise<void> and not a Promise<void[]>
16
- .then(() => { });
17
- }
18
- return;
19
- }
20
- apply(editor) {
21
- if (this.applyChunkSize === undefined) {
22
- const results = this.commands.map(cmd => cmd.apply(editor));
23
- return NonSerializableUnion.waitForAll(results);
24
- }
25
- else {
26
- return editor.asyncApplyCommands(this.commands, this.applyChunkSize);
27
- }
28
- }
29
- unapply(editor) {
30
- const commands = [...this.commands];
31
- commands.reverse();
32
- if (this.applyChunkSize === undefined) {
33
- const results = commands.map(cmd => cmd.unapply(editor));
34
- return NonSerializableUnion.waitForAll(results);
35
- }
36
- else {
37
- return editor.asyncUnapplyCommands(commands, this.applyChunkSize, false);
38
- }
39
- }
40
- description(editor, localizationTable) {
41
- const descriptions = [];
42
- let lastDescription = null;
43
- let duplicateDescriptionCount = 0;
44
- for (const part of this.commands) {
45
- const description = part.description(editor, localizationTable);
46
- if (description !== lastDescription && lastDescription !== null) {
47
- descriptions.push(localizationTable.unionOf(lastDescription, duplicateDescriptionCount));
48
- lastDescription = null;
49
- duplicateDescriptionCount = 0;
50
- }
51
- duplicateDescriptionCount++;
52
- lastDescription !== null && lastDescription !== void 0 ? lastDescription : (lastDescription = description);
53
- }
54
- if (duplicateDescriptionCount > 1) {
55
- descriptions.push(localizationTable.unionOf(lastDescription, duplicateDescriptionCount));
56
- }
57
- else if (duplicateDescriptionCount === 1) {
58
- descriptions.push(lastDescription);
59
- }
60
- return descriptions.join(', ');
61
- }
62
- }
63
- class SerializableUnion extends SerializableCommand {
64
- constructor(commands, applyChunkSize) {
65
- super('union');
66
- this.commands = commands;
67
- this.applyChunkSize = applyChunkSize;
68
- this.nonserializableCommand = new NonSerializableUnion(commands, applyChunkSize);
69
- }
70
- serializeToJSON() {
71
- return {
72
- applyChunkSize: this.applyChunkSize,
73
- data: this.commands.map(command => command.serialize()),
74
- };
75
- }
76
- apply(editor) {
77
- return this.nonserializableCommand.apply(editor);
78
- }
79
- unapply(editor) {
80
- return this.nonserializableCommand.unapply(editor);
81
- }
82
- description(editor, localizationTable) {
83
- return this.nonserializableCommand.description(editor, localizationTable);
84
- }
85
- }
86
- const uniteCommands = (commands, applyChunkSize) => {
87
- let allSerializable = true;
88
- for (const command of commands) {
89
- if (!(command instanceof SerializableCommand)) {
90
- allSerializable = false;
91
- break;
92
- }
93
- }
94
- if (!allSerializable) {
95
- return new NonSerializableUnion(commands, applyChunkSize);
96
- }
97
- else {
98
- const castedCommands = commands;
99
- return new SerializableUnion(castedCommands, applyChunkSize);
100
- }
101
- };
102
- SerializableCommand.register('union', (data, editor) => {
103
- if (typeof data.data.length !== 'number') {
104
- throw new Error('Unions of commands must serialize to lists of serialization data.');
105
- }
106
- const applyChunkSize = data.applyChunkSize;
107
- if (typeof applyChunkSize !== 'number' && applyChunkSize !== undefined) {
108
- throw new Error('serialized applyChunkSize is neither undefined nor a number.');
109
- }
110
- const commands = [];
111
- for (const part of data.data) {
112
- commands.push(SerializableCommand.deserialize(part, editor));
113
- }
114
- return uniteCommands(commands, applyChunkSize);
115
- });
116
- export default uniteCommands;
@@ -1,73 +0,0 @@
1
- import SerializableCommand from '../commands/SerializableCommand';
2
- import EditorImage from '../EditorImage';
3
- import LineSegment2 from '../math/LineSegment2';
4
- import Mat33 from '../math/Mat33';
5
- import Rect2 from '../math/Rect2';
6
- import AbstractRenderer from '../rendering/renderers/AbstractRenderer';
7
- import { ImageComponentLocalization } from './localization';
8
- export type LoadSaveData = (string[] | Record<symbol, string | number>);
9
- export type LoadSaveDataTable = Record<string, Array<LoadSaveData>>;
10
- export type DeserializeCallback = (data: string) => AbstractComponent;
11
- /**
12
- * A base class for everything that can be added to an {@link EditorImage}.
13
- */
14
- export default abstract class AbstractComponent {
15
- private readonly componentKind;
16
- protected lastChangedTime: number;
17
- protected abstract contentBBox: Rect2;
18
- private zIndex;
19
- private id;
20
- private static zIndexCounter;
21
- protected constructor(componentKind: string, initialZIndex?: number);
22
- getId(): string;
23
- private static deserializationCallbacks;
24
- static registerComponent(componentKind: string, deserialize: DeserializeCallback | null): void;
25
- private loadSaveData;
26
- /**
27
- * Attach data that can be used while exporting the component (e.g. to SVG).
28
- *
29
- * This is intended for use by a {@link ImageLoader}.
30
- */
31
- attachLoadSaveData(key: string, data: LoadSaveData): void;
32
- /** See {@link attachLoadSaveData} */
33
- getLoadSaveData(): LoadSaveDataTable;
34
- getZIndex(): number;
35
- /** @returns the bounding box of */
36
- getBBox(): Rect2;
37
- /** Called when this component is added to the given image. */
38
- onAddToImage(_image: EditorImage): void;
39
- onRemoveFromImage(): void;
40
- abstract render(canvas: AbstractRenderer, visibleRect?: Rect2): void;
41
- /** @return true if `lineSegment` intersects this component. */
42
- abstract intersects(lineSegment: LineSegment2): boolean;
43
- /**
44
- * @returns true if this component intersects `rect` -- it is entirely contained
45
- * within the rectangle or one of the rectangle's edges intersects this component.
46
- */
47
- intersectsRect(rect: Rect2): boolean;
48
- protected abstract serializeToJSON(): any[] | Record<string, any> | number | string | null;
49
- protected abstract applyTransformation(affineTransfm: Mat33): void;
50
- transformBy(affineTransfm: Mat33): SerializableCommand;
51
- setZIndex(newZIndex: number): SerializableCommand;
52
- isSelectable(): boolean;
53
- isBackground(): boolean;
54
- getProportionalRenderingTime(): number;
55
- private static transformElementCommandId;
56
- private static TransformElementCommand;
57
- /**
58
- * @return a description that could be read by a screen reader
59
- * (e.g. when adding/erasing the component)
60
- */
61
- abstract description(localizationTable: ImageComponentLocalization): string;
62
- protected abstract createClone(): AbstractComponent;
63
- clone(): AbstractComponent;
64
- serialize(): {
65
- name: string;
66
- zIndex: number;
67
- id: string;
68
- loadSaveData: LoadSaveDataTable;
69
- data: string | number | any[] | Record<string, any>;
70
- };
71
- private static isNotDeserializable;
72
- static deserialize(json: string | any): AbstractComponent;
73
- }
@@ -1,252 +0,0 @@
1
- var _a;
2
- import SerializableCommand from '../commands/SerializableCommand';
3
- import EditorImage from '../EditorImage';
4
- import Mat33 from '../math/Mat33';
5
- import UnresolvedSerializableCommand from '../commands/UnresolvedCommand';
6
- /**
7
- * A base class for everything that can be added to an {@link EditorImage}.
8
- */
9
- export default class AbstractComponent {
10
- constructor(
11
- // A unique identifier for the type of component
12
- componentKind, initialZIndex) {
13
- this.componentKind = componentKind;
14
- // Stores data attached by a loader.
15
- this.loadSaveData = {};
16
- this.lastChangedTime = (new Date()).getTime();
17
- if (initialZIndex !== undefined) {
18
- this.zIndex = initialZIndex;
19
- }
20
- else {
21
- this.zIndex = AbstractComponent.zIndexCounter++;
22
- }
23
- // Create a unique ID.
24
- this.id = `${new Date().getTime()}-${Math.random()}`;
25
- if (AbstractComponent.deserializationCallbacks[componentKind] === undefined) {
26
- throw new Error(`Component ${componentKind} has not been registered using AbstractComponent.registerComponent`);
27
- }
28
- }
29
- // Returns a unique ID for this element.
30
- // @see { @link lib!EditorImage.lookupElement }
31
- getId() {
32
- return this.id;
33
- }
34
- // Store the deserialization callback (or lack of it) for [componentKind].
35
- // If components are registered multiple times (as may be done in automated tests),
36
- // the most recent deserialization callback is used.
37
- static registerComponent(componentKind, deserialize) {
38
- this.deserializationCallbacks[componentKind] = deserialize !== null && deserialize !== void 0 ? deserialize : null;
39
- }
40
- /**
41
- * Attach data that can be used while exporting the component (e.g. to SVG).
42
- *
43
- * This is intended for use by a {@link ImageLoader}.
44
- */
45
- attachLoadSaveData(key, data) {
46
- if (!this.loadSaveData[key]) {
47
- this.loadSaveData[key] = [];
48
- }
49
- this.loadSaveData[key].push(data);
50
- }
51
- /** See {@link attachLoadSaveData} */
52
- getLoadSaveData() {
53
- return this.loadSaveData;
54
- }
55
- getZIndex() {
56
- return this.zIndex;
57
- }
58
- /** @returns the bounding box of */
59
- getBBox() {
60
- return this.contentBBox;
61
- }
62
- /** Called when this component is added to the given image. */
63
- onAddToImage(_image) { }
64
- onRemoveFromImage() { }
65
- /**
66
- * @returns true if this component intersects `rect` -- it is entirely contained
67
- * within the rectangle or one of the rectangle's edges intersects this component.
68
- */
69
- intersectsRect(rect) {
70
- // If this component intersects rect,
71
- // it is either contained entirely within rect or intersects one of rect's edges.
72
- // If contained within,
73
- if (rect.containsRect(this.getBBox())) {
74
- return true;
75
- }
76
- // Calculated bounding boxes can be slightly larger than their actual contents' bounding box.
77
- // As such, test with more lines than just the rect's edges.
78
- const testLines = [];
79
- for (const subregion of rect.divideIntoGrid(2, 2)) {
80
- testLines.push(...subregion.getEdges());
81
- }
82
- return testLines.some(edge => this.intersects(edge));
83
- }
84
- // Returns a command that, when applied, transforms this by [affineTransfm] and
85
- // updates the editor.
86
- transformBy(affineTransfm) {
87
- return new AbstractComponent.TransformElementCommand(affineTransfm, this.getId(), this);
88
- }
89
- // Returns a command that updates this component's z-index.
90
- setZIndex(newZIndex) {
91
- return new AbstractComponent.TransformElementCommand(Mat33.identity, this.getId(), this, newZIndex, this.getZIndex());
92
- }
93
- // @returns true iff this component can be selected (e.g. by the selection tool.)
94
- isSelectable() {
95
- return true;
96
- }
97
- // @returns true iff this component should be added to the background, rather than the
98
- // foreground of the image.
99
- isBackground() {
100
- return false;
101
- }
102
- // @returns an approximation of the proportional time it takes to render this component.
103
- // This is intended to be a rough estimate, but, for example, a stroke with two points sould have
104
- // a renderingWeight approximately twice that of a stroke with one point.
105
- getProportionalRenderingTime() {
106
- return 1;
107
- }
108
- // Returns a copy of this component.
109
- clone() {
110
- const clone = this.createClone();
111
- for (const attachmentKey in this.loadSaveData) {
112
- for (const val of this.loadSaveData[attachmentKey]) {
113
- clone.attachLoadSaveData(attachmentKey, val);
114
- }
115
- }
116
- return clone;
117
- }
118
- // Convert the component to an object that can be passed to
119
- // `JSON.stringify`.
120
- //
121
- // Do not rely on the output of this function to take a particular form —
122
- // this function's output can change form without a major version increase.
123
- serialize() {
124
- const data = this.serializeToJSON();
125
- if (data === null) {
126
- throw new Error(`${this} cannot be serialized.`);
127
- }
128
- return {
129
- name: this.componentKind,
130
- zIndex: this.zIndex,
131
- id: this.id,
132
- loadSaveData: this.loadSaveData,
133
- data,
134
- };
135
- }
136
- // Returns true if `data` is not deserializable. May return false even if [data]
137
- // is not deserializable.
138
- static isNotDeserializable(json) {
139
- if (typeof json === 'string') {
140
- json = JSON.parse(json);
141
- }
142
- if (typeof json !== 'object') {
143
- return true;
144
- }
145
- if (!this.deserializationCallbacks[json === null || json === void 0 ? void 0 : json.name]) {
146
- return true;
147
- }
148
- if (!json.data) {
149
- return true;
150
- }
151
- return false;
152
- }
153
- // Convert a string or an object produced by `JSON.parse` into an `AbstractComponent`.
154
- static deserialize(json) {
155
- if (typeof json === 'string') {
156
- json = JSON.parse(json);
157
- }
158
- if (AbstractComponent.isNotDeserializable(json)) {
159
- throw new Error(`Element with data ${json} cannot be deserialized.`);
160
- }
161
- const instance = this.deserializationCallbacks[json.name](json.data);
162
- instance.zIndex = json.zIndex;
163
- instance.id = json.id;
164
- // TODO: What should we do with json.loadSaveData?
165
- // If we attach it to [instance], we create a potential security risk — loadSaveData
166
- // is often used to store unrecognised attributes so they can be preserved on output.
167
- // ...but what if we're deserializing data sent across the network?
168
- return instance;
169
- }
170
- }
171
- // Topmost z-index
172
- AbstractComponent.zIndexCounter = 0;
173
- AbstractComponent.deserializationCallbacks = {};
174
- AbstractComponent.transformElementCommandId = 'transform-element';
175
- AbstractComponent.TransformElementCommand = (_a = class extends UnresolvedSerializableCommand {
176
- // Construct a new TransformElementCommand. `component`, while optional, should
177
- // be provided if available. If not provided, it will be fetched from the editor's
178
- // document when the command is applied.
179
- constructor(affineTransfm, componentID, component, targetZIndex, origZIndex) {
180
- super(AbstractComponent.transformElementCommandId, componentID, component);
181
- this.affineTransfm = affineTransfm;
182
- this.origZIndex = origZIndex;
183
- this.targetZIndex = targetZIndex !== null && targetZIndex !== void 0 ? targetZIndex : AbstractComponent.zIndexCounter++;
184
- // Ensure that we keep drawing on top even after changing the z-index.
185
- if (this.targetZIndex >= AbstractComponent.zIndexCounter) {
186
- AbstractComponent.zIndexCounter = this.targetZIndex + 1;
187
- }
188
- if (component && origZIndex === undefined) {
189
- this.origZIndex = component.getZIndex();
190
- }
191
- }
192
- resolveComponent(image) {
193
- var _a;
194
- if (this.component) {
195
- return;
196
- }
197
- super.resolveComponent(image);
198
- (_a = this.origZIndex) !== null && _a !== void 0 ? _a : (this.origZIndex = this.component.getZIndex());
199
- }
200
- updateTransform(editor, newTransfm) {
201
- if (!this.component) {
202
- throw new Error('this.component is undefined or null!');
203
- }
204
- // Any parent should have only one direct child.
205
- const parent = editor.image.findParent(this.component);
206
- let hadParent = false;
207
- if (parent) {
208
- parent.remove();
209
- hadParent = true;
210
- }
211
- this.component.applyTransformation(newTransfm);
212
- this.component.lastChangedTime = (new Date()).getTime();
213
- // Add the element back to the document.
214
- if (hadParent) {
215
- EditorImage.addElement(this.component).apply(editor);
216
- }
217
- }
218
- apply(editor) {
219
- this.resolveComponent(editor.image);
220
- this.component.zIndex = this.targetZIndex;
221
- this.updateTransform(editor, this.affineTransfm);
222
- editor.queueRerender();
223
- }
224
- unapply(editor) {
225
- this.resolveComponent(editor.image);
226
- this.component.zIndex = this.origZIndex;
227
- this.updateTransform(editor, this.affineTransfm.inverse());
228
- editor.queueRerender();
229
- }
230
- description(_editor, localizationTable) {
231
- return localizationTable.transformedElements(1);
232
- }
233
- serializeToJSON() {
234
- return {
235
- id: this.componentID,
236
- transfm: this.affineTransfm.toArray(),
237
- targetZIndex: this.targetZIndex,
238
- origZIndex: this.origZIndex,
239
- };
240
- }
241
- },
242
- (() => {
243
- SerializableCommand.register(AbstractComponent.transformElementCommandId, (json, editor) => {
244
- var _a, _b;
245
- const elem = (_a = editor.image.lookupElement(json.id)) !== null && _a !== void 0 ? _a : undefined;
246
- const transform = new Mat33(...json.transfm);
247
- const targetZIndex = json.targetZIndex;
248
- const origZIndex = (_b = json.origZIndex) !== null && _b !== void 0 ? _b : undefined;
249
- return new AbstractComponent.TransformElementCommand(transform, json.id, elem, targetZIndex, origZIndex);
250
- });
251
- })(),
252
- _a);
@@ -1,42 +0,0 @@
1
- import Color4 from '../Color4';
2
- import Editor from '../Editor';
3
- import EditorImage from '../EditorImage';
4
- import SerializableCommand from '../commands/SerializableCommand';
5
- import LineSegment2 from '../math/LineSegment2';
6
- import Mat33 from '../math/Mat33';
7
- import Rect2 from '../math/Rect2';
8
- import AbstractRenderer from '../rendering/renderers/AbstractRenderer';
9
- import AbstractComponent from './AbstractComponent';
10
- import { ImageComponentLocalization } from './localization';
11
- import RestyleableComponent, { ComponentStyle } from './RestylableComponent';
12
- export declare enum BackgroundType {
13
- SolidColor = 0,
14
- None = 1
15
- }
16
- export declare const imageBackgroundCSSClassName = "js-draw-image-background";
17
- export default class ImageBackground extends AbstractComponent implements RestyleableComponent {
18
- private backgroundType;
19
- private mainColor;
20
- protected contentBBox: Rect2;
21
- private viewportSizeChangeListener;
22
- readonly isRestylableComponent: true;
23
- constructor(backgroundType: BackgroundType, mainColor: Color4);
24
- getStyle(): ComponentStyle;
25
- updateStyle(style: ComponentStyle): SerializableCommand;
26
- forceStyle(style: ComponentStyle, editor: Editor | null): void;
27
- onAddToImage(image: EditorImage): void;
28
- onRemoveFromImage(): void;
29
- private recomputeBBox;
30
- render(canvas: AbstractRenderer, visibleRect?: Rect2): void;
31
- intersects(lineSegment: LineSegment2): boolean;
32
- isSelectable(): boolean;
33
- isBackground(): boolean;
34
- protected serializeToJSON(): {
35
- mainColor: string;
36
- backgroundType: BackgroundType;
37
- };
38
- protected applyTransformation(_affineTransfm: Mat33): void;
39
- description(localizationTable: ImageComponentLocalization): string;
40
- protected createClone(): AbstractComponent;
41
- static deserializeFromJSON(json: any): ImageBackground;
42
- }
@@ -1,139 +0,0 @@
1
- import Color4 from '../Color4';
2
- import { EditorImageEventType } from '../EditorImage';
3
- import Rect2 from '../math/Rect2';
4
- import AbstractComponent from './AbstractComponent';
5
- import { createRestyleComponentCommand } from './RestylableComponent';
6
- export var BackgroundType;
7
- (function (BackgroundType) {
8
- BackgroundType[BackgroundType["SolidColor"] = 0] = "SolidColor";
9
- BackgroundType[BackgroundType["None"] = 1] = "None";
10
- })(BackgroundType || (BackgroundType = {}));
11
- export const imageBackgroundCSSClassName = 'js-draw-image-background';
12
- // Represents the background of an image in the editor.
13
- export default class ImageBackground extends AbstractComponent {
14
- constructor(backgroundType, mainColor) {
15
- super('image-background', 0);
16
- this.backgroundType = backgroundType;
17
- this.mainColor = mainColor;
18
- this.viewportSizeChangeListener = null;
19
- // eslint-disable-next-line @typescript-eslint/prefer-as-const
20
- this.isRestylableComponent = true;
21
- this.contentBBox = Rect2.empty;
22
- }
23
- getStyle() {
24
- let color = this.mainColor;
25
- if (this.backgroundType === BackgroundType.None) {
26
- color = undefined;
27
- }
28
- return {
29
- color,
30
- };
31
- }
32
- updateStyle(style) {
33
- return createRestyleComponentCommand(this.getStyle(), style, this);
34
- }
35
- // @internal
36
- forceStyle(style, editor) {
37
- const fill = style.color;
38
- if (!fill) {
39
- return;
40
- }
41
- this.mainColor = fill;
42
- if (fill.eq(Color4.transparent)) {
43
- this.backgroundType = BackgroundType.None;
44
- }
45
- else {
46
- this.backgroundType = BackgroundType.SolidColor;
47
- }
48
- if (editor) {
49
- editor.image.queueRerenderOf(this);
50
- editor.queueRerender();
51
- }
52
- }
53
- onAddToImage(image) {
54
- if (this.viewportSizeChangeListener) {
55
- console.warn('onAddToImage called when background is already in an image');
56
- this.onRemoveFromImage();
57
- }
58
- this.viewportSizeChangeListener = image.notifier.on(EditorImageEventType.ExportViewportChanged, () => {
59
- this.recomputeBBox(image);
60
- });
61
- this.recomputeBBox(image);
62
- }
63
- onRemoveFromImage() {
64
- var _a;
65
- (_a = this.viewportSizeChangeListener) === null || _a === void 0 ? void 0 : _a.remove();
66
- this.viewportSizeChangeListener = null;
67
- }
68
- recomputeBBox(image) {
69
- const importExportRect = image.getImportExportViewport().visibleRect;
70
- if (!this.contentBBox.eq(importExportRect)) {
71
- this.contentBBox = importExportRect;
72
- // Re-render this if already added to the EditorImage.
73
- image.queueRerenderOf(this);
74
- }
75
- }
76
- render(canvas, visibleRect) {
77
- if (this.backgroundType === BackgroundType.None) {
78
- return;
79
- }
80
- canvas.startObject(this.contentBBox);
81
- if (this.backgroundType === BackgroundType.SolidColor) {
82
- // If the rectangle for this region contains the visible rect,
83
- // we can fill the entire visible rectangle (which may be more efficient than
84
- // filling the entire region for this.)
85
- if (visibleRect) {
86
- const intersection = visibleRect.intersection(this.contentBBox);
87
- if (intersection) {
88
- canvas.fillRect(intersection, this.mainColor);
89
- }
90
- }
91
- else {
92
- canvas.fillRect(this.contentBBox, this.mainColor);
93
- }
94
- }
95
- canvas.endObject(this.getLoadSaveData(), [imageBackgroundCSSClassName]);
96
- }
97
- intersects(lineSegment) {
98
- return this.contentBBox.getEdges().some(edge => edge.intersects(lineSegment));
99
- }
100
- isSelectable() {
101
- return false;
102
- }
103
- isBackground() {
104
- return true;
105
- }
106
- serializeToJSON() {
107
- return {
108
- mainColor: this.mainColor.toHexString(),
109
- backgroundType: this.backgroundType,
110
- };
111
- }
112
- applyTransformation(_affineTransfm) {
113
- // Do nothing — it doesn't make sense to transform the background.
114
- }
115
- description(localizationTable) {
116
- if (this.backgroundType === BackgroundType.SolidColor) {
117
- return localizationTable.filledBackgroundWithColor(this.mainColor.toString());
118
- }
119
- else {
120
- return localizationTable.emptyBackground;
121
- }
122
- }
123
- createClone() {
124
- return new ImageBackground(this.backgroundType, this.mainColor);
125
- }
126
- // @internal
127
- static deserializeFromJSON(json) {
128
- if (typeof json === 'string') {
129
- json = JSON.parse(json);
130
- }
131
- if (typeof json.mainColor !== 'string') {
132
- throw new Error('Error deserializing — mainColor must be of type string.');
133
- }
134
- const backgroundType = json.backgroundType === BackgroundType.SolidColor ? BackgroundType.SolidColor : BackgroundType.None;
135
- const mainColor = Color4.fromHex(json.mainColor);
136
- return new ImageBackground(backgroundType, mainColor);
137
- }
138
- }
139
- AbstractComponent.registerComponent('image-background', ImageBackground.deserializeFromJSON);