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,11 +0,0 @@
1
- import { ImageNode } from '../../EditorImage';
2
- import Viewport from '../../Viewport';
3
- import AbstractRenderer from '../renderers/AbstractRenderer';
4
- import { CacheProps } from './types';
5
- export default class RenderingCache {
6
- private sharedState;
7
- private recordManager;
8
- private rootNode;
9
- constructor(cacheProps: CacheProps);
10
- render(screenRenderer: AbstractRenderer, image: ImageNode, viewport: Viewport): void;
11
- }
@@ -1,45 +0,0 @@
1
- import Rect2 from '../../math/Rect2';
2
- import RenderingCacheNode from './RenderingCacheNode';
3
- import { CacheRecordManager } from './CacheRecordManager';
4
- export default class RenderingCache {
5
- constructor(cacheProps) {
6
- this.recordManager = new CacheRecordManager(cacheProps);
7
- this.sharedState = {
8
- props: cacheProps,
9
- currentRenderingCycle: 0,
10
- recordManager: this.recordManager,
11
- };
12
- this.recordManager.setSharedState(this.sharedState);
13
- }
14
- render(screenRenderer, image, viewport) {
15
- var _a;
16
- const visibleRect = viewport.visibleRect;
17
- this.sharedState.currentRenderingCycle++;
18
- // If we can't use the cache,
19
- if (!this.sharedState.props.isOfCorrectType(screenRenderer)) {
20
- image.render(screenRenderer, visibleRect);
21
- return;
22
- }
23
- if (!this.rootNode) {
24
- // Adjust the node so that it has the correct aspect ratio
25
- const res = this.sharedState.props.blockResolution;
26
- const topLeft = visibleRect.topLeft;
27
- this.rootNode = new RenderingCacheNode(new Rect2(topLeft.x, topLeft.y, res.x, res.y), this.sharedState);
28
- }
29
- while (!this.rootNode.region.containsRect(visibleRect)) {
30
- this.rootNode = this.rootNode.generateParent();
31
- }
32
- this.rootNode = (_a = this.rootNode.smallestChildContaining(visibleRect)) !== null && _a !== void 0 ? _a : this.rootNode;
33
- const visibleLeaves = image.getLeavesIntersectingRegion(viewport.visibleRect, rect => screenRenderer.isTooSmallToRender(rect));
34
- let approxVisibleRenderTime = 0;
35
- for (const leaf of visibleLeaves) {
36
- approxVisibleRenderTime += leaf.getContent().getProportionalRenderingTime();
37
- }
38
- if (approxVisibleRenderTime > this.sharedState.props.minProportionalRenderTimeToUseCache) {
39
- this.rootNode.renderItems(screenRenderer, [image], viewport);
40
- }
41
- else {
42
- image.render(screenRenderer, visibleRect);
43
- }
44
- }
45
- }
@@ -1,29 +0,0 @@
1
- import { ImageNode } from '../../EditorImage';
2
- import Rect2 from '../../math/Rect2';
3
- import Viewport from '../../Viewport';
4
- import AbstractRenderer from '../renderers/AbstractRenderer';
5
- import { CacheState } from './types';
6
- export default class RenderingCacheNode {
7
- readonly region: Rect2;
8
- private readonly cacheState;
9
- private instantiatedChildren;
10
- private parent;
11
- private cachedRenderer;
12
- private renderedIds;
13
- private renderedMaxZIndex;
14
- constructor(region: Rect2, cacheState: CacheState);
15
- generateParent(): RenderingCacheNode;
16
- private generateChildren;
17
- private getChildren;
18
- smallestChildContaining(rect: Rect2): RenderingCacheNode | null;
19
- private renderingWouldBeHighEnoughResolution;
20
- private allChildrenCanRender;
21
- private computeSortedByLeafIds;
22
- private idsOfIntersecting;
23
- private allRenderedIdsIn;
24
- private renderingIsUpToDate;
25
- renderItems(screenRenderer: AbstractRenderer, items: ImageNode[], viewport: Viewport): void;
26
- private isEmpty;
27
- private onRegionDealloc;
28
- private checkRep;
29
- }
@@ -1,320 +0,0 @@
1
- // A cache record with sub-nodes.
2
- import Color4 from '../../Color4';
3
- import { sortLeavesByZIndex } from '../../EditorImage';
4
- import Rect2 from '../../math/Rect2';
5
- // 3x3 divisions for each node.
6
- const cacheDivisionSize = 3;
7
- // True: Show rendering updates.
8
- const debugMode = false;
9
- export default class RenderingCacheNode {
10
- constructor(region, cacheState) {
11
- this.region = region;
12
- this.cacheState = cacheState;
13
- // invariant: instantiatedChildren.length === 9
14
- this.instantiatedChildren = [];
15
- this.parent = null;
16
- this.cachedRenderer = null;
17
- // invariant: sortedInAscendingOrder(renderedIds)
18
- this.renderedIds = [];
19
- this.renderedMaxZIndex = null;
20
- }
21
- // Creates a previous layer of the cache tree and adds this as a child near the
22
- // center of the previous layer's children.
23
- // Returns this' parent if it already exists.
24
- generateParent() {
25
- if (this.parent) {
26
- return this.parent;
27
- }
28
- const parentRegion = Rect2.fromCorners(this.region.topLeft.minus(this.region.size), this.region.bottomRight.plus(this.region.size));
29
- const parent = new RenderingCacheNode(parentRegion, this.cacheState);
30
- parent.generateChildren();
31
- // Ensure the new node is matches the middle child's region.
32
- const checkTolerance = this.region.maxDimension / 100;
33
- const middleChildIdx = (parent.instantiatedChildren.length - 1) / 2;
34
- if (!parent.instantiatedChildren[middleChildIdx].region.eq(this.region, checkTolerance)) {
35
- console.error(parent.instantiatedChildren[middleChildIdx].region, '≠', this.region);
36
- throw new Error('Logic error: [this] is not contained within its parent\'s center child');
37
- }
38
- // Replace the middle child
39
- parent.instantiatedChildren[middleChildIdx] = this;
40
- this.parent = parent;
41
- return parent;
42
- }
43
- // Generates children, if missing.
44
- generateChildren() {
45
- if (this.instantiatedChildren.length === 0) {
46
- const childRects = this.region.divideIntoGrid(cacheDivisionSize, cacheDivisionSize);
47
- if (this.region.size.x === 0 || this.region.size.y === 0) {
48
- console.warn('Cache element has zero size! Not generating children.');
49
- return;
50
- }
51
- for (const rect of childRects) {
52
- const child = new RenderingCacheNode(rect, this.cacheState);
53
- child.parent = this;
54
- this.instantiatedChildren.push(child);
55
- }
56
- }
57
- this.checkRep();
58
- }
59
- // Returns CacheNodes directly contained within this.
60
- getChildren() {
61
- this.checkRep();
62
- this.generateChildren();
63
- return this.instantiatedChildren;
64
- }
65
- smallestChildContaining(rect) {
66
- var _a;
67
- const largerThanChildren = rect.maxDimension > this.region.maxDimension / cacheDivisionSize;
68
- if (!this.region.containsRect(rect) || largerThanChildren) {
69
- return null;
70
- }
71
- for (const child of this.getChildren()) {
72
- if (child.region.containsRect(rect)) {
73
- return (_a = child.smallestChildContaining(rect)) !== null && _a !== void 0 ? _a : child;
74
- }
75
- }
76
- return null;
77
- }
78
- // => [true] iff [this] can be rendered without too much scaling
79
- renderingWouldBeHighEnoughResolution(viewport) {
80
- // Determine how 1px in this corresponds to 1px on the canvas.
81
- // this.region.w is in canvas units. Thus,
82
- const sizeOfThisPixelOnCanvas = this.region.w / this.cacheState.props.blockResolution.x;
83
- const sizeOfThisPixelOnScreen = viewport.getScaleFactor() * sizeOfThisPixelOnCanvas;
84
- if (sizeOfThisPixelOnScreen > this.cacheState.props.maxScale) {
85
- return false;
86
- }
87
- return true;
88
- }
89
- // => [true] if all children of this can be rendered from their caches.
90
- allChildrenCanRender(viewport, leavesSortedById) {
91
- if (this.instantiatedChildren.length === 0) {
92
- return false;
93
- }
94
- for (const child of this.instantiatedChildren) {
95
- if (!child.region.intersects(viewport.visibleRect)) {
96
- continue;
97
- }
98
- if (!child.renderingIsUpToDate(this.idsOfIntersecting(leavesSortedById))) {
99
- return false;
100
- }
101
- }
102
- return true;
103
- }
104
- computeSortedByLeafIds(leaves) {
105
- const ids = leaves.slice();
106
- ids.sort((a, b) => a.getId() - b.getId());
107
- return ids;
108
- }
109
- // Returns a list of the ids of the nodes intersecting this
110
- idsOfIntersecting(nodes) {
111
- const result = [];
112
- for (const node of nodes) {
113
- if (node.getBBox().intersects(this.region)) {
114
- result.push(node.getId());
115
- }
116
- }
117
- return result;
118
- }
119
- // Returns true iff all elems of this.renderedIds are in sortedIds.
120
- // sortedIds should be sorted by z-index (or some other order, so long as they are
121
- // sorted by the same thing as this.renderedIds.)
122
- allRenderedIdsIn(sortedIds) {
123
- if (this.renderedIds.length > sortedIds.length) {
124
- return false;
125
- }
126
- for (let i = 0; i < this.renderedIds.length; i++) {
127
- if (sortedIds[i] !== this.renderedIds[i]) {
128
- return false;
129
- }
130
- }
131
- return true;
132
- }
133
- renderingIsUpToDate(sortedIds) {
134
- if (this.cachedRenderer === null || sortedIds.length !== this.renderedIds.length) {
135
- return false;
136
- }
137
- return this.allRenderedIdsIn(sortedIds);
138
- }
139
- // Render all [items] within [viewport]
140
- renderItems(screenRenderer, items, viewport) {
141
- var _a, _b;
142
- if (!viewport.visibleRect.intersects(this.region)
143
- || items.length === 0) {
144
- return;
145
- }
146
- const newItems = [];
147
- // Divide [items] until nodes are leaves or smaller than this
148
- for (const item of items) {
149
- const bbox = item.getBBox();
150
- if (!bbox.intersects(this.region)) {
151
- continue;
152
- }
153
- if (bbox.maxDimension >= this.region.maxDimension) {
154
- newItems.push(...item.getChildrenOrSelfIntersectingRegion(this.region));
155
- }
156
- else {
157
- newItems.push(item);
158
- }
159
- }
160
- items = newItems;
161
- // Can we cache at all?
162
- if (!this.cacheState.props.isOfCorrectType(screenRenderer)) {
163
- items.forEach(item => item.render(screenRenderer, viewport.visibleRect));
164
- return;
165
- }
166
- if (debugMode) {
167
- screenRenderer.drawRect(this.region, 0.5 * viewport.getSizeOfPixelOnCanvas(), { fill: Color4.yellow });
168
- }
169
- // Could we render direclty from [this] or do we need to recurse?
170
- const couldRender = this.renderingWouldBeHighEnoughResolution(viewport);
171
- if (!couldRender) {
172
- for (const child of this.getChildren()) {
173
- child.renderItems(screenRenderer, items.filter(item => {
174
- return item.getBBox().intersects(child.region);
175
- }), viewport);
176
- }
177
- }
178
- else {
179
- // Determine whether we already have rendered the items
180
- const tooSmallToRender = (rect) => rect.w / this.region.w < 1 / this.cacheState.props.blockResolution.x;
181
- const leaves = [];
182
- for (const item of items) {
183
- leaves.push(...item.getLeavesIntersectingRegion(this.region, tooSmallToRender));
184
- }
185
- sortLeavesByZIndex(leaves);
186
- const leavesByIds = this.computeSortedByLeafIds(leaves);
187
- // No intersecting leaves? No need to render
188
- if (leavesByIds.length === 0) {
189
- return;
190
- }
191
- const leafIds = leavesByIds.map(leaf => leaf.getId());
192
- let thisRenderer;
193
- if (!this.renderingIsUpToDate(leafIds)) {
194
- if (this.allChildrenCanRender(viewport, leavesByIds)) {
195
- for (const child of this.getChildren()) {
196
- child.renderItems(screenRenderer, items, viewport);
197
- }
198
- return;
199
- }
200
- let leafApproxRenderTime = 0;
201
- for (const leaf of leavesByIds) {
202
- leafApproxRenderTime += leaf.getContent().getProportionalRenderingTime();
203
- }
204
- // Is it worth it to render the items?
205
- if (leafApproxRenderTime > this.cacheState.props.minProportionalRenderTimePerCache) {
206
- let fullRerenderNeeded = true;
207
- if (!this.cachedRenderer) {
208
- this.cachedRenderer = this.cacheState.recordManager.allocCanvas(this.region, () => this.onRegionDealloc());
209
- }
210
- else if (leavesByIds.length > this.renderedIds.length && this.allRenderedIdsIn(leafIds) && this.renderedMaxZIndex !== null) {
211
- // We often don't need to do a full re-render even if something's changed.
212
- // Check whether we can just draw on top of the existing cache.
213
- const newLeaves = [];
214
- let minNewZIndex = null;
215
- for (let i = 0; i < leavesByIds.length; i++) {
216
- const leaf = leavesByIds[i];
217
- const content = leaf.getContent();
218
- const zIndex = content.getZIndex();
219
- if (i >= this.renderedIds.length || leaf.getId() !== this.renderedIds[i]) {
220
- newLeaves.push(leaf);
221
- if (minNewZIndex === null || zIndex < minNewZIndex) {
222
- minNewZIndex = zIndex;
223
- }
224
- }
225
- }
226
- if (minNewZIndex !== null && minNewZIndex > this.renderedMaxZIndex) {
227
- fullRerenderNeeded = false;
228
- thisRenderer = this.cachedRenderer.startRender();
229
- // Looping is faster than re-sorting.
230
- for (let i = 0; i < leaves.length; i++) {
231
- const leaf = leaves[i];
232
- const zIndex = leaf.getContent().getZIndex();
233
- if (zIndex > this.renderedMaxZIndex) {
234
- leaf.render(thisRenderer, this.region);
235
- this.renderedMaxZIndex = zIndex;
236
- }
237
- }
238
- if (debugMode) {
239
- screenRenderer.drawRect(this.region, viewport.getSizeOfPixelOnCanvas(), { fill: Color4.clay });
240
- }
241
- }
242
- }
243
- else if (debugMode) {
244
- console.log('Decided on a full re-render. Reason: At least one of the following is false:', '\n leafIds.length > this.renderedIds.length: ', leafIds.length > this.renderedIds.length, '\n this.allRenderedIdsIn(leafIds): ', this.allRenderedIdsIn(leafIds), '\n this.renderedMaxZIndex !== null: ', this.renderedMaxZIndex !== null, '\n\nthis.rerenderedIds: ', this.renderedIds, ', leafIds: ', leafIds);
245
- }
246
- if (fullRerenderNeeded) {
247
- thisRenderer = this.cachedRenderer.startRender();
248
- thisRenderer.clear();
249
- this.renderedMaxZIndex = null;
250
- for (const leaf of leaves) {
251
- const content = leaf.getContent();
252
- (_a = this.renderedMaxZIndex) !== null && _a !== void 0 ? _a : (this.renderedMaxZIndex = content.getZIndex());
253
- this.renderedMaxZIndex = Math.max(this.renderedMaxZIndex, content.getZIndex());
254
- leaf.render(thisRenderer, this.region);
255
- }
256
- if (debugMode) {
257
- screenRenderer.drawRect(this.region, viewport.getSizeOfPixelOnCanvas(), { fill: Color4.red });
258
- }
259
- }
260
- this.renderedIds = leafIds;
261
- }
262
- else {
263
- (_b = this.cachedRenderer) === null || _b === void 0 ? void 0 : _b.dealloc();
264
- // Slightly increase the clip region to prevent seams.
265
- // Divide by two because grownBy expands the rectangle on all sides.
266
- const pixelSize = viewport.getSizeOfPixelOnCanvas();
267
- const expandedRegion = new Rect2(this.region.x, this.region.y, this.region.w + pixelSize, this.region.h + pixelSize);
268
- const clip = true;
269
- screenRenderer.startObject(expandedRegion, clip);
270
- for (const leaf of leaves) {
271
- leaf.render(screenRenderer, this.region.intersection(viewport.visibleRect));
272
- }
273
- screenRenderer.endObject();
274
- }
275
- }
276
- else {
277
- thisRenderer = this.cachedRenderer.startRender();
278
- }
279
- if (thisRenderer) {
280
- const transformMat = this.cachedRenderer.getTransform(this.region).inverse();
281
- screenRenderer.renderFromOtherOfSameType(transformMat, thisRenderer);
282
- }
283
- // Can we clean up this' children? (Are they unused?)
284
- if (this.instantiatedChildren.every(child => child.isEmpty())) {
285
- this.instantiatedChildren = [];
286
- }
287
- }
288
- this.checkRep();
289
- }
290
- // Returns true iff this/its children have no cached state.
291
- isEmpty() {
292
- if (this.cachedRenderer !== null) {
293
- return false;
294
- }
295
- return this.instantiatedChildren.every(child => child.isEmpty());
296
- }
297
- onRegionDealloc() {
298
- this.cachedRenderer = null;
299
- if (this.isEmpty()) {
300
- this.instantiatedChildren = [];
301
- }
302
- }
303
- checkRep() {
304
- if (this.instantiatedChildren.length !== cacheDivisionSize * cacheDivisionSize && this.instantiatedChildren.length !== 0) {
305
- throw new Error(`Repcheck: Wrong number of children. Got ${this.instantiatedChildren.length}`);
306
- }
307
- if (this.renderedIds[1] !== undefined && this.renderedIds[0] >= this.renderedIds[1]) {
308
- console.error(this.renderedIds);
309
- throw new Error('Repcheck: First two ids are not in ascending order!');
310
- }
311
- for (const child of this.instantiatedChildren) {
312
- if (child.parent !== this) {
313
- throw new Error('Children should be linked to their parents!');
314
- }
315
- }
316
- if (this.cachedRenderer && !this.cachedRenderer.isAllocd()) {
317
- throw new Error('this\' cachedRenderer != null, but is dealloc\'d');
318
- }
319
- }
320
- }
@@ -1,9 +0,0 @@
1
- import DummyRenderer from '../renderers/DummyRenderer';
2
- import RenderingCache from './RenderingCache';
3
- import { CacheProps } from './types';
4
- type RenderAllocCallback = (renderer: DummyRenderer) => void;
5
- export declare const createCache: (onRenderAlloc?: RenderAllocCallback, cacheOptions?: Partial<CacheProps>) => {
6
- cache: RenderingCache;
7
- editor: import("../../Editor").Editor;
8
- };
9
- export {};
@@ -1,20 +0,0 @@
1
- import { Vec2 } from '../../math/Vec2';
2
- import DummyRenderer from '../renderers/DummyRenderer';
3
- import createEditor from '../../testing/createEditor';
4
- import RenderingCache from './RenderingCache';
5
- // Override any default test options with [cacheOptions]
6
- export const createCache = (onRenderAlloc, cacheOptions) => {
7
- const editor = createEditor();
8
- const cache = new RenderingCache(Object.assign({ createRenderer() {
9
- const renderer = new DummyRenderer(editor.viewport);
10
- onRenderAlloc === null || onRenderAlloc === void 0 ? void 0 : onRenderAlloc(renderer);
11
- return renderer;
12
- },
13
- isOfCorrectType(renderer) {
14
- return renderer instanceof DummyRenderer;
15
- }, blockResolution: Vec2.of(500, 500), cacheSize: 500 * 10 * 4, maxScale: 2, minProportionalRenderTimePerCache: 0, minProportionalRenderTimeToUseCache: 0 }, cacheOptions));
16
- return {
17
- cache,
18
- editor
19
- };
20
- };
@@ -1,19 +0,0 @@
1
- import { Vec2 } from '../../math/Vec2';
2
- import AbstractRenderer from '../renderers/AbstractRenderer';
3
- import { CacheRecordManager } from './CacheRecordManager';
4
- export type CacheAddress = number;
5
- export type BeforeDeallocCallback = () => void;
6
- export interface CacheProps {
7
- createRenderer(): AbstractRenderer;
8
- isOfCorrectType(renderer: AbstractRenderer): boolean;
9
- blockResolution: Vec2;
10
- cacheSize: number;
11
- maxScale: number;
12
- minProportionalRenderTimePerCache: number;
13
- minProportionalRenderTimeToUseCache: number;
14
- }
15
- export interface CacheState {
16
- currentRenderingCycle: number;
17
- props: CacheProps;
18
- recordManager: CacheRecordManager;
19
- }
@@ -1 +0,0 @@
1
- export {};
@@ -1,5 +0,0 @@
1
- export { default as AbstractRenderer } from './renderers/AbstractRenderer';
2
- export { default as DummyRenderer } from './renderers/DummyRenderer';
3
- export { default as SVGRenderer } from './renderers/SVGRenderer';
4
- export { default as CanvasRenderer } from './renderers/CanvasRenderer';
5
- export { default as Display } from './Display';
@@ -1,5 +0,0 @@
1
- export { default as AbstractRenderer } from './renderers/AbstractRenderer';
2
- export { default as DummyRenderer } from './renderers/DummyRenderer';
3
- export { default as SVGRenderer } from './renderers/SVGRenderer';
4
- export { default as CanvasRenderer } from './renderers/CanvasRenderer';
5
- export { default as Display } from './Display';
@@ -1,10 +0,0 @@
1
- export interface TextRendererLocalization {
2
- pathNodeCount(pathCount: number): string;
3
- textNodeCount(nodeCount: number): string;
4
- imageNodeCount(nodeCount: number): string;
5
- textNode(content: string): string;
6
- unlabeledImageNode: string;
7
- imageNode(label: string): string;
8
- rerenderAsText: string;
9
- }
10
- export declare const defaultTextRendererLocalization: TextRendererLocalization;
@@ -1,9 +0,0 @@
1
- export const defaultTextRendererLocalization = {
2
- pathNodeCount: (count) => `There are ${count} visible path objects.`,
3
- textNodeCount: (count) => `There are ${count} visible text nodes.`,
4
- imageNodeCount: (nodeCount) => `There are ${nodeCount} visible image nodes.`,
5
- textNode: (content) => `Text: ${content}`,
6
- imageNode: (label) => `Image: ${label}`,
7
- unlabeledImageNode: 'Unlabeled image',
8
- rerenderAsText: 'Re-render as text',
9
- };
@@ -1,68 +0,0 @@
1
- import Color4 from '../../Color4';
2
- import { LoadSaveDataTable } from '../../components/AbstractComponent';
3
- import Mat33 from '../../math/Mat33';
4
- import Path, { PathCommand } from '../../math/Path';
5
- import Rect2 from '../../math/Rect2';
6
- import { Point2, Vec2 } from '../../math/Vec2';
7
- import Viewport from '../../Viewport';
8
- import RenderingStyle from '../RenderingStyle';
9
- import TextStyle from '../TextRenderingStyle';
10
- export interface RenderablePathSpec {
11
- startPoint: Point2;
12
- commands: PathCommand[];
13
- style: RenderingStyle;
14
- path?: Path;
15
- }
16
- export interface RenderableImage {
17
- transform: Mat33;
18
- image: HTMLImageElement | HTMLCanvasElement;
19
- base64Url: string;
20
- label?: string;
21
- }
22
- export default abstract class AbstractRenderer {
23
- private viewport;
24
- private selfTransform;
25
- private transformStack;
26
- protected constructor(viewport: Viewport);
27
- protected getViewport(): Viewport;
28
- abstract displaySize(): Vec2;
29
- abstract clear(): void;
30
- protected abstract beginPath(startPoint: Point2): void;
31
- protected abstract endPath(style: RenderingStyle): void;
32
- protected abstract lineTo(point: Point2): void;
33
- protected abstract moveTo(point: Point2): void;
34
- protected abstract traceCubicBezierCurve(p1: Point2, p2: Point2, p3: Point2): void;
35
- protected abstract traceQuadraticBezierCurve(controlPoint: Point2, endPoint: Point2): void;
36
- abstract drawText(text: string, transform: Mat33, style: TextStyle): void;
37
- abstract drawImage(image: RenderableImage): void;
38
- abstract isTooSmallToRender(rect: Rect2): boolean;
39
- setDraftMode(_draftMode: boolean): void;
40
- protected objectLevel: number;
41
- private currentPaths;
42
- private flushPath;
43
- drawPath(path: RenderablePathSpec): void;
44
- drawRect(rect: Rect2, lineWidth: number, lineFill: RenderingStyle): void;
45
- fillRect(rect: Rect2, fill: Color4): void;
46
- startObject(_boundingBox: Rect2, _clip?: boolean): void;
47
- /**
48
- * Notes the end of an object.
49
- * @param _loaderData - a map from strings to JSON-ifyable objects
50
- * and contains properties attached to the object by whatever loader loaded the image. This
51
- * is used to preserve attributes not supported by js-draw when loading/saving an image.
52
- * Renderers may ignore this.
53
- *
54
- * @param _objectTags - a list of labels (e.g. `className`s) to be attached to the object.
55
- * Renderers may ignore this.
56
- */
57
- endObject(_loaderData?: LoadSaveDataTable, _objectTags?: string[]): void;
58
- protected getNestingLevel(): number;
59
- abstract drawPoints(...points: Point2[]): void;
60
- canRenderFromWithoutDataLoss(_other: AbstractRenderer): boolean;
61
- renderFromOtherOfSameType(_renderTo: Mat33, other: AbstractRenderer): void;
62
- setTransform(transform: Mat33 | null): void;
63
- pushTransform(transform: Mat33): void;
64
- popTransform(): void;
65
- getCanvasToScreenTransform(): Mat33;
66
- canvasToScreen(vec: Vec2): Vec2;
67
- getSizeOfCanvasPixelOnScreen(): number;
68
- }