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,31 +0,0 @@
1
- import LineSegment2 from '../math/LineSegment2';
2
- import Mat33, { Mat33Array } from '../math/Mat33';
3
- import Rect2 from '../math/Rect2';
4
- import AbstractRenderer, { RenderableImage } from '../rendering/renderers/AbstractRenderer';
5
- import AbstractComponent from './AbstractComponent';
6
- import { ImageComponentLocalization } from './localization';
7
- export default class ImageComponent extends AbstractComponent {
8
- protected contentBBox: Rect2;
9
- private image;
10
- constructor(image: RenderableImage);
11
- private getImageRect;
12
- private recomputeBBox;
13
- static fromImage(elem: HTMLImageElement, transform: Mat33): Promise<ImageComponent>;
14
- render(canvas: AbstractRenderer, _visibleRect?: Rect2): void;
15
- getProportionalRenderingTime(): number;
16
- intersects(lineSegment: LineSegment2): boolean;
17
- protected serializeToJSON(): {
18
- src: string;
19
- label: string | undefined;
20
- width: number;
21
- height: number;
22
- transform: Mat33Array;
23
- };
24
- protected applyTransformation(affineTransfm: Mat33): void;
25
- description(localizationTable: ImageComponentLocalization): string;
26
- getAltText(): string | undefined;
27
- getURL(): string;
28
- getTransformation(): Mat33;
29
- protected createClone(): AbstractComponent;
30
- static deserializeFromJSON(data: any): ImageComponent;
31
- }
@@ -1,146 +0,0 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- import Mat33 from '../math/Mat33';
11
- import Rect2 from '../math/Rect2';
12
- import AbstractComponent from './AbstractComponent';
13
- // Represents a raster image.
14
- export default class ImageComponent extends AbstractComponent {
15
- constructor(image) {
16
- var _a, _b, _c;
17
- super('image-component');
18
- this.image = Object.assign(Object.assign({}, image), { label: (_c = (_b = (_a = image.label) !== null && _a !== void 0 ? _a : image.image.getAttribute('alt')) !== null && _b !== void 0 ? _b : image.image.getAttribute('aria-label')) !== null && _c !== void 0 ? _c : undefined });
19
- const isHTMLImageElem = (elem) => {
20
- return elem.getAttribute('src') !== undefined;
21
- };
22
- if (isHTMLImageElem(image.image) && !image.image.complete) {
23
- image.image.onload = () => this.recomputeBBox();
24
- }
25
- this.recomputeBBox();
26
- }
27
- getImageRect() {
28
- return new Rect2(0, 0, this.image.image.width, this.image.image.height);
29
- }
30
- recomputeBBox() {
31
- this.contentBBox = this.getImageRect();
32
- this.contentBBox = this.contentBBox.transformedBoundingBox(this.image.transform);
33
- }
34
- // Load from an image. Waits for the image to load if incomplete.
35
- static fromImage(elem, transform) {
36
- var _a, _b, _c;
37
- return __awaiter(this, void 0, void 0, function* () {
38
- if (!elem.complete) {
39
- yield new Promise((resolve, reject) => {
40
- elem.onload = resolve;
41
- elem.onerror = reject;
42
- elem.onabort = reject;
43
- });
44
- }
45
- let width, height;
46
- if (typeof elem.width === 'number' && typeof elem.height === 'number'
47
- && elem.width !== 0 && elem.height !== 0) {
48
- width = elem.width;
49
- height = elem.height;
50
- }
51
- else {
52
- width = elem.clientWidth;
53
- height = elem.clientHeight;
54
- }
55
- let image;
56
- let url = (_a = elem.src) !== null && _a !== void 0 ? _a : '';
57
- if (!url.startsWith('data:image/')) {
58
- // Convert to a data URL:
59
- const canvas = document.createElement('canvas');
60
- canvas.width = width;
61
- canvas.height = height;
62
- const ctx = canvas.getContext('2d');
63
- ctx.drawImage(elem, 0, 0, canvas.width, canvas.height);
64
- url = canvas.toDataURL();
65
- image = canvas;
66
- }
67
- else {
68
- image = new Image();
69
- image.src = url;
70
- image.width = width;
71
- image.height = height;
72
- }
73
- image.setAttribute('alt', (_b = elem.getAttribute('alt')) !== null && _b !== void 0 ? _b : '');
74
- image.setAttribute('aria-label', (_c = elem.getAttribute('aria-label')) !== null && _c !== void 0 ? _c : '');
75
- return new ImageComponent({
76
- image,
77
- base64Url: url,
78
- transform: transform,
79
- });
80
- });
81
- }
82
- render(canvas, _visibleRect) {
83
- canvas.startObject(this.contentBBox);
84
- canvas.drawImage(this.image);
85
- canvas.endObject(this.getLoadSaveData());
86
- }
87
- getProportionalRenderingTime() {
88
- // Estimate: Equivalent to a stroke with 10 segments.
89
- return 10;
90
- }
91
- intersects(lineSegment) {
92
- const rect = this.getImageRect();
93
- const edges = rect.getEdges().map(edge => edge.transformedBy(this.image.transform));
94
- for (const edge of edges) {
95
- if (edge.intersects(lineSegment)) {
96
- return true;
97
- }
98
- }
99
- return false;
100
- }
101
- serializeToJSON() {
102
- return {
103
- src: this.image.base64Url,
104
- label: this.image.label,
105
- // Store the width and height for bounding box computations while the image is loading.
106
- width: this.image.image.width,
107
- height: this.image.image.height,
108
- transform: this.image.transform.toArray(),
109
- };
110
- }
111
- applyTransformation(affineTransfm) {
112
- this.image.transform = affineTransfm.rightMul(this.image.transform);
113
- this.recomputeBBox();
114
- }
115
- description(localizationTable) {
116
- return this.image.label ? localizationTable.imageNode(this.image.label) : localizationTable.unlabeledImageNode;
117
- }
118
- getAltText() {
119
- return this.image.label;
120
- }
121
- getURL() {
122
- return this.image.base64Url;
123
- }
124
- getTransformation() {
125
- return this.image.transform;
126
- }
127
- createClone() {
128
- return new ImageComponent(Object.assign({}, this.image));
129
- }
130
- static deserializeFromJSON(data) {
131
- if (!(typeof data.src === 'string')) {
132
- throw new Error(`${data} has invalid format! Expected src property.`);
133
- }
134
- const image = new Image();
135
- image.src = data.src;
136
- image.width = data.width;
137
- image.height = data.height;
138
- return new ImageComponent({
139
- image: image,
140
- base64Url: image.src,
141
- label: data.label,
142
- transform: new Mat33(...data.transform),
143
- });
144
- }
145
- }
146
- AbstractComponent.registerComponent('image-component', ImageComponent.deserializeFromJSON);
@@ -1,24 +0,0 @@
1
- import Color4 from '../Color4';
2
- import SerializableCommand from '../commands/SerializableCommand';
3
- import Editor from '../Editor';
4
- import TextStyle from '../rendering/TextRenderingStyle';
5
- import AbstractComponent from './AbstractComponent';
6
- export interface ComponentStyle {
7
- color?: Color4;
8
- textStyle?: TextStyle;
9
- }
10
- export declare const createRestyleComponentCommand: (initialStyle: ComponentStyle, newStyle: ComponentStyle, component: RestyleableComponent) => SerializableCommand;
11
- export declare const isRestylableComponent: (component: AbstractComponent) => component is RestyleableComponent;
12
- export interface RestyleableComponent extends AbstractComponent {
13
- getStyle(): ComponentStyle;
14
- updateStyle(style: ComponentStyle): SerializableCommand;
15
- /**
16
- * Set the style of this component in a way that can't be undone/redone
17
- * (does not create a command).
18
- *
19
- * Prefer `updateStyle(style).apply(editor)`.
20
- */
21
- forceStyle(style: ComponentStyle, editor: Editor | null): void;
22
- isRestylableComponent: true;
23
- }
24
- export default RestyleableComponent;
@@ -1,80 +0,0 @@
1
- import Color4 from '../Color4';
2
- import SerializableCommand from '../commands/SerializableCommand';
3
- import UnresolvedSerializableCommand from '../commands/UnresolvedCommand';
4
- import { textStyleFromJSON, textStyleToJSON } from '../rendering/TextRenderingStyle';
5
- const serializeComponentStyle = (style) => {
6
- const result = {};
7
- if (style.color) {
8
- result.color = style.color.toHexString();
9
- }
10
- if (style.textStyle) {
11
- result.textStyle = textStyleToJSON(style.textStyle);
12
- }
13
- return result;
14
- };
15
- const deserializeComponentStyle = (json) => {
16
- const color = json.color ? Color4.fromHex(json.color) : undefined;
17
- const textStyle = json.textStyle ? textStyleFromJSON(json.textStyle) : undefined;
18
- return {
19
- color,
20
- textStyle,
21
- };
22
- };
23
- // For internal use by Components implementing `updateStyle`:
24
- export const createRestyleComponentCommand = (initialStyle, newStyle, component) => {
25
- return new DefaultRestyleComponentCommand(initialStyle, newStyle, component.getId(), component);
26
- };
27
- // Returns true if `component` is a `RestylableComponent`.
28
- export const isRestylableComponent = (component) => {
29
- const hasMethods = 'getStyle' in component && 'updateStyle' in component && 'forceStyle' in component;
30
- if (!hasMethods) {
31
- return false;
32
- }
33
- if (!('isRestylableComponent' in component) || !component['isRestylableComponent']) {
34
- return false;
35
- }
36
- return true;
37
- };
38
- const defaultRestyleComponentCommandId = 'default-restyle-element';
39
- class DefaultRestyleComponentCommand extends UnresolvedSerializableCommand {
40
- constructor(originalStyle, newStyle, componentID, component) {
41
- super(defaultRestyleComponentCommandId, componentID, component);
42
- this.originalStyle = originalStyle;
43
- this.newStyle = newStyle;
44
- }
45
- getComponent(editor) {
46
- this.resolveComponent(editor.image);
47
- const component = this.component;
48
- if (!component || !component['forceStyle'] || !component['updateStyle']) {
49
- throw new Error('this.component is missing forceStyle and/or updateStyle methods!');
50
- }
51
- return component;
52
- }
53
- apply(editor) {
54
- this.getComponent(editor).forceStyle(this.newStyle, editor);
55
- }
56
- unapply(editor) {
57
- this.getComponent(editor).forceStyle(this.originalStyle, editor);
58
- }
59
- description(editor, localizationTable) {
60
- return localizationTable.restyledElement(this.getComponent(editor).description(localizationTable));
61
- }
62
- serializeToJSON() {
63
- return {
64
- id: this.componentID,
65
- originalStyle: serializeComponentStyle(this.originalStyle),
66
- newStyle: serializeComponentStyle(this.newStyle),
67
- };
68
- }
69
- }
70
- (() => {
71
- SerializableCommand.register(defaultRestyleComponentCommandId, (json, _editor) => {
72
- const origStyle = deserializeComponentStyle(json.originalStyle);
73
- const newStyle = deserializeComponentStyle(json.newStyle);
74
- const id = json.id;
75
- if (typeof json.id !== 'string') {
76
- throw new Error(`json.id is of type ${(typeof json.id)}, not string.`);
77
- }
78
- return new DefaultRestyleComponentCommand(origStyle, newStyle, id);
79
- });
80
- })();
@@ -1,21 +0,0 @@
1
- import LineSegment2 from '../math/LineSegment2';
2
- import Mat33 from '../math/Mat33';
3
- import Rect2 from '../math/Rect2';
4
- import AbstractRenderer from '../rendering/renderers/AbstractRenderer';
5
- import AbstractComponent from './AbstractComponent';
6
- import { ImageComponentLocalization } from './localization';
7
- type GlobalAttrsList = Array<[string, string | null]>;
8
- export default class SVGGlobalAttributesObject extends AbstractComponent {
9
- private readonly attrs;
10
- protected contentBBox: Rect2;
11
- constructor(attrs: GlobalAttrsList);
12
- render(canvas: AbstractRenderer, _visibleRect?: Rect2): void;
13
- intersects(_lineSegment: LineSegment2): boolean;
14
- protected applyTransformation(_affineTransfm: Mat33): void;
15
- isSelectable(): boolean;
16
- protected createClone(): SVGGlobalAttributesObject;
17
- description(localization: ImageComponentLocalization): string;
18
- protected serializeToJSON(): string | null;
19
- static deserializeFromString(data: string): AbstractComponent;
20
- }
21
- export {};
@@ -1,59 +0,0 @@
1
- //
2
- // Used by `SVGLoader`s to store unrecognised global attributes
3
- // (e.g. unrecognised XML namespace declarations).
4
- // @internal
5
- // @packageDocumentation
6
- //
7
- import Rect2 from '../math/Rect2';
8
- import SVGRenderer from '../rendering/renderers/SVGRenderer';
9
- import AbstractComponent from './AbstractComponent';
10
- const componentKind = 'svg-global-attributes';
11
- // Stores global SVG attributes (e.g. namespace identifiers.)
12
- export default class SVGGlobalAttributesObject extends AbstractComponent {
13
- constructor(attrs) {
14
- super(componentKind);
15
- this.attrs = attrs;
16
- this.contentBBox = Rect2.empty;
17
- }
18
- render(canvas, _visibleRect) {
19
- if (!(canvas instanceof SVGRenderer)) {
20
- // Don't draw unrenderable objects if we can't
21
- return;
22
- }
23
- for (const [attr, value] of this.attrs) {
24
- canvas.setRootSVGAttribute(attr, value);
25
- }
26
- }
27
- intersects(_lineSegment) {
28
- return false;
29
- }
30
- applyTransformation(_affineTransfm) {
31
- }
32
- isSelectable() {
33
- return false;
34
- }
35
- createClone() {
36
- return new SVGGlobalAttributesObject(this.attrs);
37
- }
38
- description(localization) {
39
- return localization.svgObject;
40
- }
41
- serializeToJSON() {
42
- return JSON.stringify(this.attrs);
43
- }
44
- static deserializeFromString(data) {
45
- const json = JSON.parse(data);
46
- const attrs = [];
47
- const numericAndSpaceContentExp = /^[ \t\n0-9.-eE]+$/;
48
- // Don't deserialize all attributes, just those that should be safe.
49
- for (const [key, val] of json) {
50
- if (key === 'viewBox' || key === 'width' || key === 'height') {
51
- if (val && numericAndSpaceContentExp.exec(val)) {
52
- attrs.push([key, val]);
53
- }
54
- }
55
- }
56
- return new SVGGlobalAttributesObject(attrs);
57
- }
58
- }
59
- AbstractComponent.registerComponent(componentKind, SVGGlobalAttributesObject.deserializeFromString);
@@ -1,40 +0,0 @@
1
- import SerializableCommand from '../commands/SerializableCommand';
2
- import LineSegment2 from '../math/LineSegment2';
3
- import Mat33 from '../math/Mat33';
4
- import Path from '../math/Path';
5
- import Rect2 from '../math/Rect2';
6
- import Editor from '../Editor';
7
- import AbstractRenderer, { RenderablePathSpec } from '../rendering/renderers/AbstractRenderer';
8
- import AbstractComponent from './AbstractComponent';
9
- import { ImageComponentLocalization } from './localization';
10
- import RestyleableComponent, { ComponentStyle } from './RestylableComponent';
11
- export default class Stroke extends AbstractComponent implements RestyleableComponent {
12
- private parts;
13
- protected contentBBox: Rect2;
14
- readonly isRestylableComponent: true;
15
- private approximateRenderingTime;
16
- constructor(parts: RenderablePathSpec[]);
17
- getStyle(): ComponentStyle;
18
- updateStyle(style: ComponentStyle): SerializableCommand;
19
- forceStyle(style: ComponentStyle, editor: Editor | null): void;
20
- intersects(line: LineSegment2): boolean;
21
- render(canvas: AbstractRenderer, visibleRect?: Rect2): void;
22
- getProportionalRenderingTime(): number;
23
- private bboxForPart;
24
- protected applyTransformation(affineTransfm: Mat33): void;
25
- getPath(): Path;
26
- description(localization: ImageComponentLocalization): string;
27
- protected createClone(): AbstractComponent;
28
- protected serializeToJSON(): {
29
- style: {
30
- fill: string;
31
- stroke: {
32
- color: string;
33
- width: number;
34
- } | undefined;
35
- };
36
- path: string;
37
- }[];
38
- /** @internal */
39
- static deserializeFromJSON(json: any): Stroke;
40
- }
@@ -1,185 +0,0 @@
1
- import Path from '../math/Path';
2
- import Rect2 from '../math/Rect2';
3
- import { styleFromJSON, styleToJSON } from '../rendering/RenderingStyle';
4
- import AbstractComponent from './AbstractComponent';
5
- import { createRestyleComponentCommand } from './RestylableComponent';
6
- export default class Stroke extends AbstractComponent {
7
- // Creates a `Stroke` from the given `parts`. All parts should have the
8
- // same color.
9
- constructor(parts) {
10
- var _a;
11
- super('stroke');
12
- // eslint-disable-next-line @typescript-eslint/prefer-as-const
13
- this.isRestylableComponent = true;
14
- this.approximateRenderingTime = 0;
15
- this.parts = [];
16
- for (const section of parts) {
17
- const path = Path.fromRenderable(section);
18
- const pathBBox = this.bboxForPart(path.bbox, section.style);
19
- if (!this.contentBBox) {
20
- this.contentBBox = pathBBox;
21
- }
22
- else {
23
- this.contentBBox = this.contentBBox.union(pathBBox);
24
- }
25
- this.parts.push({
26
- path,
27
- // To implement RenderablePathSpec
28
- startPoint: path.startPoint,
29
- style: section.style,
30
- commands: path.parts,
31
- });
32
- this.approximateRenderingTime += path.parts.length;
33
- }
34
- (_a = this.contentBBox) !== null && _a !== void 0 ? _a : (this.contentBBox = Rect2.empty);
35
- }
36
- getStyle() {
37
- if (this.parts.length === 0) {
38
- return {};
39
- }
40
- const firstPart = this.parts[0];
41
- if (firstPart.style.stroke === undefined
42
- || firstPart.style.stroke.width === 0) {
43
- return {
44
- color: firstPart.style.fill,
45
- };
46
- }
47
- return {
48
- color: firstPart.style.stroke.color,
49
- };
50
- }
51
- updateStyle(style) {
52
- return createRestyleComponentCommand(this.getStyle(), style, this);
53
- }
54
- forceStyle(style, editor) {
55
- if (!style.color) {
56
- return;
57
- }
58
- this.parts = this.parts.map((part) => {
59
- const newStyle = Object.assign(Object.assign({}, part.style), { stroke: part.style.stroke ? Object.assign({}, part.style.stroke) : undefined });
60
- // Change the stroke color if a stroked shape. Else,
61
- // change the fill.
62
- if (newStyle.stroke && newStyle.stroke.width > 0) {
63
- newStyle.stroke.color = style.color;
64
- }
65
- else {
66
- newStyle.fill = style.color;
67
- }
68
- return {
69
- path: part.path,
70
- startPoint: part.startPoint,
71
- commands: part.commands,
72
- style: newStyle,
73
- };
74
- });
75
- if (editor) {
76
- editor.image.queueRerenderOf(this);
77
- editor.queueRerender();
78
- }
79
- }
80
- intersects(line) {
81
- for (const part of this.parts) {
82
- if (part.path.intersection(line).length > 0) {
83
- return true;
84
- }
85
- }
86
- return false;
87
- }
88
- render(canvas, visibleRect) {
89
- var _a, _b;
90
- canvas.startObject(this.getBBox());
91
- for (const part of this.parts) {
92
- const bbox = this.bboxForPart(part.path.bbox, part.style);
93
- if (visibleRect) {
94
- if (!bbox.intersects(visibleRect)) {
95
- continue;
96
- }
97
- const muchBiggerThanVisible = bbox.size.x > visibleRect.size.x * 2 || bbox.size.y > visibleRect.size.y * 2;
98
- if (muchBiggerThanVisible && !part.path.roughlyIntersects(visibleRect, (_b = (_a = part.style.stroke) === null || _a === void 0 ? void 0 : _a.width) !== null && _b !== void 0 ? _b : 0)) {
99
- continue;
100
- }
101
- }
102
- canvas.drawPath(part);
103
- }
104
- canvas.endObject(this.getLoadSaveData());
105
- }
106
- getProportionalRenderingTime() {
107
- return this.approximateRenderingTime;
108
- }
109
- // Grows the bounding box for a given stroke part based on that part's style.
110
- bboxForPart(origBBox, style) {
111
- if (!style.stroke) {
112
- return origBBox;
113
- }
114
- return origBBox.grownBy(style.stroke.width / 2);
115
- }
116
- applyTransformation(affineTransfm) {
117
- this.contentBBox = Rect2.empty;
118
- let isFirstPart = true;
119
- // Update each part
120
- this.parts = this.parts.map((part) => {
121
- const newPath = part.path.transformedBy(affineTransfm);
122
- const newStyle = Object.assign(Object.assign({}, part.style), { stroke: part.style.stroke ? Object.assign({}, part.style.stroke) : undefined });
123
- // Approximate the scale factor.
124
- if (newStyle.stroke) {
125
- const scaleFactor = affineTransfm.getScaleFactor();
126
- newStyle.stroke.width *= scaleFactor;
127
- }
128
- const newBBox = this.bboxForPart(newPath.bbox, newStyle);
129
- if (isFirstPart) {
130
- this.contentBBox = newBBox;
131
- isFirstPart = false;
132
- }
133
- else {
134
- this.contentBBox = this.contentBBox.union(newBBox);
135
- }
136
- return {
137
- path: newPath,
138
- startPoint: newPath.startPoint,
139
- commands: newPath.parts,
140
- style: newStyle,
141
- };
142
- });
143
- }
144
- getPath() {
145
- let result = null;
146
- for (const part of this.parts) {
147
- if (result) {
148
- result = result.union(part.path);
149
- }
150
- else {
151
- result !== null && result !== void 0 ? result : (result = part.path);
152
- }
153
- }
154
- return result !== null && result !== void 0 ? result : Path.empty;
155
- }
156
- description(localization) {
157
- return localization.stroke;
158
- }
159
- createClone() {
160
- return new Stroke(this.parts);
161
- }
162
- serializeToJSON() {
163
- return this.parts.map(part => {
164
- return {
165
- style: styleToJSON(part.style),
166
- path: part.path.serialize(),
167
- };
168
- });
169
- }
170
- /** @internal */
171
- static deserializeFromJSON(json) {
172
- if (typeof json === 'string') {
173
- json = JSON.parse(json);
174
- }
175
- if (typeof json !== 'object' || typeof json.length !== 'number') {
176
- throw new Error(`${json} is missing required field, parts, or parts is of the wrong type.`);
177
- }
178
- const pathSpec = json.map((part) => {
179
- const style = styleFromJSON(part.style);
180
- return Path.fromString(part.path).toRenderable(style);
181
- });
182
- return new Stroke(pathSpec);
183
- }
184
- }
185
- AbstractComponent.registerComponent('stroke', Stroke.deserializeFromJSON);
@@ -1,53 +0,0 @@
1
- import SerializableCommand from '../commands/SerializableCommand';
2
- import LineSegment2 from '../math/LineSegment2';
3
- import Mat33 from '../math/Mat33';
4
- import Rect2 from '../math/Rect2';
5
- import Editor from '../Editor';
6
- import AbstractRenderer from '../rendering/renderers/AbstractRenderer';
7
- import { TextStyle } from '../rendering/TextRenderingStyle';
8
- import AbstractComponent from './AbstractComponent';
9
- import { ImageComponentLocalization } from './localization';
10
- import RestyleableComponent, { ComponentStyle } from './RestylableComponent';
11
- export default class TextComponent extends AbstractComponent implements RestyleableComponent {
12
- protected readonly textObjects: Array<string | TextComponent>;
13
- private transform;
14
- private style;
15
- protected contentBBox: Rect2;
16
- readonly isRestylableComponent: true;
17
- constructor(textObjects: Array<string | TextComponent>, transform: Mat33, style: TextStyle);
18
- static applyTextStyles(ctx: CanvasRenderingContext2D, style: TextStyle): void;
19
- private static textMeasuringCtx;
20
- private static estimateTextDimens;
21
- private static getTextDimens;
22
- private computeBBoxOfPart;
23
- private recomputeBBox;
24
- private renderInternal;
25
- render(canvas: AbstractRenderer, _visibleRect?: Rect2): void;
26
- getProportionalRenderingTime(): number;
27
- intersects(lineSegment: LineSegment2): boolean;
28
- getStyle(): ComponentStyle;
29
- updateStyle(style: ComponentStyle): SerializableCommand;
30
- forceStyle(style: ComponentStyle, editor: Editor | null): void;
31
- getTextStyle(): {
32
- renderingStyle: {
33
- fill: import("../Color4").default;
34
- stroke: {
35
- color: import("../Color4").default;
36
- width: number;
37
- } | undefined;
38
- };
39
- size: number;
40
- fontFamily: string;
41
- fontWeight?: string | undefined;
42
- fontVariant?: string | undefined;
43
- };
44
- getBaselinePos(): import("../lib").Vec3;
45
- getTransform(): Mat33;
46
- protected applyTransformation(affineTransfm: Mat33): void;
47
- protected createClone(): AbstractComponent;
48
- getText(): string;
49
- description(localizationTable: ImageComponentLocalization): string;
50
- protected serializeToJSON(): Record<string, any>;
51
- static deserializeFromString(json: any): TextComponent;
52
- static fromLines(lines: string[], transform: Mat33, style: TextStyle): AbstractComponent;
53
- }